obsidian-dev-utils 22.1.1-beta.2 → 22.1.1-beta.20

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 (91) hide show
  1. package/CHANGELOG.md +102 -0
  2. package/dist/dprint.json +1 -0
  3. package/dist/lib/cjs/Library.cjs +1 -1
  4. package/dist/lib/cjs/Object.cjs +38 -3
  5. package/dist/lib/cjs/Object.d.cts +16 -6
  6. package/dist/lib/cjs/ScriptUtils/CliUtils.cjs +1 -2
  7. package/dist/lib/cjs/ScriptUtils/CliUtils.d.cts +3 -2
  8. package/dist/lib/cjs/ScriptUtils/cli.cjs +1 -1
  9. package/dist/lib/cjs/String.cjs +1 -1
  10. package/dist/lib/cjs/String.d.cts +2 -1
  11. package/dist/lib/cjs/Transformers/Transformer.cjs +9 -2
  12. package/dist/lib/cjs/Type.cjs +24 -0
  13. package/dist/lib/cjs/Type.d.cts +12 -0
  14. package/dist/lib/cjs/index.cjs +4 -1
  15. package/dist/lib/cjs/index.d.cts +1 -0
  16. package/dist/lib/cjs/obsidian/Callout.cjs +1 -1
  17. package/dist/lib/cjs/obsidian/Callout.d.cts +2 -1
  18. package/dist/lib/cjs/obsidian/Components/MultipleTextComponent.cjs +29 -2
  19. package/dist/lib/cjs/obsidian/Components/MultipleTextComponent.d.cts +20 -1
  20. package/dist/lib/cjs/obsidian/Components/TextBasedComponent.cjs +60 -0
  21. package/dist/lib/cjs/obsidian/Components/TextBasedComponent.d.cts +30 -0
  22. package/dist/lib/cjs/obsidian/Components/TypedTextComponent.cjs +27 -3
  23. package/dist/lib/cjs/obsidian/Components/TypedTextComponent.d.cts +19 -1
  24. package/dist/lib/cjs/obsidian/Components/index.cjs +4 -1
  25. package/dist/lib/cjs/obsidian/Components/index.d.cts +1 -0
  26. package/dist/lib/cjs/obsidian/FileManager.cjs +1 -1
  27. package/dist/lib/cjs/obsidian/FileManager.d.cts +2 -1
  28. package/dist/lib/cjs/obsidian/Link.cjs +1 -1
  29. package/dist/lib/cjs/obsidian/Link.d.cts +4 -3
  30. package/dist/lib/cjs/obsidian/Markdown.cjs +5 -8
  31. package/dist/lib/cjs/obsidian/Modals/Prompt.cjs +1 -1
  32. package/dist/lib/cjs/obsidian/Modals/Prompt.d.cts +2 -1
  33. package/dist/lib/cjs/obsidian/MonkeyAround.cjs +1 -1
  34. package/dist/lib/cjs/obsidian/MonkeyAround.d.cts +2 -2
  35. package/dist/lib/cjs/obsidian/Plugin/PluginBase.cjs +31 -2
  36. package/dist/lib/cjs/obsidian/Plugin/PluginBase.d.cts +15 -3
  37. package/dist/lib/cjs/obsidian/Plugin/PluginSettingsManagerBase.cjs +186 -62
  38. package/dist/lib/cjs/obsidian/Plugin/PluginSettingsManagerBase.d.cts +42 -21
  39. package/dist/lib/cjs/obsidian/Plugin/PluginSettingsTabBase.cjs +33 -20
  40. package/dist/lib/cjs/obsidian/Plugin/PluginSettingsTabBase.d.cts +20 -17
  41. package/dist/lib/cjs/obsidian/RenameDeleteHandler.cjs +75 -75
  42. package/dist/lib/cjs/obsidian/ValidationMessage.cjs +38 -0
  43. package/dist/lib/cjs/obsidian/ValidationMessage.d.cts +16 -0
  44. package/dist/lib/cjs/obsidian/index.cjs +4 -1
  45. package/dist/lib/cjs/obsidian/index.d.cts +1 -0
  46. package/dist/lib/esm/Library.mjs +1 -1
  47. package/dist/lib/esm/Object.d.mts +16 -6
  48. package/dist/lib/esm/Object.mjs +36 -3
  49. package/dist/lib/esm/ScriptUtils/CliUtils.d.mts +3 -2
  50. package/dist/lib/esm/ScriptUtils/CliUtils.mjs +1 -2
  51. package/dist/lib/esm/ScriptUtils/cli.mjs +1 -1
  52. package/dist/lib/esm/String.d.mts +2 -1
  53. package/dist/lib/esm/String.mjs +1 -1
  54. package/dist/lib/esm/Transformers/Transformer.mjs +9 -2
  55. package/dist/lib/esm/Type.d.mts +12 -0
  56. package/dist/lib/esm/Type.mjs +8 -0
  57. package/dist/lib/esm/index.d.mts +1 -0
  58. package/dist/lib/esm/index.mjs +3 -1
  59. package/dist/lib/esm/obsidian/Callout.d.mts +2 -1
  60. package/dist/lib/esm/obsidian/Callout.mjs +1 -1
  61. package/dist/lib/esm/obsidian/Components/MultipleTextComponent.d.mts +20 -1
  62. package/dist/lib/esm/obsidian/Components/MultipleTextComponent.mjs +29 -2
  63. package/dist/lib/esm/obsidian/Components/TextBasedComponent.d.mts +30 -0
  64. package/dist/lib/esm/obsidian/Components/TextBasedComponent.mjs +36 -0
  65. package/dist/lib/esm/obsidian/Components/TypedTextComponent.d.mts +19 -1
  66. package/dist/lib/esm/obsidian/Components/TypedTextComponent.mjs +27 -3
  67. package/dist/lib/esm/obsidian/Components/index.d.mts +1 -0
  68. package/dist/lib/esm/obsidian/Components/index.mjs +3 -1
  69. package/dist/lib/esm/obsidian/FileManager.d.mts +2 -1
  70. package/dist/lib/esm/obsidian/FileManager.mjs +1 -1
  71. package/dist/lib/esm/obsidian/Link.d.mts +4 -3
  72. package/dist/lib/esm/obsidian/Link.mjs +1 -1
  73. package/dist/lib/esm/obsidian/Markdown.mjs +5 -8
  74. package/dist/lib/esm/obsidian/Modals/Prompt.d.mts +2 -1
  75. package/dist/lib/esm/obsidian/Modals/Prompt.mjs +1 -1
  76. package/dist/lib/esm/obsidian/MonkeyAround.d.mts +2 -2
  77. package/dist/lib/esm/obsidian/MonkeyAround.mjs +1 -1
  78. package/dist/lib/esm/obsidian/Plugin/PluginBase.d.mts +15 -3
  79. package/dist/lib/esm/obsidian/Plugin/PluginBase.mjs +35 -3
  80. package/dist/lib/esm/obsidian/Plugin/PluginSettingsManagerBase.d.mts +42 -21
  81. package/dist/lib/esm/obsidian/Plugin/PluginSettingsManagerBase.mjs +186 -63
  82. package/dist/lib/esm/obsidian/Plugin/PluginSettingsTabBase.d.mts +20 -17
  83. package/dist/lib/esm/obsidian/Plugin/PluginSettingsTabBase.mjs +36 -20
  84. package/dist/lib/esm/obsidian/RenameDeleteHandler.mjs +75 -75
  85. package/dist/lib/esm/obsidian/ValidationMessage.d.mts +16 -0
  86. package/dist/lib/esm/obsidian/ValidationMessage.mjs +14 -0
  87. package/dist/lib/esm/obsidian/index.d.mts +1 -0
  88. package/dist/lib/esm/obsidian/index.mjs +3 -1
  89. package/obsidian/Components/TextBasedComponent/package.json +6 -0
  90. package/obsidian/ValidationMessage/package.json +6 -0
  91. package/package.json +4 -4
package/CHANGELOG.md CHANGED
@@ -1,5 +1,107 @@
1
1
  # CHANGELOG
2
2
 
3
+ ## 22.1.1-beta.20
4
+
5
+ - Reuse getAllKeys when transform
6
+ - Format
7
+ - getAllEntries
8
+ - Reuse getAllKeys
9
+ - Skip __proto__
10
+
11
+ ## 22.1.1-beta.19
12
+
13
+ - Sort keys
14
+
15
+ ## 22.1.1-beta.18
16
+
17
+ - Return full PluginSettings
18
+ - Add missing await
19
+
20
+ ## 22.1.1-beta.17
21
+
22
+ - getAllKeys
23
+
24
+ ## 22.1.1-beta.16
25
+
26
+ - More reliable ExtractPluginSettings
27
+
28
+ ## 22.1.1-beta.15
29
+
30
+ - Use properties
31
+ - Use default values by default
32
+ - Better set placeholder
33
+ - Show better tooltip
34
+ - Make optional
35
+ - Improve ExtractPluginSettings
36
+ - shouldResetSettingWhenComponentIsEmpty
37
+
38
+ ## 22.1.1-beta.14
39
+
40
+ - Allow optional functions
41
+
42
+ ## 22.1.1-beta.13
43
+
44
+ - Refactor to use monkey-around internally
45
+ - Hook after load and before saving record
46
+
47
+ ## 22.1.1-beta.12
48
+
49
+ - Move helpers to Type
50
+ - Add access to plugin and app
51
+ - Update libs
52
+
53
+ ## 22.1.1-beta.11
54
+
55
+ - TextBasedComponent
56
+
57
+ ## 22.1.1-beta.10
58
+
59
+ - Init components without placeholders
60
+
61
+ ## 22.1.1-beta.9
62
+
63
+ - Separate setValueAndValidate and setValidationMessage
64
+ - Don't save unmodified
65
+
66
+ ## 22.1.1-beta.8
67
+
68
+ - Save only if there are changes
69
+ - Properly check for JSON changes
70
+
71
+ ## 22.1.1-beta.7
72
+
73
+ - Detailed Invalid value type warning
74
+
75
+ ## 22.1.1-beta.6
76
+
77
+ - Rename PropertyName
78
+ - Show warning for wrong values
79
+ - Fix dprint rule
80
+ - Add default value placeholder
81
+ - Support empty validation messages
82
+
83
+ ## 22.1.1-beta.5
84
+
85
+ - Format
86
+ - Save transformed settings
87
+ - onSaveSettings hook
88
+ - Simplify ExtractPluginSettings
89
+ - Pass values to onChanged
90
+ - Add setAndValidate
91
+ - Remove useless validations
92
+ - Rename getSettingsRecord
93
+ - Restore getSafe
94
+ - Refactor to MaybeReturn
95
+
96
+ ## 22.1.1-beta.4
97
+
98
+ - Switch to promisable
99
+ - Remove unused
100
+
101
+ ## 22.1.1-beta.3
102
+
103
+ - Add validators
104
+
3
105
  ## 22.1.1-beta.2
4
106
 
5
107
  - Fix array props
