refactor scp function

This commit is contained in:
Snarling 2022-08-17 20:31:26 -04:00
parent f6a8d5d337
commit 07e9cb9277

@ -829,132 +829,106 @@ const base: InternalAPI<NS> = {
}, },
scp: scp:
(ctx: NetscriptContext) => (ctx: NetscriptContext) =>
(_scriptname: unknown, _destination: unknown, _source: unknown = ctx.workerScript.hostname): boolean => { (_files: unknown, _destination: unknown, _source: unknown = ctx.workerScript.hostname): boolean => {
const destination = helpers.string(ctx, "destination", _destination); const destination = helpers.string(ctx, "destination", _destination);
const source = helpers.string(ctx, "source", _source); const source = helpers.string(ctx, "source", _source);
if (Array.isArray(_scriptname)) { const destServer = helpers.getServer(ctx, destination);
// Recursively call scp on all elements of array const sourceServ = helpers.getServer(ctx, source);
const scripts: string[] = _scriptname; const files = Array.isArray(_files) ? _files : [_files];
if (scripts.length === 0) {
throw helpers.makeRuntimeErrorMsg(ctx, "No scripts to copy");
}
let res = true;
scripts.forEach(function (script) {
//TODO: This array method still needs to be reworked because it is terribly inefficient.
if (!NetscriptFunctions(ctx.workerScript).scp(script, destination, source)) {
res = false;
}
});
return res;
}
const scriptName = helpers.string(ctx, "scriptName", _scriptname); //First loop through filenames to find all errors before moving anything.
for (const file of files) {
// Invalid file type // Not a string
if (!isValidFilePath(scriptName)) { if (typeof file !== "string")
throw helpers.makeRuntimeErrorMsg(ctx, `Invalid filename: '${scriptName}'`); throw helpers.makeRuntimeErrorMsg(ctx, "files should be a string or an array of strings.");
}
// Invalid file name // Invalid file name
if (!scriptName.endsWith(".lit") && !isScriptFilename(scriptName) && !scriptName.endsWith("txt")) { if (!isValidFilePath(file)) throw helpers.makeRuntimeErrorMsg(ctx, `Invalid filename: '${file}'`);
throw helpers.makeRuntimeErrorMsg(ctx, "Only works for scripts, .lit and .txt files");
// Invalid file type
if (!file.endsWith(".lit") && !isScriptFilename(file) && !file.endsWith("txt")) {
throw helpers.makeRuntimeErrorMsg(ctx, "Only works for scripts, .lit and .txt files.");
}
} }
const destServer = helpers.getServer(ctx, destination); let noFailures = true;
const currServ = helpers.getServer(ctx, source); //ts detects files as any[] here even though we would have thrown in the above loop if it wasn't string[]
for (const file of files as string[]) {
// Scp for lit files // Scp for lit files
if (scriptName.endsWith(".lit")) { if (file.endsWith(".lit")) {
let found = false; const sourceMessage = sourceServ.messages.find((message) => message === file);
for (let i = 0; i < currServ.messages.length; ++i) { if (!sourceMessage) {
if (currServ.messages[i] == scriptName) { helpers.log(ctx, () => `File '${file}' does not exist.`);
found = true; noFailures = false;
break; continue;
}
} }
if (!found) { const destMessage = destServer.messages.find((message) => message === file);
helpers.log(ctx, () => `File '${scriptName}' does not exist.`); if (destMessage) {
return false; helpers.log(ctx, () => `File '${file}' was already on '${destServer?.hostname}'.`);
continue;
} }
for (let i = 0; i < destServer.messages.length; ++i) { destServer.messages.push(file);
if (destServer.messages[i] === scriptName) { helpers.log(ctx, () => `File '${file}' copied over to '${destServer?.hostname}'.`);
helpers.log(ctx, () => `File '${scriptName}' copied over to '${destServer?.hostname}'.`); continue;
return true; // Already exists
}
}
destServer.messages.push(scriptName);
helpers.log(ctx, () => `File '${scriptName}' copied over to '${destServer?.hostname}'.`);
return true;
} }
// Scp for text files // Scp for text files
if (scriptName.endsWith(".txt")) { if (file.endsWith(".txt")) {
let txtFile; const sourceTextFile = sourceServ.textFiles.find((textFile) => textFile.fn === file);
for (let i = 0; i < currServ.textFiles.length; ++i) { if (!sourceTextFile) {
if (currServ.textFiles[i].fn === scriptName) { helpers.log(ctx, () => `File '${file}' does not exist.`);
txtFile = currServ.textFiles[i]; noFailures = false;
break; continue;
}
}
if (txtFile === undefined) {
helpers.log(ctx, () => `File '${scriptName}' does not exist.`);
return false;
} }
for (let i = 0; i < destServer.textFiles.length; ++i) { const destTextFile = destServer.textFiles.find((textFile) => textFile.fn === file);
if (destServer.textFiles[i].fn === scriptName) { if (destTextFile) {
// Overwrite destTextFile.text = sourceTextFile.text;
destServer.textFiles[i].text = txtFile.text; helpers.log(ctx, () => `File '${file}' overwritten on '${destServer?.hostname}'.`);
helpers.log(ctx, () => `File '${scriptName}' copied over to '${destServer?.hostname}'.`); continue;
return true;
} }
}
const newFile = new TextFile(txtFile.fn, txtFile.text); const newFile = new TextFile(sourceTextFile.fn, sourceTextFile.text);
destServer.textFiles.push(newFile); destServer.textFiles.push(newFile);
helpers.log(ctx, () => `File '${scriptName}' copied over to '${destServer?.hostname}'.`); helpers.log(ctx, () => `File '${file}' copied over to '${destServer?.hostname}'.`);
return true; continue;
} }
// Scp for script files // Scp for script files
let sourceScript = null; const sourceScript = sourceServ.scripts.find((script) => script.filename === file);
for (let i = 0; i < currServ.scripts.length; ++i) { if (!sourceScript) {
if (scriptName == currServ.scripts[i].filename) { helpers.log(ctx, () => `File '${file}' does not exist.`);
sourceScript = currServ.scripts[i]; noFailures = false;
break; continue;
}
}
if (sourceScript == null) {
helpers.log(ctx, () => `File '${scriptName}' does not exist.`);
return false;
} }
// Overwrite script if it already exists // Overwrite script if it already exists
for (let i = 0; i < destServer.scripts.length; ++i) { const destScript = destServer.scripts.find((script) => script.filename === file);
if (scriptName == destServer.scripts[i].filename) { if (destScript) {
helpers.log(ctx, () => `WARNING: File '${scriptName}' overwritten on '${destServer?.hostname}'`); if (destScript.code === sourceScript.code) {
const oldScript = destServer.scripts[i]; helpers.log(ctx, () => `Identical file '${file}' was already on '${destServer?.hostname}'`);
// If it's the exact same file don't actually perform the continue;
// copy to avoid recompiling uselessly. Players tend to scp
// liberally.
if (oldScript.code === sourceScript.code) return true;
oldScript.code = sourceScript.code;
oldScript.ramUsage = sourceScript.ramUsage;
oldScript.markUpdated();
return true;
} }
destScript.code = sourceScript.code;
destScript.ramUsage = destScript.ramUsage;
destScript.markUpdated();
helpers.log(ctx, () => `WARNING: File '${file}' overwritten on '${destServer?.hostname}'`);
continue;
} }
// Create new script if it does not already exist // Create new script if it does not already exist
const newScript = new Script(Player, scriptName); const newScript = new Script(Player, file);
newScript.code = sourceScript.code; newScript.code = sourceScript.code;
newScript.ramUsage = sourceScript.ramUsage; newScript.ramUsage = sourceScript.ramUsage;
newScript.server = destServer.hostname; newScript.server = destServer.hostname;
destServer.scripts.push(newScript); destServer.scripts.push(newScript);
helpers.log(ctx, () => `File '${scriptName}' copied over to '${destServer?.hostname}'.`); helpers.log(ctx, () => `File '${file}' copied over to '${destServer?.hostname}'.`);
newScript.updateRamUsage(Player, destServer.scripts); newScript.updateRamUsage(Player, destServer.scripts);
return true; }
return noFailures;
}, },
ls: ls:
(ctx: NetscriptContext) => (ctx: NetscriptContext) =>