Change: tidy up

This commit is contained in:
n loewen 2023-08-26 20:58:49 -04:00
parent 81b106088d
commit bd2a0c300d
1 changed files with 24 additions and 67 deletions

View File

@ -2,33 +2,21 @@
const test = require('node:test');
// WIP
// TODO:
// - building a structured output
// - testing
// - exporting as object/library
// Example
/*
let cpuArguments = {
help: '', // TODO
args: [
{ flags: { short: 'f' },
name: 'Filename',
requiresValue: true, },
{ name: 'Clock speed',
flags: { short: 'c', long: 'clock' },
requiresValue: true,
optional: true },
{ name: 'Pretty-print display',
flags: { short: 'p', long: 'pretty' },
optional: true, },
{ name: 'Single-step',
flags: { short: 's', long: 'step' },
optional: true, },
{ 'name': 'Debug',
flags: { short: 'd', long: 'debug' },
optional: true,
}
]
};
*/
// Testing -- constructors
let cpuArguments = new Arguments();
cpuArguments.add(
new Arg({name: 'Filename', shortFlag: 'f', requiresValue: true}),
new Arg({name: 'Clock speed', shortFlag: 'c', longFlag: 'clock', requiresValue: true, optional: true}),
new Arg({name: 'Debug', shortFlag: 'd', longFlag: 'debug', optional: true}),
new Arg({name: 'Pretty-print display', shortFlag: 'p', longFlag: 'pretty', optional: true}),
new Arg({name: 'Single-step', shortFlag: 's', longFlag: 'step', optional: true}));
// Constructors
@ -52,26 +40,8 @@ function Arg({
this.optional = optional;
};
// Test constructors
let cpuArguments = new Arguments();
cpuArguments.add(
new Arg({name: 'Filename', shortFlag: 'f', requiresValue: true}),
new Arg({name: 'Clock speed', shortFlag: 'c', longFlag: 'clock', requiresValue: true, optional: true}),
new Arg({name: 'Debug', shortFlag: 'd', longFlag: 'debug', optional: true}),
new Arg({name: 'Pretty-print display', shortFlag: 'p', longFlag: 'pretty', optional: true}),
new Arg({name: 'Single-step', shortFlag: 's', longFlag: 'step', optional: true}));
///console.log(cpuArguments);
///console.log('flags', cpuArguments.args[0].flags);
// MODULE:
// TODO:
// - building a structured output
// - testing
// - exporting as object
// MODULE
const argsRequiringValues = cpuArguments.args.filter((a) => a.requiresValue);
const requiredArgs = cpuArguments.args.filter((a) => !a.optional);
@ -98,40 +68,27 @@ requiredArgs.forEach((a) => {
});
// Validate...
argvSplit.forEach((currentArg, index) => {
console.log('checking', currentArg);
argvSplit.forEach((av, index) => {
// Check for attempts to use --flags that don't exist
if (currentArg.startsWith('--')) {
console.log('--');
let valid = cpuArguments.args.filter((a) => { return A.flags.long === currentArg.substring(2)}).length > 0;
console.log('valid', valid);
if (!valid) { throw new Error(`There is no ${currentArg} option`); }
} else if (currentArg.startsWith('-')) {
console.log(currentArg.substring(1));
let valid = cpuArguments.args.filter((a) => { console.log(a); return a.flags.short === currentArg.substring(1)}).length > 0;
if (!valid) { throw new Error(`There is no ${currentArg} option`); }
let valid = true;
if (av.startsWith('--')) {
valid = cpuArguments.args.filter((a) => a.flags.long === av.substring(2)).length > 0;
} else if (av.startsWith('-')) {
valid = cpuArguments.args.filter((a) => a.flags.short === av.substring(1)).length > 0;
}
///console.log(' it\'s a valid argument');
///console.log(' argsrequiringvalues', argsRequiringValues);
///console.log(' currentarg', currentArg);
if (!valid) { throw new Error(`There is no ${av} option`); }
// Check if it requires a value...
// and if it does, do a cursory check to see if one is likely to be there
let shouldCheckValue = argsRequiringValues.filter((a) => {
/// console.log('a', a);
let noDash = currentArg.substring(1);
let noDash = av.substring(1);
return (a.flags.short === noDash || a.flags.long === noDash);
}).length > 0;
/// console.log(' requires a value?', shouldCheckValue);
/// console.log(' split', argvSplit);
if (shouldCheckValue) {
///console.log(currentArg);
let errorMessage = `Value required for ${currentArg}`;
let errorMessage = `Value required for ${av}`;
// If there's nothing after this flag, error;
// Or if the next item is a flag... error:
/// console.log('idx', index, argvSplit[index]);
if (typeof argvSplit[index + 1] === 'undefined') { throw new Error(errorMessage); }
else if (argvSplit[index + 1].startsWith('-')) { throw new Error(errorMessage); };
}