package/dist/dprint.json CHANGED
@@ -1,5 +1,6 @@
1
1
  {
2
2
  "typescript": {
3
+ "bracePosition": "sameLine",
3
4
  "constructSignature.spaceAfterNewKeyword": true,
4
5
  "constructorType.spaceAfterNewKeyword": true,
5
6
  "exportDeclaration.forceMultiLine": "whenMultiple",
@@ -30,7 +30,7 @@ __export(Library_exports, {
30
30
  LIBRARY_VERSION: () => LIBRARY_VERSION
31
31
  });
32
32
  module.exports = __toCommonJS(Library_exports);
33
- const LIBRARY_VERSION = "22.1.1-beta.2";
33
+ const LIBRARY_VERSION = "22.1.1-beta.20";
34
34
  const LIBRARY_NAME = "obsidian-dev-utils";
35
35
  const LIBRARY_STYLES = ".obsidian-dev-utils input[type=url] {\n height: var(--input-height);\n}\n.obsidian-dev-utils input[type=month],\n.obsidian-dev-utils input[type=time],\n.obsidian-dev-utils input[type=url],\n.obsidian-dev-utils input[type=week] {\n -webkit-app-region: no-drag;\n background: var(--background-modifier-form-field);\n border: var(--input-border-width) solid var(--background-modifier-border);\n color: var(--text-normal);\n font-family: inherit;\n padding: var(--size-4-1) var(--size-4-2);\n font-size: var(--font-ui-small);\n border-radius: var(--input-radius);\n outline: none;\n}\n@media (hover: hover) {\n .obsidian-dev-utils input[type=month]:hover,\n .obsidian-dev-utils input[type=time]:hover,\n .obsidian-dev-utils input[type=url]:hover,\n .obsidian-dev-utils input[type=week]:hover {\n border-color: var(--background-modifier-border-hover);\n transition: box-shadow 0.15s ease-in-out, border 0.15s ease-in-out;\n }\n}\n.obsidian-dev-utils input[type=month]:active, .obsidian-dev-utils input[type=month]:focus,\n.obsidian-dev-utils input[type=time]:active,\n.obsidian-dev-utils input[type=time]:focus,\n.obsidian-dev-utils input[type=url]:active,\n.obsidian-dev-utils input[type=url]:focus,\n.obsidian-dev-utils input[type=week]:active,\n.obsidian-dev-utils input[type=week]:focus {\n border-color: var(--background-modifier-border-focus);\n transition: box-shadow 0.15s ease-in-out, border 0.15s ease-in-out;\n}\n.obsidian-dev-utils input[type=month]:active, .obsidian-dev-utils input[type=month]:focus, .obsidian-dev-utils input[type=month]:focus-visible,\n.obsidian-dev-utils input[type=time]:active,\n.obsidian-dev-utils input[type=time]:focus,\n.obsidian-dev-utils input[type=time]:focus-visible,\n.obsidian-dev-utils input[type=url]:active,\n.obsidian-dev-utils input[type=url]:focus,\n.obsidian-dev-utils input[type=url]:focus-visible,\n.obsidian-dev-utils input[type=week]:active,\n.obsidian-dev-utils input[type=week]:focus,\n.obsidian-dev-utils input[type=week]:focus-visible {\n box-shadow: 0 0 0 2px var(--background-modifier-border-focus);\n}\n.obsidian-dev-utils input[type=month]::placeholder,\n.obsidian-dev-utils input[type=time]::placeholder,\n.obsidian-dev-utils input[type=url]::placeholder,\n.obsidian-dev-utils input[type=week]::placeholder {\n color: var(--text-faint);\n}\n.mod-rtl input[type=month],\n.mod-rtl input[type=time],\n.mod-rtl input[type=week],\n.is-rtl input[type=month],\n.is-rtl input[type=time],\n.is-rtl input[type=week],\n.rtl input[type=month],\n.rtl input[type=time],\n.rtl input[type=week] {\n direction: rtl;\n}\n.mod-rtl input[type=month]::-webkit-calendar-picker-indicator,\n.mod-rtl input[type=time]::-webkit-calendar-picker-indicator,\n.mod-rtl input[type=week]::-webkit-calendar-picker-indicator,\n.is-rtl input[type=month]::-webkit-calendar-picker-indicator,\n.is-rtl input[type=time]::-webkit-calendar-picker-indicator,\n.is-rtl input[type=week]::-webkit-calendar-picker-indicator,\n.rtl input[type=month]::-webkit-calendar-picker-indicator,\n.rtl input[type=time]::-webkit-calendar-picker-indicator,\n.rtl input[type=week]::-webkit-calendar-picker-indicator {\n right: var(--size-4-1);\n left: auto;\n}\n\n.obsidian-dev-utils input[type=month],\n.obsidian-dev-utils input[type=time],\n.obsidian-dev-utils input[type=week] {\n font-variant-numeric: tabular-nums;\n position: relative;\n}\n.obsidian-dev-utils input[type=month]::-webkit-datetime-edit-text,\n.obsidian-dev-utils input[type=time]::-webkit-datetime-edit-text,\n.obsidian-dev-utils input[type=week]::-webkit-datetime-edit-text {\n color: var(--text-faint);\n padding-inline-end: 0;\n}\n.obsidian-dev-utils input[type=month]::-webkit-calendar-picker-indicator,\n.obsidian-dev-utils input[type=time]::-webkit-calendar-picker-indicator,\n.obsidian-dev-utils input[type=week]::-webkit-calendar-picker-indicator {\n position: absolute;\n left: var(--size-4-1);\n right: auto;\n opacity: 0.5;\n}\n.obsidian-dev-utils input[type=month]::-webkit-datetime-edit-month-field:active, .obsidian-dev-utils input[type=month]::-webkit-datetime-edit-month-field:focus, .obsidian-dev-utils input[type=month]::-webkit-datetime-edit-day-field:active, .obsidian-dev-utils input[type=month]::-webkit-datetime-edit-day-field:focus, .obsidian-dev-utils input[type=month]::-webkit-datetime-edit-year-field:active, .obsidian-dev-utils input[type=month]::-webkit-datetime-edit-year-field:focus,\n.obsidian-dev-utils input[type=time]::-webkit-datetime-edit-month-field:active,\n.obsidian-dev-utils input[type=time]::-webkit-datetime-edit-month-field:focus,\n.obsidian-dev-utils input[type=time]::-webkit-datetime-edit-day-field:active,\n.obsidian-dev-utils input[type=time]::-webkit-datetime-edit-day-field:focus,\n.obsidian-dev-utils input[type=time]::-webkit-datetime-edit-year-field:active,\n.obsidian-dev-utils input[type=time]::-webkit-datetime-edit-year-field:focus,\n.obsidian-dev-utils input[type=week]::-webkit-datetime-edit-month-field:active,\n.obsidian-dev-utils input[type=week]::-webkit-datetime-edit-month-field:focus,\n.obsidian-dev-utils input[type=week]::-webkit-datetime-edit-day-field:active,\n.obsidian-dev-utils input[type=week]::-webkit-datetime-edit-day-field:focus,\n.obsidian-dev-utils input[type=week]::-webkit-datetime-edit-year-field:active,\n.obsidian-dev-utils input[type=week]::-webkit-datetime-edit-year-field:focus {\n background-color: var(--text-selection);\n color: var(--text-normal);\n cursor: text;\n}\n.mod-rtl .obsidian-dev-utils input[type=month], .is-rtl .obsidian-dev-utils input[type=month], .rtl .obsidian-dev-utils input[type=month],\n.mod-rtl .obsidian-dev-utils input[type=time],\n.is-rtl .obsidian-dev-utils input[type=time],\n.rtl .obsidian-dev-utils input[type=time],\n.mod-rtl .obsidian-dev-utils input[type=week],\n.is-rtl .obsidian-dev-utils input[type=week],\n.rtl .obsidian-dev-utils input[type=week] {\n direction: rtl;\n}\n.mod-rtl .obsidian-dev-utils input[type=month]::-webkit-calendar-picker-indicator, .is-rtl .obsidian-dev-utils input[type=month]::-webkit-calendar-picker-indicator, .rtl .obsidian-dev-utils input[type=month]::-webkit-calendar-picker-indicator,\n.mod-rtl .obsidian-dev-utils input[type=time]::-webkit-calendar-picker-indicator,\n.is-rtl .obsidian-dev-utils input[type=time]::-webkit-calendar-picker-indicator,\n.rtl .obsidian-dev-utils input[type=time]::-webkit-calendar-picker-indicator,\n.mod-rtl .obsidian-dev-utils input[type=week]::-webkit-calendar-picker-indicator,\n.is-rtl .obsidian-dev-utils input[type=week]::-webkit-calendar-picker-indicator,\n.rtl .obsidian-dev-utils input[type=week]::-webkit-calendar-picker-indicator {\n left: auto;\n right: var(--size-4-1);\n}\n\nbody:not(.is-ios):not(.is-android) .obsidian-dev-utils input[type=month],\nbody:not(.is-ios):not(.is-android) .obsidian-dev-utils input[type=time],\nbody:not(.is-ios):not(.is-android) .obsidian-dev-utils input[type=week] {\n padding-inline-start: var(--size-4-6);\n}\n\n.obsidian-dev-utils input[type=time]::-webkit-calendar-picker-indicator {\n margin-inline-start: 0;\n}\n\n.obsidian-dev-utils.modal-container .ok-button {\n margin-right: 10px;\n margin-top: 20px;\n}\n\n.obsidian-dev-utils .multiple-dropdown-component select,\n.obsidian-dev-utils .multiple-dropdown-component select:focus,\n.obsidian-dev-utils .multiple-dropdown-component .dropdown {\n height: auto;\n}\n.obsidian-dev-utils .multiple-dropdown-component select option:checked,\n.obsidian-dev-utils .multiple-dropdown-component select:focus option:checked,\n.obsidian-dev-utils .multiple-dropdown-component .dropdown option:checked {\n background-color: #1967d2;\n color: #fff;\n}\n\n.obsidian-dev-utils.prompt-modal .text-box {\n width: 100%;\n}\n\n.obsidian-dev-utils :invalid {\n box-shadow: 0 0 0 2px var(--text-error);\n}\n\n/*# sourceMappingURL=data:application/json;charset=utf-8,%7B%22version%22:3,%22sourceRoot%22:%22%22,%22sources%22:%5B%22../src/styles/input.scss%22,%22../src/styles/input-time.scss%22,%22../src/styles/modal-container.scss%22,%22../src/styles/multiple-dropdown-component.scss%22,%22../src/styles/prompt-modal.scss%22,%22../src/styles/validation.scss%22%5D,%22names%22:%5B%5D,%22mappings%22:%22AACE;EACE;;AAGF;AAAA;AAAA;AAAA;EAIE;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;AAGE;EACE;AAAA;AAAA;AAAA;IACE;IACA,YACE;;;AAMR;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;EAEE;EACA,YACE;;AAIJ;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;EAGE;;AAGF;AAAA;AAAA;AAAA;EACE;;AASE;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;EAGE;;AAEA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;EACE;EACA;;;AC5DV;AAAA;AAAA;EAGE;EACA;;AAEA;AAAA;AAAA;EACE;EACA;;AAGF;AAAA;AAAA;EACE;EACA;EACA;EACA;;AAMA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;EAEE;EACA;EACA;;AAIK;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;EAGP;;AAEA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;EACE;EACA;;;AAKF;AAAA;AAAA;EACE;;;AAMJ;EACE;;;AChDF;EACE;EACA;;;ACFF;AAAA;AAAA;EAGE;;AAEA;AAAA;AAAA;EACE;EACA;;;ACPJ;EACE;;;ACFJ;EACE%22,%22file%22:%22styles.css%22,%22sourcesContent%22:%5B%22.obsidian-dev-utils%20%7B%5Cn%20%20input%5Btype='url'%5D%20%7B%5Cn%20%20%20%20height:%20var(--input-height)%5Cn%20%20%7D%5Cn%5Cn%20%20input%5Btype='month'%5D,%5Cn%20%20input%5Btype='time'%5D,%5Cn%20%20input%5Btype='url'%5D,%5Cn%20%20input%5Btype='week'%5D%20%7B%5Cn%20%20%20%20-webkit-app-region:%20no-drag;%5Cn%20%20%20%20background:%20var(--background-modifier-form-field);%5Cn%20%20%20%20border:%20var(--input-border-width)%20solid%20var(--background-modifier-border);%5Cn%20%20%20%20color:%20var(--text-normal);%5Cn%20%20%20%20font-family:%20inherit;%5Cn%20%20%20%20padding:%20var(--size-4-1)%20var(--size-4-2);%5Cn%20%20%20%20font-size:%20var(--font-ui-small);%5Cn%20%20%20%20border-radius:%20var(--input-radius);%5Cn%20%20%20%20outline:%20none;%5Cn%5Cn%20%20%20%20@at-root%20%7B%5Cn%20%20%20%20%20%20@media%20(hover:%20hover)%20%7B%5Cn%20%20%20%20%20%20%20%20&:hover%20%7B%5Cn%20%20%20%20%20%20%20%20%20%20border-color:%20var(--background-modifier-border-hover);%5Cn%20%20%20%20%20%20%20%20%20%20transition:%5Cn%20%20%20%20%20%20%20%20%20%20%20%20box-shadow%200.15s%20ease-in-out,%5Cn%20%20%20%20%20%20%20%20%20%20%20%20border%200.15s%20ease-in-out;%5Cn%20%20%20%20%20%20%20%20%7D%5Cn%20%20%20%20%20%20%7D%5Cn%20%20%20%20%7D%5Cn%5Cn%20%20%20%20&:active,%5Cn%20%20%20%20&:focus%20%7B%5Cn%20%20%20%20%20%20border-color:%20var(--background-modifier-border-focus);%5Cn%20%20%20%20%20%20transition:%5Cn%20%20%20%20%20%20%20%20box-shadow%200.15s%20ease-in-out,%5Cn%20%20%20%20%20%20%20%20border%200.15s%20ease-in-out;%5Cn%20%20%20%20%7D%5Cn%5Cn%20%20%20%20&:active,%5Cn%20%20%20%20&:focus,%5Cn%20%20%20%20&:focus-visible%20%7B%5Cn%20%20%20%20%20%20box-shadow:%200%200%200%202px%20var(--background-modifier-border-focus);%5Cn%20%20%20%20%7D%5Cn%5Cn%20%20%20%20&::placeholder%20%7B%5Cn%20%20%20%20%20%20color:%20var(--text-faint);%5Cn%20%20%20%20%7D%5Cn%20%20%7D%5Cn%5Cn%20%20@at-root%20%7B%5Cn%20%20%20%20.mod-rtl,%5Cn%20%20%20%20.is-rtl,%5Cn%20%20%20%20.rtl%20%7B%5Cn%20%20%20%20%20%20&%20%7B%5Cn%20%20%20%20%20%20%20%20input%5Btype='month'%5D,%5Cn%20%20%20%20%20%20%20%20input%5Btype='time'%5D,%5Cn%20%20%20%20%20%20%20%20input%5Btype='week'%5D%20%7B%5Cn%20%20%20%20%20%20%20%20%20%20direction:%20rtl;%5Cn%5Cn%20%20%20%20%20%20%20%20%20%20&::-webkit-calendar-picker-indicator%20%7B%5Cn%20%20%20%20%20%20%20%20%20%20%20%20right:%20var(--size-4-1);%5Cn%20%20%20%20%20%20%20%20%20%20%20%20left:%20auto;%5Cn%20%20%20%20%20%20%20%20%20%20%7D%5Cn%20%20%20%20%20%20%20%20%7D%5Cn%20%20%20%20%20%20%7D%5Cn%20%20%20%20%7D%5Cn%20%20%7D%5Cn%7D%5Cn%22,%22.obsidian-dev-utils%20%7B%5Cn%20%20input%5Btype='month'%5D,%5Cn%20%20input%5Btype='time'%5D,%5Cn%20%20input%5Btype='week'%5D%20%7B%5Cn%20%20%20%20font-variant-numeric:%20tabular-nums;%5Cn%20%20%20%20position:%20relative;%5Cn%5Cn%20%20%20%20&::-webkit-datetime-edit-text%20%7B%5Cn%20%20%20%20%20%20color:%20var(--text-faint);%5Cn%20%20%20%20%20%20padding-inline-end:%200;%5Cn%20%20%20%20%7D%5Cn%5Cn%20%20%20%20&::-webkit-calendar-picker-indicator%20%7B%5Cn%20%20%20%20%20%20position:%20absolute;%5Cn%20%20%20%20%20%20left:%20var(--size-4-1);%5Cn%20%20%20%20%20%20right:%20auto;%5Cn%20%20%20%20%20%20opacity:%200.5;%5Cn%20%20%20%20%7D%5Cn%5Cn%20%20%20%20&::-webkit-datetime-edit-month-field,%5Cn%20%20%20%20&::-webkit-datetime-edit-day-field,%5Cn%20%20%20%20&::-webkit-datetime-edit-year-field%20%7B%5Cn%20%20%20%20%20%20&:active,%5Cn%20%20%20%20%20%20&:focus%20%7B%5Cn%20%20%20%20%20%20%20%20background-color:%20var(--text-selection);%5Cn%20%20%20%20%20%20%20%20color:%20var(--text-normal);%5Cn%20%20%20%20%20%20%20%20cursor:%20text;%5Cn%20%20%20%20%20%20%7D%5Cn%20%20%20%20%7D%5Cn%5Cn%20%20%20%20@at-root%20.mod-rtl%20&,%5Cn%20%20%20%20%20%20.is-rtl%20&,%5Cn%20%20%20%20%20%20.rtl%20&%20%7B%5Cn%20%20%20%20%20%20direction:%20rtl;%5Cn%5Cn%20%20%20%20%20%20&::-webkit-calendar-picker-indicator%20%7B%5Cn%20%20%20%20%20%20%20%20left:%20auto;%5Cn%20%20%20%20%20%20%20%20right:%20var(--size-4-1);%5Cn%20%20%20%20%20%20%7D%5Cn%20%20%20%20%7D%5Cn%5Cn%20%20%20%20@at-root%20%7B%5Cn%20%20%20%20%20%20body:not(.is-ios):not(.is-android)%20&%20%7B%5Cn%20%20%20%20%20%20%20%20padding-inline-start:%20var(--size-4-6);%5Cn%20%20%20%20%20%20%7D%5Cn%20%20%20%20%7D%5Cn%20%20%7D%5Cn%5Cn%20%20input%5Btype='time'%5D%20%7B%5Cn%20%20%20%20&::-webkit-calendar-picker-indicator%20%7B%5Cn%20%20%20%20%20%20margin-inline-start:%200;%5Cn%20%20%20%20%7D%5Cn%20%20%7D%5Cn%7D%5Cn%22,%22.obsidian-dev-utils%20%7B%5Cn%20%20&.modal-container%20%7B%5Cn%20%20%20%20.ok-button%20%7B%5Cn%20%20%20%20%20%20margin-right:%2010px;%5Cn%20%20%20%20%20%20margin-top:%2020px;%5Cn%20%20%20%20%7D%5Cn%20%20%7D%5Cn%7D%5Cn%22,%22.obsidian-dev-utils%20%7B%5Cn%20%20.multiple-dropdown-component%20%7B%5Cn%20%20%20%20select,%5Cn%20%20%20%20select:focus,%5Cn%20%20%20%20.dropdown%20%7B%5Cn%20%20%20%20%20%20height:%20auto;%5Cn%5Cn%20%20%20%20%20%20option:checked%20%7B%5Cn%20%20%20%20%20%20%20%20background-color:%20%231967d2;%5Cn%20%20%20%20%20%20%20%20color:%20%23fff;%5Cn%20%20%20%20%20%20%7D%5Cn%20%20%20%20%7D%5Cn%20%20%7D%5Cn%7D%5Cn%22,%22.obsidian-dev-utils%20%7B%5Cn%20%20&.prompt-modal%20%7B%5Cn%20%20%20%20.text-box%20%7B%5Cn%20%20%20%20%20%20width:%20100%25;%5Cn%20%20%20%20%7D%5Cn%20%20%7D%5Cn%7D%5Cn%22,%22.obsidian-dev-utils%20%7B%5Cn%20%20:invalid%20%7B%5Cn%20%20%20%20box-shadow:%200%200%200%202px%20var(--text-error);%5Cn%20%20%7D%5Cn%7D%5Cn%22%5D%7D */\n";
36
36
  // Annotate the CommonJS export names for ESM import in node:
@@ -31,6 +31,8 @@ __export(Object_exports, {
31
31
  deepEqual: () => deepEqual,
32
32
  deleteProperties: () => deleteProperties,
33
33
  deleteProperty: () => deleteProperty,
34
+ getAllEntries: () => getAllEntries,
35
+ getAllKeys: () => getAllKeys,
34
36
  getNestedPropertyValue: () => getNestedPropertyValue,
35
37
  getPrototypeOf: () => getPrototypeOf,
36
38
  nameof: () => nameof,
@@ -61,8 +63,8 @@ function deepEqual(a, b) {
61
63
  if (typeof a !== "object" || typeof b !== "object" || a === null || b === null) {
62
64
  return false;
63
65
  }
64
- const keysA = Object.keys(a);
65
- const keysB = Object.keys(b);
66
+ const keysA = getAllKeys(a);
67
+ const keysB = getAllKeys(b);
66
68
  if (keysA.length !== keysB.length) {
67
69
  return false;
68
70
  }
@@ -89,6 +91,37 @@ function deleteProperty(obj, propertyName) {
89
91
  delete obj[propertyName];
90
92
  return true;
91
93
  }
94
+ function getAllEntries(obj) {
95
+ return getAllKeys(obj).map((key) => [key, obj[key]]);
96
+ }
97
+ function getAllKeys(obj) {
98
+ const keys = [];
99
+ let current = obj;
100
+ while (current) {
101
+ const descriptors = Object.getOwnPropertyDescriptors(current);
102
+ for (const [key, descriptor] of Object.entries(descriptors)) {
103
+ if (key === "__proto__") {
104
+ continue;
105
+ }
106
+ if (typeof descriptor.value === "function") {
107
+ continue;
108
+ }
109
+ const hasGetter = typeof descriptor.get === "function";
110
+ const hasSetter = typeof descriptor.set === "function";
111
+ if (hasGetter || hasSetter) {
112
+ if (hasGetter && hasSetter) {
113
+ keys.push(key);
114
+ }
115
+ continue;
116
+ }
117
+ if (descriptor.enumerable && descriptor.writable) {
118
+ keys.push(key);
119
+ }
120
+ }
121
+ current = Object.getPrototypeOf(current);
122
+ }
123
+ return keys.sort();
124
+ }
92
125
  function getNestedPropertyValue(obj, path) {
93
126
  let node = obj;
94
127
  const keys = path.split(KEY_SEPARATOR);
@@ -308,6 +341,8 @@ function tryHandleToJSON(value, key, depth, fullOptions, functionTexts, usedObje
308
341
  deepEqual,
309
342
  deleteProperties,
310
343
  deleteProperty,
344
+ getAllEntries,
345
+ getAllKeys,
311
346
  getNestedPropertyValue,
312
347
  getPrototypeOf,
313
348
  nameof,
@@ -315,4 +350,4 @@ function tryHandleToJSON(value, key, depth, fullOptions, functionTexts, usedObje
315
350
  setNestedPropertyValue,
316
351
  toJson
317
352
  });
318
- //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../src/Object.ts"],
  "sourcesContent": ["/**\n * @packageDocumentation Object\n * Contains utility functions for Objects.\n */\n\nimport type { UndefinedOnPartialDeep } from 'type-fest';\n\nimport {\n  errorToString,\n  throwExpression\n} from './Error.ts';\nimport { replaceAll } from './String.ts';\n\n/**\n * Specifies how functions should be handled in the JSON output.\n */\nexport enum FunctionHandlingMode {\n  /**\n   * Excludes functions from the JSON output.\n   */\n  Exclude = 'exclude',\n  /**\n   * Includes the full function definition in the JSON output.\n   */\n  Full = 'full',\n  /**\n   * Includes only the function name in the JSON output.\n   */\n  NameOnly = 'nameOnly'\n}\n\nenum TokenSubstitutionKey {\n  CircularReference = 'CircularReference',\n  Function = 'Function',\n  MaxDepthLimitReached = 'MaxDepthLimitReached',\n  MaxDepthLimitReachedArray = 'MaxDepthLimitReachedArray',\n  ToJSONFailed = 'ToJSONFailed',\n  Undefined = 'Undefined'\n}\n\n/**\n * A type that represents the keys of an object as strings.\n *\n * @typeParam T - The type of the object.\n */\nexport type StringKeys<T extends object> = Extract<keyof T, string>;\n\n/**\n * Options for converting an object to JSON.\n */\nexport interface ToJsonOptions {\n  /**\n   * Specifies how functions should be handled in the JSON output (default: `exclude`).\n   */\n  functionHandlingMode: FunctionHandlingMode;\n  /**\n   * Specifies the maximum depth of nested objects to include in the JSON output.\n   * Use `-1` for no limit.\n   * Defaults to `-1`.\n   */\n  maxDepth: number;\n  /**\n   * Specifies whether to catch errors in `toJSON()` and replace them with a placeholder.\n   * Defaults to `false`.\n   */\n  shouldCatchToJSONErrors: boolean;\n  /**\n   * Specifies whether to handle circular references in the JSON output.\n   * Defaults to `false`.\n   */\n  shouldHandleCircularReferences: boolean;\n  /**\n   * Specifies whether to handle errors in the JSON output.\n   * Defaults to `false`.\n   */\n  shouldHandleErrors: boolean;\n  /**\n   * Specifies whether to handle undefined values in the JSON output.\n   * Defaults to `false`.\n   */\n  shouldHandleUndefined: boolean;\n  /**\n   * Specifies whether to sort the keys of the JSON output.\n   * Defaults to `false`.\n   */\n  shouldSortKeys: boolean;\n  /**\n   * Specifies the indentation of the JSON output. This can be a number of spaces or a string. Defaults to `2`.\n   */\n  space: number | string;\n  /**\n   * Specifies the substitutions to use in the JSON output.\n   */\n  tokenSubstitutions: Partial<TokenSubstitutions>;\n}\n\ninterface ApplySubstitutionsOptions {\n  functionTexts: string[];\n  index: number;\n  key: TokenSubstitutionKey;\n  substitutions: TokenSubstitutions;\n}\n\ninterface JSONSerializable {\n  toJSON(...args: unknown[]): unknown;\n}\n\ninterface TokenSubstitutions {\n  circularReference: string;\n  maxDepthLimitReached: string;\n  toJSONFailed: string;\n}\n\nconst KEY_SEPARATOR = '.';\n\n/**\n * Assigns properties from one or more source objects to a target object, including non-enumerable properties.\n *\n * @param target - The target object to assign properties to.\n * @param source - The source object to assign properties from.\n * @returns The target object with the assigned properties.\n */\nexport function assignWithNonEnumerableProperties<T extends object, U>(target: T, source: U): T & U;\n\n/**\n * @param target - The target object to assign properties to.\n * @param source1 - The first source object to assign properties from.\n * @param source2 - The second source object to assign properties from.\n * @returns The target object with the assigned properties.\n */\nexport function assignWithNonEnumerableProperties<T extends object, U, V>(target: T, source1: U, source2: V): T & U & V;\n\n/**\n * Assigns properties from one or more source objects to a target object, including non-enumerable properties.\n *\n * @param target - The target object to assign properties to.\n * @param source1 - The first source object to assign properties from.\n * @param source2 - The second source object to assign properties from.\n * @param source3 - The third source object to assign properties from.\n * @returns The target object with the assigned properties.\n */\nexport function assignWithNonEnumerableProperties<T extends object, U, V, W>(target: T, source1: U, source2: V, source3: W): T & U & V & W;\n\n/**\n * Assigns properties from one or more source objects to a target object, including non-enumerable properties.\n *\n * @param target - The target object to assign properties to.\n * @param sources - The source objects to assign properties from.\n * @returns The target object with the assigned properties.\n */\nexport function assignWithNonEnumerableProperties(target: object, ...sources: object[]): object {\n  return _assignWithNonEnumerableProperties(target, ...sources);\n}\n\n/**\n * Clones an object, including non-enumerable properties.\n *\n * @param obj - The object to clone.\n * @returns A new object with the same properties as the original object, including non-enumerable properties.\n */\nexport function cloneWithNonEnumerableProperties<T extends object>(obj: T): T {\n  return Object.create(getPrototypeOf(obj), Object.getOwnPropertyDescriptors(obj)) as T;\n}\n\n/**\n * Compares two values to determine if they are deeply equal.\n *\n * @param a - The first value to compare.\n * @param b - The second value to compare.\n * @returns `true` if the values are deeply equal, otherwise `false`.\n */\nexport function deepEqual(a: unknown, b: unknown): boolean {\n  if (a === b) {\n    return true;\n  }\n\n  if (typeof a !== 'object' || typeof b !== 'object' || a === null || b === null) {\n    return false;\n  }\n\n  const keysA = Object.keys(a);\n  const keysB = Object.keys(b);\n\n  if (keysA.length !== keysB.length) {\n    return false;\n  }\n\n  const aRecord = a as Record<string, unknown>;\n  const bRecord = b as Record<string, unknown>;\n\n  for (const key of keysA) {\n    if (!keysB.includes(key) || !deepEqual(aRecord[key], bRecord[key])) {\n      return false;\n    }\n  }\n\n  return true;\n}\n\n/**\n * Deletes multiple properties from an object.\n *\n * @typeParam T - The type of the object.\n * @param obj - The object to delete the properties from.\n * @param propertyNames - The names of the properties to delete.\n * @returns `true` if any of the properties were present, otherwise `false`.\n */\nexport function deleteProperties<T extends object>(obj: T, propertyNames: (keyof T)[]): boolean {\n  let ans = false;\n\n  for (const propertyName of propertyNames) {\n    ans = deleteProperty(obj, propertyName) || ans;\n  }\n\n  return ans;\n}\n\n/**\n * Deletes a property from an object.\n *\n * @typeParam T - The type of the object.\n * @param obj - The object to delete the property from.\n * @param propertyName - The name of the property to delete.\n * @returns `true` if the property was present, otherwise `false`.\n */\nexport function deleteProperty<T extends object>(obj: T, propertyName: keyof T): boolean {\n  if (!Object.hasOwn(obj, propertyName)) {\n    return false;\n  }\n  // eslint-disable-next-line @typescript-eslint/no-dynamic-delete\n  delete obj[propertyName];\n  return true;\n}\n\n/**\n * Gets the value of a nested property from an object.\n *\n * @param obj - The object to get the nested property value from.\n * @param path - The path to the nested property.\n * @returns The value of the nested property.\n */\nexport function getNestedPropertyValue(obj: Record<string, unknown>, path: string): unknown {\n  let node: Record<string, unknown> | undefined = obj;\n  const keys = path.split(KEY_SEPARATOR);\n  for (const key of keys) {\n    if (node === undefined) {\n      return undefined;\n    }\n    node = node[key] as Record<string, unknown> | undefined;\n  }\n\n  return node;\n}\n\n/**\n * Gets the prototype of the specified object.\n *\n * @typeParam T - The type of the object.\n * @param instance - The object instance to retrieve the prototype of.\n * @returns The prototype of the object.\n */\nexport function getPrototypeOf<T>(instance: T): T {\n  if (instance === undefined || instance === null) {\n    return instance;\n  }\n  return Object.getPrototypeOf(instance) as T;\n}\n\n/**\n * Retrieves the name of a property of a given type `T`.\n *\n * @typeParam T - The type of the object containing the property.\n * @param name - The name of the property as a string.\n * @returns The name of the property.\n */\nexport function nameof<T>(name: Extract<keyof T, string>): string {\n  return name;\n}\n\n/**\n * Normalizes optional properties to allow `undefined` assignment in strict mode.\n *\n * This utility provides a workaround for the `exactOptionalPropertyTypes` TypeScript flag,\n * which prohibits directly assigning `undefined` to optional properties when the type\n * explicitly omits `undefined`.\n *\n * Example:\n * ```typescript\n * // With `exactOptionalPropertyTypes: true`\n * const x: { prop?: string } = { prop: undefined }; // Compiler error\n *\n * // Using this utility:\n * const y: { prop?: string } = normalizeOptionalProperties<{ prop?: string }>({ prop: undefined }); // Works\n * ```\n *\n * @typeParam T - The target type with optional properties to normalize.\n * @param obj - The object to normalize, allowing explicit `undefined` for optional properties.\n * @returns The normalized object, compatible with `exactOptionalPropertyTypes`.\n */\nexport function normalizeOptionalProperties<T>(obj: UndefinedOnPartialDeep<T>): T {\n  return obj as T;\n}\n\n/**\n * Sets the value of a nested property in an object.\n *\n * @param obj - The object to set the nested property value in.\n * @param path - The path to the nested property.\n * @param value - The value to set.\n */\nexport function setNestedPropertyValue(obj: Record<string, unknown>, path: string, value: unknown): void {\n  const error = new Error(`Property path ${path} not found`);\n  let node: Record<string, unknown> | undefined = obj;\n  const keys = path.split(KEY_SEPARATOR);\n  for (const key of keys.slice(0, -1)) {\n    if (node === undefined) {\n      throw error;\n    }\n    node = node[key] as Record<string, unknown> | undefined;\n  }\n\n  const lastKey = keys.at(-1);\n  if (node === undefined || lastKey === undefined) {\n    throw error;\n  }\n\n  node[lastKey] = value;\n}\n\n/**\n * Converts a given value to a JSON string.\n *\n * @param value - The value to be converted to JSON. This can be of any type.\n * @param options - Options for customizing the JSON conversion process.\n * @returns The JSON string representation of the input value.\n */\nexport function toJson(value: unknown, options: Partial<ToJsonOptions> = {}): string {\n  const DEFAULT_OPTIONS: { tokenSubstitutions: TokenSubstitutions } & ToJsonOptions = {\n    functionHandlingMode: FunctionHandlingMode.Exclude,\n    maxDepth: -1,\n    shouldCatchToJSONErrors: false,\n    shouldHandleCircularReferences: false,\n    shouldHandleErrors: false,\n    shouldHandleUndefined: false,\n    shouldSortKeys: false,\n    // eslint-disable-next-line no-magic-numbers\n    space: 2,\n    tokenSubstitutions: {\n      circularReference: makeObjectTokenSubstitution(TokenSubstitutionKey.CircularReference),\n      maxDepthLimitReached: makeObjectTokenSubstitution(TokenSubstitutionKey.MaxDepthLimitReached),\n      toJSONFailed: makeObjectTokenSubstitution(TokenSubstitutionKey.ToJSONFailed)\n    }\n  };\n\n  const fullOptions = {\n    ...DEFAULT_OPTIONS,\n    ...options,\n    tokenSubstitutions: {\n      ...DEFAULT_OPTIONS.tokenSubstitutions,\n      ...options.tokenSubstitutions\n    }\n  };\n\n  if (fullOptions.maxDepth === -1) {\n    fullOptions.maxDepth = Infinity;\n  }\n\n  const functionTexts: string[] = [];\n  const usedObjects = new WeakSet<object>();\n\n  const plainObject = toPlainObject(value, '', 0, true, fullOptions, functionTexts, usedObjects);\n  let json = JSON.stringify(plainObject, null, fullOptions.space) ?? '';\n  json = replaceAll(json, /\"\\[\\[(?<Key>[A-Za-z]+)(?<Index>\\d*)\\]\\]\"/g, (_, key, indexStr) =>\n    applySubstitutions({\n      functionTexts,\n      index: indexStr ? parseInt(indexStr, 10) : 0,\n      key: key as TokenSubstitutionKey,\n      substitutions: fullOptions.tokenSubstitutions\n    }));\n  return json;\n}\n\nfunction _assignWithNonEnumerableProperties(target: object, ...sources: object[]): object {\n  for (const source of sources) {\n    const descriptors = Object.getOwnPropertyDescriptors(source);\n\n    for (const [key, descriptor] of Object.entries(descriptors)) {\n      try {\n        // Avoid redefining read-only properties (especially `prototype`)\n        if (\n          key === 'prototype'\n          || (Object.getOwnPropertyDescriptor(target, key)?.writable === false\n            && !Object.getOwnPropertyDescriptor(target, key)?.configurable)\n        ) {\n          continue;\n        }\n\n        Object.defineProperty(target, key, descriptor);\n      } catch {\n        // Silently ignore if defineProperty fails\n      }\n    }\n  }\n\n  const sourcePrototypes = sources\n    .map((source) => getPrototypeOf<object | undefined>(source))\n    .filter((proto): proto is object => !!proto);\n\n  if (sourcePrototypes.length > 0) {\n    const targetPrototype = _assignWithNonEnumerableProperties({}, getPrototypeOf(target), ...sourcePrototypes);\n\n    try {\n      Object.setPrototypeOf(target, targetPrototype);\n    } catch {\n      // Silently ignore if setPrototypeOf fails\n    }\n  }\n\n  return target;\n}\n\n// eslint-disable-next-line @typescript-eslint/no-invalid-void-type\nfunction applySubstitutions(options: ApplySubstitutionsOptions): string | void {\n  switch (options.key) {\n    case TokenSubstitutionKey.CircularReference:\n      return options.substitutions.circularReference;\n    case TokenSubstitutionKey.Function:\n      return options.functionTexts[options.index] ?? throwExpression(new Error(`Function with index ${options.index.toString()} not found`));\n    case TokenSubstitutionKey.MaxDepthLimitReached:\n      return options.substitutions.maxDepthLimitReached;\n    case TokenSubstitutionKey.MaxDepthLimitReachedArray:\n      return `Array(${options.index.toString()})`;\n    case TokenSubstitutionKey.ToJSONFailed:\n      return options.substitutions.toJSONFailed;\n    case TokenSubstitutionKey.Undefined:\n      return 'undefined';\n    default:\n      break;\n  }\n}\n\nfunction handleArray(\n  value: unknown[],\n  depth: number,\n  canUseToJSON: boolean,\n  fullOptions: ToJsonOptions,\n  functionTexts: string[],\n  usedObjects: WeakSet<object>\n): unknown {\n  if (depth > fullOptions.maxDepth) {\n    return makePlaceholder(TokenSubstitutionKey.MaxDepthLimitReachedArray, value.length);\n  }\n\n  return value.map((item, index) => toPlainObject(item, index.toString(), depth + 1, canUseToJSON, fullOptions, functionTexts, usedObjects));\n}\n\nfunction handleCircularReference(value: object, key: string, fullOptions: ToJsonOptions): unknown {\n  if (fullOptions.shouldHandleCircularReferences) {\n    return makePlaceholder(TokenSubstitutionKey.CircularReference);\n  }\n  const valueConstructorName = value.constructor.name || 'Object';\n  throw new TypeError(`Converting circular structure to JSON\n--> starting at object with constructor '${valueConstructorName}'\n--- property '${key}' closes the circle`);\n}\n\n// eslint-disable-next-line @typescript-eslint/no-unsafe-function-type\nfunction handleFunction(value: Function, functionTexts: string[], fullOptions: ToJsonOptions): unknown {\n  if (fullOptions.functionHandlingMode === FunctionHandlingMode.Exclude) {\n    return undefined;\n  }\n  const index = functionTexts.length;\n  const functionText = fullOptions.functionHandlingMode === FunctionHandlingMode.Full\n    ? value.toString()\n    : `function ${value.name || 'anonymous'}() { /* ... */ }`;\n  functionTexts.push(functionText);\n  return makePlaceholder(TokenSubstitutionKey.Function, index);\n}\n\nfunction handleObject(\n  value: object,\n  key: string,\n  depth: number,\n  canUseToJSON: boolean,\n  fullOptions: ToJsonOptions,\n  functionTexts: string[],\n  usedObjects: WeakSet<object>\n): unknown {\n  if (usedObjects.has(value)) {\n    return handleCircularReference(value, key, fullOptions);\n  }\n\n  usedObjects.add(value);\n\n  if (canUseToJSON) {\n    const toJSONResult = tryHandleToJSON(value, key, depth, fullOptions, functionTexts, usedObjects);\n    if (toJSONResult !== undefined) {\n      return toJSONResult;\n    }\n  }\n\n  if (Array.isArray(value)) {\n    return handleArray(value, depth, canUseToJSON, fullOptions, functionTexts, usedObjects);\n  }\n\n  if (depth > fullOptions.maxDepth) {\n    return makePlaceholder(TokenSubstitutionKey.MaxDepthLimitReached);\n  }\n\n  if (value instanceof Error && fullOptions.shouldHandleErrors) {\n    return errorToString(value);\n  }\n\n  return handlePlainObject(value, depth, canUseToJSON, fullOptions, functionTexts, usedObjects);\n}\n\nfunction handlePlainObject(\n  value: object,\n  depth: number,\n  canUseToJSON: boolean,\n  fullOptions: ToJsonOptions,\n  functionTexts: string[],\n  usedObjects: WeakSet<object>\n): unknown {\n  const entries = Object.entries(value);\n  if (fullOptions.shouldSortKeys) {\n    entries.sort(([key1], [key2]) => key1.localeCompare(key2));\n  }\n\n  return Object.fromEntries(\n    entries.map(([key2, value2]) => [\n      key2,\n      toPlainObject(value2, key2, depth + 1, canUseToJSON, fullOptions, functionTexts, usedObjects)\n    ])\n  );\n}\n\nfunction makeObjectTokenSubstitution(key: TokenSubstitutionKey): string {\n  return `{ \"[[${key}]]\": null }`;\n}\n\nfunction makePlaceholder(key: TokenSubstitutionKey, index?: number): string {\n  return `[[${key}${index?.toString() ?? ''}]]`;\n}\n\nfunction toPlainObject(\n  value: unknown,\n  key: string,\n  depth: number,\n  canUseToJSON: boolean,\n  fullOptions: ToJsonOptions,\n  functionTexts: string[],\n  usedObjects: WeakSet<object>\n): unknown {\n  if (value === undefined) {\n    return (depth === 0 || fullOptions.shouldHandleUndefined)\n      ? makePlaceholder(TokenSubstitutionKey.Undefined)\n      : undefined;\n  }\n\n  if (typeof value === 'function') {\n    return handleFunction(value, functionTexts, fullOptions);\n  }\n\n  if (typeof value !== 'object' || value === null) {\n    return value;\n  }\n\n  return handleObject(value, key, depth, canUseToJSON, fullOptions, functionTexts, usedObjects);\n}\n\nfunction tryHandleToJSON(\n  value: object,\n  key: string,\n  depth: number,\n  fullOptions: ToJsonOptions,\n  functionTexts: string[],\n  usedObjects: WeakSet<object>\n): unknown {\n  const toJSON = (value as Partial<JSONSerializable>).toJSON;\n  if (typeof toJSON === 'function') {\n    try {\n      const newValue = toJSON.call(value, key);\n      return toPlainObject(newValue, key, depth, false, fullOptions, functionTexts, usedObjects);\n    } catch (e) {\n      if (fullOptions.shouldCatchToJSONErrors) {\n        return makePlaceholder(TokenSubstitutionKey.ToJSONFailed);\n      }\n      throw e;\n    }\n  }\n  return undefined;\n}\n"],
  "mappings": "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",
  "names": ["FunctionHandlingMode"]
}

353
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../src/Object.ts"],
  "sourcesContent": ["/**\n * @packageDocumentation Object\n * Contains utility functions for Objects.\n */\n\nimport type { UndefinedOnPartialDeep } from 'type-fest';\n\nimport type {\n  MaybeReturn,\n  StringKeys\n} from './Type.ts';\n\nimport {\n  errorToString,\n  throwExpression\n} from './Error.ts';\nimport { replaceAll } from './String.ts';\n\n/**\n * Specifies how functions should be handled in the JSON output.\n */\nexport enum FunctionHandlingMode {\n  /**\n   * Excludes functions from the JSON output.\n   */\n  Exclude = 'exclude',\n  /**\n   * Includes the full function definition in the JSON output.\n   */\n  Full = 'full',\n  /**\n   * Includes only the function name in the JSON output.\n   */\n  NameOnly = 'nameOnly'\n}\n\nenum TokenSubstitutionKey {\n  CircularReference = 'CircularReference',\n  Function = 'Function',\n  MaxDepthLimitReached = 'MaxDepthLimitReached',\n  MaxDepthLimitReachedArray = 'MaxDepthLimitReachedArray',\n  ToJSONFailed = 'ToJSONFailed',\n  Undefined = 'Undefined'\n}\n\n/**\n * Options for converting an object to JSON.\n */\nexport interface ToJsonOptions {\n  /**\n   * Specifies how functions should be handled in the JSON output (default: `exclude`).\n   */\n  functionHandlingMode: FunctionHandlingMode;\n  /**\n   * Specifies the maximum depth of nested objects to include in the JSON output.\n   * Use `-1` for no limit.\n   * Defaults to `-1`.\n   */\n  maxDepth: number;\n  /**\n   * Specifies whether to catch errors in `toJSON()` and replace them with a placeholder.\n   * Defaults to `false`.\n   */\n  shouldCatchToJSONErrors: boolean;\n  /**\n   * Specifies whether to handle circular references in the JSON output.\n   * Defaults to `false`.\n   */\n  shouldHandleCircularReferences: boolean;\n  /**\n   * Specifies whether to handle errors in the JSON output.\n   * Defaults to `false`.\n   */\n  shouldHandleErrors: boolean;\n  /**\n   * Specifies whether to handle undefined values in the JSON output.\n   * Defaults to `false`.\n   */\n  shouldHandleUndefined: boolean;\n  /**\n   * Specifies whether to sort the keys of the JSON output.\n   * Defaults to `false`.\n   */\n  shouldSortKeys: boolean;\n  /**\n   * Specifies the indentation of the JSON output. This can be a number of spaces or a string. Defaults to `2`.\n   */\n  space: number | string;\n  /**\n   * Specifies the substitutions to use in the JSON output.\n   */\n  tokenSubstitutions: Partial<TokenSubstitutions>;\n}\n\ninterface ApplySubstitutionsOptions {\n  functionTexts: string[];\n  index: number;\n  key: TokenSubstitutionKey;\n  substitutions: TokenSubstitutions;\n}\n\ninterface JSONSerializable {\n  toJSON(...args: unknown[]): unknown;\n}\n\ninterface TokenSubstitutions {\n  circularReference: string;\n  maxDepthLimitReached: string;\n  toJSONFailed: string;\n}\n\nconst KEY_SEPARATOR = '.';\n\n/**\n * Assigns properties from one or more source objects to a target object, including non-enumerable properties.\n *\n * @param target - The target object to assign properties to.\n * @param source - The source object to assign properties from.\n * @returns The target object with the assigned properties.\n */\nexport function assignWithNonEnumerableProperties<T extends object, U>(target: T, source: U): T & U;\n\n/**\n * @param target - The target object to assign properties to.\n * @param source1 - The first source object to assign properties from.\n * @param source2 - The second source object to assign properties from.\n * @returns The target object with the assigned properties.\n */\nexport function assignWithNonEnumerableProperties<T extends object, U, V>(target: T, source1: U, source2: V): T & U & V;\n\n/**\n * Assigns properties from one or more source objects to a target object, including non-enumerable properties.\n *\n * @param target - The target object to assign properties to.\n * @param source1 - The first source object to assign properties from.\n * @param source2 - The second source object to assign properties from.\n * @param source3 - The third source object to assign properties from.\n * @returns The target object with the assigned properties.\n */\nexport function assignWithNonEnumerableProperties<T extends object, U, V, W>(target: T, source1: U, source2: V, source3: W): T & U & V & W;\n\n/**\n * Assigns properties from one or more source objects to a target object, including non-enumerable properties.\n *\n * @param target - The target object to assign properties to.\n * @param sources - The source objects to assign properties from.\n * @returns The target object with the assigned properties.\n */\nexport function assignWithNonEnumerableProperties(target: object, ...sources: object[]): object {\n  return _assignWithNonEnumerableProperties(target, ...sources);\n}\n\n/**\n * Clones an object, including non-enumerable properties.\n *\n * @param obj - The object to clone.\n * @returns A new object with the same properties as the original object, including non-enumerable properties.\n */\nexport function cloneWithNonEnumerableProperties<T extends object>(obj: T): T {\n  return Object.create(getPrototypeOf(obj), Object.getOwnPropertyDescriptors(obj)) as T;\n}\n\n/**\n * Compares two values to determine if they are deeply equal.\n *\n * @param a - The first value to compare.\n * @param b - The second value to compare.\n * @returns `true` if the values are deeply equal, otherwise `false`.\n */\nexport function deepEqual(a: unknown, b: unknown): boolean {\n  if (a === b) {\n    return true;\n  }\n\n  if (typeof a !== 'object' || typeof b !== 'object' || a === null || b === null) {\n    return false;\n  }\n\n  const keysA = getAllKeys(a);\n  const keysB = getAllKeys(b);\n\n  if (keysA.length !== keysB.length) {\n    return false;\n  }\n\n  const aRecord = a as Record<string, unknown>;\n  const bRecord = b as Record<string, unknown>;\n\n  for (const key of keysA) {\n    if (!keysB.includes(key) || !deepEqual(aRecord[key], bRecord[key])) {\n      return false;\n    }\n  }\n\n  return true;\n}\n\n/**\n * Deletes multiple properties from an object.\n *\n * @typeParam T - The type of the object.\n * @param obj - The object to delete the properties from.\n * @param propertyNames - The names of the properties to delete.\n * @returns `true` if any of the properties were present, otherwise `false`.\n */\nexport function deleteProperties<T extends object>(obj: T, propertyNames: (keyof T)[]): boolean {\n  let ans = false;\n\n  for (const propertyName of propertyNames) {\n    ans = deleteProperty(obj, propertyName) || ans;\n  }\n\n  return ans;\n}\n\n/**\n * Deletes a property from an object.\n *\n * @typeParam T - The type of the object.\n * @param obj - The object to delete the property from.\n * @param propertyName - The name of the property to delete.\n * @returns `true` if the property was present, otherwise `false`.\n */\nexport function deleteProperty<T extends object>(obj: T, propertyName: keyof T): boolean {\n  if (!Object.hasOwn(obj, propertyName)) {\n    return false;\n  }\n  // eslint-disable-next-line @typescript-eslint/no-dynamic-delete\n  delete obj[propertyName];\n  return true;\n}\n\n/**\n * Gets all entries of an object.\n *\n * @param obj - The object to get the entries of.\n * @returns An array of all entries of the object.\n */\nexport function getAllEntries<T extends object>(obj: T): [StringKeys<T>, T[StringKeys<T>]][] {\n  return getAllKeys(obj).map((key) => [key, obj[key]]);\n}\n\n/**\n * Gets all keys of an object.\n * Includes fields and properties.\n *\n * @param obj - The object to get the keys of.\n * @returns An array of all keys of the object.\n */\nexport function getAllKeys<T extends object>(obj: T): StringKeys<T>[] {\n  const keys: StringKeys<T>[] = [];\n  let current: null | object = obj;\n  while (current) {\n    const descriptors = Object.getOwnPropertyDescriptors(current) as Record<string, PropertyDescriptor>;\n    for (const [key, descriptor] of Object.entries(descriptors)) {\n      if (key === '__proto__') {\n        continue;\n      }\n\n      if (typeof descriptor.value === 'function') {\n        continue;\n      }\n\n      const hasGetter = typeof descriptor.get === 'function';\n      const hasSetter = typeof descriptor.set === 'function';\n      if (hasGetter || hasSetter) {\n        if (hasGetter && hasSetter) {\n          keys.push(key as StringKeys<T>);\n        }\n        continue;\n      }\n\n      if (descriptor.enumerable && descriptor.writable) {\n        keys.push(key as StringKeys<T>);\n      }\n    }\n\n    current = Object.getPrototypeOf(current) as null | object;\n  }\n  return keys.sort();\n}\n\n/**\n * Gets the value of a nested property from an object.\n *\n * @param obj - The object to get the nested property value from.\n * @param path - The path to the nested property.\n * @returns The value of the nested property.\n */\nexport function getNestedPropertyValue(obj: Record<string, unknown>, path: string): unknown {\n  let node: Record<string, unknown> | undefined = obj;\n  const keys = path.split(KEY_SEPARATOR);\n  for (const key of keys) {\n    if (node === undefined) {\n      return undefined;\n    }\n    node = node[key] as Record<string, unknown> | undefined;\n  }\n\n  return node;\n}\n\n/**\n * Gets the prototype of the specified object.\n *\n * @typeParam T - The type of the object.\n * @param instance - The object instance to retrieve the prototype of.\n * @returns The prototype of the object.\n */\nexport function getPrototypeOf<T>(instance: T): T {\n  if (instance === undefined || instance === null) {\n    return instance;\n  }\n  return Object.getPrototypeOf(instance) as T;\n}\n\n/**\n * Retrieves the name of a property of a given type `T`.\n *\n * @typeParam T - The type of the object containing the property.\n * @param name - The name of the property as a string.\n * @returns The name of the property.\n */\nexport function nameof<T>(name: Extract<keyof T, string>): string {\n  return name;\n}\n\n/**\n * Normalizes optional properties to allow `undefined` assignment in strict mode.\n *\n * This utility provides a workaround for the `exactOptionalPropertyTypes` TypeScript flag,\n * which prohibits directly assigning `undefined` to optional properties when the type\n * explicitly omits `undefined`.\n *\n * Example:\n * ```typescript\n * // With `exactOptionalPropertyTypes: true`\n * const x: { prop?: string } = { prop: undefined }; // Compiler error\n *\n * // Using this utility:\n * const y: { prop?: string } = normalizeOptionalProperties<{ prop?: string }>({ prop: undefined }); // Works\n * ```\n *\n * @typeParam T - The target type with optional properties to normalize.\n * @param obj - The object to normalize, allowing explicit `undefined` for optional properties.\n * @returns The normalized object, compatible with `exactOptionalPropertyTypes`.\n */\nexport function normalizeOptionalProperties<T>(obj: UndefinedOnPartialDeep<T>): T {\n  return obj as T;\n}\n\n/**\n * Sets the value of a nested property in an object.\n *\n * @param obj - The object to set the nested property value in.\n * @param path - The path to the nested property.\n * @param value - The value to set.\n */\nexport function setNestedPropertyValue(obj: Record<string, unknown>, path: string, value: unknown): void {\n  const error = new Error(`Property path ${path} not found`);\n  let node: Record<string, unknown> | undefined = obj;\n  const keys = path.split(KEY_SEPARATOR);\n  for (const key of keys.slice(0, -1)) {\n    if (node === undefined) {\n      throw error;\n    }\n    node = node[key] as Record<string, unknown> | undefined;\n  }\n\n  const lastKey = keys.at(-1);\n  if (node === undefined || lastKey === undefined) {\n    throw error;\n  }\n\n  node[lastKey] = value;\n}\n\n/**\n * Converts a given value to a JSON string.\n *\n * @param value - The value to be converted to JSON. This can be of any type.\n * @param options - Options for customizing the JSON conversion process.\n * @returns The JSON string representation of the input value.\n */\nexport function toJson(value: unknown, options: Partial<ToJsonOptions> = {}): string {\n  const DEFAULT_OPTIONS: { tokenSubstitutions: TokenSubstitutions } & ToJsonOptions = {\n    functionHandlingMode: FunctionHandlingMode.Exclude,\n    maxDepth: -1,\n    shouldCatchToJSONErrors: false,\n    shouldHandleCircularReferences: false,\n    shouldHandleErrors: false,\n    shouldHandleUndefined: false,\n    shouldSortKeys: false,\n    // eslint-disable-next-line no-magic-numbers\n    space: 2,\n    tokenSubstitutions: {\n      circularReference: makeObjectTokenSubstitution(TokenSubstitutionKey.CircularReference),\n      maxDepthLimitReached: makeObjectTokenSubstitution(TokenSubstitutionKey.MaxDepthLimitReached),\n      toJSONFailed: makeObjectTokenSubstitution(TokenSubstitutionKey.ToJSONFailed)\n    }\n  };\n\n  const fullOptions = {\n    ...DEFAULT_OPTIONS,\n    ...options,\n    tokenSubstitutions: {\n      ...DEFAULT_OPTIONS.tokenSubstitutions,\n      ...options.tokenSubstitutions\n    }\n  };\n\n  if (fullOptions.maxDepth === -1) {\n    fullOptions.maxDepth = Infinity;\n  }\n\n  const functionTexts: string[] = [];\n  const usedObjects = new WeakSet<object>();\n\n  const plainObject = toPlainObject(value, '', 0, true, fullOptions, functionTexts, usedObjects);\n  let json = JSON.stringify(plainObject, null, fullOptions.space) ?? '';\n  json = replaceAll(json, /\"\\[\\[(?<Key>[A-Za-z]+)(?<Index>\\d*)\\]\\]\"/g, (_, key, indexStr) =>\n    applySubstitutions({\n      functionTexts,\n      index: indexStr ? parseInt(indexStr, 10) : 0,\n      key: key as TokenSubstitutionKey,\n      substitutions: fullOptions.tokenSubstitutions\n    }));\n  return json;\n}\n\nfunction _assignWithNonEnumerableProperties(target: object, ...sources: object[]): object {\n  for (const source of sources) {\n    const descriptors = Object.getOwnPropertyDescriptors(source);\n\n    for (const [key, descriptor] of Object.entries(descriptors)) {\n      try {\n        // Avoid redefining read-only properties (especially `prototype`)\n        if (\n          key === 'prototype'\n          || (Object.getOwnPropertyDescriptor(target, key)?.writable === false\n            && !Object.getOwnPropertyDescriptor(target, key)?.configurable)\n        ) {\n          continue;\n        }\n\n        Object.defineProperty(target, key, descriptor);\n      } catch {\n        // Silently ignore if defineProperty fails\n      }\n    }\n  }\n\n  const sourcePrototypes = sources\n    .map((source) => getPrototypeOf<object | undefined>(source))\n    .filter((proto): proto is object => !!proto);\n\n  if (sourcePrototypes.length > 0) {\n    const targetPrototype = _assignWithNonEnumerableProperties({}, getPrototypeOf(target), ...sourcePrototypes);\n\n    try {\n      Object.setPrototypeOf(target, targetPrototype);\n    } catch {\n      // Silently ignore if setPrototypeOf fails\n    }\n  }\n\n  return target;\n}\n\nfunction applySubstitutions(options: ApplySubstitutionsOptions): MaybeReturn<string> {\n  switch (options.key) {\n    case TokenSubstitutionKey.CircularReference:\n      return options.substitutions.circularReference;\n    case TokenSubstitutionKey.Function:\n      return options.functionTexts[options.index] ?? throwExpression(new Error(`Function with index ${options.index.toString()} not found`));\n    case TokenSubstitutionKey.MaxDepthLimitReached:\n      return options.substitutions.maxDepthLimitReached;\n    case TokenSubstitutionKey.MaxDepthLimitReachedArray:\n      return `Array(${options.index.toString()})`;\n    case TokenSubstitutionKey.ToJSONFailed:\n      return options.substitutions.toJSONFailed;\n    case TokenSubstitutionKey.Undefined:\n      return 'undefined';\n    default:\n      break;\n  }\n}\n\nfunction handleArray(\n  value: unknown[],\n  depth: number,\n  canUseToJSON: boolean,\n  fullOptions: ToJsonOptions,\n  functionTexts: string[],\n  usedObjects: WeakSet<object>\n): unknown {\n  if (depth > fullOptions.maxDepth) {\n    return makePlaceholder(TokenSubstitutionKey.MaxDepthLimitReachedArray, value.length);\n  }\n\n  return value.map((item, index) => toPlainObject(item, index.toString(), depth + 1, canUseToJSON, fullOptions, functionTexts, usedObjects));\n}\n\nfunction handleCircularReference(value: object, key: string, fullOptions: ToJsonOptions): unknown {\n  if (fullOptions.shouldHandleCircularReferences) {\n    return makePlaceholder(TokenSubstitutionKey.CircularReference);\n  }\n  const valueConstructorName = value.constructor.name || 'Object';\n  throw new TypeError(`Converting circular structure to JSON\n--> starting at object with constructor '${valueConstructorName}'\n--- property '${key}' closes the circle`);\n}\n\n// eslint-disable-next-line @typescript-eslint/no-unsafe-function-type\nfunction handleFunction(value: Function, functionTexts: string[], fullOptions: ToJsonOptions): unknown {\n  if (fullOptions.functionHandlingMode === FunctionHandlingMode.Exclude) {\n    return undefined;\n  }\n  const index = functionTexts.length;\n  const functionText = fullOptions.functionHandlingMode === FunctionHandlingMode.Full\n    ? value.toString()\n    : `function ${value.name || 'anonymous'}() { /* ... */ }`;\n  functionTexts.push(functionText);\n  return makePlaceholder(TokenSubstitutionKey.Function, index);\n}\n\nfunction handleObject(\n  value: object,\n  key: string,\n  depth: number,\n  canUseToJSON: boolean,\n  fullOptions: ToJsonOptions,\n  functionTexts: string[],\n  usedObjects: WeakSet<object>\n): unknown {\n  if (usedObjects.has(value)) {\n    return handleCircularReference(value, key, fullOptions);\n  }\n\n  usedObjects.add(value);\n\n  if (canUseToJSON) {\n    const toJSONResult = tryHandleToJSON(value, key, depth, fullOptions, functionTexts, usedObjects);\n    if (toJSONResult !== undefined) {\n      return toJSONResult;\n    }\n  }\n\n  if (Array.isArray(value)) {\n    return handleArray(value, depth, canUseToJSON, fullOptions, functionTexts, usedObjects);\n  }\n\n  if (depth > fullOptions.maxDepth) {\n    return makePlaceholder(TokenSubstitutionKey.MaxDepthLimitReached);\n  }\n\n  if (value instanceof Error && fullOptions.shouldHandleErrors) {\n    return errorToString(value);\n  }\n\n  return handlePlainObject(value, depth, canUseToJSON, fullOptions, functionTexts, usedObjects);\n}\n\nfunction handlePlainObject(\n  value: object,\n  depth: number,\n  canUseToJSON: boolean,\n  fullOptions: ToJsonOptions,\n  functionTexts: string[],\n  usedObjects: WeakSet<object>\n): unknown {\n  const entries = Object.entries(value);\n  if (fullOptions.shouldSortKeys) {\n    entries.sort(([key1], [key2]) => key1.localeCompare(key2));\n  }\n\n  return Object.fromEntries(\n    entries.map(([key2, value2]) => [\n      key2,\n      toPlainObject(value2, key2, depth + 1, canUseToJSON, fullOptions, functionTexts, usedObjects)\n    ])\n  );\n}\n\nfunction makeObjectTokenSubstitution(key: TokenSubstitutionKey): string {\n  return `{ \"[[${key}]]\": null }`;\n}\n\nfunction makePlaceholder(key: TokenSubstitutionKey, index?: number): string {\n  return `[[${key}${index?.toString() ?? ''}]]`;\n}\n\nfunction toPlainObject(\n  value: unknown,\n  key: string,\n  depth: number,\n  canUseToJSON: boolean,\n  fullOptions: ToJsonOptions,\n  functionTexts: string[],\n  usedObjects: WeakSet<object>\n): unknown {\n  if (value === undefined) {\n    return (depth === 0 || fullOptions.shouldHandleUndefined)\n      ? makePlaceholder(TokenSubstitutionKey.Undefined)\n      : undefined;\n  }\n\n  if (typeof value === 'function') {\n    return handleFunction(value, functionTexts, fullOptions);\n  }\n\n  if (typeof value !== 'object' || value === null) {\n    return value;\n  }\n\n  return handleObject(value, key, depth, canUseToJSON, fullOptions, functionTexts, usedObjects);\n}\n\nfunction tryHandleToJSON(\n  value: object,\n  key: string,\n  depth: number,\n  fullOptions: ToJsonOptions,\n  functionTexts: string[],\n  usedObjects: WeakSet<object>\n): unknown {\n  const toJSON = (value as Partial<JSONSerializable>).toJSON;\n  if (typeof toJSON === 'function') {\n    try {\n      const newValue = toJSON.call(value, key);\n      return toPlainObject(newValue, key, depth, false, fullOptions, functionTexts, usedObjects);\n    } catch (e) {\n      if (fullOptions.shouldCatchToJSONErrors) {\n        return makePlaceholder(TokenSubstitutionKey.ToJSONFailed);\n      }\n      throw e;\n    }\n  }\n  return undefined;\n}\n"],
  "mappings": "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",
  "names": ["FunctionHandlingMode"]
}

@@ -3,6 +3,7 @@
3
3
  * Contains utility functions for Objects.
4
4
  */
5
5
  import type { UndefinedOnPartialDeep } from 'type-fest';
6
+ import type { StringKeys } from './Type.cjs';
6
7
  /**
7
8
  * Specifies how functions should be handled in the JSON output.
8
9
  */
@@ -20,12 +21,6 @@ export declare enum FunctionHandlingMode {
20
21
  */
21
22
  NameOnly = "nameOnly"
22
23
  }
23
- /**
24
- * A type that represents the keys of an object as strings.
25
- *
26
- * @typeParam T - The type of the object.
27
- */
28
- export type StringKeys<T extends object> = Extract<keyof T, string>;
29
24
  /**
30
25
  * Options for converting an object to JSON.
31
26
  */
@@ -137,6 +132,21 @@ export declare function deleteProperties<T extends object>(obj: T, propertyNames
137
132
  * @returns `true` if the property was present, otherwise `false`.
138
133
  */
139
134
  export declare function deleteProperty<T extends object>(obj: T, propertyName: keyof T): boolean;
135
+ /**
136
+ * Gets all entries of an object.
137
+ *
138
+ * @param obj - The object to get the entries of.
139
+ * @returns An array of all entries of the object.
140
+ */
141
+ export declare function getAllEntries<T extends object>(obj: T): [StringKeys<T>, T[StringKeys<T>]][];
142
+ /**
143
+ * Gets all keys of an object.
144
+ * Includes fields and properties.
145
+ *
146
+ * @param obj - The object to get the keys of.
147
+ * @returns An array of all keys of the object.
148
+ */
149
+ export declare function getAllKeys<T extends object>(obj: T): StringKeys<T>[];
140
150
  /**
141
151
  * Gets the value of a nested property from an object.
142
152
  *
@@ -42,7 +42,6 @@ class CliTaskResult {
42
42
  * @param tasks - An array of task functions that return a `TaskResult` or `void`.
43
43
  * @returns A promise that resolves with the first failed `TaskResult` or a success result.
44
44
  */
45
- // eslint-disable-next-line @typescript-eslint/no-invalid-void-type
46
45
  static async chain(tasks) {
47
46
  for (const task of tasks) {
48
47
  const result = await wrapResult(task);
@@ -158,4 +157,4 @@ async function wrapResult(taskFn) {
158
157
  toCommandLine,
159
158
  wrapCliTask
160
159
  });
161
- //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../../src/ScriptUtils/CliUtils.ts"],
  "sourcesContent": ["/**\n * @packageDocumentation cli\n * Contains utility classes and functions for managing task results, including\n * success, exit codes, and chaining multiple tasks.\n */\n\nimport type { Promisable } from 'type-fest';\n\nimport { enableLibraryDebuggers } from '../Debug.ts';\nimport { printError } from '../Error.ts';\nimport { noop } from '../Function.ts';\nimport { replaceAll } from '../String.ts';\nimport { process } from './NodeModules.ts';\n\n/**\n * Abstract class representing the result of a task. Includes methods for handling success,\n * exit codes, and chaining tasks.\n */\nexport abstract class CliTaskResult {\n  /**\n   * Chains multiple tasks together, executing them sequentially until one fails.\n   *\n   * @param tasks - An array of task functions that return a `TaskResult` or `void`.\n   * @returns A promise that resolves with the first failed `TaskResult` or a success result.\n   */\n  // eslint-disable-next-line @typescript-eslint/no-invalid-void-type\n  public static async chain(tasks: (() => Promisable<CliTaskResult | void>)[]): Promise<CliTaskResult> {\n    for (const task of tasks) {\n      const result = await wrapResult(task);\n      if (!result.isSuccessful()) {\n        return result;\n      }\n    }\n\n    return CliTaskResult.Success();\n  }\n\n  /**\n   * Creates a `TaskResult` that does not exit the process.\n   *\n   * @returns A `TaskResult` that does not exit the process.\n   */\n  public static DoNotExit(): CliTaskResult {\n    return new DoNotExitTaskResult();\n  }\n\n  /**\n   * Represents a failure result of a CLI task.\n   *\n   * @returns The failure result.\n   */\n  public static Failure(): CliTaskResult {\n    return this.Success(false);\n  }\n\n  /**\n   * Creates a `TaskResult` based on an exit code.\n   *\n   * @param exitCode - The exit code to represent.\n   * @returns A `TaskResult` representing the exit code.\n   */\n  public static FromExitCode(exitCode: number): CliTaskResult {\n    return new ExitCodeTaskResult(exitCode);\n  }\n\n  /**\n   * Creates a CliTaskResult representing a successful task result.\n   *\n   * @param isSuccess - A boolean indicating whether the task was successful. Default is true.\n   * @returns A CliTaskResult object representing a successful task result.\n   */\n  public static Success(isSuccess = true): CliTaskResult {\n    return new SuccessTaskResult(isSuccess);\n  }\n\n  /**\n   * Exits the process based on the task result.\n   */\n  public abstract exit(): void;\n\n  /**\n   * Determines if the task was successful.\n   *\n   * @returns `true` if the task was successful, otherwise `false`.\n   */\n  protected abstract isSuccessful(): boolean;\n}\n\n/**\n * Represents a task result that does not exit the process.\n */\nclass DoNotExitTaskResult extends CliTaskResult {\n  /**\n   * Does not exit the process.\n   */\n  public override exit(): void {\n    noop();\n  }\n\n  protected override isSuccessful(): boolean {\n    return true;\n  }\n}\n\n/**\n * Represents a task result based on an exit code.\n */\nclass ExitCodeTaskResult extends CliTaskResult {\n  public constructor(private readonly exitCode: number) {\n    super();\n  }\n\n  /**\n   * Exits the process with the specified exit code.\n   */\n  public override exit(): void {\n    process.exit(this.exitCode);\n  }\n\n  protected override isSuccessful(): boolean {\n    return this.exitCode === 0;\n  }\n}\n\n/**\n * Represents a task result based on success or failure.\n */\nclass SuccessTaskResult extends CliTaskResult {\n  public constructor(private readonly _isSuccessful: boolean) {\n    super();\n  }\n\n  /**\n   * Exits the process based on the success of the task.\n   */\n  public override exit(): void {\n    process.exit(this._isSuccessful ? 0 : 1);\n  }\n\n  protected override isSuccessful(): boolean {\n    return this._isSuccessful;\n  }\n}\n\n/**\n * Converts an array of command-line arguments into a single command-line string.\n * Handles escaping of special characters such as spaces, quotes, and newlines.\n *\n * @param args - The array of command-line arguments to convert.\n * @returns A string representing the command-line invocation.\n */\nexport function toCommandLine(args: string[]): string {\n  return args\n    .map((arg) => {\n      if (/[\\s\"\\n]/.test(arg)) {\n        let escapedArg = arg;\n        escapedArg = replaceAll(escapedArg, /\"/g, '\\\\\"');\n        escapedArg = replaceAll(escapedArg, /\\n/g, '\\\\n');\n        return `\"${escapedArg}\"`;\n      }\n      return arg;\n    })\n    .join(' ');\n}\n\n/**\n * Wraps a CLI task function to ensure it runs safely and handles its `TaskResult`.\n *\n * @param taskFn - The task function to execute, which may return a `TaskResult` or void.\n * @returns A promise that resolves when the task is completed and exits with the appropriate status.\n */\n// eslint-disable-next-line @typescript-eslint/no-invalid-void-type\nexport async function wrapCliTask(taskFn: () => Promisable<CliTaskResult | void>): Promise<void> {\n  enableLibraryDebuggers();\n  const result = await wrapResult(taskFn);\n  result.exit();\n}\n\n/**\n * Safely executes a task function and returns a `TaskResult`. If the task function throws an error,\n * the error is caught, and a failure `TaskResult` is returned.\n *\n * @param taskFn - The task function to execute.\n * @returns A promise that resolves with a `TaskResult` representing the outcome of the task.\n */\n// eslint-disable-next-line @typescript-eslint/no-invalid-void-type\nasync function wrapResult(taskFn: () => Promisable<CliTaskResult | void>): Promise<CliTaskResult> {\n  try {\n    return await taskFn() as CliTaskResult | undefined ?? CliTaskResult.Success();\n  } catch (error) {\n    printError(new Error('An error occurred during task execution', { cause: error }));\n    return CliTaskResult.Failure();\n  }\n}\n"],
  "mappings": ";;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAQA,mBAAuC;AACvC,mBAA2B;AAC3B,sBAAqB;AACrB,oBAA2B;AAC3B,yBAAwB;AAMjB,MAAe,cAAc;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQlC,aAAoB,MAAM,OAA2E;AACnG,eAAW,QAAQ,OAAO;AACxB,YAAM,SAAS,MAAM,WAAW,IAAI;AACpC,UAAI,CAAC,OAAO,aAAa,GAAG;AAC1B,eAAO;AAAA,MACT;AAAA,IACF;AAEA,WAAO,cAAc,QAAQ;AAAA,EAC/B;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,OAAc,YAA2B;AACvC,WAAO,IAAI,oBAAoB;AAAA,EACjC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,OAAc,UAAyB;AACrC,WAAO,KAAK,QAAQ,KAAK;AAAA,EAC3B;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQA,OAAc,aAAa,UAAiC;AAC1D,WAAO,IAAI,mBAAmB,QAAQ;AAAA,EACxC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQA,OAAc,QAAQ,YAAY,MAAqB;AACrD,WAAO,IAAI,kBAAkB,SAAS;AAAA,EACxC;AAaF;AAKA,MAAM,4BAA4B,cAAc;AAAA;AAAA;AAAA;AAAA,EAI9B,OAAa;AAC3B,8BAAK;AAAA,EACP;AAAA,EAEmB,eAAwB;AACzC,WAAO;AAAA,EACT;AACF;AAKA,MAAM,2BAA2B,cAAc;AAAA,EACtC,YAA6B,UAAkB;AACpD,UAAM;AAD4B;AAAA,EAEpC;AAAA;AAAA;AAAA;AAAA,EAKgB,OAAa;AAC3B,+BAAQ,KAAK,KAAK,QAAQ;AAAA,EAC5B;AAAA,EAEmB,eAAwB;AACzC,WAAO,KAAK,aAAa;AAAA,EAC3B;AACF;AAKA,MAAM,0BAA0B,cAAc;AAAA,EACrC,YAA6B,eAAwB;AAC1D,UAAM;AAD4B;AAAA,EAEpC;AAAA;AAAA;AAAA;AAAA,EAKgB,OAAa;AAC3B,+BAAQ,KAAK,KAAK,gBAAgB,IAAI,CAAC;AAAA,EACzC;AAAA,EAEmB,eAAwB;AACzC,WAAO,KAAK;AAAA,EACd;AACF;AASO,SAAS,cAAc,MAAwB;AACpD,SAAO,KACJ,IAAI,CAAC,QAAQ;AACZ,QAAI,UAAU,KAAK,GAAG,GAAG;AACvB,UAAI,aAAa;AACjB,uBAAa,0BAAW,YAAY,MAAM,KAAK;AAC/C,uBAAa,0BAAW,YAAY,OAAO,KAAK;AAChD,aAAO,IAAI,UAAU;AAAA,IACvB;AACA,WAAO;AAAA,EACT,CAAC,EACA,KAAK,GAAG;AACb;AASA,eAAsB,YAAY,QAA+D;AAC/F,2CAAuB;AACvB,QAAM,SAAS,MAAM,WAAW,MAAM;AACtC,SAAO,KAAK;AACd;AAUA,eAAe,WAAW,QAAwE;AAChG,MAAI;AACF,WAAO,MAAM,OAAO,KAAkC,cAAc,QAAQ;AAAA,EAC9E,SAAS,OAAO;AACd,iCAAW,IAAI,MAAM,2CAA2C,EAAE,OAAO,MAAM,CAAC,CAAC;AACjF,WAAO,cAAc,QAAQ;AAAA,EAC/B;AACF;",
  "names": []
}

160
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../../src/ScriptUtils/CliUtils.ts"],
  "sourcesContent": ["/**\n * @packageDocumentation cli\n * Contains utility classes and functions for managing task results, including\n * success, exit codes, and chaining multiple tasks.\n */\n\nimport type { Promisable } from 'type-fest';\n\nimport type { MaybeReturn } from '../Type.ts';\n\nimport { enableLibraryDebuggers } from '../Debug.ts';\nimport { printError } from '../Error.ts';\nimport { noop } from '../Function.ts';\nimport { replaceAll } from '../String.ts';\nimport { process } from './NodeModules.ts';\n\n/**\n * Abstract class representing the result of a task. Includes methods for handling success,\n * exit codes, and chaining tasks.\n */\nexport abstract class CliTaskResult {\n  /**\n   * Chains multiple tasks together, executing them sequentially until one fails.\n   *\n   * @param tasks - An array of task functions that return a `TaskResult` or `void`.\n   * @returns A promise that resolves with the first failed `TaskResult` or a success result.\n   */\n  public static async chain(tasks: (() => Promisable<MaybeReturn<CliTaskResult>>)[]): Promise<CliTaskResult> {\n    for (const task of tasks) {\n      const result = await wrapResult(task);\n      if (!result.isSuccessful()) {\n        return result;\n      }\n    }\n\n    return CliTaskResult.Success();\n  }\n\n  /**\n   * Creates a `TaskResult` that does not exit the process.\n   *\n   * @returns A `TaskResult` that does not exit the process.\n   */\n  public static DoNotExit(): CliTaskResult {\n    return new DoNotExitTaskResult();\n  }\n\n  /**\n   * Represents a failure result of a CLI task.\n   *\n   * @returns The failure result.\n   */\n  public static Failure(): CliTaskResult {\n    return this.Success(false);\n  }\n\n  /**\n   * Creates a `TaskResult` based on an exit code.\n   *\n   * @param exitCode - The exit code to represent.\n   * @returns A `TaskResult` representing the exit code.\n   */\n  public static FromExitCode(exitCode: number): CliTaskResult {\n    return new ExitCodeTaskResult(exitCode);\n  }\n\n  /**\n   * Creates a CliTaskResult representing a successful task result.\n   *\n   * @param isSuccess - A boolean indicating whether the task was successful. Default is true.\n   * @returns A CliTaskResult object representing a successful task result.\n   */\n  public static Success(isSuccess = true): CliTaskResult {\n    return new SuccessTaskResult(isSuccess);\n  }\n\n  /**\n   * Exits the process based on the task result.\n   */\n  public abstract exit(): void;\n\n  /**\n   * Determines if the task was successful.\n   *\n   * @returns `true` if the task was successful, otherwise `false`.\n   */\n  protected abstract isSuccessful(): boolean;\n}\n\n/**\n * Represents a task result that does not exit the process.\n */\nclass DoNotExitTaskResult extends CliTaskResult {\n  /**\n   * Does not exit the process.\n   */\n  public override exit(): void {\n    noop();\n  }\n\n  protected override isSuccessful(): boolean {\n    return true;\n  }\n}\n\n/**\n * Represents a task result based on an exit code.\n */\nclass ExitCodeTaskResult extends CliTaskResult {\n  public constructor(private readonly exitCode: number) {\n    super();\n  }\n\n  /**\n   * Exits the process with the specified exit code.\n   */\n  public override exit(): void {\n    process.exit(this.exitCode);\n  }\n\n  protected override isSuccessful(): boolean {\n    return this.exitCode === 0;\n  }\n}\n\n/**\n * Represents a task result based on success or failure.\n */\nclass SuccessTaskResult extends CliTaskResult {\n  public constructor(private readonly _isSuccessful: boolean) {\n    super();\n  }\n\n  /**\n   * Exits the process based on the success of the task.\n   */\n  public override exit(): void {\n    process.exit(this._isSuccessful ? 0 : 1);\n  }\n\n  protected override isSuccessful(): boolean {\n    return this._isSuccessful;\n  }\n}\n\n/**\n * Converts an array of command-line arguments into a single command-line string.\n * Handles escaping of special characters such as spaces, quotes, and newlines.\n *\n * @param args - The array of command-line arguments to convert.\n * @returns A string representing the command-line invocation.\n */\nexport function toCommandLine(args: string[]): string {\n  return args\n    .map((arg) => {\n      if (/[\\s\"\\n]/.test(arg)) {\n        let escapedArg = arg;\n        escapedArg = replaceAll(escapedArg, /\"/g, '\\\\\"');\n        escapedArg = replaceAll(escapedArg, /\\n/g, '\\\\n');\n        return `\"${escapedArg}\"`;\n      }\n      return arg;\n    })\n    .join(' ');\n}\n\n/**\n * Wraps a CLI task function to ensure it runs safely and handles its `TaskResult`.\n *\n * @param taskFn - The task function to execute, which may return a `TaskResult` or void.\n * @returns A promise that resolves when the task is completed and exits with the appropriate status.\n */\nexport async function wrapCliTask(taskFn: () => Promisable<MaybeReturn<CliTaskResult>>): Promise<void> {\n  enableLibraryDebuggers();\n  const result = await wrapResult(taskFn);\n  result.exit();\n}\n\n/**\n * Safely executes a task function and returns a `TaskResult`. If the task function throws an error,\n * the error is caught, and a failure `TaskResult` is returned.\n *\n * @param taskFn - The task function to execute.\n * @returns A promise that resolves with a `TaskResult` representing the outcome of the task.\n */\nasync function wrapResult(taskFn: () => Promisable<MaybeReturn<CliTaskResult>>): Promise<CliTaskResult> {\n  try {\n    return (await taskFn()) as CliTaskResult | undefined ?? CliTaskResult.Success();\n  } catch (error) {\n    printError(new Error('An error occurred during task execution', { cause: error }));\n    return CliTaskResult.Failure();\n  }\n}\n"],
  "mappings": ";;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAUA,mBAAuC;AACvC,mBAA2B;AAC3B,sBAAqB;AACrB,oBAA2B;AAC3B,yBAAwB;AAMjB,MAAe,cAAc;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOlC,aAAoB,MAAM,OAAiF;AACzG,eAAW,QAAQ,OAAO;AACxB,YAAM,SAAS,MAAM,WAAW,IAAI;AACpC,UAAI,CAAC,OAAO,aAAa,GAAG;AAC1B,eAAO;AAAA,MACT;AAAA,IACF;AAEA,WAAO,cAAc,QAAQ;AAAA,EAC/B;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,OAAc,YAA2B;AACvC,WAAO,IAAI,oBAAoB;AAAA,EACjC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,OAAc,UAAyB;AACrC,WAAO,KAAK,QAAQ,KAAK;AAAA,EAC3B;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQA,OAAc,aAAa,UAAiC;AAC1D,WAAO,IAAI,mBAAmB,QAAQ;AAAA,EACxC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQA,OAAc,QAAQ,YAAY,MAAqB;AACrD,WAAO,IAAI,kBAAkB,SAAS;AAAA,EACxC;AAaF;AAKA,MAAM,4BAA4B,cAAc;AAAA;AAAA;AAAA;AAAA,EAI9B,OAAa;AAC3B,8BAAK;AAAA,EACP;AAAA,EAEmB,eAAwB;AACzC,WAAO;AAAA,EACT;AACF;AAKA,MAAM,2BAA2B,cAAc;AAAA,EACtC,YAA6B,UAAkB;AACpD,UAAM;AAD4B;AAAA,EAEpC;AAAA;AAAA;AAAA;AAAA,EAKgB,OAAa;AAC3B,+BAAQ,KAAK,KAAK,QAAQ;AAAA,EAC5B;AAAA,EAEmB,eAAwB;AACzC,WAAO,KAAK,aAAa;AAAA,EAC3B;AACF;AAKA,MAAM,0BAA0B,cAAc;AAAA,EACrC,YAA6B,eAAwB;AAC1D,UAAM;AAD4B;AAAA,EAEpC;AAAA;AAAA;AAAA;AAAA,EAKgB,OAAa;AAC3B,+BAAQ,KAAK,KAAK,gBAAgB,IAAI,CAAC;AAAA,EACzC;AAAA,EAEmB,eAAwB;AACzC,WAAO,KAAK;AAAA,EACd;AACF;AASO,SAAS,cAAc,MAAwB;AACpD,SAAO,KACJ,IAAI,CAAC,QAAQ;AACZ,QAAI,UAAU,KAAK,GAAG,GAAG;AACvB,UAAI,aAAa;AACjB,uBAAa,0BAAW,YAAY,MAAM,KAAK;AAC/C,uBAAa,0BAAW,YAAY,OAAO,KAAK;AAChD,aAAO,IAAI,UAAU;AAAA,IACvB;AACA,WAAO;AAAA,EACT,CAAC,EACA,KAAK,GAAG;AACb;AAQA,eAAsB,YAAY,QAAqE;AACrG,2CAAuB;AACvB,QAAM,SAAS,MAAM,WAAW,MAAM;AACtC,SAAO,KAAK;AACd;AASA,eAAe,WAAW,QAA8E;AACtG,MAAI;AACF,WAAQ,MAAM,OAAO,KAAmC,cAAc,QAAQ;AAAA,EAChF,SAAS,OAAO;AACd,iCAAW,IAAI,MAAM,2CAA2C,EAAE,OAAO,MAAM,CAAC,CAAC;AACjF,WAAO,cAAc,QAAQ;AAAA,EAC/B;AACF;",
  "names": []
}

@@ -4,6 +4,7 @@
4
4
  * success, exit codes, and chaining multiple tasks.
5
5
  */
6
6
  import type { Promisable } from 'type-fest';
7
+ import type { MaybeReturn } from '../Type.cjs';
7
8
  /**
8
9
  * Abstract class representing the result of a task. Includes methods for handling success,
9
10
  * exit codes, and chaining tasks.
@@ -15,7 +16,7 @@ export declare abstract class CliTaskResult {
15
16
  * @param tasks - An array of task functions that return a `TaskResult` or `void`.
16
17
  * @returns A promise that resolves with the first failed `TaskResult` or a success result.
17
18
  */
18
- static chain(tasks: (() => Promisable<CliTaskResult | void>)[]): Promise<CliTaskResult>;
19
+ static chain(tasks: (() => Promisable<MaybeReturn<CliTaskResult>>)[]): Promise<CliTaskResult>;
19
20
  /**
20
21
  * Creates a `TaskResult` that does not exit the process.
21
22
  *
@@ -67,4 +68,4 @@ export declare function toCommandLine(args: string[]): string;
67
68
  * @param taskFn - The task function to execute, which may return a `TaskResult` or void.
68
69
  * @returns A promise that resolves when the task is completed and exits with the appropriate status.
69
70
  */
70
- export declare function wrapCliTask(taskFn: () => Promisable<CliTaskResult | void>): Promise<void>;
71
+ export declare function wrapCliTask(taskFn: () => Promisable<MaybeReturn<CliTaskResult>>): Promise<void>;
@@ -102,4 +102,4 @@ function addCommand(program, name, description, taskFn) {
102
102
  0 && (module.exports = {
103
103
  cli
104
104
  });
105
- //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../../src/ScriptUtils/cli.ts"],
  "sourcesContent": ["var __import_meta_url = globalThis['import.meta.url'] ?? (()=>{if(typeof __filename===\"string\"){const localRequire=require;const url=localRequire(\"node:url\");return url.pathToFileURL(__filename).href}if(typeof window!==\"undefined\"){return window.location.href}return\"\"})();\n/**\n * @packageDocumentation cli\n * This module defines a CLI for managing various tasks related to Obsidian plugin development.\n * It leverages the `commander` library to define commands for building, linting, spellchecking,\n * and updating the version of the plugin. The CLI is designed to be flexible and can handle both\n * synchronous and asynchronous tasks.\n */\n\nimport type { Promisable } from 'type-fest';\n\nimport { Command } from 'commander';\nimport { tsImport } from 'tsx/esm/api';\n\nimport { invokeAsyncSafely } from '../Async.ts';\nimport {\n  getDirname,\n  join,\n  relative\n} from '../Path.ts';\nimport {\n  buildClean,\n  buildCompile,\n  buildCompileSvelte,\n  buildCompileTypeScript,\n  buildStatic\n} from './build.ts';\nimport {\n  CliTaskResult,\n  wrapCliTask\n} from './CliUtils.ts';\nimport {\n  BuildMode,\n  buildObsidianPlugin\n} from './esbuild/ObsidianPluginBuilder.ts';\nimport { lint } from './ESLint/ESLint.ts';\nimport { format } from './format.ts';\nimport {\n  existsSync,\n  process\n} from './NodeModules.ts';\nimport { readPackageJson } from './Npm.ts';\nimport { publish } from './NpmPublish.ts';\nimport { ObsidianDevUtilsRepoPaths } from './ObsidianDevUtilsRepoPaths.ts';\nimport { resolvePathFromRootSafe } from './Root.ts';\nimport { spellcheck } from './spellcheck.ts';\nimport { updateVersion } from './version.ts';\n\n/**\n * The number of leading arguments to skip when parsing command-line arguments.\n * The first two elements typically represent the Node.js executable and the script path:\n * `[\"node\", \"path/to/cli.cjs\", ...actualArgs]`\n */\nconst NODE_SCRIPT_ARGV_SKIP_COUNT = 2;\n\n/**\n * Enum representing the names of the commands available in the CLI.\n */\nenum CommandNames {\n  Build = 'build',\n  BuildClean = 'build:clean',\n  BuildCompile = 'build:compile',\n  BuildCompileSvelte = 'build:compile:svelte',\n  BuildCompileTypeScript = 'build:compile:typescript',\n  BuildStatic = 'build:static',\n  Dev = 'dev',\n  Format = 'format',\n  FormatCheck = 'format:check',\n  Lint = 'lint',\n  LintFix = 'lint:fix',\n  Publish = 'publish',\n  Spellcheck = 'spellcheck',\n  Version = 'version'\n}\n\ninterface OverrideModule<Args extends unknown[]> {\n  // eslint-disable-next-line @typescript-eslint/no-invalid-void-type\n  invoke(...args: Args): Promise<CliTaskResult | void>;\n}\n\n/**\n * Main function to run the CLI. It sets up the commands using the `commander` library and\n * handles the execution of tasks like building, cleaning, linting, spellchecking, and versioning.\n *\n * @param argv - The command-line arguments to parse. Defaults to `process.argv` minus the first two elements.\n */\nexport function cli(argv: string[] = process.argv.slice(NODE_SCRIPT_ARGV_SKIP_COUNT)): void {\n  invokeAsyncSafely(() =>\n    wrapCliTask(async () => {\n      const packageJson = await readPackageJson(getDirname(import.meta.url));\n      const program = new Command();\n\n      program\n        .name(packageJson.name ?? '(unknown)')\n        .description('CLI for Obsidian plugin development utilities')\n        .version(packageJson.version ?? '(unknown)');\n\n      addCommand(program, CommandNames.Build, 'Build the plugin', () => buildObsidianPlugin({ mode: BuildMode.Production }));\n      addCommand(program, CommandNames.BuildClean, 'Clean the dist folder', () => buildClean());\n      addCommand(program, CommandNames.BuildCompile, 'Check if code compiles', () => buildCompile());\n      addCommand(program, CommandNames.BuildCompileSvelte, 'Check if Svelte code compiles', () => buildCompileSvelte());\n      addCommand(program, CommandNames.BuildCompileTypeScript, 'Check if TypeScript code compiles', () => buildCompileTypeScript());\n      addCommand(program, CommandNames.BuildStatic, 'Copy static content to dist', () => buildStatic());\n      addCommand(program, CommandNames.Dev, 'Build the plugin in development mode', () => buildObsidianPlugin({ mode: BuildMode.Development }));\n      addCommand(program, CommandNames.Format, 'Format the source code', () => format());\n      addCommand(program, CommandNames.FormatCheck, 'Check if the source code is formatted', () => format(false));\n      addCommand(program, CommandNames.Lint, 'Lint the source code', () => lint());\n      addCommand(program, CommandNames.LintFix, 'Lint the source code and apply automatic fixes', () => lint(true));\n      addCommand(program, CommandNames.Publish, 'Publish to NPM', (isBeta: boolean) => publish(isBeta))\n        .argument('[isBeta]', 'Publish to NPM beta');\n      addCommand(program, CommandNames.Spellcheck, 'Spellcheck the source code', () => spellcheck());\n      addCommand(program, CommandNames.Version, 'Release a new version', (versionUpdateType: string) => updateVersion(versionUpdateType))\n        .argument('[versionUpdateType]', 'Version update type: major, minor, patch, beta, or x.y.z[-suffix]');\n      await program.parseAsync(argv, { from: 'user' });\n      return CliTaskResult.DoNotExit();\n    })\n  );\n}\n\n/**\n * Adds a command to the CLI program with the specified name, description, and task function.\n *\n * @param program - The `commander` program instance to which the command is added.\n * @param name - The name of the command.\n * @param description - A brief description of what the command does.\n * @param taskFn - The function to execute when the command is invoked. Can return a `TaskResult` or void.\n * @returns The `commander` command instance for further chaining.\n */\n// eslint-disable-next-line @typescript-eslint/no-unnecessary-type-parameters\nfunction addCommand<Args extends unknown[]>(\n  program: Command,\n  name: string,\n  description: string,\n  // eslint-disable-next-line @typescript-eslint/no-invalid-void-type\n  taskFn: (...args: Args) => Promisable<CliTaskResult | void>\n): Command {\n  return program.command(name)\n    .description(description)\n    .action((...args: Args) =>\n      wrapCliTask(async () => {\n        const scriptPath = resolvePathFromRootSafe(join(ObsidianDevUtilsRepoPaths.Scripts, `${name.replace(':', '-')}.ts`));\n        if (existsSync(scriptPath)) {\n          const dir = getDirname(import.meta.url);\n          const relativeScriptPath = relative(dir, scriptPath);\n          const module = await tsImport(relativeScriptPath, { parentURL: import.meta.url }) as Partial<OverrideModule<Args>>;\n          if (typeof module.invoke !== 'function') {\n            throw new Error(`${relativeScriptPath} does not export an invoke function`);\n          }\n          return module.invoke(...args);\n        }\n\n        return await taskFn(...args);\n      })\n    );\n}\n"],
  "mappings": "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",
  "names": ["module"]
}

105
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../../src/ScriptUtils/cli.ts"],
  "sourcesContent": ["var __import_meta_url = globalThis['import.meta.url'] ?? (()=>{if(typeof __filename===\"string\"){const localRequire=require;const url=localRequire(\"node:url\");return url.pathToFileURL(__filename).href}if(typeof window!==\"undefined\"){return window.location.href}return\"\"})();\n/**\n * @packageDocumentation cli\n * This module defines a CLI for managing various tasks related to Obsidian plugin development.\n * It leverages the `commander` library to define commands for building, linting, spellchecking,\n * and updating the version of the plugin. The CLI is designed to be flexible and can handle both\n * synchronous and asynchronous tasks.\n */\n\nimport type { Promisable } from 'type-fest';\n\nimport { Command } from 'commander';\nimport { tsImport } from 'tsx/esm/api';\n\nimport type { MaybeReturn } from '../Type.ts';\n\nimport { invokeAsyncSafely } from '../Async.ts';\nimport {\n  getDirname,\n  join,\n  relative\n} from '../Path.ts';\nimport {\n  buildClean,\n  buildCompile,\n  buildCompileSvelte,\n  buildCompileTypeScript,\n  buildStatic\n} from './build.ts';\nimport {\n  CliTaskResult,\n  wrapCliTask\n} from './CliUtils.ts';\nimport {\n  BuildMode,\n  buildObsidianPlugin\n} from './esbuild/ObsidianPluginBuilder.ts';\nimport { lint } from './ESLint/ESLint.ts';\nimport { format } from './format.ts';\nimport {\n  existsSync,\n  process\n} from './NodeModules.ts';\nimport { readPackageJson } from './Npm.ts';\nimport { publish } from './NpmPublish.ts';\nimport { ObsidianDevUtilsRepoPaths } from './ObsidianDevUtilsRepoPaths.ts';\nimport { resolvePathFromRootSafe } from './Root.ts';\nimport { spellcheck } from './spellcheck.ts';\nimport { updateVersion } from './version.ts';\n\n/**\n * The number of leading arguments to skip when parsing command-line arguments.\n * The first two elements typically represent the Node.js executable and the script path:\n * `[\"node\", \"path/to/cli.cjs\", ...actualArgs]`\n */\nconst NODE_SCRIPT_ARGV_SKIP_COUNT = 2;\n\n/**\n * Enum representing the names of the commands available in the CLI.\n */\nenum CommandNames {\n  Build = 'build',\n  BuildClean = 'build:clean',\n  BuildCompile = 'build:compile',\n  BuildCompileSvelte = 'build:compile:svelte',\n  BuildCompileTypeScript = 'build:compile:typescript',\n  BuildStatic = 'build:static',\n  Dev = 'dev',\n  Format = 'format',\n  FormatCheck = 'format:check',\n  Lint = 'lint',\n  LintFix = 'lint:fix',\n  Publish = 'publish',\n  Spellcheck = 'spellcheck',\n  Version = 'version'\n}\n\ninterface OverrideModule<Args extends unknown[]> {\n  invoke(...args: Args): Promise<MaybeReturn<CliTaskResult>>;\n}\n\n/**\n * Main function to run the CLI. It sets up the commands using the `commander` library and\n * handles the execution of tasks like building, cleaning, linting, spellchecking, and versioning.\n *\n * @param argv - The command-line arguments to parse. Defaults to `process.argv` minus the first two elements.\n */\nexport function cli(argv: string[] = process.argv.slice(NODE_SCRIPT_ARGV_SKIP_COUNT)): void {\n  invokeAsyncSafely(() =>\n    wrapCliTask(async () => {\n      const packageJson = await readPackageJson(getDirname(import.meta.url));\n      const program = new Command();\n\n      program\n        .name(packageJson.name ?? '(unknown)')\n        .description('CLI for Obsidian plugin development utilities')\n        .version(packageJson.version ?? '(unknown)');\n\n      addCommand(program, CommandNames.Build, 'Build the plugin', () => buildObsidianPlugin({ mode: BuildMode.Production }));\n      addCommand(program, CommandNames.BuildClean, 'Clean the dist folder', () => buildClean());\n      addCommand(program, CommandNames.BuildCompile, 'Check if code compiles', () => buildCompile());\n      addCommand(program, CommandNames.BuildCompileSvelte, 'Check if Svelte code compiles', () => buildCompileSvelte());\n      addCommand(program, CommandNames.BuildCompileTypeScript, 'Check if TypeScript code compiles', () => buildCompileTypeScript());\n      addCommand(program, CommandNames.BuildStatic, 'Copy static content to dist', () => buildStatic());\n      addCommand(program, CommandNames.Dev, 'Build the plugin in development mode', () => buildObsidianPlugin({ mode: BuildMode.Development }));\n      addCommand(program, CommandNames.Format, 'Format the source code', () => format());\n      addCommand(program, CommandNames.FormatCheck, 'Check if the source code is formatted', () => format(false));\n      addCommand(program, CommandNames.Lint, 'Lint the source code', () => lint());\n      addCommand(program, CommandNames.LintFix, 'Lint the source code and apply automatic fixes', () => lint(true));\n      addCommand(program, CommandNames.Publish, 'Publish to NPM', (isBeta: boolean) => publish(isBeta))\n        .argument('[isBeta]', 'Publish to NPM beta');\n      addCommand(program, CommandNames.Spellcheck, 'Spellcheck the source code', () => spellcheck());\n      addCommand(program, CommandNames.Version, 'Release a new version', (versionUpdateType: string) => updateVersion(versionUpdateType))\n        .argument('[versionUpdateType]', 'Version update type: major, minor, patch, beta, or x.y.z[-suffix]');\n      await program.parseAsync(argv, { from: 'user' });\n      return CliTaskResult.DoNotExit();\n    })\n  );\n}\n\n/**\n * Adds a command to the CLI program with the specified name, description, and task function.\n *\n * @param program - The `commander` program instance to which the command is added.\n * @param name - The name of the command.\n * @param description - A brief description of what the command does.\n * @param taskFn - The function to execute when the command is invoked. Can return a `TaskResult` or void.\n * @returns The `commander` command instance for further chaining.\n */\n// eslint-disable-next-line @typescript-eslint/no-unnecessary-type-parameters\nfunction addCommand<Args extends unknown[]>(\n  program: Command,\n  name: string,\n  description: string,\n  taskFn: (...args: Args) => Promisable<MaybeReturn<CliTaskResult>>\n): Command {\n  return program.command(name)\n    .description(description)\n    .action((...args: Args) =>\n      wrapCliTask(async () => {\n        const scriptPath = resolvePathFromRootSafe(join(ObsidianDevUtilsRepoPaths.Scripts, `${name.replace(':', '-')}.ts`));\n        if (existsSync(scriptPath)) {\n          const dir = getDirname(import.meta.url);\n          const relativeScriptPath = relative(dir, scriptPath);\n          const module = await tsImport(relativeScriptPath, { parentURL: import.meta.url }) as Partial<OverrideModule<Args>>;\n          if (typeof module.invoke !== 'function') {\n            throw new Error(`${relativeScriptPath} does not export an invoke function`);\n          }\n          return module.invoke(...args);\n        }\n\n        return await taskFn(...args);\n      })\n    );\n}\n"],
  "mappings": "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",
  "names": ["module"]
}
