summaryrefslogtreecommitdiff
path: root/u/process/argv.ts
diff options
context:
space:
mode:
authorElizabeth Hunt <me@liz.coffee>2025-07-27 18:50:33 -0700
committerElizabeth Hunt <me@liz.coffee>2025-07-27 19:31:06 -0700
commit7aa11b7a8abacf81dec20fff21216df35d333756 (patch)
tree40f6a76c37412cf1c5a67f99a4ee30e3aae863c9 /u/process/argv.ts
parente4df72cd446270cf867ec308995a05e21b3aa601 (diff)
downloadci-7aa11b7a8abacf81dec20fff21216df35d333756.tar.gz
ci-7aa11b7a8abacf81dec20fff21216df35d333756.zip
Pulls in pengueno from npm
Diffstat (limited to 'u/process/argv.ts')
-rw-r--r--u/process/argv.ts79
1 files changed, 0 insertions, 79 deletions
diff --git a/u/process/argv.ts b/u/process/argv.ts
deleted file mode 100644
index 396fa96..0000000
--- a/u/process/argv.ts
+++ /dev/null
@@ -1,79 +0,0 @@
-import { Either, type Mapper, type IEither, Optional } from '@emprespresso/pengueno';
-
-export const isArgKey = <K extends string>(k: string): k is K => k.startsWith('--');
-
-interface ArgHandler<V> {
- absent?: V;
- unspecified?: V;
- present: Mapper<string, V>;
-}
-
-export const getArg = <K extends string, V>(
- arg: K,
- argv: Array<string>,
- whenValue: ArgHandler<V>,
-): IEither<Error, V> => {
- const argIndex = Optional.from(argv.findIndex((_argv) => isArgKey(_argv) && _argv.split('=')[0] === arg)).filter(
- (index) => index >= 0 && index < argv.length,
- );
- if (!argIndex.present()) {
- return Optional.from(whenValue.absent)
- .map((v) => Either.right<Error, V>(v))
- .orSome(() =>
- Either.left(
- new Error(`arg ${arg} is not present in arguments list and does not have an 'absent' value`),
- ),
- )
- .get();
- }
-
- return argIndex
- .flatMap((idx) =>
- Optional.from(argv.at(idx)).map((_argv) => (_argv.includes('=') ? _argv.split('=')[1] : argv.at(idx + 1))),
- )
- .filter((next) => !isArgKey(next))
- .map((next) => whenValue.present(next))
- .orSome(() => whenValue.unspecified)
- .map((v) => Either.right<Error, V>(<V>v))
- .get();
-};
-
-type MappedArgs<
- Args extends ReadonlyArray<string>,
- Handlers extends Partial<Record<Args[number], ArgHandler<unknown>>>,
-> = {
- [K in Args[number]]: K extends keyof Handlers ? (Handlers[K] extends ArgHandler<infer T> ? T : string) : string;
-};
-
-export const argv = <
- const Args extends ReadonlyArray<string>,
- const Handlers extends Partial<Record<Args[number], ArgHandler<unknown>>>,
->(
- args: Args,
- handlers?: Handlers,
- argv = process.argv.slice(2),
-): IEither<Error, MappedArgs<Args, Handlers>> => {
- type Result = MappedArgs<Args, Handlers>;
-
- const defaultHandler: ArgHandler<string> = { present: (value: string) => value };
-
- const processArg = (arg: Args[number]): IEither<Error, [Args[number], unknown]> => {
- const handler = handlers?.[arg] ?? defaultHandler;
- return getArg(arg, argv, handler).mapRight((value) => [arg, value] as const);
- };
-
- const res = args
- .map(processArg)
- .reduce(
- (acc: IEither<Error, Partial<Result>>, current: IEither<Error, [Args[number], unknown]>) =>
- acc.flatMap((accValue) =>
- current.mapRight(([key, value]) => ({
- ...accValue,
- [key]: value,
- })),
- ),
- Either.right(<Partial<Result>>{}),
- )
- .mapRight((result) => <Result>result);
- return res;
-};