@shell-shock/preset-script 0.4.2 → 0.5.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (71) hide show
  1. package/dist/components/banner-function-declaration.cjs +1 -1
  2. package/dist/components/banner-function-declaration.cjs.map +1 -1
  3. package/dist/components/banner-function-declaration.mjs +1 -1
  4. package/dist/components/banner-function-declaration.mjs.map +1 -1
  5. package/dist/components/bin-entry.cjs +1 -2
  6. package/dist/components/bin-entry.cjs.map +1 -1
  7. package/dist/components/bin-entry.d.cts.map +1 -1
  8. package/dist/components/bin-entry.d.mts.map +1 -1
  9. package/dist/components/bin-entry.mjs +1 -2
  10. package/dist/components/bin-entry.mjs.map +1 -1
  11. package/dist/components/command-entry.cjs +49 -6
  12. package/dist/components/command-entry.cjs.map +1 -1
  13. package/dist/components/command-entry.d.cts.map +1 -1
  14. package/dist/components/command-entry.d.mts.map +1 -1
  15. package/dist/components/command-entry.mjs +50 -7
  16. package/dist/components/command-entry.mjs.map +1 -1
  17. package/dist/components/command-router.cjs +5 -5
  18. package/dist/components/command-router.cjs.map +1 -1
  19. package/dist/components/command-router.d.cts +1 -1
  20. package/dist/components/command-router.d.cts.map +1 -1
  21. package/dist/components/command-router.d.mts +1 -1
  22. package/dist/components/command-router.d.mts.map +1 -1
  23. package/dist/components/command-router.mjs +5 -5
  24. package/dist/components/command-router.mjs.map +1 -1
  25. package/dist/components/console-builtin.cjs +15 -10
  26. package/dist/components/console-builtin.cjs.map +1 -1
  27. package/dist/components/console-builtin.d.cts.map +1 -1
  28. package/dist/components/console-builtin.d.mts.map +1 -1
  29. package/dist/components/console-builtin.mjs +15 -10
  30. package/dist/components/console-builtin.mjs.map +1 -1
  31. package/dist/components/help.cjs +25 -18
  32. package/dist/components/help.cjs.map +1 -1
  33. package/dist/components/help.d.cts +9 -9
  34. package/dist/components/help.d.cts.map +1 -1
  35. package/dist/components/help.d.mts +9 -9
  36. package/dist/components/help.d.mts.map +1 -1
  37. package/dist/components/help.mjs +26 -19
  38. package/dist/components/help.mjs.map +1 -1
  39. package/dist/components/helpers.cjs +54 -0
  40. package/dist/components/helpers.cjs.map +1 -0
  41. package/dist/components/helpers.d.cts +29 -0
  42. package/dist/components/helpers.d.cts.map +1 -0
  43. package/dist/components/helpers.d.mts +29 -0
  44. package/dist/components/helpers.d.mts.map +1 -0
  45. package/dist/components/helpers.mjs +50 -0
  46. package/dist/components/helpers.mjs.map +1 -0
  47. package/dist/components/index.cjs +1 -0
  48. package/dist/components/index.d.cts +2 -2
  49. package/dist/components/index.d.mts +2 -2
  50. package/dist/components/index.mjs +2 -2
  51. package/dist/components/utils-builtin.cjs +160 -6
  52. package/dist/components/utils-builtin.cjs.map +1 -1
  53. package/dist/components/utils-builtin.d.cts +9 -8
  54. package/dist/components/utils-builtin.d.cts.map +1 -1
  55. package/dist/components/utils-builtin.d.mts +9 -8
  56. package/dist/components/utils-builtin.d.mts.map +1 -1
  57. package/dist/components/utils-builtin.mjs +161 -8
  58. package/dist/components/utils-builtin.mjs.map +1 -1
  59. package/dist/components/virtual-command-entry.cjs +10 -7
  60. package/dist/components/virtual-command-entry.cjs.map +1 -1
  61. package/dist/components/virtual-command-entry.mjs +10 -7
  62. package/dist/components/virtual-command-entry.mjs.map +1 -1
  63. package/dist/helpers/ansi-utils.cjs +4 -4
  64. package/dist/helpers/ansi-utils.cjs.map +1 -1
  65. package/dist/helpers/ansi-utils.mjs +4 -4
  66. package/dist/helpers/ansi-utils.mjs.map +1 -1
  67. package/dist/index.cjs +1 -1
  68. package/dist/index.cjs.map +1 -1
  69. package/dist/index.mjs +1 -1
  70. package/dist/index.mjs.map +1 -1
  71. package/package.json +23 -9
@@ -1,4 +1,4 @@
1
- import * as _alloy_js_core0 from "@alloy-js/core";
1
+ import * as _alloy_js_core3 from "@alloy-js/core";
2
2
  import { BuiltinFileProps } from "@powerlines/plugin-alloy/typescript/components/builtin-file";
3
3
 
4
4
  //#region src/components/utils-builtin.d.ts
@@ -6,27 +6,28 @@ interface UtilsBuiltinProps extends Omit<BuiltinFileProps, "id" | "description">
6
6
  /**
7
7
  * Generates utilities for detecting terminal color support.
8
8
  */
9
- declare function EnvSupportUtilities(): _alloy_js_core0.Children;
9
+ declare function EnvSupportUtilities(): _alloy_js_core3.Children;
10
10
  /**
11
11
  * Generates utilities for detecting terminal color support.
12
12
  */
13
- declare function ColorSupportUtilities(): _alloy_js_core0.Children;
13
+ declare function ColorSupportUtilities(): _alloy_js_core3.Children;
14
14
  /**
15
15
  * Generates utilities for detecting terminal color support.
16
16
  */
17
- declare function HyperlinkSupportUtilities(): _alloy_js_core0.Children;
17
+ declare function HyperlinkSupportUtilities(): _alloy_js_core3.Children;
18
18
  /**
19
19
  * Generates utilities for detecting terminal color support.
20
20
  */
21
- declare function ArgsUtilities(): _alloy_js_core0.Children;
21
+ declare function ArgsUtilities(): _alloy_js_core3.Children;
22
22
  /**
23
23
  * The `exit` handler function declaration code for the Shell Shock project.
24
24
  */
25
- declare function ExitFunctionDeclaration(): _alloy_js_core0.Children;
25
+ declare function ExitFunctionDeclaration(): _alloy_js_core3.Children;
26
+ declare function ContextUtilities(): _alloy_js_core3.Children;
26
27
  /**
27
28
  * A built-in utilities module for Shell Shock.
28
29
  */
29
- declare function UtilsBuiltin(props: UtilsBuiltinProps): _alloy_js_core0.Children;
30
+ declare function UtilsBuiltin(props: UtilsBuiltinProps): _alloy_js_core3.Children;
30
31
  //#endregion
31
- export { ArgsUtilities, ColorSupportUtilities, EnvSupportUtilities, ExitFunctionDeclaration, HyperlinkSupportUtilities, UtilsBuiltin, UtilsBuiltinProps };
32
+ export { ArgsUtilities, ColorSupportUtilities, ContextUtilities, EnvSupportUtilities, ExitFunctionDeclaration, HyperlinkSupportUtilities, UtilsBuiltin, UtilsBuiltinProps };
32
33
  //# sourceMappingURL=utils-builtin.d.mts.map
@@ -1 +1 @@
1
- {"version":3,"file":"utils-builtin.d.mts","names":[],"sources":["../../src/components/utils-builtin.tsx"],"sourcesContent":[],"mappings":";;;;UAsCiB,iBAAA,SAA0B,KACzC;;AADF;AASA;AAmCgB,iBAnCA,mBAAA,CAAA,CAmCqB,EAnCF,eAAA,CAAA,QAmCE;AA0MrC;AA2GA;AA+DA;AAiJgB,iBArgBA,qBAAA,CAAA,CAqgBoB,EArgBC,eAAA,CAAA,QAqgBgB;;;;iBA3TrC,yBAAA,CAAA,GAAyB,eAAA,CAAA;;;;iBA2GzB,aAAA,CAAA,GAAa,eAAA,CAAA;;;;iBA+Db,uBAAA,CAAA,GAAuB,eAAA,CAAA;;;;iBAiJvB,YAAA,QAAoB,oBAAiB,eAAA,CAAA"}
1
+ {"version":3,"file":"utils-builtin.d.mts","names":[],"sources":["../../src/components/utils-builtin.tsx"],"sourcesContent":[],"mappings":";;;;UAwCiB,iBAAA,SAA0B,KACzC;;AADF;AASA;AAmCgB,iBAnCA,mBAAA,CAAA,CAmCqB,EAnCF,eAAA,CAAA,QAmCE;AA0MrC;AA2GA;AA+DA;AAkJgB,iBAtgBA,qBAAA,CAAA,CAsgBgB,EAtgBK,eAAA,CAAA,QAsgBL;AAwIhC;;;iBApcgB,yBAAA,CAAA,GAAyB,eAAA,CAAA;;;;iBA2GzB,aAAA,CAAA,GAAa,eAAA,CAAA;;;;iBA+Db,uBAAA,CAAA,GAAuB,eAAA,CAAA;iBAkJvB,gBAAA,CAAA,GAAgB,eAAA,CAAA;;;;iBAwIhB,YAAA,QAAoB,oBAAiB,eAAA,CAAA"}
@@ -1,6 +1,7 @@
1
+ import { IsVerbose } from "./helpers.mjs";
1
2
  import { createComponent, createIntrinsic, memo, mergeProps } from "@alloy-js/core/jsx-runtime";
2
3
  import { Show, code, splitProps } from "@alloy-js/core";
3
- import { FunctionDeclaration, InterfaceDeclaration, InterfaceMember, VarDeclaration } from "@alloy-js/typescript";
4
+ import { FunctionDeclaration, IfStatement, InterfaceDeclaration, InterfaceMember, VarDeclaration } from "@alloy-js/typescript";
4
5
  import { usePowerlines } from "@powerlines/plugin-alloy/core/contexts/context";
5
6
  import { getAppTitle } from "@shell-shock/core/plugin-utils/context-helpers";
6
7
  import { TSDoc, TSDocLink, TSDocParam, TSDocReturns } from "@powerlines/plugin-alloy/typescript/components/tsdoc";
@@ -495,7 +496,8 @@ function ExitFunctionDeclaration() {
495
496
  default: "{}"
496
497
  }],
