2022-04-20 11:32:10 -04:00
|
|
|
import {ArgParser} from '/scripts/lib/arg-parser';
|
|
|
|
import {maxThreads, progressBar} from '/scripts/lib/utils';
|
2022-03-16 19:07:36 -04:00
|
|
|
|
|
|
|
/**
|
2022-04-20 11:32:10 -04:00
|
|
|
* Copy a file & it's dependencies to a server.
|
|
|
|
*
|
|
|
|
* @param {NS} ns - BitBurner API
|
|
|
|
* @param {string} src - File to scan & copy
|
|
|
|
* @param {string} server - Device to copy files to
|
|
|
|
* @returns {Promise<string[]>} - Array of copied files
|
2022-03-16 19:07:36 -04:00
|
|
|
*/
|
2022-04-20 11:32:10 -04:00
|
|
|
export async function copyWithDependencies(ns, src, server) {
|
|
|
|
const queue = [src], found = [src];
|
|
|
|
while(queue.length) {
|
|
|
|
const file = queue.splice(0, 1)[0];
|
|
|
|
const imports = new RegExp(/from ["']\.?(\/.+)["']/g);
|
|
|
|
const script = await ns.read(file);
|
|
|
|
let match;
|
|
|
|
while((match = imports.exec(script)) != null) {
|
|
|
|
const path = `${match[1]}.js`;
|
|
|
|
if(!found.includes(path)) found.push(path);
|
|
|
|
queue.push(path);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
await ns.scp(found, server);
|
|
|
|
return found.reverse();
|
2022-03-16 19:07:36 -04:00
|
|
|
}
|
|
|
|
|
2022-04-20 11:32:10 -04:00
|
|
|
/**
|
|
|
|
* Copy a file & it's dependencies to a server.
|
|
|
|
*
|
|
|
|
* @param {NS} ns - BitBurner API
|
|
|
|
*/
|
2022-03-16 19:07:36 -04:00
|
|
|
export async function main(ns) {
|
|
|
|
// Setup
|
|
|
|
ns.disableLog('ALL');
|
2022-04-20 11:32:10 -04:00
|
|
|
const argParser = new ArgParser('copy.js', 'Copy a file & it\'s dependencies to a server.', [
|
|
|
|
{name: 'file', desc: 'File to copy'},
|
|
|
|
{name: 'server', desc: 'Server to copy file(s) to'},
|
|
|
|
{name: 'args', desc: 'Arguments to start file/script with', optional: true, extras: true},
|
|
|
|
{name: 'cpu', desc: 'Number of CPU threads to start script with, will use maximum if not specified', flags: ['-c', '--cpu']},
|
|
|
|
{name: 'execute', desc: 'Start script after copying', flags: ['-e', '--execute'], default: false},
|
|
|
|
{name: 'noDeps', desc: 'Skip copying dependencies', flags: ['-n', '--no-deps'], default: false},
|
|
|
|
{name: 'quite', desc: 'Suppress program output', flags: ['-q', '--quite'], default: false},
|
|
|
|
]);
|
|
|
|
const args = argParser.parse(ns.args);
|
|
|
|
|
|
|
|
// Help
|
|
|
|
if(args['help'] || args['_error'].length)
|
|
|
|
return ns.tprint(argParser.help(args['help'] ? null : args['_error'][0], args['_command']));
|
|
|
|
|
|
|
|
// Banner
|
|
|
|
if(!args['quite']) {
|
|
|
|
ns.tprint('===================================================');
|
|
|
|
ns.tprint(`Copying: ${args['server']}`);
|
|
|
|
ns.tprint('===================================================');
|
|
|
|
ns.tprint('');
|
|
|
|
ns.tprint('Copying Files:');
|
|
|
|
await ns.sleep(500);
|
|
|
|
}
|
2022-03-16 19:07:36 -04:00
|
|
|
|
2022-04-20 11:32:10 -04:00
|
|
|
// Copy files & create download bar
|
|
|
|
if(args['noDeps']) {
|
|
|
|
await ns.scp(args['file'], args['server']);
|
|
|
|
if(!args['quite']) await progressBar(ns, args['file']);
|
|
|
|
} else {
|
2022-05-02 12:21:56 -04:00
|
|
|
const files = await copyWithDependencies(ns, args['file'], args['server']);
|
2022-04-20 11:32:10 -04:00
|
|
|
if(!args['quite']) {
|
|
|
|
for(let file of files) {
|
|
|
|
await progressBar(ns, file);
|
2022-03-16 19:07:36 -04:00
|
|
|
}
|
|
|
|
}
|
2022-04-20 11:32:10 -04:00
|
|
|
}
|
2022-03-16 19:07:36 -04:00
|
|
|
|
2022-04-20 11:32:10 -04:00
|
|
|
// Run the script if requested
|
|
|
|
if(args['execute']) {
|
|
|
|
const threads = args['cpu'] || maxThreads(ns, args['file'], args['server']) || 1;
|
|
|
|
if(!args['quite']) {
|
2022-03-16 19:07:36 -04:00
|
|
|
ns.tprint('');
|
2022-04-20 11:32:10 -04:00
|
|
|
ns.tprint(`Executing with ${threads} thread${threads > 1 ? 's' : ''}...`);
|
|
|
|
await ns.sleep(500);
|
|
|
|
}
|
|
|
|
ns.killall(args['server']);
|
2022-04-26 20:46:41 -04:00
|
|
|
const pid = ns.exec(args['file'], args['server'], threads, ...args['args']);
|
2022-04-20 11:32:10 -04:00
|
|
|
if(!args['quite']) {
|
|
|
|
ns.tprint(!!pid ? 'Done!' : 'Failed to start');
|
2022-03-16 19:07:36 -04:00
|
|
|
ns.tprint('');
|
|
|
|
}
|
|
|
|
}
|
2022-04-20 11:32:10 -04:00
|
|
|
|
|
|
|
// Done message
|
|
|
|
if(!args['quite']) {
|
|
|
|
ns.tprint('');
|
|
|
|
ns.tprint('Done!');
|
|
|
|
ns.tprint('');
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* BitBurner autocomplete.
|
|
|
|
*
|
|
|
|
* @param {{servers: string[], txts: string[], scripts: string[], flags: string[]}} data - Contextual information
|
|
|
|
* @returns {string[]} - Pool of autocomplete options
|
|
|
|
*/
|
|
|
|
export function autocomplete(data) {
|
|
|
|
return [...data.servers, ...data.scripts];
|
2022-03-16 19:07:36 -04:00
|
|
|
}
|