497
498
  get children() {
498
- return code`
499
+ return [
500
+ memo(() => code`
499
501
  try {
500
502
  if (isExiting) {
501
503
  return;
@@ -514,7 +516,15 @@ function ExitFunctionDeclaration() {
514
516
  error(\`A fatal error occured while running the application - please contact the ${getAppTitle(context)} support team: \\n\\n\${typeof options.exception === "string" ? options.exception : options.exception.message}\`);
515
517
  }
516
518
 
517
- const terminate = (force = false) => {
519
+ const terminate = (force = false) => { `),
520
+ createComponent(IfStatement, {
521
+ get condition() {
522
+ return createComponent(IsVerbose, {});
523
+ },
524
+ children: code`writeLine("");`
525
+ }),
526
+ createIntrinsic("hbr", {}),
527
+ memo(() => code`
518
528
  verbose(\`The ${getAppTitle(context)} application exited \${options.exception ? \`early due to an exception\` : "successfully"}\${options.startDate ? \`. Total processing time is \${Date.now() - options.startDate.getTime() > 100_000 ? (Date.now() - options.startDate.getTime()) / 1000 : Date.now() - options.startDate.getTime()} \${Date.now() - options.startDate.getTime() > 100_000 ? "seconds" : "milliseconds"}\` : ""}...\`);
519
529
  if (!options.skipProcessExit) {
520
530
  process.exit(exitCode);
@@ -548,11 +558,144 @@ function ExitFunctionDeclaration() {
548
558
  process.exit(1);
549
559
  }
550
560
  }
551
- `;
561
+ `)
562
+ ];
552
563
  }
553
564
  })
554
565
  ];
555
566
  }
567
+ function ContextUtilities() {
568
+ return code`
569
+ /**
570
+ * The context object for the current command execution, containing the command path and segments.
571
+ */
572
+ interface CommandContext {
573
+ path: string;
574
+ segments: string[];
575
+ }
576
+
577
+ interface UseCommandContext {
578
+ /**
579
+ * Get the current context. Throws if no context is set.
580
+ */
581
+ use: () => CommandContext;
582
+
583
+ /**
584
+ * Call a function with a specific context instance. This is used internally to set the context for command executions, but can also be used by advanced users to manually set the context for specific operations if needed.
585
+ */
586
+ call: <R>(instance: CommandContext, callback: () => R | Promise<R>) => Promise<R>;
587
+ }
588
+
589
+ const _globalThis = (
590
+ typeof globalThis !== "undefined"
591
+ ? globalThis
592
+ : typeof self !== "undefined"
593
+ ? self
594
+ : typeof global !== "undefined"
595
+ ? global
596
+ : typeof window !== "undefined"
597
+ ? window
598
+ : {}
599
+ ) as typeof globalThis;
600
+
601
+ const asyncHandlers: Set<() => void | (() => void)> =
602
+ (_globalThis as any)["__shell-shock_async_handlers__"] ||
603
+ ((_globalThis as any)["__shell-shock_async_handlers__"] = new Set());
604
+
605
+ function createContext(): UseCommandContext {
606
+ let currentInstance: CommandContext | undefined;
607
+ let als = new AsyncLocalStorage<CommandContext>();
608
+ const getCurrentInstance = (): CommandContext | undefined => {
609
+ if (als) {
610
+ const instance = als.getStore();
611
+ if (instance) {
612
+ return instance;
613
+ }
614
+ }
615
+ return currentInstance;
616
+ };
617
+
618
+ const result = {
619
+ use() {
620
+ const instance = getCurrentInstance();
621
+ if (!instance) {
622
+ throw new Error(
623
+ \`The Shell Shock - Command context is not available. Make sure to call useCommand() within a valid context scope.\`
624
+ );
625
+ }
626
+ return instance;
627
+ },
628
+ async call(instance: CommandContext, callback: () => Promise<any> | any) {
629
+ currentInstance = instance;
630
+ const onRestore = () => {
631
+ currentInstance = instance;
632
+ };
633
+ const onLeave = () =>
634
+ currentInstance === instance ? onRestore : undefined;
635
+
636
+ asyncHandlers.add(onLeave);
637
+
638
+ try {
639
+ return await (als ? als.run(instance, callback) : callback());
640
+ } finally {
641
+ asyncHandlers.delete(onLeave);
642
+ }
643
+ },
644
+ };
645
+
646
+ ((_globalThis as any)["__shell-shock__"]) ??= {};
647
+ ((_globalThis as any)["__shell-shock__"]).__command__ = result;
648
+
649
+ return result;
650
+ }
651
+
652
+ /**
653
+ * The global Shell Shock - Command context instance.
654
+ *
655
+ * @internal
656
+ */
657
+ export let internal_commandContext = createContext();
658
+
659
+ /**
660
+ * Get the Shell Shock - Command context for the current application.
661
+ *
662
+ * @param options - The options to use when getting the context.
663
+ * @returns The Shell Shock - Command context for the current application.
664
+ * @throws If the Shell Shock - Command context is not available.
665
+ */
666
+ function useCommand(): CommandContext {
667
+ if (!internal_commandContext) {
668
+ if ((_globalThis as any)["__shell-shock__"]?.__command__) {
669
+ internal_commandContext = (_globalThis as any)["__shell-shock__"].__command__;
670
+ } else {
671
+ internal_commandContext = createContext();
672
+ }
673
+ }
674
+
675
+ return internal_commandContext.use();
676
+ }
677
+
678
+ /**
679
+ * A utility hook function to get the individual segments of the current command path.
680
+ *
681
+ * @returns An array of command path segments.
682
+ * @throws If the command context is not available.
683
+ */
684
+ export function useSegments(): string[] {
685
+ return useCommand().segments;
686
+ }
687
+
688
+ /**
689
+ * A utility hook function to get the full command path as a string.
690
+ *
691
+ * @returns The full command path as a string.
692
+ * @throws If the command context is not available.
693
+ */
694
+ export function usePath(): string {
695
+ return useCommand().path;
696
+ }
697
+ `;
698
+ }
556
699
  /**
557
700
  * A built-in utilities module for Shell Shock.
558
701
  */
@@ -565,17 +708,24 @@ function UtilsBuiltin(props) {
565
708
  get imports() {
566
709
  return defu(rest.imports ?? {}, {
567
710
  "node:os": "os",
568
- "node:process": "process"
711
+ "node:process": "process",
712
+ "node:async_hooks": ["AsyncLocalStorage"]
569
713
  });
570
714
  },
571
715
  get builtinImports() {
572
716
  return defu(rest.builtinImports ?? {}, {
573
- console: ["error", "verbose"],
717
+ console: [
718
+ "error",
719
+ "verbose",
720
+ "writeLine"
721
+ ],
574
722
  env: [
575
723
  "env",
576
724
  "isCI",
577
725
  "isTest",
578
- "isWindows"
726
+ "isWindows",
727
+ "isDevelopment",
728
+ "isDebug"
579
729
  ]
580
730
  });
581
731
  },
@@ -595,6 +745,9 @@ function UtilsBuiltin(props) {
595
745
  createComponent(ColorSupportUtilities, {}),
596
746
  createIntrinsic("hbr", {}),
597
747
  createIntrinsic("hbr", {}),
748
+ createComponent(ContextUtilities, {}),
749
+ createIntrinsic("hbr", {}),
750
+ createIntrinsic("hbr", {}),
598
751
  createComponent(ExitFunctionDeclaration, {}),
599
752
  createIntrinsic("hbr", {}),
600
753
  createIntrinsic("hbr", {}),
@@ -610,5 +763,5 @@ function UtilsBuiltin(props) {
610
763
  }
611
764
 
612
765
  //#endregion
613
- export { ArgsUtilities, ColorSupportUtilities, EnvSupportUtilities, ExitFunctionDeclaration, HyperlinkSupportUtilities, UtilsBuiltin };
766
+ export { ArgsUtilities, ColorSupportUtilities, ContextUtilities, EnvSupportUtilities, ExitFunctionDeclaration, HyperlinkSupportUtilities, UtilsBuiltin };
614
767
  //# sourceMappingURL=utils-builtin.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"utils-builtin.mjs","names":["code","Show","splitProps","FunctionDeclaration","InterfaceDeclaration","InterfaceMember","VarDeclaration","usePowerlines","BuiltinFile","TSDoc","TSDocLink","TSDocParam","TSDocReturns","getAppTitle","defu","EnvSupportUtilities","_$createComponent","name","doc","initializer","_$createIntrinsic","ColorSupportUtilities","children","type","heading","parameters","default","HyperlinkSupportUtilities","returnType","ArgsUtilities","ExitFunctionDeclaration","context","optional","async","UtilsBuiltin","props","rest","_$mergeProps","id","description","imports","builtinImports","console","env","when","Boolean"],"sources":["../../src/components/utils-builtin.tsx"],"sourcesContent":["/* -------------------------------------------------------------------\n\n ⚡ Storm Software - Shell Shock\n\n This code was released as part of the Shell Shock project. Shell Shock\n is maintained by Storm Software under the Apache-2.0 license, and is\n free for commercial and private use. For more information, please visit\n our licensing page at https://stormsoftware.com/licenses/projects/shell-shock.\n\n Website: https://stormsoftware.com\n Repository: https://github.com/storm-software/shell-shock\n Documentation: https://docs.stormsoftware.com/projects/shell-shock\n Contact: https://stormsoftware.com/contact\n\n SPDX-License-Identifier: Apache-2.0\n\n ------------------------------------------------------------------- */\n\nimport { code, Show, splitProps } from \"@alloy-js/core\";\nimport {\n FunctionDeclaration,\n InterfaceDeclaration,\n InterfaceMember,\n VarDeclaration\n} from \"@alloy-js/typescript\";\nimport { usePowerlines } from \"@powerlines/plugin-alloy/core/contexts/context\";\nimport type { BuiltinFileProps } from \"@powerlines/plugin-alloy/typescript/components/builtin-file\";\nimport { BuiltinFile } from \"@powerlines/plugin-alloy/typescript/components/builtin-file\";\nimport {\n TSDoc,\n TSDocLink,\n TSDocParam,\n TSDocReturns\n} from \"@powerlines/plugin-alloy/typescript/components/tsdoc\";\nimport { getAppTitle } from \"@shell-shock/core/plugin-utils/context-helpers\";\nimport defu from \"defu\";\nimport type { ScriptPresetContext } from \"../types/plugin\";\n\nexport interface UtilsBuiltinProps extends Omit<\n BuiltinFileProps,\n \"id\" | \"description\"\n> {}\n\n/**\n * Generates utilities for detecting terminal color support.\n */\n\nexport function EnvSupportUtilities() {\n return (\n <>\n <VarDeclaration\n export\n const\n name=\"isTTY\"\n doc=\"Detect if stdout.TTY is available\"\n initializer={code`Boolean(process.stdout && process.stdout.isTTY);`}\n />\n <hbr />\n <hbr />\n <VarDeclaration\n export\n const\n name=\"isMinimal\"\n doc=\"Detect if the current environment is minimal (CI, non-TTY, etc.)\"\n initializer={code` env.MINIMAL || isCI || isTest || !isTTY; `}\n />\n <hbr />\n <hbr />\n <VarDeclaration\n export\n const\n name=\"isInteractive\"\n doc=\"Detect if the current environment is interactive\"\n initializer={code` !isMinimal && process.stdin?.isTTY && env.TERM !== \"dumb\"; `}\n />\n </>\n );\n}\n\n/**\n * Generates utilities for detecting terminal color support.\n */\nexport function ColorSupportUtilities() {\n return (\n <>\n <InterfaceDeclaration\n export\n name=\"GetColorSupportLevelOptions\"\n doc=\"Options for the getColorSupportLevel function\">\n <InterfaceMember\n name=\"ignoreFlags\"\n type=\"boolean\"\n doc=\"Indicates if the function should skip checking command-line flags for color support\"\n />\n </InterfaceDeclaration>\n <hbr />\n <hbr />\n <TSDoc heading=\"Checks if a specific flag is present in the command line arguments.\">\n <TSDocLink>\n {\"https://github.com/sindresorhus/has-flag/blob/main/index.js\"}\n </TSDocLink>\n <TSDocParam name=\"flag\">\n {'The flag to check for, e.g., \"color\", \"no-color\".'}\n </TSDocParam>\n <TSDocParam name=\"argv\">\n {\n \"The command line arguments to check against. Defaults to global Deno args or process args.\"\n }\n </TSDocParam>\n <TSDocReturns>\n {\"True if the flag is present, false otherwise.\"}\n </TSDocReturns>\n </TSDoc>\n <FunctionDeclaration\n export\n name=\"getColorSupportLevel\"\n parameters={[\n { name: \"stream\", type: \"NodeJS.WriteStream & { fd: 1 | 2; }\" },\n {\n name: \"options\",\n type: \"GetColorSupportLevelOptions\",\n default: \"{ ignoreFlags: false }\"\n }\n ]}>\n {code`const { ignoreFlags } = options;\n\n let forceColor: number | undefined;\n if (env.FORCE_COLOR !== undefined) {\n forceColor = !env.FORCE_COLOR\n ? 0\n : typeof env.FORCE_COLOR === \"boolean\"\n ? 1\n : typeof env.FORCE_COLOR === \"number\" &&\n [0, 1, 2, 3].includes(Math.min(env.FORCE_COLOR as number, 3))\n ? Math.min(env.FORCE_COLOR as number, 3)\n : undefined;\n }\n\n if (ignoreFlags !== true && forceColor === undefined) {\n if (\n hasFlag(\"no-color\") ||\n hasFlag(\"no-colors\") ||\n hasFlag(\"color=false\") ||\n hasFlag(\"color=never\")\n ) {\n return 0;\n }\n\n if (\n hasFlag(\"color=16m\") ||\n hasFlag(\"color=full\") ||\n hasFlag(\"color=truecolor\")\n ) {\n return 3;\n }\n\n if (hasFlag(\"color=256\")) {\n return 2;\n }\n\n if (\n hasFlag(\"color\") ||\n hasFlag(\"colors\") ||\n hasFlag(\"color=true\") ||\n hasFlag(\"color=always\")\n ) {\n forceColor = 1;\n }\n }\n\n const level = Boolean(env.TF_BUILD) || Boolean(env.AGENT_NAME)\n ? 1\n : stream &&\n !(isTTY || (stream && stream.isTTY)) &&\n forceColor === undefined\n ? 0\n : env.TERM === \"dumb\"\n ? forceColor || 0\n : isWindows\n ? Number(os.release().split(\".\")[0]) >= 10 &&\n Number(os.release().split(\".\")[2]) >= 10_586\n ? Number(os.release().split(\".\")[2]) >= 14_931\n ? 3\n : 2\n : 1\n : isCI\n ? Boolean(env.GITHUB_ACTIONS) ||\n Boolean(env.GITEA_ACTIONS) ||\n Boolean(env.CIRCLECI)\n ? 3\n : Boolean(env.TRAVIS) ||\n Boolean(env.APPVEYOR) ||\n Boolean(env.GITLAB_CI) ||\n Boolean(env.BUILDKITE) ||\n Boolean(env.DRONE) ||\n env.CI_NAME === \"codeship\"\n ? 1\n : forceColor || 0\n : Boolean(env.TEAMCITY_VERSION)\n ? /^(?:9\\.0*[1-9]\\d*\\.|\\d{2,}\\.)/.test(String(env.TEAMCITY_VERSION) || \"\")\n ? 1\n : 0\n : String(env.COLORTERM) === \"truecolor\" ||\n env.TERM === \"xterm-kitty\"\n ? 3\n : Boolean(env.TERM_PROGRAM)\n ? env.TERM_PROGRAM === \"iTerm.app\"\n ? Number.parseInt(\n (env.TERM_PROGRAM_VERSION || \"\").split(\".\")[0] as string,\n 10\n ) >= 3\n ? 3\n : 2\n : env.TERM_PROGRAM === \"Apple_Terminal\"\n ? 2\n : 0\n : /-256(?:color)?$/i.test(env.TERM || \"\")\n ? 2\n : /^screen|^xterm|^vt100|^vt220|^rxvt|color|ansi|cygwin|linux/i.test(\n env.TERM || \"\"\n )\n ? 1\n : Boolean(env.COLORTERM);\n\n return typeof level === \"boolean\" || level === 0\n ? false\n : {\n level,\n hasBasic: true,\n has256: level >= 2,\n has16m: level >= 3,\n };\n\n `}\n </FunctionDeclaration>\n <hbr />\n <hbr />\n <VarDeclaration\n export\n const\n name=\"colorSupportLevels\"\n doc=\"Detect the terminal color support level in the current environment\"\n initializer={code` {\n stdout: getColorSupportLevel(process.stdout),\n stderr: getColorSupportLevel(process.stderr),\n }; `}\n />\n <hbr />\n <hbr />\n <VarDeclaration\n export\n const\n name=\"isColorSupported\"\n doc=\"Detect if terminal color is supported in the current environment\"\n initializer={code` Boolean(colorSupportLevels.stdout); `}\n />\n <hbr />\n <hbr />\n <VarDeclaration\n export\n const\n name=\"isUnicodeSupported\"\n doc=\"Detect if Unicode characters are supported in the current environment\"\n initializer={code` !isWindows\n ? env.TERM !== \"linux\"\n : Boolean(env.WT_SESSION) ||\n Boolean(env.TERMINUS_SUBLIME) ||\n env.ConEmuTask === \"{cmd::Cmder}\" ||\n env.TERM_PROGRAM === \"Terminus-Sublime\" ||\n env.TERM_PROGRAM === \"vscode\" ||\n env.TERM === \"xterm-256color\" ||\n env.TERM === \"alacritty\" ||\n env.TERM === \"rxvt-unicode\" ||\n env.TERM === \"rxvt-unicode-256color\" ||\n env.TERMINAL_EMULATOR === \"JetBrains-JediTerm\"; `}\n />\n </>\n );\n}\n\n/**\n * Generates utilities for detecting terminal color support.\n */\n\nexport function HyperlinkSupportUtilities() {\n return (\n <>\n <FunctionDeclaration\n name=\"parseVersion\"\n parameters={[{ name: \"version\", type: \"string\", default: '\"\"' }]}>\n {code`if (/^\\d{3,4}$/.test(version)) {\n const match = /(\\d{1,2})(\\d{2})/.exec(version) ?? [];\n\n return {\n major: 0,\n minor: Number.parseInt(match[1]!, 10),\n patch: Number.parseInt(match[2]!, 10)\n };\n }\n\n const versionParts = (version ?? \"\")\n .split(\".\")\n .map(n => Number.parseInt(n, 10));\n\n return {\n major: versionParts[0],\n minor: versionParts[1],\n patch: versionParts[2]\n }; `}\n </FunctionDeclaration>\n <hbr />\n <hbr />\n <TSDoc heading=\"Check if the current environment/terminal supports hyperlinks in the terminal.\">\n <TSDocReturns>\n {\"True if the current environment/terminal supports hyperlinks.\"}\n </TSDocReturns>\n </TSDoc>\n <FunctionDeclaration\n export\n name=\"isHyperlinkSupported\"\n returnType=\"boolean\">\n {code`if (Boolean(env.FORCE_HYPERLINK)) {\n return true;\n }\n\n if (Boolean(env.NETLIFY)) {\n return true;\n } else if (isColorSupported || isTTY) {\n return false;\n } else if (Boolean(env.WT_SESSION)) {\n return true;\n } else if (isWindows || isMinimal || Boolean(env.TEAMCITY_VERSION)) {\n return false;\n } else if (Boolean(env.TERM_PROGRAM)) {\n const version = parseVersion(env.TERM_PROGRAM_VERSION);\n\n switch (String(env.TERM_PROGRAM)) {\n case \"iTerm.app\": {\n if (version.major === 3) {\n return version.minor !== undefined && version.minor >= 1;\n }\n\n return version.major !== undefined && version.major > 3;\n }\n case \"WezTerm\": {\n return version.major !== undefined && version.major >= 20_200_620;\n }\n\n case \"vscode\": {\n if (Boolean(env.CURSOR_TRACE_ID)) {\n return true;\n }\n\n return (\n version.minor !== undefined &&\n version.major !== undefined &&\n (version.major > 1 || (version.major === 1 && version.minor >= 72))\n );\n }\n\n case \"ghostty\": {\n return true;\n }\n }\n }\n\n if (Boolean(env.VTE_VERSION)) {\n if (env.VTE_VERSION === \"0.50.0\") {\n return false;\n }\n\n const version = parseVersion(env.VTE_VERSION);\n return (\n (version.major !== undefined && version.major > 0) ||\n (version.minor !== undefined && version.minor >= 50)\n );\n }\n\n if (String(env.TERM) === \"alacritty\") {\n return true;\n }\n\n return false; `}\n </FunctionDeclaration>\n </>\n );\n}\n\n/**\n * Generates utilities for detecting terminal color support.\n */\nexport function ArgsUtilities() {\n return (\n <>\n <TSDoc heading=\"Retrieves the command line arguments from Deno or Node.js environments.\">\n <TSDocReturns>\n {\n \"An array of command line arguments from Deno or Node.js environments.\"\n }\n </TSDocReturns>\n </TSDoc>\n <FunctionDeclaration export name=\"getArgs\">\n {code`return ((globalThis as { Deno?: { args: string[] } })?.Deno?.args ?? process.argv ?? []) as string[];`}\n </FunctionDeclaration>\n <hbr />\n <hbr />\n <TSDoc heading=\"Checks if a specific flag is present in the command line arguments.\">\n <TSDocLink>\n {\"https://github.com/sindresorhus/has-flag/blob/main/index.js\"}\n </TSDocLink>\n <TSDocParam name=\"flag\">\n {\n 'The flag (or an array of flags/aliases) to check for, e.g., \"color\", \"no-color\".'\n }\n </TSDocParam>\n <TSDocParam name=\"argv\">\n {\n \"The command line arguments to check against. Defaults to global Deno args or process args.\"\n }\n </TSDocParam>\n <TSDocReturns>\n {\"True if the flag is present, false otherwise.\"}\n </TSDocReturns>\n </TSDoc>\n <FunctionDeclaration\n export\n name=\"hasFlag\"\n parameters={[\n { name: \"flag\", type: \"string | string[]\" },\n {\n name: \"argv\",\n type: \"string[]\",\n default: \"getArgs()\"\n }\n ]}>\n <VarDeclaration\n const\n name=\"position\"\n type=\"number\"\n initializer={code`(Array.isArray(flag) ? flag : [flag]).reduce((ret, f) => {\n const pos = argv.findIndex(arg => (f.startsWith(\"-\") ? \"\" : (f.length === 1 ? \"-\" : \"--\") + f)?.toLowerCase() === arg?.toLowerCase() || arg?.toLowerCase().startsWith((f.length === 1 ? \"-\" : \"--\") + f + \"=\"));\n return pos !== -1 ? pos : ret;\n }, -1);`}\n />\n <hbr />\n {code`return position !== -1 && argv.indexOf(\"--\") === -1 || position < argv.indexOf(\"--\");`}\n </FunctionDeclaration>\n </>\n );\n}\n\n/**\n * The `exit` handler function declaration code for the Shell Shock project.\n */\nexport function ExitFunctionDeclaration() {\n const context = usePowerlines<ScriptPresetContext>();\n\n return (\n <>\n <InterfaceDeclaration\n export\n name=\"ExitOptions\"\n doc=\"Options for the exit handler function.\">\n <InterfaceMember\n name=\"exception\"\n optional\n type=\"string | Error\"\n doc=\"An optional exception that caused the exit. This can be a string message or an Error object.\"\n />\n <hbr />\n <InterfaceMember\n name=\"skipProcessExit\"\n optional\n type=\"boolean\"\n doc=\"Indicates whether the exit function should manually exit the process or not. If set to true, the exit function will not call process.exit() and will allow the application to continue running. If set to false or not specified, the exit function will call process.exit() to terminate the application.\"\n />\n <hbr />\n <InterfaceMember\n name=\"isSynchronous\"\n optional\n type=\"boolean\"\n doc=\"Indicates whether the exit function should perform synchronous operations only. If set to true, the exit function will avoid any asynchronous operations during exit. If set to false or not specified, the exit function may perform asynchronous operations as needed.\"\n />\n <hbr />\n <InterfaceMember\n name=\"signal\"\n optional\n type=\"number\"\n doc=\"The signal number that triggered the exit. This is typically used when the shutdown is initiated by a system signal (e.g., SIGINT, SIGTERM).\"\n />\n <hbr />\n <InterfaceMember\n name=\"startDate\"\n optional\n type=\"Date\"\n doc=\"A Date object representing the timestamp when the process started. This can be used to measure the duration of the shutdown process.\"\n />\n </InterfaceDeclaration>\n <hbr />\n <hbr />\n <VarDeclaration\n let\n name=\"isExiting\"\n type=\"boolean\"\n initializer={code`false;`}\n />\n <VarDeclaration\n const\n name=\"callbackAsyncQueue\"\n type=\"Array<[(code: number | string) => Promise<void> | void, number]>\"\n initializer={code`[];`}\n />\n <VarDeclaration\n const\n name=\"callbackSyncQueue\"\n type=\"Array<(code: number | string) => void>\"\n initializer={code`[];`}\n />\n <hbr />\n <hbr />\n <FunctionDeclaration\n export\n async\n name=\"exit\"\n parameters={[\n {\n name: \"options\",\n type: \"ExitOptions\",\n default: \"{}\"\n }\n ]}>\n {code`\n try {\n if (isExiting) {\n return;\n }\n\n isExiting = true;\n\n let exitCode: number | string = 0;\n if ((options.signal !== undefined && options.signal > 0) || options.exception) {\n exitCode = 128 + (options.signal ?? 1);\n } else if (typeof process.exitCode === \"number\" || typeof process.exitCode === \"string\") {\n exitCode = process.exitCode;\n }\n\n if (options.exception) {\n error(\\`A fatal error occured while running the application - please contact the ${getAppTitle(\n context\n )} support team: \\\\n\\\\n\\${typeof options.exception === \"string\" ? options.exception : options.exception.message}\\`);\n }\n\n const terminate = (force = false) => {\n verbose(\\`The ${getAppTitle(\n context\n )} application exited \\${options.exception ? \\`early due to an exception\\` : \"successfully\"}\\${options.startDate ? \\`. Total processing time is \\${Date.now() - options.startDate.getTime() > 100_000 ? (Date.now() - options.startDate.getTime()) / 1000 : Date.now() - options.startDate.getTime()} \\${Date.now() - options.startDate.getTime() > 100_000 ? \"seconds\" : \"milliseconds\"}\\` : \"\"}...\\`);\n if (!options.skipProcessExit) {\n process.exit(exitCode);\n }\n };\n\n for (const callbackSync of callbackSyncQueue) {\n callbackSync(exitCode);\n }\n\n if (!options.isSynchronous) {\n const promises = [];\n let forceAfter = 0;\n for (const [callbackAsync, wait] of callbackAsyncQueue) {\n forceAfter = Math.max(forceAfter, wait);\n promises.push(Promise.resolve(callbackAsync(exitCode)));\n }\n\n const asyncTimer = setTimeout(() => {\n terminate(true);\n }, forceAfter);\n await Promise.all(promises);\n clearTimeout(asyncTimer);\n }\n\n terminate();\n } catch (err) {\n error(\\`The exit process failed to complete\\${(err as Error).message ? \\` - (err as Error).message\\` : \"\"}. Please contact the ${getAppTitle(\n context\n )} support team.\\`);\n\n if (!options.skipProcessExit) {\n process.exit(1);\n }\n }\n `}\n </FunctionDeclaration>\n </>\n );\n}\n\n/**\n * A built-in utilities module for Shell Shock.\n */\nexport function UtilsBuiltin(props: UtilsBuiltinProps) {\n const [{ children }, rest] = splitProps(props, [\"children\"]);\n\n return (\n <BuiltinFile\n id=\"utils\"\n description=\"A collection of helper utilities that ease command-line application development.\"\n {...rest}\n imports={defu(rest.imports ?? {}, {\n \"node:os\": \"os\",\n \"node:process\": \"process\"\n })}\n builtinImports={defu(rest.builtinImports ?? {}, {\n console: [\"error\", \"verbose\"],\n env: [\"env\", \"isCI\", \"isTest\", \"isWindows\"]\n })}>\n <hbr />\n <hbr />\n <ArgsUtilities />\n <hbr />\n <hbr />\n <EnvSupportUtilities />\n <hbr />\n <hbr />\n <HyperlinkSupportUtilities />\n <hbr />\n <hbr />\n <ColorSupportUtilities />\n <hbr />\n <hbr />\n <ExitFunctionDeclaration />\n <hbr />\n <hbr />\n <Show when={Boolean(children)}>{children}</Show>\n </BuiltinFile>\n );\n}\n"],"mappings":"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"}
1
+ {"version":3,"file":"utils-builtin.mjs","names":["code","Show","splitProps","FunctionDeclaration","IfStatement","InterfaceDeclaration","InterfaceMember","VarDeclaration","usePowerlines","BuiltinFile","TSDoc","TSDocLink","TSDocParam","TSDocReturns","getAppTitle","defu","IsVerbose","EnvSupportUtilities","_$createComponent","name","doc","initializer","_$createIntrinsic","ColorSupportUtilities","children","type","heading","parameters","default","HyperlinkSupportUtilities","returnType","ArgsUtilities","ExitFunctionDeclaration","context","optional","async","_$memo","condition","ContextUtilities","UtilsBuiltin","props","rest","_$mergeProps","id","description","imports","builtinImports","console","env","when","Boolean"],"sources":["../../src/components/utils-builtin.tsx"],"sourcesContent":["/* -------------------------------------------------------------------\n\n ⚡ Storm Software - Shell Shock\n\n This code was released as part of the Shell Shock project. Shell Shock\n is maintained by Storm Software under the Apache-2.0 license, and is\n free for commercial and private use. For more information, please visit\n our licensing page at https://stormsoftware.com/licenses/projects/shell-shock.\n\n Website: https://stormsoftware.com\n Repository: https://github.com/storm-software/shell-shock\n Documentation: https://docs.stormsoftware.com/projects/shell-shock\n Contact: https://stormsoftware.com/contact\n\n SPDX-License-Identifier: Apache-2.0\n\n ------------------------------------------------------------------- */\n\nimport { code, Show, splitProps } from \"@alloy-js/core\";\nimport {\n FunctionDeclaration,\n IfStatement,\n InterfaceDeclaration,\n InterfaceMember,\n VarDeclaration\n} from \"@alloy-js/typescript\";\nimport { usePowerlines } from \"@powerlines/plugin-alloy/core/contexts/context\";\nimport type { BuiltinFileProps } from \"@powerlines/plugin-alloy/typescript/components/builtin-file\";\nimport { BuiltinFile } from \"@powerlines/plugin-alloy/typescript/components/builtin-file\";\nimport {\n TSDoc,\n TSDocLink,\n TSDocParam,\n TSDocReturns\n} from \"@powerlines/plugin-alloy/typescript/components/tsdoc\";\nimport { getAppTitle } from \"@shell-shock/core/plugin-utils/context-helpers\";\nimport defu from \"defu\";\nimport type { ScriptPresetContext } from \"../types/plugin\";\nimport { IsVerbose } from \"./helpers\";\n\nexport interface UtilsBuiltinProps extends Omit<\n BuiltinFileProps,\n \"id\" | \"description\"\n> {}\n\n/**\n * Generates utilities for detecting terminal color support.\n */\n\nexport function EnvSupportUtilities() {\n return (\n <>\n <VarDeclaration\n export\n const\n name=\"isTTY\"\n doc=\"Detect if stdout.TTY is available\"\n initializer={code`Boolean(process.stdout && process.stdout.isTTY);`}\n />\n <hbr />\n <hbr />\n <VarDeclaration\n export\n const\n name=\"isMinimal\"\n doc=\"Detect if the current environment is minimal (CI, non-TTY, etc.)\"\n initializer={code` env.MINIMAL || isCI || isTest || !isTTY; `}\n />\n <hbr />\n <hbr />\n <VarDeclaration\n export\n const\n name=\"isInteractive\"\n doc=\"Detect if the current environment is interactive\"\n initializer={code` !isMinimal && process.stdin?.isTTY && env.TERM !== \"dumb\"; `}\n />\n </>\n );\n}\n\n/**\n * Generates utilities for detecting terminal color support.\n */\nexport function ColorSupportUtilities() {\n return (\n <>\n <InterfaceDeclaration\n export\n name=\"GetColorSupportLevelOptions\"\n doc=\"Options for the getColorSupportLevel function\">\n <InterfaceMember\n name=\"ignoreFlags\"\n type=\"boolean\"\n doc=\"Indicates if the function should skip checking command-line flags for color support\"\n />\n </InterfaceDeclaration>\n <hbr />\n <hbr />\n <TSDoc heading=\"Checks if a specific flag is present in the command line arguments.\">\n <TSDocLink>\n {\"https://github.com/sindresorhus/has-flag/blob/main/index.js\"}\n </TSDocLink>\n <TSDocParam name=\"flag\">\n {'The flag to check for, e.g., \"color\", \"no-color\".'}\n </TSDocParam>\n <TSDocParam name=\"argv\">\n {\n \"The command line arguments to check against. Defaults to global Deno args or process args.\"\n }\n </TSDocParam>\n <TSDocReturns>\n {\"True if the flag is present, false otherwise.\"}\n </TSDocReturns>\n </TSDoc>\n <FunctionDeclaration\n export\n name=\"getColorSupportLevel\"\n parameters={[\n { name: \"stream\", type: \"NodeJS.WriteStream & { fd: 1 | 2; }\" },\n {\n name: \"options\",\n type: \"GetColorSupportLevelOptions\",\n default: \"{ ignoreFlags: false }\"\n }\n ]}>\n {code`const { ignoreFlags } = options;\n\n let forceColor: number | undefined;\n if (env.FORCE_COLOR !== undefined) {\n forceColor = !env.FORCE_COLOR\n ? 0\n : typeof env.FORCE_COLOR === \"boolean\"\n ? 1\n : typeof env.FORCE_COLOR === \"number\" &&\n [0, 1, 2, 3].includes(Math.min(env.FORCE_COLOR as number, 3))\n ? Math.min(env.FORCE_COLOR as number, 3)\n : undefined;\n }\n\n if (ignoreFlags !== true && forceColor === undefined) {\n if (\n hasFlag(\"no-color\") ||\n hasFlag(\"no-colors\") ||\n hasFlag(\"color=false\") ||\n hasFlag(\"color=never\")\n ) {\n return 0;\n }\n\n if (\n hasFlag(\"color=16m\") ||\n hasFlag(\"color=full\") ||\n hasFlag(\"color=truecolor\")\n ) {\n return 3;\n }\n\n if (hasFlag(\"color=256\")) {\n return 2;\n }\n\n if (\n hasFlag(\"color\") ||\n hasFlag(\"colors\") ||\n hasFlag(\"color=true\") ||\n hasFlag(\"color=always\")\n ) {\n forceColor = 1;\n }\n }\n\n const level = Boolean(env.TF_BUILD) || Boolean(env.AGENT_NAME)\n ? 1\n : stream &&\n !(isTTY || (stream && stream.isTTY)) &&\n forceColor === undefined\n ? 0\n : env.TERM === \"dumb\"\n ? forceColor || 0\n : isWindows\n ? Number(os.release().split(\".\")[0]) >= 10 &&\n Number(os.release().split(\".\")[2]) >= 10_586\n ? Number(os.release().split(\".\")[2]) >= 14_931\n ? 3\n : 2\n : 1\n : isCI\n ? Boolean(env.GITHUB_ACTIONS) ||\n Boolean(env.GITEA_ACTIONS) ||\n Boolean(env.CIRCLECI)\n ? 3\n : Boolean(env.TRAVIS) ||\n Boolean(env.APPVEYOR) ||\n Boolean(env.GITLAB_CI) ||\n Boolean(env.BUILDKITE) ||\n Boolean(env.DRONE) ||\n env.CI_NAME === \"codeship\"\n ? 1\n : forceColor || 0\n : Boolean(env.TEAMCITY_VERSION)\n ? /^(?:9\\.0*[1-9]\\d*\\.|\\d{2,}\\.)/.test(String(env.TEAMCITY_VERSION) || \"\")\n ? 1\n : 0\n : String(env.COLORTERM) === \"truecolor\" ||\n env.TERM === \"xterm-kitty\"\n ? 3\n : Boolean(env.TERM_PROGRAM)\n ? env.TERM_PROGRAM === \"iTerm.app\"\n ? Number.parseInt(\n (env.TERM_PROGRAM_VERSION || \"\").split(\".\")[0] as string,\n 10\n ) >= 3\n ? 3\n : 2\n : env.TERM_PROGRAM === \"Apple_Terminal\"\n ? 2\n : 0\n : /-256(?:color)?$/i.test(env.TERM || \"\")\n ? 2\n : /^screen|^xterm|^vt100|^vt220|^rxvt|color|ansi|cygwin|linux/i.test(\n env.TERM || \"\"\n )\n ? 1\n : Boolean(env.COLORTERM);\n\n return typeof level === \"boolean\" || level === 0\n ? false\n : {\n level,\n hasBasic: true,\n has256: level >= 2,\n has16m: level >= 3,\n };\n\n `}\n </FunctionDeclaration>\n <hbr />\n <hbr />\n <VarDeclaration\n export\n const\n name=\"colorSupportLevels\"\n doc=\"Detect the terminal color support level in the current environment\"\n initializer={code` {\n stdout: getColorSupportLevel(process.stdout),\n stderr: getColorSupportLevel(process.stderr),\n }; `}\n />\n <hbr />\n <hbr />\n <VarDeclaration\n export\n const\n name=\"isColorSupported\"\n doc=\"Detect if terminal color is supported in the current environment\"\n initializer={code` Boolean(colorSupportLevels.stdout); `}\n />\n <hbr />\n <hbr />\n <VarDeclaration\n export\n const\n name=\"isUnicodeSupported\"\n doc=\"Detect if Unicode characters are supported in the current environment\"\n initializer={code` !isWindows\n ? env.TERM !== \"linux\"\n : Boolean(env.WT_SESSION) ||\n Boolean(env.TERMINUS_SUBLIME) ||\n env.ConEmuTask === \"{cmd::Cmder}\" ||\n env.TERM_PROGRAM === \"Terminus-Sublime\" ||\n env.TERM_PROGRAM === \"vscode\" ||\n env.TERM === \"xterm-256color\" ||\n env.TERM === \"alacritty\" ||\n env.TERM === \"rxvt-unicode\" ||\n env.TERM === \"rxvt-unicode-256color\" ||\n env.TERMINAL_EMULATOR === \"JetBrains-JediTerm\"; `}\n />\n </>\n );\n}\n\n/**\n * Generates utilities for detecting terminal color support.\n */\n\nexport function HyperlinkSupportUtilities() {\n return (\n <>\n <FunctionDeclaration\n name=\"parseVersion\"\n parameters={[{ name: \"version\", type: \"string\", default: '\"\"' }]}>\n {code`if (/^\\d{3,4}$/.test(version)) {\n const match = /(\\d{1,2})(\\d{2})/.exec(version) ?? [];\n\n return {\n major: 0,\n minor: Number.parseInt(match[1]!, 10),\n patch: Number.parseInt(match[2]!, 10)\n };\n }\n\n const versionParts = (version ?? \"\")\n .split(\".\")\n .map(n => Number.parseInt(n, 10));\n\n return {\n major: versionParts[0],\n minor: versionParts[1],\n patch: versionParts[2]\n }; `}\n </FunctionDeclaration>\n <hbr />\n <hbr />\n <TSDoc heading=\"Check if the current environment/terminal supports hyperlinks in the terminal.\">\n <TSDocReturns>\n {\"True if the current environment/terminal supports hyperlinks.\"}\n </TSDocReturns>\n </TSDoc>\n <FunctionDeclaration\n export\n name=\"isHyperlinkSupported\"\n returnType=\"boolean\">\n {code`if (Boolean(env.FORCE_HYPERLINK)) {\n return true;\n }\n\n if (Boolean(env.NETLIFY)) {\n return true;\n } else if (isColorSupported || isTTY) {\n return false;\n } else if (Boolean(env.WT_SESSION)) {\n return true;\n } else if (isWindows || isMinimal || Boolean(env.TEAMCITY_VERSION)) {\n return false;\n } else if (Boolean(env.TERM_PROGRAM)) {\n const version = parseVersion(env.TERM_PROGRAM_VERSION);\n\n switch (String(env.TERM_PROGRAM)) {\n case \"iTerm.app\": {\n if (version.major === 3) {\n return version.minor !== undefined && version.minor >= 1;\n }\n\n return version.major !== undefined && version.major > 3;\n }\n case \"WezTerm\": {\n return version.major !== undefined && version.major >= 20_200_620;\n }\n\n case \"vscode\": {\n if (Boolean(env.CURSOR_TRACE_ID)) {\n return true;\n }\n\n return (\n version.minor !== undefined &&\n version.major !== undefined &&\n (version.major > 1 || (version.major === 1 && version.minor >= 72))\n );\n }\n\n case \"ghostty\": {\n return true;\n }\n }\n }\n\n if (Boolean(env.VTE_VERSION)) {\n if (env.VTE_VERSION === \"0.50.0\") {\n return false;\n }\n\n const version = parseVersion(env.VTE_VERSION);\n return (\n (version.major !== undefined && version.major > 0) ||\n (version.minor !== undefined && version.minor >= 50)\n );\n }\n\n if (String(env.TERM) === \"alacritty\") {\n return true;\n }\n\n return false; `}\n </FunctionDeclaration>\n </>\n );\n}\n\n/**\n * Generates utilities for detecting terminal color support.\n */\nexport function ArgsUtilities() {\n return (\n <>\n <TSDoc heading=\"Retrieves the command line arguments from Deno or Node.js environments.\">\n <TSDocReturns>\n {\n \"An array of command line arguments from Deno or Node.js environments.\"\n }\n </TSDocReturns>\n </TSDoc>\n <FunctionDeclaration export name=\"getArgs\">\n {code`return ((globalThis as { Deno?: { args: string[] } })?.Deno?.args ?? process.argv ?? []) as string[];`}\n </FunctionDeclaration>\n <hbr />\n <hbr />\n <TSDoc heading=\"Checks if a specific flag is present in the command line arguments.\">\n <TSDocLink>\n {\"https://github.com/sindresorhus/has-flag/blob/main/index.js\"}\n </TSDocLink>\n <TSDocParam name=\"flag\">\n {\n 'The flag (or an array of flags/aliases) to check for, e.g., \"color\", \"no-color\".'\n }\n </TSDocParam>\n <TSDocParam name=\"argv\">\n {\n \"The command line arguments to check against. Defaults to global Deno args or process args.\"\n }\n </TSDocParam>\n <TSDocReturns>\n {\"True if the flag is present, false otherwise.\"}\n </TSDocReturns>\n </TSDoc>\n <FunctionDeclaration\n export\n name=\"hasFlag\"\n parameters={[\n { name: \"flag\", type: \"string | string[]\" },\n {\n name: \"argv\",\n type: \"string[]\",\n default: \"getArgs()\"\n }\n ]}>\n <VarDeclaration\n const\n name=\"position\"\n type=\"number\"\n initializer={code`(Array.isArray(flag) ? flag : [flag]).reduce((ret, f) => {\n const pos = argv.findIndex(arg => (f.startsWith(\"-\") ? \"\" : (f.length === 1 ? \"-\" : \"--\") + f)?.toLowerCase() === arg?.toLowerCase() || arg?.toLowerCase().startsWith((f.length === 1 ? \"-\" : \"--\") + f + \"=\"));\n return pos !== -1 ? pos : ret;\n }, -1);`}\n />\n <hbr />\n {code`return position !== -1 && argv.indexOf(\"--\") === -1 || position < argv.indexOf(\"--\");`}\n </FunctionDeclaration>\n </>\n );\n}\n\n/**\n * The `exit` handler function declaration code for the Shell Shock project.\n */\nexport function ExitFunctionDeclaration() {\n const context = usePowerlines<ScriptPresetContext>();\n\n return (\n <>\n <InterfaceDeclaration\n export\n name=\"ExitOptions\"\n doc=\"Options for the exit handler function.\">\n <InterfaceMember\n name=\"exception\"\n optional\n type=\"string | Error\"\n doc=\"An optional exception that caused the exit. This can be a string message or an Error object.\"\n />\n <hbr />\n <InterfaceMember\n name=\"skipProcessExit\"\n optional\n type=\"boolean\"\n doc=\"Indicates whether the exit function should manually exit the process or not. If set to true, the exit function will not call process.exit() and will allow the application to continue running. If set to false or not specified, the exit function will call process.exit() to terminate the application.\"\n />\n <hbr />\n <InterfaceMember\n name=\"isSynchronous\"\n optional\n type=\"boolean\"\n doc=\"Indicates whether the exit function should perform synchronous operations only. If set to true, the exit function will avoid any asynchronous operations during exit. If set to false or not specified, the exit function may perform asynchronous operations as needed.\"\n />\n <hbr />\n <InterfaceMember\n name=\"signal\"\n optional\n type=\"number\"\n doc=\"The signal number that triggered the exit. This is typically used when the shutdown is initiated by a system signal (e.g., SIGINT, SIGTERM).\"\n />\n <hbr />\n <InterfaceMember\n name=\"startDate\"\n optional\n type=\"Date\"\n doc=\"A Date object representing the timestamp when the process started. This can be used to measure the duration of the shutdown process.\"\n />\n </InterfaceDeclaration>\n <hbr />\n <hbr />\n <VarDeclaration\n let\n name=\"isExiting\"\n type=\"boolean\"\n initializer={code`false;`}\n />\n <VarDeclaration\n const\n name=\"callbackAsyncQueue\"\n type=\"Array<[(code: number | string) => Promise<void> | void, number]>\"\n initializer={code`[];`}\n />\n <VarDeclaration\n const\n name=\"callbackSyncQueue\"\n type=\"Array<(code: number | string) => void>\"\n initializer={code`[];`}\n />\n <hbr />\n <hbr />\n <FunctionDeclaration\n export\n async\n name=\"exit\"\n parameters={[\n {\n name: \"options\",\n type: \"ExitOptions\",\n default: \"{}\"\n }\n ]}>\n {code`\n try {\n if (isExiting) {\n return;\n }\n\n isExiting = true;\n\n let exitCode: number | string = 0;\n if ((options.signal !== undefined && options.signal > 0) || options.exception) {\n exitCode = 128 + (options.signal ?? 1);\n } else if (typeof process.exitCode === \"number\" || typeof process.exitCode === \"string\") {\n exitCode = process.exitCode;\n }\n\n if (options.exception) {\n error(\\`A fatal error occured while running the application - please contact the ${getAppTitle(\n context\n )} support team: \\\\n\\\\n\\${typeof options.exception === \"string\" ? options.exception : options.exception.message}\\`);\n }\n\n const terminate = (force = false) => { `}\n <IfStatement\n condition={<IsVerbose />}>{code`writeLine(\"\");`}</IfStatement>\n <hbr />\n {code`\n verbose(\\`The ${getAppTitle(\n context\n )} application exited \\${options.exception ? \\`early due to an exception\\` : \"successfully\"}\\${options.startDate ? \\`. Total processing time is \\${Date.now() - options.startDate.getTime() > 100_000 ? (Date.now() - options.startDate.getTime()) / 1000 : Date.now() - options.startDate.getTime()} \\${Date.now() - options.startDate.getTime() > 100_000 ? \"seconds\" : \"milliseconds\"}\\` : \"\"}...\\`);\n if (!options.skipProcessExit) {\n process.exit(exitCode);\n }\n };\n\n for (const callbackSync of callbackSyncQueue) {\n callbackSync(exitCode);\n }\n\n if (!options.isSynchronous) {\n const promises = [];\n let forceAfter = 0;\n for (const [callbackAsync, wait] of callbackAsyncQueue) {\n forceAfter = Math.max(forceAfter, wait);\n promises.push(Promise.resolve(callbackAsync(exitCode)));\n }\n\n const asyncTimer = setTimeout(() => {\n terminate(true);\n }, forceAfter);\n await Promise.all(promises);\n clearTimeout(asyncTimer);\n }\n\n terminate();\n } catch (err) {\n error(\\`The exit process failed to complete\\${(err as Error).message ? \\` - (err as Error).message\\` : \"\"}. Please contact the ${getAppTitle(\n context\n )} support team.\\`);\n\n if (!options.skipProcessExit) {\n process.exit(1);\n }\n }\n `}\n </FunctionDeclaration>\n </>\n );\n}\n\nexport function ContextUtilities() {\n return code`\n /**\n * The context object for the current command execution, containing the command path and segments.\n */\n interface CommandContext {\n path: string;\n segments: string[];\n }\n\n interface UseCommandContext {\n /**\n * Get the current context. Throws if no context is set.\n */\n use: () => CommandContext;\n\n /**\n * Call a function with a specific context instance. This is used internally to set the context for command executions, but can also be used by advanced users to manually set the context for specific operations if needed.\n */\n call: <R>(instance: CommandContext, callback: () => R | Promise<R>) => Promise<R>;\n }\n\n const _globalThis = (\n typeof globalThis !== \"undefined\"\n ? globalThis\n : typeof self !== \"undefined\"\n ? self\n : typeof global !== \"undefined\"\n ? global\n : typeof window !== \"undefined\"\n ? window\n : {}\n ) as typeof globalThis;\n\n const asyncHandlers: Set<() => void | (() => void)> =\n (_globalThis as any)[\"__shell-shock_async_handlers__\"] ||\n ((_globalThis as any)[\"__shell-shock_async_handlers__\"] = new Set());\n\n function createContext(): UseCommandContext {\n let currentInstance: CommandContext | undefined;\n let als = new AsyncLocalStorage<CommandContext>();\n const getCurrentInstance = (): CommandContext | undefined => {\n if (als) {\n const instance = als.getStore();\n if (instance) {\n return instance;\n }\n }\n return currentInstance;\n };\n\n const result = {\n use() {\n const instance = getCurrentInstance();\n if (!instance) {\n throw new Error(\n \\`The Shell Shock - Command context is not available. Make sure to call useCommand() within a valid context scope.\\`\n );\n }\n return instance;\n },\n async call(instance: CommandContext, callback: () => Promise<any> | any) {\n currentInstance = instance;\n const onRestore = () => {\n currentInstance = instance;\n };\n const onLeave = () =>\n currentInstance === instance ? onRestore : undefined;\n\n asyncHandlers.add(onLeave);\n\n try {\n return await (als ? als.run(instance, callback) : callback());\n } finally {\n asyncHandlers.delete(onLeave);\n }\n },\n };\n\n ((_globalThis as any)[\"__shell-shock__\"]) ??= {};\n ((_globalThis as any)[\"__shell-shock__\"]).__command__ = result;\n\n return result;\n }\n\n /**\n * The global Shell Shock - Command context instance.\n *\n * @internal\n */\n export let internal_commandContext = createContext();\n\n /**\n * Get the Shell Shock - Command context for the current application.\n *\n * @param options - The options to use when getting the context.\n * @returns The Shell Shock - Command context for the current application.\n * @throws If the Shell Shock - Command context is not available.\n */\n function useCommand(): CommandContext {\n if (!internal_commandContext) {\n if ((_globalThis as any)[\"__shell-shock__\"]?.__command__) {\n internal_commandContext = (_globalThis as any)[\"__shell-shock__\"].__command__;\n } else {\n internal_commandContext = createContext();\n }\n }\n\n return internal_commandContext.use();\n }\n\n /**\n * A utility hook function to get the individual segments of the current command path.\n *\n * @returns An array of command path segments.\n * @throws If the command context is not available.\n */\n export function useSegments(): string[] {\n return useCommand().segments;\n }\n\n /**\n * A utility hook function to get the full command path as a string.\n *\n * @returns The full command path as a string.\n * @throws If the command context is not available.\n */\n export function usePath(): string {\n return useCommand().path;\n }\n `;\n}\n\n/**\n * A built-in utilities module for Shell Shock.\n */\nexport function UtilsBuiltin(props: UtilsBuiltinProps) {\n const [{ children }, rest] = splitProps(props, [\"children\"]);\n\n return (\n <BuiltinFile\n id=\"utils\"\n description=\"A collection of helper utilities that ease command-line application development.\"\n {...rest}\n imports={defu(rest.imports ?? {}, {\n \"node:os\": \"os\",\n \"node:process\": \"process\",\n \"node:async_hooks\": [\"AsyncLocalStorage\"]\n })}\n builtinImports={defu(rest.builtinImports ?? {}, {\n console: [\"error\", \"verbose\", \"writeLine\"],\n env: [\"env\", \"isCI\", \"isTest\", \"isWindows\", \"isDevelopment\", \"isDebug\"]\n })}>\n <hbr />\n <hbr />\n <ArgsUtilities />\n <hbr />\n <hbr />\n <EnvSupportUtilities />\n <hbr />\n <hbr />\n <HyperlinkSupportUtilities />\n <hbr />\n <hbr />\n <ColorSupportUtilities />\n <hbr />\n <hbr />\n <ContextUtilities />\n <hbr />\n <hbr />\n <ExitFunctionDeclaration />\n <hbr />\n <hbr />\n <Show when={Boolean(children)}>{children}</Show>\n </BuiltinFile>\n );\n}\n"],"mappings":"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"}
@@ -25,7 +25,7 @@ function VirtualCommandHandlerDeclaration(props) {
25
25
  const context = (0, __powerlines_plugin_alloy_core_contexts_context.usePowerlines)();
26
26
  return [(0, __alloy_js_core_jsx_runtime.createComponent)(__powerlines_plugin_alloy_typescript_components_tsdoc.TSDoc, {
27
27
  get heading() {
28
- return `The ${command.title} (${(0, __shell_shock_core_plugin_utils_context_helpers.getAppBin)(context)} ${command.path.segments.map((segment) => (0, __shell_shock_core_plugin_utils_context_helpers.isDynamicPathSegment)(segment) ? `[${(0, __stryke_string_format_constant_case.constantCase)((0, __shell_shock_core_plugin_utils_context_helpers.getDynamicPathSegmentName)(segment))}]` : segment).join(" ")}) virtual command.`;
28
+ return `The ${command.title} (${(0, __shell_shock_core_plugin_utils_context_helpers.getAppBin)(context)} ${command.segments.map((segment) => (0, __shell_shock_core_plugin_utils_context_helpers.isDynamicPathSegment)(segment) ? `[${(0, __stryke_string_format_constant_case.constantCase)((0, __shell_shock_core_plugin_utils_context_helpers.getDynamicPathSegmentName)(segment))}]` : segment).join(" ")}) virtual command.`;
29
29
  },
30
30
  get children() {
31
31
  return [
@@ -57,8 +57,8 @@ function VirtualCommandHandlerDeclaration(props) {
57
57
  (0, __alloy_js_core_jsx_runtime.createIntrinsic)("hbr", {}),
58
58
  children,
59
59
  (0, __alloy_js_core_jsx_runtime.createComponent)(require_components_command_router.CommandRouter, {
60
- get path() {
61
- return command.path.segments;
60
+ get segments() {
61
+ return command.segments;
62
62
  },
63
63
  get commands() {
64
64
  return command.children;
@@ -71,8 +71,8 @@ function VirtualCommandHandlerDeclaration(props) {
71
71
  (0, __alloy_js_core_jsx_runtime.createIntrinsic)("hbr", {}),
72
72
  (0, __alloy_js_core_jsx_runtime.createIntrinsic)("hbr", {}),
73
73
  (0, __alloy_js_core_jsx_runtime.createComponent)(require_components_help.VirtualHelp, {
74
- get path() {
75
- return command.path;
74
+ get segments() {
75
+ return command.segments;
76
76
  },
77
77
  get options() {
78
78
  return Object.values(command.options);
@@ -91,7 +91,7 @@ function VirtualCommandHandlerDeclaration(props) {
91
91
  function VirtualCommandEntry(props) {
92
92
  const { command, imports, builtinImports, ...rest } = props;
93
93
  const context = (0, __powerlines_plugin_alloy_core_contexts_context.usePowerlines)();
94
- const filePath = (0, __alloy_js_core.computed)(() => (0, __stryke_path_join.joinPaths)(context.entryPath, command.path.segments.filter((segment) => !(0, __shell_shock_core_plugin_utils_context_helpers.isDynamicPathSegment)(segment)).join("/"), "index.ts"));
94
+ const filePath = (0, __alloy_js_core.computed)(() => (0, __stryke_path_join.joinPaths)(context.entryPath, command.segments.filter((segment) => !(0, __shell_shock_core_plugin_utils_context_helpers.isDynamicPathSegment)(segment)).join("/"), "index.ts"));
95
95
  return [(0, __alloy_js_core_jsx_runtime.createComponent)(__powerlines_plugin_alloy_typescript_components_typescript_file.TypescriptFile, (0, __alloy_js_core_jsx_runtime.mergeProps)(rest, {
96
96
  get path() {
97
97
  return filePath.value;
@@ -115,11 +115,14 @@ function VirtualCommandEntry(props) {
115
115
  get builtinImports() {
116
116
  return (0, defu.default)(builtinImports ?? {}, {
117
117
  console: [
118
+ "help",
118
119
  "warn",
119
120
  "error",
120
121
  "table",
121
122
  "colors",
122
- "writeLine"
123
+ "writeLine",
124
+ "splitText",
125
+ "stripAnsi"
123
126
  ],
124
127
  utils: [
125
128
  "getArgs",
@@ -1 +1 @@
1
- {"version":3,"file":"virtual-command-entry.cjs","names":["code","computed","For","Show","FunctionDeclaration","usePowerlines","TSDoc","TSDocParam","TSDocRemarks","TSDocTitle","TypescriptFile","getAppBin","getDynamicPathSegmentName","isDynamicPathSegment","joinPaths","constantCase","pascalCase","defu","BannerFunctionDeclaration","CommandEntry","CommandRouter","VirtualHelp","VirtualCommandHandlerDeclaration","props","command","children","context","_$createComponent","heading","title","path","segments","map","segment","join","description","replace","_$createIntrinsic","name","async","parameters","type","default","commands","options","Object","values","VirtualCommandEntry","imports","builtinImports","rest","filePath","entryPath","filter","_$mergeProps","value","didyoumean2","entries","child","isVirtual","reduce","ret","alias","console","utils","each","when","fallback"],"sources":["../../src/components/virtual-command-entry.tsx"],"sourcesContent":["/* -------------------------------------------------------------------\n\n ⚡ Storm Software - Shell Shock\n\n This code was released as part of the Shell Shock project. Shell Shock\n is maintained by Storm Software under the Apache-2.0 license, and is\n free for commercial and private use. For more information, please visit\n our licensing page at https://stormsoftware.com/licenses/projects/shell-shock.\n\n Website: https://stormsoftware.com\n Repository: https://github.com/storm-software/shell-shock\n Documentation: https://docs.stormsoftware.com/projects/shell-shock\n Contact: https://stormsoftware.com/contact\n\n SPDX-License-Identifier: Apache-2.0\n\n ------------------------------------------------------------------- */\n\nimport type { Children } from \"@alloy-js/core\";\nimport { code, computed, For, Show } from \"@alloy-js/core\";\nimport { FunctionDeclaration } from \"@alloy-js/typescript\";\nimport { usePowerlines } from \"@powerlines/plugin-alloy/core/contexts/context\";\nimport type { TypescriptFileImports } from \"@powerlines/plugin-alloy/types/components\";\nimport type { EntryFileProps } from \"@powerlines/plugin-alloy/typescript/components/entry-file\";\nimport {\n TSDoc,\n TSDocParam,\n TSDocRemarks,\n TSDocTitle\n} from \"@powerlines/plugin-alloy/typescript/components/tsdoc\";\nimport { TypescriptFile } from \"@powerlines/plugin-alloy/typescript/components/typescript-file\";\nimport {\n getAppBin,\n getDynamicPathSegmentName,\n isDynamicPathSegment\n} from \"@shell-shock/core/plugin-utils/context-helpers\";\nimport type { CommandTree } from \"@shell-shock/core/types/command\";\nimport { joinPaths } from \"@stryke/path/join\";\nimport { constantCase } from \"@stryke/string-format/constant-case\";\nimport { pascalCase } from \"@stryke/string-format/pascal-case\";\nimport defu from \"defu\";\nimport type { ScriptPresetContext } from \"../types/plugin\";\nimport { BannerFunctionDeclaration } from \"./banner-function-declaration\";\nimport { CommandEntry } from \"./command-entry\";\nimport { CommandRouter } from \"./command-router\";\nimport { VirtualHelp } from \"./help\";\n\nexport interface VirtualCommandHandlerDeclarationProps {\n command: CommandTree;\n children?: Children;\n}\n\n/**\n * A component that generates the `handler` function declaration for a command.\n */\nexport function VirtualCommandHandlerDeclaration(\n props: VirtualCommandHandlerDeclarationProps\n) {\n const { command, children } = props;\n\n const context = usePowerlines<ScriptPresetContext>();\n\n return (\n <>\n <TSDoc\n heading={`The ${command.title} (${getAppBin(context)} ${command.path.segments\n .map(segment =>\n isDynamicPathSegment(segment)\n ? `[${constantCase(getDynamicPathSegmentName(segment))}]`\n : segment\n )\n .join(\" \")}) virtual command.`}>\n <TSDocRemarks>{`${command.description.replace(/\\.+$/, \"\")}.`}</TSDocRemarks>\n <hbr />\n <TSDocTitle>{command.title}</TSDocTitle>\n <TSDocParam name=\"args\">{`The command-line arguments passed to the command.`}</TSDocParam>\n </TSDoc>\n <FunctionDeclaration\n export\n async\n name=\"handler\"\n parameters={[{ name: \"args\", type: \"string[]\", default: \"getArgs()\" }]}>\n <hbr />\n <hbr />\n {children}\n <CommandRouter\n path={command.path.segments}\n commands={command.children}\n />\n <hbr />\n <hbr />\n {code`writeLine(\"\");\n banner();`}\n <hbr />\n <hbr />\n <VirtualHelp\n path={command.path}\n options={Object.values(command.options)}\n commands={command.children ?? {}}\n />\n </FunctionDeclaration>\n </>\n );\n}\n\nexport interface VirtualCommandEntryProps extends Omit<\n EntryFileProps,\n \"path\" | \"typeDefinition\"\n> {\n command: CommandTree;\n}\n\n/**\n * The virtual command entry point for the Shell Shock project.\n */\nexport function VirtualCommandEntry(props: VirtualCommandEntryProps) {\n const { command, imports, builtinImports, ...rest } = props;\n\n const context = usePowerlines<ScriptPresetContext>();\n const filePath = computed(() =>\n joinPaths(\n context.entryPath,\n command.path.segments\n .filter(segment => !isDynamicPathSegment(segment))\n .join(\"/\"),\n \"index.ts\"\n )\n );\n\n return (\n <>\n <TypescriptFile\n {...rest}\n path={filePath.value}\n imports={defu(\n {\n didyoumean2: [\n { name: \"didYouMean\", default: true },\n { name: \"ReturnTypeEnums\" },\n { name: \"ThresholdTypeEnums\" }\n ]\n },\n imports ?? {},\n Object.entries(command.children)\n .filter(([, child]) => child.isVirtual)\n .reduce((ret, [name, child]) => {\n ret[`./${child.name}`] = [\n { name: \"handler\", alias: `handle${pascalCase(name)}` }\n ];\n\n return ret;\n }, {} as TypescriptFileImports)\n )}\n builtinImports={defu(builtinImports ?? {}, {\n console: [\"warn\", \"error\", \"table\", \"colors\", \"writeLine\"],\n utils: [\"getArgs\", \"hasFlag\", \"isMinimal\", \"isUnicodeSupported\"]\n })}>\n <BannerFunctionDeclaration command={command} />\n <hbr />\n <hbr />\n <VirtualCommandHandlerDeclaration command={command} />\n </TypescriptFile>\n <For each={Object.values(command.children)}>\n {child => (\n <Show\n when={child.isVirtual}\n fallback={<CommandEntry command={child} />}>\n <VirtualCommandEntry command={child} />\n </Show>\n )}\n </For>\n </>\n );\n}\n"],"mappings":"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"}
1
+ {"version":3,"file":"virtual-command-entry.cjs","names":["code","computed","For","Show","FunctionDeclaration","usePowerlines","TSDoc","TSDocParam","TSDocRemarks","TSDocTitle","TypescriptFile","getAppBin","getDynamicPathSegmentName","isDynamicPathSegment","joinPaths","constantCase","pascalCase","defu","BannerFunctionDeclaration","CommandEntry","CommandRouter","VirtualHelp","VirtualCommandHandlerDeclaration","props","command","children","context","_$createComponent","heading","title","segments","map","segment","join","description","replace","_$createIntrinsic","name","async","parameters","type","default","commands","options","Object","values","VirtualCommandEntry","imports","builtinImports","rest","filePath","entryPath","filter","_$mergeProps","path","value","didyoumean2","entries","child","isVirtual","reduce","ret","alias","console","utils","each","when","fallback"],"sources":["../../src/components/virtual-command-entry.tsx"],"sourcesContent":["/* -------------------------------------------------------------------\n\n ⚡ Storm Software - Shell Shock\n\n This code was released as part of the Shell Shock project. Shell Shock\n is maintained by Storm Software under the Apache-2.0 license, and is\n free for commercial and private use. For more information, please visit\n our licensing page at https://stormsoftware.com/licenses/projects/shell-shock.\n\n Website: https://stormsoftware.com\n Repository: https://github.com/storm-software/shell-shock\n Documentation: https://docs.stormsoftware.com/projects/shell-shock\n Contact: https://stormsoftware.com/contact\n\n SPDX-License-Identifier: Apache-2.0\n\n ------------------------------------------------------------------- */\n\nimport type { Children } from \"@alloy-js/core\";\nimport { code, computed, For, Show } from \"@alloy-js/core\";\nimport { FunctionDeclaration } from \"@alloy-js/typescript\";\nimport { usePowerlines } from \"@powerlines/plugin-alloy/core/contexts/context\";\nimport type { TypescriptFileImports } from \"@powerlines/plugin-alloy/types/components\";\nimport type { EntryFileProps } from \"@powerlines/plugin-alloy/typescript/components/entry-file\";\nimport {\n TSDoc,\n TSDocParam,\n TSDocRemarks,\n TSDocTitle\n} from \"@powerlines/plugin-alloy/typescript/components/tsdoc\";\nimport { TypescriptFile } from \"@powerlines/plugin-alloy/typescript/components/typescript-file\";\nimport {\n getAppBin,\n getDynamicPathSegmentName,\n isDynamicPathSegment\n} from \"@shell-shock/core/plugin-utils/context-helpers\";\nimport type { CommandTree } from \"@shell-shock/core/types/command\";\nimport { joinPaths } from \"@stryke/path/join\";\nimport { constantCase } from \"@stryke/string-format/constant-case\";\nimport { pascalCase } from \"@stryke/string-format/pascal-case\";\nimport defu from \"defu\";\nimport type { ScriptPresetContext } from \"../types/plugin\";\nimport { BannerFunctionDeclaration } from \"./banner-function-declaration\";\nimport { CommandEntry } from \"./command-entry\";\nimport { CommandRouter } from \"./command-router\";\nimport { VirtualHelp } from \"./help\";\n\nexport interface VirtualCommandHandlerDeclarationProps {\n command: CommandTree;\n children?: Children;\n}\n\n/**\n * A component that generates the `handler` function declaration for a command.\n */\nexport function VirtualCommandHandlerDeclaration(\n props: VirtualCommandHandlerDeclarationProps\n) {\n const { command, children } = props;\n\n const context = usePowerlines<ScriptPresetContext>();\n\n return (\n <>\n <TSDoc\n heading={`The ${command.title} (${getAppBin(context)} ${command.segments\n .map(segment =>\n isDynamicPathSegment(segment)\n ? `[${constantCase(getDynamicPathSegmentName(segment))}]`\n : segment\n )\n .join(\" \")}) virtual command.`}>\n <TSDocRemarks>{`${command.description.replace(/\\.+$/, \"\")}.`}</TSDocRemarks>\n <hbr />\n <TSDocTitle>{command.title}</TSDocTitle>\n <TSDocParam name=\"args\">{`The command-line arguments passed to the command.`}</TSDocParam>\n </TSDoc>\n <FunctionDeclaration\n export\n async\n name=\"handler\"\n parameters={[{ name: \"args\", type: \"string[]\", default: \"getArgs()\" }]}>\n <hbr />\n <hbr />\n {children}\n <CommandRouter\n segments={command.segments}\n commands={command.children}\n />\n <hbr />\n <hbr />\n {code`writeLine(\"\");\n banner();`}\n <hbr />\n <hbr />\n <VirtualHelp\n segments={command.segments}\n options={Object.values(command.options)}\n commands={command.children ?? {}}\n />\n </FunctionDeclaration>\n </>\n );\n}\n\nexport interface VirtualCommandEntryProps extends Omit<\n EntryFileProps,\n \"path\" | \"typeDefinition\"\n> {\n command: CommandTree;\n}\n\n/**\n * The virtual command entry point for the Shell Shock project.\n */\nexport function VirtualCommandEntry(props: VirtualCommandEntryProps) {\n const { command, imports, builtinImports, ...rest } = props;\n\n const context = usePowerlines<ScriptPresetContext>();\n const filePath = computed(() =>\n joinPaths(\n context.entryPath,\n command.segments\n .filter(segment => !isDynamicPathSegment(segment))\n .join(\"/\"),\n \"index.ts\"\n )\n );\n\n return (\n <>\n <TypescriptFile\n {...rest}\n path={filePath.value}\n imports={defu(\n {\n didyoumean2: [\n { name: \"didYouMean\", default: true },\n { name: \"ReturnTypeEnums\" },\n { name: \"ThresholdTypeEnums\" }\n ]\n },\n imports ?? {},\n Object.entries(command.children)\n .filter(([, child]) => child.isVirtual)\n .reduce((ret, [name, child]) => {\n ret[`./${child.name}`] = [\n { name: \"handler\", alias: `handle${pascalCase(name)}` }\n ];\n\n return ret;\n }, {} as TypescriptFileImports)\n )}\n builtinImports={defu(builtinImports ?? {}, {\n console: [\n \"help\",\n \"warn\",\n \"error\",\n \"table\",\n \"colors\",\n \"writeLine\",\n \"splitText\",\n \"stripAnsi\"\n ],\n utils: [\"getArgs\", \"hasFlag\", \"isMinimal\", \"isUnicodeSupported\"]\n })}>\n <BannerFunctionDeclaration command={command} />\n <hbr />\n <hbr />\n <VirtualCommandHandlerDeclaration command={command} />\n </TypescriptFile>\n <For each={Object.values(command.children)}>\n {child => (\n <Show\n when={child.isVirtual}\n fallback={<CommandEntry command={child} />}>\n <VirtualCommandEntry command={child} />\n </Show>\n )}\n </For>\n </>\n );\n}\n"],"mappings":"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"}
@@ -23,7 +23,7 @@ function VirtualCommandHandlerDeclaration(props) {
23
23
  const context = usePowerlines();
24
24
  return [createComponent(TSDoc, {
25
25
  get heading() {
26
- return `The ${command.title} (${getAppBin(context)} ${command.path.segments.map((segment) => isDynamicPathSegment(segment) ? `[${constantCase(getDynamicPathSegmentName(segment))}]` : segment).join(" ")}) virtual command.`;
26
+ return `The ${command.title} (${getAppBin(context)} ${command.segments.map((segment) => isDynamicPathSegment(segment) ? `[${constantCase(getDynamicPathSegmentName(segment))}]` : segment).join(" ")}) virtual command.`;
27
27
  },
28
28
  get children() {
29
29
  return [
@@ -55,8 +55,8 @@ function VirtualCommandHandlerDeclaration(props) {
55
55
  createIntrinsic("hbr", {}),
56
56
  children,
57
57
  createComponent(CommandRouter, {
58
- get path() {
59
- return command.path.segments;
58
+ get segments() {
59
+ return command.segments;
60
60
  },
61
61
  get commands() {
62
62
  return command.children;
@@ -69,8 +69,8 @@ function VirtualCommandHandlerDeclaration(props) {
69
69
  createIntrinsic("hbr", {}),
70
70
  createIntrinsic("hbr", {}),
71
71
  createComponent(VirtualHelp, {
72
- get path() {
73
- return command.path;
72
+ get segments() {
73
+ return command.segments;
74
74
  },
75
75
  get options() {
76
76
  return Object.values(command.options);
@@ -89,7 +89,7 @@ function VirtualCommandHandlerDeclaration(props) {
89
89
  function VirtualCommandEntry(props) {
90
90
  const { command, imports, builtinImports, ...rest } = props;
91
91
  const context = usePowerlines();
92
- const filePath = computed(() => joinPaths(context.entryPath, command.path.segments.filter((segment) => !isDynamicPathSegment(segment)).join("/"), "index.ts"));
92
+ const filePath = computed(() => joinPaths(context.entryPath, command.segments.filter((segment) => !isDynamicPathSegment(segment)).join("/"), "index.ts"));
93
93
  return [createComponent(TypescriptFile, mergeProps(rest, {
94
94
  get path() {
95
95
  return filePath.value;
@@ -113,11 +113,14 @@ function VirtualCommandEntry(props) {
113
113
  get builtinImports() {
114
114
  return defu(builtinImports ?? {}, {
115
115
  console: [
116
+ "help",
116
117
  "warn",
117
118
  "error",
118
119
  "table",
119
120
  "colors",
120
- "writeLine"
121
+ "writeLine",
122
+ "splitText",
123
+ "stripAnsi"
121
124
  ],
122
125
  utils: [
123
126
  "getArgs",