obsidian-dev-utils 48.1.2 → 48.1.4

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 (257) hide show
  1. package/CHANGELOG.md +9 -0
  2. package/dist/lib/cjs/Async.cjs +4 -2
  3. package/dist/lib/cjs/Async.d.cts +28 -19
  4. package/dist/lib/cjs/Blob.cjs +3 -4
  5. package/dist/lib/cjs/Debug.cjs +1 -1
  6. package/dist/lib/cjs/DebugController.cjs +1 -1
  7. package/dist/lib/cjs/Enum.cjs +4 -11
  8. package/dist/lib/cjs/Error.cjs +5 -4
  9. package/dist/lib/cjs/Library.cjs +1 -1
  10. package/dist/lib/cjs/ObjectUtils.cjs +15 -7
  11. package/dist/lib/cjs/ObjectUtils.d.cts +17 -13
  12. package/dist/lib/cjs/RegExp.cjs +3 -1
  13. package/dist/lib/cjs/ScriptUtils/ESLint/ESLint.cjs +3 -4
  14. package/dist/lib/cjs/ScriptUtils/ESLint/eslint.config.cjs +4 -2
  15. package/dist/lib/cjs/ScriptUtils/Exec.cjs +1 -1
  16. package/dist/lib/cjs/ScriptUtils/Exec.d.cts +6 -6
  17. package/dist/lib/cjs/ScriptUtils/Fs.cjs +1 -1
  18. package/dist/lib/cjs/ScriptUtils/Fs.d.cts +7 -7
  19. package/dist/lib/cjs/ScriptUtils/JSON.cjs +1 -1
  20. package/dist/lib/cjs/ScriptUtils/JSON.d.cts +1 -1
  21. package/dist/lib/cjs/ScriptUtils/NodeModules.cjs +1 -1
  22. package/dist/lib/cjs/ScriptUtils/Npm.cjs +5 -5
  23. package/dist/lib/cjs/ScriptUtils/Npm.d.cts +2 -2
  24. package/dist/lib/cjs/ScriptUtils/NpmRun.cjs +12 -3
  25. package/dist/lib/cjs/ScriptUtils/NpmRun.d.cts +7 -0
  26. package/dist/lib/cjs/ScriptUtils/cli.cjs +1 -1
  27. package/dist/lib/cjs/ScriptUtils/esbuild/Dependency.cjs +3 -3
  28. package/dist/lib/cjs/ScriptUtils/esbuild/ObsidianPluginBuilder.cjs +11 -11
  29. package/dist/lib/cjs/ScriptUtils/esbuild/ObsidianPluginBuilder.d.cts +4 -4
  30. package/dist/lib/cjs/ScriptUtils/esbuild/changeExtensionPlugin.cjs +1 -1
  31. package/dist/lib/cjs/ScriptUtils/esbuild/copyToObsidianPluginsFolderPlugin.cjs +1 -1
  32. package/dist/lib/cjs/ScriptUtils/esbuild/customEsbuildOptionsPlugin.cjs +1 -1
  33. package/dist/lib/cjs/ScriptUtils/esbuild/fixEsmPlugin.cjs +1 -1
  34. package/dist/lib/cjs/ScriptUtils/esbuild/fixSourceMapsPlugin.cjs +1 -1
  35. package/dist/lib/cjs/ScriptUtils/esbuild/preprocessPlugin.cjs +14 -1
  36. package/dist/lib/cjs/ScriptUtils/esbuild/renameCssPlugin.cjs +1 -1
  37. package/dist/lib/cjs/ScriptUtils/esbuild/svelteWrapperPlugin.cjs +1 -1
  38. package/dist/lib/cjs/ScriptUtils/format.cjs +4 -7
  39. package/dist/lib/cjs/ScriptUtils/markdownlint/markdownlint-cli2-config.cjs +1 -1
  40. package/dist/lib/cjs/ScriptUtils/markdownlint/markdownlint.cjs +3 -4
  41. package/dist/lib/cjs/ScriptUtils/version.cjs +12 -10
  42. package/dist/lib/cjs/String.cjs +1 -1
  43. package/dist/lib/cjs/Transformers/GroupTransformer.cjs +4 -6
  44. package/dist/lib/cjs/Transformers/Transformer.cjs +1 -1
  45. package/dist/lib/cjs/Transformers/Transformer.d.cts +1 -1
  46. package/dist/lib/cjs/Type.cjs +13 -33
  47. package/dist/lib/cjs/Type.d.cts +52 -73
  48. package/dist/lib/cjs/TypeGuards.cjs +156 -0
  49. package/dist/lib/cjs/TypeGuards.d.cts +47 -0
  50. package/dist/lib/cjs/codemirror/StateFieldSpec.cjs +1 -1
  51. package/dist/lib/cjs/index.cjs +4 -1
  52. package/dist/lib/cjs/index.d.cts +1 -0
  53. package/dist/lib/cjs/obsidian/App.cjs +1 -1
  54. package/dist/lib/cjs/obsidian/AsyncWithNotice.cjs +1 -1
  55. package/dist/lib/cjs/obsidian/AsyncWithNotice.d.cts +11 -11
  56. package/dist/lib/cjs/obsidian/AttachmentPath.cjs +1 -1
  57. package/dist/lib/cjs/obsidian/AttachmentPath.d.cts +23 -23
  58. package/dist/lib/cjs/obsidian/Backlink.cjs +3 -3
  59. package/dist/lib/cjs/obsidian/Backlink.d.cts +6 -6
  60. package/dist/lib/cjs/obsidian/Callout.cjs +3 -3
  61. package/dist/lib/cjs/obsidian/Callout.d.cts +6 -6
  62. package/dist/lib/cjs/obsidian/CodeBlockMarkdownInformation.cjs +1 -1
  63. package/dist/lib/cjs/obsidian/Commands/AbstractFileCommandBase.cjs +1 -1
  64. package/dist/lib/cjs/obsidian/Commands/AbstractFileCommandBase.d.cts +7 -7
  65. package/dist/lib/cjs/obsidian/Commands/CommandBase.cjs +3 -4
  66. package/dist/lib/cjs/obsidian/Commands/CommandBase.d.cts +4 -4
  67. package/dist/lib/cjs/obsidian/Commands/EditorCommandBase.cjs +1 -1
  68. package/dist/lib/cjs/obsidian/Commands/EditorCommandBase.d.cts +4 -4
  69. package/dist/lib/cjs/obsidian/Commands/FileCommandBase.cjs +1 -1
  70. package/dist/lib/cjs/obsidian/Commands/FolderCommandBase.cjs +1 -1
  71. package/dist/lib/cjs/obsidian/Commands/NonEditorCommandBase.cjs +1 -1
  72. package/dist/lib/cjs/obsidian/Components/SettingComponents/CodeHighlighterComponent.cjs +13 -2
  73. package/dist/lib/cjs/obsidian/Components/SettingComponents/CodeHighlighterComponent.d.cts +5 -0
  74. package/dist/lib/cjs/obsidian/Components/SettingComponents/MultipleDropdownComponent.cjs +13 -2
  75. package/dist/lib/cjs/obsidian/Components/SettingComponents/MultipleDropdownComponent.d.cts +5 -0
  76. package/dist/lib/cjs/obsidian/Components/SettingComponents/MultipleTextComponent.cjs +13 -2
  77. package/dist/lib/cjs/obsidian/Components/SettingComponents/MultipleTextComponent.d.cts +5 -0
  78. package/dist/lib/cjs/obsidian/Components/SettingComponents/SettingComponentWrapper.cjs +3 -4
  79. package/dist/lib/cjs/obsidian/Components/SettingComponents/TypedDropdownComponent.cjs +13 -2
  80. package/dist/lib/cjs/obsidian/Components/SettingComponents/TypedDropdownComponent.d.cts +5 -0
  81. package/dist/lib/cjs/obsidian/Components/SettingComponents/TypedMultipleDropdownComponent.cjs +13 -2
  82. package/dist/lib/cjs/obsidian/Components/SettingComponents/TypedMultipleDropdownComponent.d.cts +5 -0
  83. package/dist/lib/cjs/obsidian/Components/SettingComponents/ValueComponentWithChangeTracking.cjs +1 -1
  84. package/dist/lib/cjs/obsidian/Dataview.cjs +3 -2
  85. package/dist/lib/cjs/obsidian/Dataview.d.cts +15 -15
  86. package/dist/lib/cjs/obsidian/FileChange.cjs +1 -1
  87. package/dist/lib/cjs/obsidian/FileSystem.cjs +12 -10
  88. package/dist/lib/cjs/obsidian/Frontmatter.cjs +1 -1
  89. package/dist/lib/cjs/obsidian/Frontmatter.d.cts +1 -1
  90. package/dist/lib/cjs/obsidian/Link.cjs +23 -14
  91. package/dist/lib/cjs/obsidian/Link.d.cts +58 -58
  92. package/dist/lib/cjs/obsidian/Loop.cjs +3 -1
  93. package/dist/lib/cjs/obsidian/Loop.d.cts +11 -11
  94. package/dist/lib/cjs/obsidian/Markdown.cjs +3 -4
  95. package/dist/lib/cjs/obsidian/Markdown.d.cts +6 -6
  96. package/dist/lib/cjs/obsidian/MarkdownCodeBlockProcessor.cjs +4 -7
  97. package/dist/lib/cjs/obsidian/MarkdownCodeBlockProcessor.d.cts +12 -12
  98. package/dist/lib/cjs/obsidian/MetadataCache.cjs +3 -5
  99. package/dist/lib/cjs/obsidian/MetadataCache.d.cts +1 -1
  100. package/dist/lib/cjs/obsidian/Modals/Alert.cjs +1 -1
  101. package/dist/lib/cjs/obsidian/Modals/Alert.d.cts +5 -5
  102. package/dist/lib/cjs/obsidian/Modals/Confirm.cjs +1 -1
  103. package/dist/lib/cjs/obsidian/Modals/Confirm.d.cts +6 -6
  104. package/dist/lib/cjs/obsidian/Modals/Prompt.cjs +1 -1
  105. package/dist/lib/cjs/obsidian/Modals/Prompt.d.cts +7 -7
  106. package/dist/lib/cjs/obsidian/Modals/SelectItem.cjs +1 -1
  107. package/dist/lib/cjs/obsidian/Modals/SelectItem.d.cts +5 -5
  108. package/dist/lib/cjs/obsidian/MonkeyAround.cjs +1 -1
  109. package/dist/lib/cjs/obsidian/Pdf.cjs +1 -1
  110. package/dist/lib/cjs/obsidian/Pdf.d.cts +8 -8
  111. package/dist/lib/cjs/obsidian/Plugin/ObsidianPluginRepoPaths.cjs +3 -1
  112. package/dist/lib/cjs/obsidian/Plugin/ObsidianPluginRepoPaths.d.cts +4 -0
  113. package/dist/lib/cjs/obsidian/Plugin/PathSettings.cjs +5 -1
  114. package/dist/lib/cjs/obsidian/Plugin/PluginBase.cjs +1 -1
  115. package/dist/lib/cjs/obsidian/Plugin/PluginSettingsManagerBase.cjs +1 -1
  116. package/dist/lib/cjs/obsidian/Plugin/PluginSettingsManagerBase.d.cts +1 -1
  117. package/dist/lib/cjs/obsidian/Plugin/PluginSettingsTabBase.cjs +1 -1
  118. package/dist/lib/cjs/obsidian/Plugin/PluginSettingsTabBase.d.cts +6 -6
  119. package/dist/lib/cjs/obsidian/Plugin/PluginSettingsWrapper.cjs +1 -1
  120. package/dist/lib/cjs/obsidian/Plugin/PluginTypesBase.cjs +1 -1
  121. package/dist/lib/cjs/obsidian/Queue.cjs +1 -1
  122. package/dist/lib/cjs/obsidian/Queue.d.cts +14 -14
  123. package/dist/lib/cjs/obsidian/React/AppContext.cjs +3 -6
  124. package/dist/lib/cjs/obsidian/Reference.cjs +1 -1
  125. package/dist/lib/cjs/obsidian/RenameDeleteHandler.cjs +1 -1
  126. package/dist/lib/cjs/obsidian/Vault.cjs +1 -1
  127. package/dist/lib/cjs/obsidian/Vault.d.cts +3 -3
  128. package/dist/lib/cjs/obsidian/VaultEx.cjs +1 -1
  129. package/dist/lib/cjs/obsidian/i18n/CustomTypeOptionsBase.cjs +1 -1
  130. package/dist/lib/cjs/obsidian/i18n/DefaultTranslationsBase.cjs +1 -1
  131. package/dist/lib/cjs/obsidian/i18n/i18n.cjs +13 -3
  132. package/dist/lib/esm/Async.d.mts +28 -19
  133. package/dist/lib/esm/Async.mjs +4 -2
  134. package/dist/lib/esm/Blob.mjs +3 -4
  135. package/dist/lib/esm/Debug.mjs +1 -1
  136. package/dist/lib/esm/Enum.mjs +4 -11
  137. package/dist/lib/esm/Error.mjs +5 -4
  138. package/dist/lib/esm/Library.mjs +1 -1
  139. package/dist/lib/esm/ObjectUtils.d.mts +17 -13
  140. package/dist/lib/esm/ObjectUtils.mjs +18 -11
  141. package/dist/lib/esm/RegExp.mjs +3 -1
  142. package/dist/lib/esm/ScriptUtils/ESLint/ESLint.mjs +3 -4
  143. package/dist/lib/esm/ScriptUtils/ESLint/eslint.config.mjs +4 -2
  144. package/dist/lib/esm/ScriptUtils/Exec.d.mts +6 -6
  145. package/dist/lib/esm/ScriptUtils/Exec.mjs +1 -1
  146. package/dist/lib/esm/ScriptUtils/Fs.d.mts +7 -7
  147. package/dist/lib/esm/ScriptUtils/Fs.mjs +1 -1
  148. package/dist/lib/esm/ScriptUtils/JSON.d.mts +1 -1
  149. package/dist/lib/esm/ScriptUtils/JSON.mjs +1 -1
  150. package/dist/lib/esm/ScriptUtils/NodeModules.mjs +1 -1
  151. package/dist/lib/esm/ScriptUtils/Npm.d.mts +2 -2
  152. package/dist/lib/esm/ScriptUtils/Npm.mjs +5 -5
  153. package/dist/lib/esm/ScriptUtils/NpmRun.d.mts +7 -0
  154. package/dist/lib/esm/ScriptUtils/NpmRun.mjs +10 -2
  155. package/dist/lib/esm/ScriptUtils/cli.mjs +1 -1
  156. package/dist/lib/esm/ScriptUtils/esbuild/Dependency.mjs +3 -3
  157. package/dist/lib/esm/ScriptUtils/esbuild/ObsidianPluginBuilder.d.mts +4 -4
  158. package/dist/lib/esm/ScriptUtils/esbuild/ObsidianPluginBuilder.mjs +11 -11
  159. package/dist/lib/esm/ScriptUtils/esbuild/changeExtensionPlugin.mjs +1 -1
  160. package/dist/lib/esm/ScriptUtils/esbuild/copyToObsidianPluginsFolderPlugin.mjs +1 -1
  161. package/dist/lib/esm/ScriptUtils/esbuild/customEsbuildOptionsPlugin.mjs +1 -1
  162. package/dist/lib/esm/ScriptUtils/esbuild/fixEsmPlugin.mjs +1 -1
  163. package/dist/lib/esm/ScriptUtils/esbuild/fixSourceMapsPlugin.mjs +1 -1
  164. package/dist/lib/esm/ScriptUtils/esbuild/preprocessPlugin.mjs +1 -1
  165. package/dist/lib/esm/ScriptUtils/esbuild/renameCssPlugin.mjs +1 -1
  166. package/dist/lib/esm/ScriptUtils/esbuild/svelteWrapperPlugin.mjs +1 -1
  167. package/dist/lib/esm/ScriptUtils/format.mjs +4 -7
  168. package/dist/lib/esm/ScriptUtils/markdownlint/markdownlint-cli2-config.mjs +1 -1
  169. package/dist/lib/esm/ScriptUtils/markdownlint/markdownlint.mjs +3 -4
  170. package/dist/lib/esm/ScriptUtils/version.mjs +19 -11
  171. package/dist/lib/esm/String.mjs +1 -1
  172. package/dist/lib/esm/Transformers/GroupTransformer.mjs +7 -6
  173. package/dist/lib/esm/Transformers/Transformer.d.mts +1 -1
  174. package/dist/lib/esm/Transformers/Transformer.mjs +1 -1
  175. package/dist/lib/esm/Type.d.mts +52 -73
  176. package/dist/lib/esm/Type.mjs +12 -30
  177. package/dist/lib/esm/TypeGuards.d.mts +47 -0
  178. package/dist/lib/esm/TypeGuards.mjs +47 -0
  179. package/dist/lib/esm/index.d.mts +1 -0
  180. package/dist/lib/esm/index.mjs +3 -1
  181. package/dist/lib/esm/obsidian/App.mjs +1 -1
  182. package/dist/lib/esm/obsidian/AsyncWithNotice.d.mts +11 -11
  183. package/dist/lib/esm/obsidian/AsyncWithNotice.mjs +1 -1
  184. package/dist/lib/esm/obsidian/AttachmentPath.d.mts +23 -23
  185. package/dist/lib/esm/obsidian/AttachmentPath.mjs +1 -1
  186. package/dist/lib/esm/obsidian/Backlink.d.mts +6 -6
  187. package/dist/lib/esm/obsidian/Backlink.mjs +3 -3
  188. package/dist/lib/esm/obsidian/Callout.d.mts +6 -6
  189. package/dist/lib/esm/obsidian/Callout.mjs +3 -3
  190. package/dist/lib/esm/obsidian/Commands/AbstractFileCommandBase.d.mts +7 -7
  191. package/dist/lib/esm/obsidian/Commands/AbstractFileCommandBase.mjs +1 -1
  192. package/dist/lib/esm/obsidian/Commands/CommandBase.d.mts +4 -4
  193. package/dist/lib/esm/obsidian/Commands/CommandBase.mjs +3 -4
  194. package/dist/lib/esm/obsidian/Commands/EditorCommandBase.d.mts +4 -4
  195. package/dist/lib/esm/obsidian/Commands/EditorCommandBase.mjs +1 -1
  196. package/dist/lib/esm/obsidian/Commands/FileCommandBase.mjs +1 -1
  197. package/dist/lib/esm/obsidian/Commands/FolderCommandBase.mjs +1 -1
  198. package/dist/lib/esm/obsidian/Commands/NonEditorCommandBase.mjs +1 -1
  199. package/dist/lib/esm/obsidian/Components/SettingComponents/CodeHighlighterComponent.d.mts +5 -0
  200. package/dist/lib/esm/obsidian/Components/SettingComponents/CodeHighlighterComponent.mjs +13 -2
  201. package/dist/lib/esm/obsidian/Components/SettingComponents/MultipleDropdownComponent.d.mts +5 -0
  202. package/dist/lib/esm/obsidian/Components/SettingComponents/MultipleDropdownComponent.mjs +13 -2
  203. package/dist/lib/esm/obsidian/Components/SettingComponents/MultipleTextComponent.d.mts +5 -0
  204. package/dist/lib/esm/obsidian/Components/SettingComponents/MultipleTextComponent.mjs +13 -2
  205. package/dist/lib/esm/obsidian/Components/SettingComponents/SettingComponentWrapper.mjs +3 -4
  206. package/dist/lib/esm/obsidian/Components/SettingComponents/TypedDropdownComponent.d.mts +5 -0
  207. package/dist/lib/esm/obsidian/Components/SettingComponents/TypedDropdownComponent.mjs +13 -2
  208. package/dist/lib/esm/obsidian/Components/SettingComponents/TypedMultipleDropdownComponent.d.mts +5 -0
  209. package/dist/lib/esm/obsidian/Components/SettingComponents/TypedMultipleDropdownComponent.mjs +13 -2
  210. package/dist/lib/esm/obsidian/Dataview.d.mts +15 -15
  211. package/dist/lib/esm/obsidian/Dataview.mjs +4 -6
  212. package/dist/lib/esm/obsidian/FileChange.mjs +1 -1
  213. package/dist/lib/esm/obsidian/FileSystem.mjs +12 -10
  214. package/dist/lib/esm/obsidian/Frontmatter.d.mts +1 -1
  215. package/dist/lib/esm/obsidian/Frontmatter.mjs +1 -1
  216. package/dist/lib/esm/obsidian/Link.d.mts +58 -58
  217. package/dist/lib/esm/obsidian/Link.mjs +26 -14
  218. package/dist/lib/esm/obsidian/Loop.d.mts +11 -11
  219. package/dist/lib/esm/obsidian/Loop.mjs +3 -1
  220. package/dist/lib/esm/obsidian/Markdown.d.mts +6 -6
  221. package/dist/lib/esm/obsidian/Markdown.mjs +3 -4
  222. package/dist/lib/esm/obsidian/MarkdownCodeBlockProcessor.d.mts +12 -12
  223. package/dist/lib/esm/obsidian/MarkdownCodeBlockProcessor.mjs +4 -7
  224. package/dist/lib/esm/obsidian/MetadataCache.d.mts +1 -1
  225. package/dist/lib/esm/obsidian/MetadataCache.mjs +3 -5
  226. package/dist/lib/esm/obsidian/Modals/Alert.d.mts +5 -5
  227. package/dist/lib/esm/obsidian/Modals/Alert.mjs +1 -1
  228. package/dist/lib/esm/obsidian/Modals/Confirm.d.mts +6 -6
  229. package/dist/lib/esm/obsidian/Modals/Confirm.mjs +1 -1
  230. package/dist/lib/esm/obsidian/Modals/Prompt.d.mts +7 -7
  231. package/dist/lib/esm/obsidian/Modals/Prompt.mjs +1 -1
  232. package/dist/lib/esm/obsidian/Modals/SelectItem.d.mts +5 -5
  233. package/dist/lib/esm/obsidian/Modals/SelectItem.mjs +1 -1
  234. package/dist/lib/esm/obsidian/MonkeyAround.mjs +1 -1
  235. package/dist/lib/esm/obsidian/Pdf.d.mts +8 -8
  236. package/dist/lib/esm/obsidian/Pdf.mjs +1 -1
  237. package/dist/lib/esm/obsidian/Plugin/ObsidianPluginRepoPaths.d.mts +4 -0
  238. package/dist/lib/esm/obsidian/Plugin/ObsidianPluginRepoPaths.mjs +3 -1
  239. package/dist/lib/esm/obsidian/Plugin/PathSettings.mjs +5 -1
  240. package/dist/lib/esm/obsidian/Plugin/PluginBase.mjs +1 -1
  241. package/dist/lib/esm/obsidian/Plugin/PluginSettingsManagerBase.d.mts +1 -1
  242. package/dist/lib/esm/obsidian/Plugin/PluginSettingsManagerBase.mjs +1 -1
  243. package/dist/lib/esm/obsidian/Plugin/PluginSettingsTabBase.d.mts +6 -6
  244. package/dist/lib/esm/obsidian/Plugin/PluginSettingsTabBase.mjs +1 -1
  245. package/dist/lib/esm/obsidian/Queue.d.mts +14 -14
  246. package/dist/lib/esm/obsidian/Queue.mjs +1 -1
  247. package/dist/lib/esm/obsidian/React/AppContext.mjs +3 -6
  248. package/dist/lib/esm/obsidian/Reference.mjs +1 -1
  249. package/dist/lib/esm/obsidian/RenameDeleteHandler.mjs +1 -1
  250. package/dist/lib/esm/obsidian/Vault.d.mts +3 -3
  251. package/dist/lib/esm/obsidian/Vault.mjs +1 -1
  252. package/dist/lib/esm/obsidian/VaultEx.mjs +1 -1
  253. package/dist/lib/esm/obsidian/i18n/CustomTypeOptionsBase.mjs +1 -1
  254. package/dist/lib/esm/obsidian/i18n/DefaultTranslationsBase.mjs +1 -1
  255. package/dist/lib/esm/obsidian/i18n/i18n.mjs +2 -3
  256. package/dist/scripts/examples/format.prettier.ts +2 -3
  257. package/package.json +10 -2
@@ -133,6 +133,7 @@ __export(Error_exports, {
133
133
  });
134
134
  module.exports = __toCommonJS(Error_exports);
135
135
  var import_AsyncEvents = require('./AsyncEvents.cjs');
136
+ var import_TypeGuards = require('./TypeGuards.cjs');
136
137
  const ASYNC_ERROR_EVENT = "asyncError";
137
138
  const asyncErrorEventEmitter = new import_AsyncEvents.AsyncEvents();
138
139
  asyncErrorEventEmitter.on(ASYNC_ERROR_EVENT, handleAsyncError);
@@ -159,10 +160,10 @@ class CustomStackTraceError extends Error {
159
160
  parentCauses.add(rootCause);
160
161
  rootCause = rootCause.cause;
161
162
  }
162
- const originalStackLines = (this.stack ?? "").split("\n");
163
+ const originalStackLines = (0, import_TypeGuards.ensureNonNullable)(this.stack).split("\n");
163
164
  const stackLines = stackTrace.split("\n");
164
165
  const ERROR_HEADER_REG_EXP = /^\w*Error(?:: |$)/;
165
- if (ERROR_HEADER_REG_EXP.test(stackLines[0] ?? "")) {
166
+ if (ERROR_HEADER_REG_EXP.test((0, import_TypeGuards.ensureNonNullable)(stackLines[0]))) {
166
167
  stackLines.splice(0, 1);
167
168
  }
168
169
  originalStackLines.splice(1, originalStackLines.length - 1, ...stackLines);
@@ -206,7 +207,7 @@ ${generateStackTraceLine(line)}`;
206
207
  }
207
208
  function getStackTrace(framesToSkip = 0) {
208
209
  const ADDITIONAL_FRAMES_TO_SKIP = 2;
209
- const stack = new Error().stack ?? "";
210
+ const stack = (0, import_TypeGuards.ensureNonNullable)(new Error().stack);
210
211
  const lines = stack.split("\n");
211
212
  return lines.slice(framesToSkip + ADDITIONAL_FRAMES_TO_SKIP).join("\n");
212
213
  }
@@ -241,4 +242,4 @@ function handleAsyncError(asyncError) {
241
242
  registerAsyncErrorEventHandler,
242
243
  throwExpression
243
244
  });
244
- //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../src/Error.ts"],
  "sourcesContent": ["/**\n * @packageDocumentation\n *\n * Contains utility functions for error handling.\n */\n\nimport { AsyncEvents } from './AsyncEvents.ts';\n\nconst ASYNC_ERROR_EVENT = 'asyncError';\n\nconst asyncErrorEventEmitter = new AsyncEvents();\nasyncErrorEventEmitter.on(ASYNC_ERROR_EVENT, handleAsyncError);\n\n/**\n * A message of the AsyncWrapperError.\n */\nexport const ASYNC_WRAPPER_ERROR_MESSAGE = 'An unhandled error occurred executing async operation';\n\nconst STACK_TRACE_PREFIX = '    at';\n\n/**\n * An error that wraps an error with a custom stack trace.\n */\nexport class CustomStackTraceError extends Error {\n  /**\n   * Creates a new CustomStackTraceError.\n   *\n   * @param message - The message of the error.\n   * @param stackTrace - The stack trace of the error.\n   * @param cause - The cause of the error.\n   */\n  public constructor(message: string, stackTrace: string, cause: unknown) {\n    super(message, { cause });\n    this.name = 'CustomStackTraceError';\n\n    // eslint-disable-next-line @typescript-eslint/no-unnecessary-condition -- `?.` is used to support iOS before 17.2\n    Error.captureStackTrace?.(this, CustomStackTraceError);\n\n    let rootCause = cause;\n    const parentCauses = new Set<CustomStackTraceError>();\n    while (rootCause instanceof CustomStackTraceError) {\n      if (parentCauses.has(rootCause)) {\n        throw new Error('Circular cause detected');\n      }\n      parentCauses.add(rootCause);\n      rootCause = rootCause.cause;\n    }\n\n    const originalStackLines = (this.stack ?? '').split('\\n');\n    const stackLines = stackTrace.split('\\n');\n    const ERROR_HEADER_REG_EXP = /^\\w*Error(?:: |$)/;\n    if (ERROR_HEADER_REG_EXP.test(stackLines[0] ?? '')) {\n      stackLines.splice(0, 1);\n    }\n    originalStackLines.splice(1, originalStackLines.length - 1, ...stackLines);\n    this.stack = originalStackLines.join('\\n');\n  }\n}\n\n/**\n * An error that is not printed to the console.\n */\nexport class SilentError extends Error {\n  /**\n   * Creates a new SilentError.\n   *\n   * @param message - The message of the error.\n   */\n  public constructor(message: string) {\n    super(message);\n    this.name = 'SilentError';\n\n    // eslint-disable-next-line @typescript-eslint/no-unnecessary-condition -- `?.` is used to support iOS before 17.2\n    Error.captureStackTrace?.(this, SilentError);\n  }\n}\n\n/**\n * Emits an asynchronous error event.\n *\n * @param asyncError - The error to emit as an asynchronous error event.\n */\nexport function emitAsyncErrorEvent(asyncError: unknown): void {\n  asyncErrorEventEmitter.trigger(ASYNC_ERROR_EVENT, asyncError);\n}\n\n/**\n * Converts an error to a string representation, including nested causes with indentation.\n *\n * @param error - The error to convert to a string.\n * @returns The string representation of the error.\n */\nexport function errorToString(error: unknown): string {\n  if (!(error instanceof Error)) {\n    return String(error);\n  }\n\n  let message = error.stack ?? `${error.name}: ${error.message}`;\n  if (error.cause !== undefined) {\n    const causeStrLines = errorToString(error.cause).split('\\n');\n    message += `\\n${generateStackTraceLine('Caused by:')}`;\n    for (const line of causeStrLines) {\n      if (!line.trim()) {\n        continue;\n      }\n      message += line.startsWith(STACK_TRACE_PREFIX)\n        ? `\\n${line}`\n        : `\\n${generateStackTraceLine(line)}`;\n    }\n  }\n  return message;\n}\n\n/**\n * Gets the current stack trace as a string, excluding the current function call.\n *\n * @param framesToSkip - The number of frames to skip in the stack trace.\n * @returns A string representation of the current stack trace, excluding the current function call.\n */\nexport function getStackTrace(framesToSkip = 0): string {\n  // Skipping Error prefix and `getStackTrace` function call\n  const ADDITIONAL_FRAMES_TO_SKIP = 2;\n  const stack = new Error().stack ?? '';\n  const lines = stack.split('\\n');\n  return lines.slice(framesToSkip + ADDITIONAL_FRAMES_TO_SKIP).join('\\n');\n}\n\n/**\n * Prints an error to the console, including nested causes and optional ANSI sequence clearing.\n *\n * @param error - The error to print.\n * @param console - The console to print to (default: `globalThis.console`).\n */\nexport function printError(error: unknown, console?: Console): void {\n  console ??= globalThis.console;\n  console.error(errorToString(error));\n}\n\n/**\n * Registers an event handler for asynchronous errors.\n *\n * @param handler - The handler function to be called when an asynchronous error event occurs.\n * @returns A function to unregister the handler.\n */\nexport function registerAsyncErrorEventHandler(handler: (asyncError: unknown) => void): () => void {\n  const eventRef = asyncErrorEventEmitter.on(ASYNC_ERROR_EVENT, handler);\n  return () => {\n    asyncErrorEventEmitter.offref(eventRef);\n  };\n}\n\n/**\n * Throws an error with the specified message.\n *\n * @param error - The error to throw.\n * @throws\n */\nexport function throwExpression(error: unknown): never {\n  throw error;\n}\n\nfunction generateStackTraceLine(title: string): string {\n  return `${STACK_TRACE_PREFIX} --- ${title} --- (0)`;\n}\n\n/**\n * Handles asynchronous errors by printing them.\n *\n * @param asyncError - The asynchronous error to handle.\n */\nfunction handleAsyncError(asyncError: unknown): void {\n  printError(asyncError);\n}\n"],
  "mappings": "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",
  "names": []
}

245
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../src/Error.ts"],
  "sourcesContent": ["/**\n * @packageDocumentation\n *\n * Contains utility functions for error handling.\n */\n\nimport { AsyncEvents } from './AsyncEvents.ts';\nimport { ensureNonNullable } from './TypeGuards.ts';\n\nconst ASYNC_ERROR_EVENT = 'asyncError';\n\nconst asyncErrorEventEmitter = new AsyncEvents();\nasyncErrorEventEmitter.on(ASYNC_ERROR_EVENT, handleAsyncError);\n\n/**\n * A message of the AsyncWrapperError.\n */\nexport const ASYNC_WRAPPER_ERROR_MESSAGE = 'An unhandled error occurred executing async operation';\n\nconst STACK_TRACE_PREFIX = '    at';\n\n/**\n * An error that wraps an error with a custom stack trace.\n */\nexport class CustomStackTraceError extends Error {\n  /**\n   * Creates a new CustomStackTraceError.\n   *\n   * @param message - The message of the error.\n   * @param stackTrace - The stack trace of the error.\n   * @param cause - The cause of the error.\n   */\n  public constructor(message: string, stackTrace: string, cause: unknown) {\n    super(message, { cause });\n    this.name = 'CustomStackTraceError';\n\n    // eslint-disable-next-line @typescript-eslint/no-unnecessary-condition -- `?.` is used to support iOS before 17.2.\n    Error.captureStackTrace?.(this, CustomStackTraceError);\n\n    let rootCause = cause;\n    const parentCauses = new Set<CustomStackTraceError>();\n    while (rootCause instanceof CustomStackTraceError) {\n      if (parentCauses.has(rootCause)) {\n        throw new Error('Circular cause detected');\n      }\n      parentCauses.add(rootCause);\n      rootCause = rootCause.cause;\n    }\n\n    const originalStackLines = ensureNonNullable(this.stack).split('\\n');\n    const stackLines = stackTrace.split('\\n');\n    const ERROR_HEADER_REG_EXP = /^\\w*Error(?:: |$)/;\n    if (ERROR_HEADER_REG_EXP.test(ensureNonNullable(stackLines[0]))) {\n      stackLines.splice(0, 1);\n    }\n    originalStackLines.splice(1, originalStackLines.length - 1, ...stackLines);\n    this.stack = originalStackLines.join('\\n');\n  }\n}\n\n/**\n * An error that is not printed to the console.\n */\nexport class SilentError extends Error {\n  /**\n   * Creates a new SilentError.\n   *\n   * @param message - The message of the error.\n   */\n  public constructor(message: string) {\n    super(message);\n    this.name = 'SilentError';\n\n    // eslint-disable-next-line @typescript-eslint/no-unnecessary-condition -- `?.` is used to support iOS before 17.2.\n    Error.captureStackTrace?.(this, SilentError);\n  }\n}\n\n/**\n * Emits an asynchronous error event.\n *\n * @param asyncError - The error to emit as an asynchronous error event.\n */\nexport function emitAsyncErrorEvent(asyncError: unknown): void {\n  asyncErrorEventEmitter.trigger(ASYNC_ERROR_EVENT, asyncError);\n}\n\n/**\n * Converts an error to a string representation, including nested causes with indentation.\n *\n * @param error - The error to convert to a string.\n * @returns The string representation of the error.\n */\nexport function errorToString(error: unknown): string {\n  if (!(error instanceof Error)) {\n    return String(error);\n  }\n\n  let message = error.stack ?? `${error.name}: ${error.message}`;\n  if (error.cause !== undefined) {\n    const causeStrLines = errorToString(error.cause).split('\\n');\n    message += `\\n${generateStackTraceLine('Caused by:')}`;\n    for (const line of causeStrLines) {\n      if (!line.trim()) {\n        continue;\n      }\n      message += line.startsWith(STACK_TRACE_PREFIX)\n        ? `\\n${line}`\n        : `\\n${generateStackTraceLine(line)}`;\n    }\n  }\n  return message;\n}\n\n/**\n * Gets the current stack trace as a string, excluding the current function call.\n *\n * @param framesToSkip - The number of frames to skip in the stack trace.\n * @returns A string representation of the current stack trace, excluding the current function call.\n */\nexport function getStackTrace(framesToSkip = 0): string {\n  // Skipping Error prefix and `getStackTrace` function call\n  const ADDITIONAL_FRAMES_TO_SKIP = 2;\n  const stack = ensureNonNullable(new Error().stack);\n  const lines = stack.split('\\n');\n  return lines.slice(framesToSkip + ADDITIONAL_FRAMES_TO_SKIP).join('\\n');\n}\n\n/**\n * Prints an error to the console, including nested causes and optional ANSI sequence clearing.\n *\n * @param error - The error to print.\n * @param console - The console to print to (default: `globalThis.console`).\n */\nexport function printError(error: unknown, console?: Console): void {\n  console ??= globalThis.console;\n  console.error(errorToString(error));\n}\n\n/**\n * Registers an event handler for asynchronous errors.\n *\n * @param handler - The handler function to be called when an asynchronous error event occurs.\n * @returns A function to unregister the handler.\n */\nexport function registerAsyncErrorEventHandler(handler: (asyncError: unknown) => void): () => void {\n  const eventRef = asyncErrorEventEmitter.on(ASYNC_ERROR_EVENT, handler);\n  return () => {\n    asyncErrorEventEmitter.offref(eventRef);\n  };\n}\n\n/**\n * Throws an error with the specified message.\n *\n * @param error - The error to throw.\n * @throws\n */\nexport function throwExpression(error: unknown): never {\n  throw error;\n}\n\nfunction generateStackTraceLine(title: string): string {\n  return `${STACK_TRACE_PREFIX} --- ${title} --- (0)`;\n}\n\n/**\n * Handles asynchronous errors by printing them.\n *\n * @param asyncError - The asynchronous error to handle.\n */\nfunction handleAsyncError(asyncError: unknown): void {\n  printError(asyncError);\n}\n"],
  "mappings": "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",
  "names": []
}

@@ -126,7 +126,7 @@ __export(Library_exports, {
126
126
  LIBRARY_VERSION: () => LIBRARY_VERSION
127
127
  });
128
128
  module.exports = __toCommonJS(Library_exports);
129
- const LIBRARY_VERSION = "48.1.2";
129
+ const LIBRARY_VERSION = "48.1.4";
130
130
  const LIBRARY_NAME = "obsidian-dev-utils";
131
131
  const LIBRARY_STYLES = ".obsidian-dev-utils.code-highlighter-component textarea, .obsidian-dev-utils.code-highlighter-component pre, .obsidian-dev-utils.code-highlighter-component code {\n font-family: var(--font-monospace);\n line-height: var(--line-height-normal);\n margin: 0;\n}\n.obsidian-dev-utils.code-highlighter-component textarea, .obsidian-dev-utils.code-highlighter-component code {\n font-size: var(--code-size);\n}\n.obsidian-dev-utils.code-highlighter-component textarea {\n background: transparent;\n color: transparent;\n z-index: 2;\n width: 20em;\n height: 10em;\n}\n.obsidian-dev-utils.code-highlighter-component pre {\n position: absolute;\n pointer-events: none;\n border: var(--input-border-width) solid transparent;\n overflow: auto;\n inset: 0;\n padding: var(--size-4-1) var(--size-4-2);\n z-index: 1;\n}\n.obsidian-dev-utils.code-highlighter-component pre::after {\n content: \"\";\n display: block;\n height: var(--bottom-gap, 0);\n}\n.obsidian-dev-utils.code-highlighter-component pre.is-placeholder {\n opacity: 0.6;\n}\n.obsidian-dev-utils.code-highlighter-component code {\n display: block;\n padding: 0;\n}\n\n.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=tel],\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=tel]: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=tel]:active,\n.obsidian-dev-utils input[type=tel]: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=tel]:active,\n.obsidian-dev-utils input[type=tel]:focus,\n.obsidian-dev-utils input[type=tel]: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=tel]::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-utilsprogress.loop {\n min-width: 200px;\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 padding-top: 3px;\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.plugin-settings-tab a:focus {\n outline: 2px solid var(--link-color);\n}\n\n.obsidian-dev-utils.prompt-modal .text-box {\n width: 100%;\n}\n\n.obsidian-dev-utils.tri-state-checkbox-component input[type=checkbox]:indeterminate {\n appearance: checkbox;\n}\n\n.obsidian-dev-utils :invalid {\n box-shadow: 0 0 0 2px var(--text-error);\n}\n.obsidian-dev-utils input.metadata-input-text:active:invalid, .obsidian-dev-utils input.metadata-input-text:focus-visible:invalid, .obsidian-dev-utils input.metadata-input-text:focus:invalid,\n.obsidian-dev-utils input[type=date]:active:invalid,\n.obsidian-dev-utils input[type=date]:focus-visible:invalid,\n.obsidian-dev-utils input[type=date]:focus:invalid,\n.obsidian-dev-utils input[type=datetime-local]:active:invalid,\n.obsidian-dev-utils input[type=datetime-local]:focus-visible:invalid,\n.obsidian-dev-utils input[type=datetime-local]:focus:invalid,\n.obsidian-dev-utils input[type=email]:active:invalid,\n.obsidian-dev-utils input[type=email]:focus-visible:invalid,\n.obsidian-dev-utils input[type=email]:focus:invalid,\n.obsidian-dev-utils input[type=number]:active:invalid,\n.obsidian-dev-utils input[type=number]:focus-visible:invalid,\n.obsidian-dev-utils input[type=number]:focus:invalid,\n.obsidian-dev-utils input[type=password]:active:invalid,\n.obsidian-dev-utils input[type=password]:focus-visible:invalid,\n.obsidian-dev-utils input[type=password]:focus:invalid,\n.obsidian-dev-utils input[type=search]:active:invalid,\n.obsidian-dev-utils input[type=search]:focus-visible:invalid,\n.obsidian-dev-utils input[type=search]:focus:invalid,\n.obsidian-dev-utils input[type=text]:active:invalid,\n.obsidian-dev-utils input[type=text]:focus-visible:invalid,\n.obsidian-dev-utils input[type=text]:focus:invalid,\n.obsidian-dev-utils textarea:active:invalid,\n.obsidian-dev-utils textarea:focus-visible:invalid,\n.obsidian-dev-utils textarea:focus:invalid {\n box-shadow: 0 0 0 2px var(--text-error);\n}\n.obsidian-dev-utils.setting-component-wrapper {\n position: relative;\n display: inline-flex;\n}\n.obsidian-dev-utils.overlay-validator {\n caret-color: transparent;\n cursor: default;\n position: absolute;\n background-color: transparent;\n border: none;\n outline: none;\n pointer-events: none;\n z-index: 9999;\n left: 0;\n top: 0;\n width: 100%;\n height: 100%;\n}\n.obsidian-dev-utils.tooltip.tooltip-validator {\n position: absolute;\n top: calc(100% + 8px);\n width: max-content;\n}\n\n/*# sourceMappingURL=data:application/json;charset=utf-8,%7B%22version%22:3,%22sourceRoot%22:%22%22,%22sources%22:%5B%22../src/styles/code-highlighter-component.scss%22,%22../src/styles/input.scss%22,%22../src/styles/input-time.scss%22,%22../src/styles/loop.scss%22,%22../src/styles/modal-container.scss%22,%22../src/styles/multiple-dropdown-component.scss%22,%22../src/styles/plugin-settings-tab.scss%22,%22../src/styles/prompt-modal.scss%22,%22../src/styles/tri-state-checkbox-component.scss%22,%22../src/styles/validation.scss%22%5D,%22names%22:%5B%5D,%22mappings%22:%22AAEI;EACE;EACA;EACA;;AAGF;EACE;;AAGF;EACE;EACA;EACA;EACA;EACA;;AAGF;EACE;EACA;EACA;EACA;EACA;EACA;EACA;;AAGF;EACE;EACA;EACA;;AAGF;EACE;;AAGF;EACE;EACA;;;ACzCJ;EACE;;AAGF;AAAA;AAAA;AAAA;AAAA;EAKE;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;AAGE;EACE;AAAA;AAAA;AAAA;AAAA;IACE;IACA,YACE;;;AAMR;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;EAEE;EACA,YACE;;AAIJ;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;EAGE;;AAGF;AAAA;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;;;AC7DV;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;;;ACjDJ;EACE;;;ACAA;EACE;EACA;;;ACFF;AAAA;AAAA;EAGE;EACA;;AAEA;AAAA;AAAA;EACE;EACA;;;ACRJ;EACE;;;ACDF;EACE;;;ACDF;EACE;;;ACEJ;EAJA;;AAoBI;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;EApBJ;;AA0BA;EACE;EACA;;AAGF;EACE;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;AAGF;EACE;EACA;EACA%22,%22file%22:%22styles.css%22,%22sourcesContent%22:%5B%22.obsidian-dev-utils%20%7B%5Cn%20%20&.code-highlighter-component%20%7B%5Cn%20%20%20%20textarea,%20pre,%20code%20%7B%5Cn%20%20%20%20%20%20font-family:%20var(--font-monospace);%5Cn%20%20%20%20%20%20line-height:%20var(--line-height-normal);%5Cn%20%20%20%20%20%20margin:%200;%5Cn%20%20%20%20%7D%5Cn%5Cn%20%20%20%20textarea,%20code%20%7B%5Cn%20%20%20%20%20%20font-size:%20var(--code-size);%5Cn%20%20%20%20%7D%5Cn%5Cn%20%20%20%20textarea%20%7B%5Cn%20%20%20%20%20%20background:%20transparent;%5Cn%20%20%20%20%20%20color:%20transparent;%5Cn%20%20%20%20%20%20z-index:%202;%5Cn%20%20%20%20%20%20width:%2020em;%5Cn%20%20%20%20%20%20height:%2010em;%5Cn%20%20%20%20%7D%5Cn%5Cn%20%20%20%20pre%20%7B%5Cn%20%20%20%20%20%20position:%20absolute;%5Cn%20%20%20%20%20%20pointer-events:%20none;%5Cn%20%20%20%20%20%20border:%20var(--input-border-width)%20solid%20transparent;%5Cn%20%20%20%20%20%20overflow:%20auto;%5Cn%20%20%20%20%20%20inset:%200;%5Cn%20%20%20%20%20%20padding:%20var(--size-4-1)%20var(--size-4-2);%5Cn%20%20%20%20%20%20z-index:%201;%5Cn%20%20%20%20%7D%5Cn%5Cn%20%20%20%20pre::after%20%7B%5Cn%20%20%20%20%20%20content:%20%5C%22%5C%22;%5Cn%20%20%20%20%20%20display:%20block;%5Cn%20%20%20%20%20%20height:%20var(--bottom-gap,%200);%5Cn%20%20%20%20%7D%5Cn%5Cn%20%20%20%20pre.is-placeholder%20%7B%5Cn%20%20%20%20%20%20opacity:%200.6;%5Cn%20%20%20%20%7D%5Cn%5Cn%20%20%20%20code%20%7B%5Cn%20%20%20%20%20%20display:%20block;%5Cn%20%20%20%20%20%20padding:%200;%5Cn%20%20%20%20%7D%5Cn%20%20%7D%5Cn%7D%5Cn%22,%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='tel'%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&progress.loop%20%7B%5Cn%20%20%20%20min-width:%20200px;%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%20%20%20%20%20%20padding-top:%203px;%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&.plugin-settings-tab%20%7B%5Cn%20%20%20%20a:focus%20%7B%5Cn%20%20%20%20%20%20outline:%202px%20solid%20var(--link-color);%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%5Cr%5Cn%20%20&.tri-state-checkbox-component%20%7B%5Cr%5Cn%20%20%20%20input%5Btype='checkbox'%5D:indeterminate%20%7B%5Cr%5Cn%20%20%20%20%20%20appearance:%20checkbox;%5Cr%5Cn%20%20%20%20%7D%5Cr%5Cn%20%20%7D%5Cr%5Cn%7D%5Cr%5Cn%22,%22@mixin%20invalid%20%7B%5Cn%20%20box-shadow:%200%200%200%202px%20var(--text-error);%5Cn%7D%5Cn%5Cn.obsidian-dev-utils%20%7B%5Cn%20%20:invalid%20%7B%5Cn%20%20%20%20@include%20invalid;%5Cn%20%20%7D%5Cn%5Cn%20%20input.metadata-input-text,%5Cn%20%20input%5Btype='date'%5D,%5Cn%20%20input%5Btype='datetime-local'%5D,%5Cn%20%20input%5Btype='email'%5D,%5Cn%20%20input%5Btype='number'%5D,%5Cn%20%20input%5Btype='password'%5D,%5Cn%20%20input%5Btype='search'%5D,%5Cn%20%20input%5Btype='text'%5D,%5Cn%20%20textarea%20%7B%5Cn%20%20%20%20&:active,%5Cn%20%20%20%20&:focus-visible,%5Cn%20%20%20%20&:focus%20%7B%5Cn%20%20%20%20%20%20&:invalid%20%7B%5Cn%20%20%20%20%20%20%20%20@include%20invalid;%5Cn%20%20%20%20%20%20%7D%5Cn%20%20%20%20%7D%5Cn%20%20%7D%5Cn%5Cn%20%20&.setting-component-wrapper%20%7B%5Cn%20%20%20%20position:%20relative;%5Cn%20%20%20%20display:%20inline-flex;%5Cn%20%20%7D%5Cn%5Cn%20%20&.overlay-validator%20%7B%5Cn%20%20%20%20caret-color:%20transparent;%5Cn%20%20%20%20cursor:%20default;%5Cn%20%20%20%20position:%20absolute;%5Cn%20%20%20%20background-color:%20transparent;%5Cn%20%20%20%20border:%20none;%5Cn%20%20%20%20outline:%20none;%5Cn%20%20%20%20pointer-events:%20none;%5Cn%20%20%20%20z-index:%209999;%5Cn%20%20%20%20left:%200;%5Cn%20%20%20%20top:%200;%5Cn%20%20%20%20width:%20100%25;%5Cn%20%20%20%20height:%20100%25;%5Cn%20%20%7D%5Cn%5Cn%20%20&.tooltip.tooltip-validator%20%7B%5Cn%20%20%20%20position:%20absolute;%5Cn%20%20%20%20top:%20calc(100%25%20+%208px);%5Cn%20%20%20%20width:%20max-content;%5Cn%20%20%7D%5Cn%7D%5Cn%22%5D%7D */\n";
132
132
  // Annotate the CommonJS export names for ESM import in node:
@@ -123,6 +123,7 @@ var ObjectUtils_exports = {};
123
123
  __export(ObjectUtils_exports, {
124
124
  FunctionHandlingMode: () => FunctionHandlingMode,
125
125
  assignWithNonEnumerableProperties: () => assignWithNonEnumerableProperties,
126
+ castTo: () => castTo,
126
127
  cloneWithNonEnumerableProperties: () => cloneWithNonEnumerableProperties,
127
128
  deepEqual: () => deepEqual,
128
129
  deleteProperties: () => deleteProperties,
@@ -141,6 +142,7 @@ __export(ObjectUtils_exports, {
141
142
  module.exports = __toCommonJS(ObjectUtils_exports);
142
143
  var import_Error = require('./Error.cjs');
143
144
  var import_String = require('./String.cjs');
145
+ var import_TypeGuards = require('./TypeGuards.cjs');
144
146
  var FunctionHandlingMode = /* @__PURE__ */ ((FunctionHandlingMode2) => {
145
147
  FunctionHandlingMode2["Exclude"] = "exclude";
146
148
  FunctionHandlingMode2["Full"] = "full";
@@ -160,6 +162,9 @@ const equalityComparerEntries = createEqualityComparerEntries(
160
162
  function assignWithNonEnumerableProperties(target, ...sources) {
161
163
  return _assignWithNonEnumerableProperties(target, ...sources);
162
164
  }
165
+ function castTo(value) {
166
+ return value;
167
+ }
163
168
  function cloneWithNonEnumerableProperties(obj) {
164
169
  return Object.create(getPrototypeOf(obj), Object.getOwnPropertyDescriptors(obj));
165
170
  }
@@ -186,8 +191,8 @@ function deepEqual(a, b) {
186
191
  if (keysA.length !== keysB.length) {
187
192
  return false;
188
193
  }
189
- const aRecord = a;
190
- const bRecord = b;
194
+ const aRecord = (0, import_TypeGuards.ensureGenericObject)(a);
195
+ const bRecord = (0, import_TypeGuards.ensureGenericObject)(b);
191
196
  for (const key of keysA) {
192
197
  if (!keysB.includes(key) || !deepEqual(aRecord[key], bRecord[key])) {
193
198
  return false;
@@ -290,8 +295,8 @@ function setNestedPropertyValue(obj, path, value) {
290
295
  }
291
296
  node = node[key];
292
297
  }
293
- const lastKey = keys.at(-1);
294
- if (node === void 0 || lastKey === void 0) {
298
+ const lastKey = (0, import_TypeGuards.ensureNonNullable)(keys.at(-1));
299
+ if (node === void 0) {
295
300
  throw error;
296
301
  }
297
302
  node[lastKey] = value;
@@ -327,7 +332,7 @@ function toJson(value, options = {}) {
327
332
  const functionTexts = [];
328
333
  const usedObjects = /* @__PURE__ */ new WeakSet();
329
334
  const plainObject = toPlainObject(value, "", 0, true, fullOptions, functionTexts, usedObjects);
330
- let json = JSON.stringify(plainObject, null, fullOptions.space) ?? "";
335
+ let json = (0, import_TypeGuards.ensureNonNullable)(JSON.stringify(plainObject, null, fullOptions.space));
331
336
  json = (0, import_String.replaceAll)(json, /"\[\[(?<Key>[A-Za-z]+)(?<Index>\d*)\]\]"/g, (_, key, indexStr) => applySubstitutions({
332
337
  functionTexts,
333
338
  index: indexStr ? parseInt(indexStr, 10) : 0,
@@ -361,10 +366,12 @@ function _assignWithNonEnumerableProperties(target, ...sources) {
361
366
  }
362
367
  function applySubstitutions(options) {
363
368
  switch (options.key) {
369
+ /* v8 ignore stop */
364
370
  case "CircularReference" /* CircularReference */:
365
371
  return options.substitutions.circularReference;
366
372
  case "Function" /* Function */:
367
- return options.functionTexts[options.index] ?? (0, import_Error.throwExpression)(new Error(`Function with index ${String(options.index)} not found`));
373
+ return (0, import_TypeGuards.ensureNonNullable)(options.functionTexts[options.index], `Function with index ${String(options.index)} not found`);
374
+ /* v8 ignore stop */
368
375
  case "MaxDepthLimitReached" /* MaxDepthLimitReached */:
369
376
  return options.substitutions.maxDepthLimitReached;
370
377
  case "MaxDepthLimitReachedArray" /* MaxDepthLimitReachedArray */:
@@ -529,6 +536,7 @@ function tryHandleToJSON(value, key, depth, fullOptions, functionTexts, usedObje
529
536
  0 && (module.exports = {
530
537
  FunctionHandlingMode,
531
538
  assignWithNonEnumerableProperties,
539
+ castTo,
532
540
  cloneWithNonEnumerableProperties,
533
541
  deepEqual,
534
542
  deleteProperties,
@@ -544,4 +552,4 @@ function tryHandleToJSON(value, key, depth, fullOptions, functionTexts, usedObje
544
552
  setNestedPropertyValue,
545
553
  toJson
546
554
  });
547
- //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../src/ObjectUtils.ts"],
  "sourcesContent": ["/**\n * @packageDocumentation\n *\n * Contains utility functions for Objects.\n */\n\nimport type {\n  Constructor,\n  RequiredKeysOf,\n  UndefinedOnPartialDeep\n} from 'type-fest';\n\nimport type {\n  ExactMembers,\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 {@link toJson}.\n */\nexport interface ToJsonOptions {\n  /**\n   * Specifies how functions should be handled in the JSON output (default: `exclude`).\n   */\n  functionHandlingMode: FunctionHandlingMode;\n\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  /**\n   * Specifies whether to catch errors in `toJSON()` and replace them with a placeholder.\n   * Defaults to `false`.\n   */\n  shouldCatchToJSONErrors: boolean;\n\n  /**\n   * Specifies whether to handle circular references in the JSON output.\n   * Defaults to `false`.\n   */\n  shouldHandleCircularReferences: boolean;\n\n  /**\n   * Specifies whether to handle errors in the JSON output.\n   * Defaults to `false`.\n   */\n  shouldHandleErrors: boolean;\n\n  /**\n   * Specifies whether to handle undefined values in the JSON output.\n   * Defaults to `false`.\n   */\n  shouldHandleUndefined: boolean;\n\n  /**\n   * Specifies whether to sort the keys of the JSON output.\n   * Defaults to `false`.\n   */\n  shouldSortKeys: boolean;\n\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  /**\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 EqualityComparerEntry<T> {\n  constructor: Constructor<T>;\n  equalityComparer(a: T, b: T): boolean;\n}\n\ninterface JSONSerializable {\n  toJSON(...args: unknown[]): unknown;\n}\n\ninterface ModuleWithDefaultExport<T> {\n  default: T;\n}\n\ninterface TokenSubstitutions {\n  circularReference: string;\n  maxDepthLimitReached: string;\n  toJSONFailed: string;\n}\n\nconst KEY_SEPARATOR = '.';\nconst equalityComparerEntries = createEqualityComparerEntries(\n  [\n    { constructor: ArrayBuffer, equalityComparer: deepEqualArrayBuffer },\n    { constructor: Date, equalityComparer: deepEqualDate },\n    { constructor: RegExp, equalityComparer: deepEqualRegExp },\n    { constructor: Map, equalityComparer: deepEqualMap },\n    { constructor: Set, equalityComparer: deepEqualSet }\n  ] as const\n);\n\n/**\n * A type that represents a generic object.\n */\nexport type GenericObject = Record<string, unknown>;\n\ntype KeysWithUndefined<T> = {\n  [K in keyof T]-?: undefined extends T[K] ? K : never;\n}[keyof T];\n\ntype MandatoryKeysWithUndefined<T extends object> = Extract<RequiredKeysOf<T> & StringKeys<T>, KeysWithUndefined<T>>;\n\ntype RemoveUndefinedOverload<T extends object> = MandatoryKeysWithUndefined<T> extends never ? [obj: T]\n  : never;\n\ntype RemoveUndefinedWithKeysOverload<T extends object, K extends readonly string[]> = [obj: T, keysToKeep: ExactMembers<MandatoryKeysWithUndefined<T>, K>];\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 * @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 * 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 * 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 aConstructor = a.constructor;\n  const bConstructor = b.constructor;\n\n  if (aConstructor !== bConstructor) {\n    return false;\n  }\n\n  if (aConstructor !== Object) {\n    const result = deepEqualTyped(a, b);\n    if (result !== undefined) {\n      return result;\n    }\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 GenericObject;\n  const bRecord = b as GenericObject;\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 -- We have no other way to delete the property.\n  delete obj[propertyName];\n  return true;\n}\n\n/**\n * Extracts the default export from a module.\n *\n * Useful to handle incorrect default export interop between ESM and CJS.\n *\n * @param module - The module to extract the default export from.\n * @returns The default export.\n */\nexport function extractDefaultExportInterop<T>(module: ModuleWithDefaultExport<T> | T): T {\n  if (typeof module !== 'object' || module === null) {\n    return module;\n  }\n\n  if ('default' in module) {\n    return module.default;\n  }\n\n  return module;\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: GenericObject, path: string): unknown {\n  let node: GenericObject | 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 GenericObject | 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 extends object>(name: StringKeys<T>): StringKeys<T> {\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 * Removes all undefined properties from an object when there are no mandatory keys with undefined values.\n *\n * @typeParam Type - The type of the object.\n * @param args - The arguments to the function.\n * @returns The object with all undefined properties removed.\n */\nexport function removeUndefinedProperties<Type extends object>(\n  ...args: RemoveUndefinedOverload<Type>\n): Type;\n/**\n * Removes all undefined properties from an object when there are mandatory keys with undefined values.\n *\n * @typeParam Type - The type of the object.\n * @typeParam KeysToKeep - The keys to keep.\n * @param args - The arguments to the function.\n * @returns The object with all undefined properties removed.\n */\nexport function removeUndefinedProperties<Type extends object, const KeysToKeep extends readonly string[]>(\n  ...args: RemoveUndefinedWithKeysOverload<Type, KeysToKeep>\n): Type;\n/**\n * Removes all undefined properties from an object.\n *\n * @typeParam Type - The type of the object.\n * @typeParam KeysToKeep - The keys to keep.\n * @param obj - The object to remove undefined properties from.\n * @param keysToKeep - The keys to keep.\n * @returns The object with all undefined properties removed.\n */\nexport function removeUndefinedProperties<Type extends object>(obj: Type, keysToKeep?: readonly string[]): Type {\n  for (const [key, value] of Object.entries(obj) as [StringKeys<Type>, unknown][]) {\n    if (value === undefined && !keysToKeep?.includes(key as string)) {\n      // eslint-disable-next-line @typescript-eslint/no-dynamic-delete -- We have no other way to delete the property.\n      delete obj[key];\n    }\n  }\n  return obj;\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: GenericObject, path: string, value: unknown): void {\n  const error = new Error(`Property path ${path} not found`);\n  let node: GenericObject | 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 GenericObject | 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 -- Extracting magic number as a constant would be repetitive, as the value is used only once and its name would be the same as the property.\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 ${String(options.index)} not found`));\n    case TokenSubstitutionKey.MaxDepthLimitReached:\n      return options.substitutions.maxDepthLimitReached;\n    case TokenSubstitutionKey.MaxDepthLimitReachedArray:\n      return `Array(${String(options.index)})`;\n    case TokenSubstitutionKey.ToJSONFailed:\n      return options.substitutions.toJSONFailed;\n    case TokenSubstitutionKey.Undefined:\n      return 'undefined';\n    default:\n      break;\n  }\n}\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any -- `unknown` doesn't work, getting compiler errors.\nfunction createEqualityComparerEntries<const T extends readonly EqualityComparerEntry<any>[]>(entries: T): T {\n  return entries;\n}\n\nfunction deepEqualArrayBuffer(a: ArrayBuffer, b: ArrayBuffer): boolean {\n  if (a.byteLength !== b.byteLength) {\n    return false;\n  }\n\n  const viewA = new Uint8Array(a);\n  const viewB = new Uint8Array(b);\n  return deepEqual(viewA, viewB);\n}\n\nfunction deepEqualDate(a: Date, b: Date): boolean {\n  return a.getTime() === b.getTime();\n}\n\nfunction deepEqualMap(a: Map<unknown, unknown>, b: Map<unknown, unknown>): boolean {\n  if (a.size !== b.size) {\n    return false;\n  }\n\n  for (const [key, value] of a.entries()) {\n    if (!b.has(key) || !deepEqual(value, b.get(key))) {\n      return false;\n    }\n  }\n\n  return true;\n}\n\nfunction deepEqualRegExp(a: RegExp, b: RegExp): boolean {\n  return a.source === b.source && a.flags === b.flags;\n}\n\nfunction deepEqualSet(a: Set<unknown>, b: Set<unknown>): boolean {\n  if (a.size !== b.size) {\n    return false;\n  }\n\n  for (const valueA of a) {\n    if (b.has(valueA)) {\n      continue;\n    }\n    let found = false;\n    for (const valueB of b) {\n      if (deepEqual(valueA, valueB)) {\n        found = true;\n        break;\n      }\n    }\n    if (!found) {\n      return false;\n    }\n  }\n\n  return true;\n}\n\nfunction deepEqualTyped(a: unknown, b: unknown): boolean | undefined {\n  for (const { constructor, equalityComparer } of equalityComparerEntries) {\n    if (a instanceof constructor && b instanceof constructor) {\n      return equalityComparer(a as never, b as never);\n    }\n  }\n  return undefined;\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, String(index), 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 -- We need to use `Function` type to handle them separately.\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    ? String(value)\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 ? String(index) : ''}]]`;\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", "module"]
}

555
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../src/ObjectUtils.ts"],
  "sourcesContent": ["/**\n * @packageDocumentation\n *\n * Contains utility functions for Objects.\n */\n\nimport type {\n  Constructor,\n  RequiredKeysOf,\n  UndefinedOnPartialDeep\n} from 'type-fest';\n\nimport type {\n  ExactMembers,\n  MaybeReturn,\n  StringKeys\n} from './Type.ts';\nimport type { GenericObject } from './TypeGuards.ts';\n\nimport { errorToString } from './Error.ts';\nimport { replaceAll } from './String.ts';\nimport {\n  ensureGenericObject,\n  ensureNonNullable\n} from './TypeGuards.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 {@link toJson}.\n */\nexport interface ToJsonOptions {\n  /**\n   * Specifies how functions should be handled in the JSON output (default: `exclude`).\n   */\n  readonly functionHandlingMode: FunctionHandlingMode;\n\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  readonly maxDepth: number;\n\n  /**\n   * Specifies whether to catch errors in `toJSON()` and replace them with a placeholder.\n   * Defaults to `false`.\n   */\n  readonly shouldCatchToJSONErrors: boolean;\n\n  /**\n   * Specifies whether to handle circular references in the JSON output.\n   * Defaults to `false`.\n   */\n  readonly shouldHandleCircularReferences: boolean;\n\n  /**\n   * Specifies whether to handle errors in the JSON output.\n   * Defaults to `false`.\n   */\n  readonly shouldHandleErrors: boolean;\n\n  /**\n   * Specifies whether to handle undefined values in the JSON output.\n   * Defaults to `false`.\n   */\n  readonly shouldHandleUndefined: boolean;\n\n  /**\n   * Specifies whether to sort the keys of the JSON output.\n   * Defaults to `false`.\n   */\n  readonly shouldSortKeys: boolean;\n\n  /**\n   * Specifies the indentation of the JSON output. This can be a number of spaces or a string. Defaults to `2`.\n   */\n  readonly space: number | string;\n\n  /**\n   * Specifies the substitutions to use in the JSON output.\n   */\n  readonly tokenSubstitutions: Partial<TokenSubstitutions>;\n}\n\ninterface ApplySubstitutionsOptions {\n  readonly functionTexts: readonly string[];\n  readonly index: number;\n  readonly key: TokenSubstitutionKey;\n  readonly substitutions: TokenSubstitutions;\n}\n\ninterface EqualityComparerEntry<T> {\n  constructor: Constructor<T>;\n  equalityComparer(a: T, b: T): boolean;\n}\n\ninterface JSONSerializable {\n  toJSON(...args: unknown[]): unknown;\n}\n\ninterface ModuleWithDefaultExport<T> {\n  default: T;\n}\n\ninterface TokenSubstitutions {\n  circularReference: string;\n  maxDepthLimitReached: string;\n  toJSONFailed: string;\n}\n\nconst KEY_SEPARATOR = '.';\nconst equalityComparerEntries = createEqualityComparerEntries(\n  [\n    { constructor: ArrayBuffer, equalityComparer: deepEqualArrayBuffer },\n    { constructor: Date, equalityComparer: deepEqualDate },\n    { constructor: RegExp, equalityComparer: deepEqualRegExp },\n    { constructor: Map, equalityComparer: deepEqualMap },\n    { constructor: Set, equalityComparer: deepEqualSet }\n  ] as const\n);\n\ntype KeysWithUndefined<T> = {\n  [K in keyof T]-?: undefined extends T[K] ? K : never;\n}[keyof T];\n\ntype MandatoryKeysWithUndefined<T extends object> = Extract<RequiredKeysOf<T> & StringKeys<T>, KeysWithUndefined<T>>;\n\ntype RemoveUndefinedOverload<T extends object> = MandatoryKeysWithUndefined<T> extends never ? [obj: T]\n  : never;\n\ntype RemoveUndefinedWithKeysOverload<T extends object, K extends readonly string[]> = [obj: T, keysToKeep: ExactMembers<MandatoryKeysWithUndefined<T>, K>];\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 * @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 * 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 * 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 * Casts a value to a specific type.\n *\n * @param value - The value to cast.\n * @returns The value as the specified type.\n */\n// eslint-disable-next-line @typescript-eslint/no-unnecessary-type-parameters -- We need to cast.\nexport function castTo<T>(value: unknown): T {\n  return value as T;\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 * 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 aConstructor = a.constructor;\n  const bConstructor = b.constructor;\n\n  if (aConstructor !== bConstructor) {\n    return false;\n  }\n\n  if (aConstructor !== Object) {\n    const result = deepEqualTyped(a, b);\n    if (result !== undefined) {\n      return result;\n    }\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 = ensureGenericObject(a);\n  const bRecord = ensureGenericObject(b);\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 -- We have no other way to delete the property.\n  delete obj[propertyName];\n  return true;\n}\n\n/**\n * Extracts the default export from a module.\n *\n * Useful to handle incorrect default export interop between ESM and CJS.\n *\n * @param module - The module to extract the default export from.\n * @returns The default export.\n */\nexport function extractDefaultExportInterop<T>(module: ModuleWithDefaultExport<T> | T): T {\n  if (typeof module !== 'object' || module === null) {\n    return module;\n  }\n\n  if ('default' in module) {\n    return module.default;\n  }\n\n  return module;\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: GenericObject, path: string): unknown {\n  let node: GenericObject | 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 GenericObject | 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 extends object>(name: StringKeys<T>): StringKeys<T> {\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 * Removes all undefined properties from an object when there are no mandatory keys with undefined values.\n *\n * @typeParam Type - The type of the object.\n * @param args - The arguments to the function.\n * @returns The object with all undefined properties removed.\n */\nexport function removeUndefinedProperties<Type extends object>(\n  ...args: RemoveUndefinedOverload<Type>\n): Type;\n/**\n * Removes all undefined properties from an object when there are mandatory keys with undefined values.\n *\n * @typeParam Type - The type of the object.\n * @typeParam KeysToKeep - The keys to keep.\n * @param args - The arguments to the function.\n * @returns The object with all undefined properties removed.\n */\nexport function removeUndefinedProperties<Type extends object, const KeysToKeep extends readonly string[]>(\n  ...args: RemoveUndefinedWithKeysOverload<Type, KeysToKeep>\n): Type;\n/**\n * Removes all undefined properties from an object.\n *\n * @typeParam Type - The type of the object.\n * @typeParam KeysToKeep - The keys to keep.\n * @param obj - The object to remove undefined properties from.\n * @param keysToKeep - The keys to keep.\n * @returns The object with all undefined properties removed.\n */\nexport function removeUndefinedProperties<Type extends object>(obj: Type, keysToKeep?: readonly string[]): Type {\n  for (const [key, value] of Object.entries(obj) as [StringKeys<Type>, unknown][]) {\n    if (value === undefined && !keysToKeep?.includes(key as string)) {\n      // eslint-disable-next-line @typescript-eslint/no-dynamic-delete -- We have no other way to delete the property.\n      delete obj[key];\n    }\n  }\n  return obj;\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: GenericObject, path: string, value: unknown): void {\n  const error = new Error(`Property path ${path} not found`);\n  let node: GenericObject | 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 GenericObject | undefined;\n  }\n\n  const lastKey = ensureNonNullable(keys.at(-1));\n  if (node === 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 -- Extracting magic number as a constant would be repetitive, as the value is used only once and its name would be the same as the property.\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 = ensureNonNullable(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  /* v8 ignore start -- All enum values are handled above; default branch is unreachable. */\n  switch (options.key) {\n    /* v8 ignore stop */\n    case TokenSubstitutionKey.CircularReference:\n      return options.substitutions.circularReference;\n    case TokenSubstitutionKey.Function:\n      /* v8 ignore start -- Function index is always valid since we push before accessing. */\n      return ensureNonNullable(options.functionTexts[options.index], `Function with index ${String(options.index)} not found`);\n      /* v8 ignore stop */\n    case TokenSubstitutionKey.MaxDepthLimitReached:\n      return options.substitutions.maxDepthLimitReached;\n    case TokenSubstitutionKey.MaxDepthLimitReachedArray:\n      return `Array(${String(options.index)})`;\n    case TokenSubstitutionKey.ToJSONFailed:\n      return options.substitutions.toJSONFailed;\n    case TokenSubstitutionKey.Undefined:\n      return 'undefined';\n    default:\n      /* v8 ignore start -- All enum values are handled above. */\n      break;\n      /* v8 ignore stop */\n  }\n}\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any -- `unknown` doesn't work, getting compiler errors.\nfunction createEqualityComparerEntries<const T extends readonly EqualityComparerEntry<any>[]>(entries: T): T {\n  return entries;\n}\n\nfunction deepEqualArrayBuffer(a: ArrayBuffer, b: ArrayBuffer): boolean {\n  if (a.byteLength !== b.byteLength) {\n    return false;\n  }\n\n  const viewA = new Uint8Array(a);\n  const viewB = new Uint8Array(b);\n  return deepEqual(viewA, viewB);\n}\n\nfunction deepEqualDate(a: Date, b: Date): boolean {\n  return a.getTime() === b.getTime();\n}\n\nfunction deepEqualMap(a: Map<unknown, unknown>, b: Map<unknown, unknown>): boolean {\n  if (a.size !== b.size) {\n    return false;\n  }\n\n  for (const [key, value] of a.entries()) {\n    if (!b.has(key) || !deepEqual(value, b.get(key))) {\n      return false;\n    }\n  }\n\n  return true;\n}\n\nfunction deepEqualRegExp(a: RegExp, b: RegExp): boolean {\n  return a.source === b.source && a.flags === b.flags;\n}\n\nfunction deepEqualSet(a: Set<unknown>, b: Set<unknown>): boolean {\n  if (a.size !== b.size) {\n    return false;\n  }\n\n  for (const valueA of a) {\n    if (b.has(valueA)) {\n      continue;\n    }\n    let found = false;\n    for (const valueB of b) {\n      if (deepEqual(valueA, valueB)) {\n        found = true;\n        break;\n      }\n    }\n    if (!found) {\n      return false;\n    }\n  }\n\n  return true;\n}\n\nfunction deepEqualTyped(a: unknown, b: unknown): boolean | undefined {\n  for (const { constructor, equalityComparer } of equalityComparerEntries) {\n    if (a instanceof constructor && b instanceof constructor) {\n      return equalityComparer(a as never, b as never);\n    }\n  }\n  return undefined;\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, String(index), 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 -- We need to use `Function` type to handle them separately.\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    ? String(value)\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 ? String(index) : ''}]]`;\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", "module"]
}

@@ -5,6 +5,7 @@
5
5
  */
6
6
  import type { RequiredKeysOf, UndefinedOnPartialDeep } from 'type-fest';
7
7
  import type { ExactMembers, StringKeys } from './Type.cjs';
8
+ import type { GenericObject } from './TypeGuards.cjs';
8
9
  /**
9
10
  * Specifies how functions should be handled in the JSON output.
10
11
  */
@@ -29,46 +30,46 @@ export interface ToJsonOptions {
29
30
  /**
30
31
  * Specifies how functions should be handled in the JSON output (default: `exclude`).
31
32
  */
32
- functionHandlingMode: FunctionHandlingMode;
33
+ readonly functionHandlingMode: FunctionHandlingMode;
33
34
  /**
34
35
  * Specifies the maximum depth of nested objects to include in the JSON output.
35
36
  * Use `-1` for no limit.
36
37
  * Defaults to `-1`.
37
38
  */
38
- maxDepth: number;
39
+ readonly maxDepth: number;
39
40
  /**
40
41
  * Specifies whether to catch errors in `toJSON()` and replace them with a placeholder.
41
42
  * Defaults to `false`.
42
43
  */
43
- shouldCatchToJSONErrors: boolean;
44
+ readonly shouldCatchToJSONErrors: boolean;
44
45
  /**
45
46
  * Specifies whether to handle circular references in the JSON output.
46
47
  * Defaults to `false`.
47
48
  */
48
- shouldHandleCircularReferences: boolean;
49
+ readonly shouldHandleCircularReferences: boolean;
49
50
  /**
50
51
  * Specifies whether to handle errors in the JSON output.
51
52
  * Defaults to `false`.
52
53
  */
53
- shouldHandleErrors: boolean;
54
+ readonly shouldHandleErrors: boolean;
54
55
  /**
55
56
  * Specifies whether to handle undefined values in the JSON output.
56
57
  * Defaults to `false`.
57
58
  */
58
- shouldHandleUndefined: boolean;
59
+ readonly shouldHandleUndefined: boolean;
59
60
  /**
60
61
  * Specifies whether to sort the keys of the JSON output.
61
62
  * Defaults to `false`.
62
63
  */
63
- shouldSortKeys: boolean;
64
+ readonly shouldSortKeys: boolean;
64
65
  /**
65
66
  * Specifies the indentation of the JSON output. This can be a number of spaces or a string. Defaults to `2`.
66
67
  */
67
- space: number | string;
68
+ readonly space: number | string;
68
69
  /**
69
70
  * Specifies the substitutions to use in the JSON output.
70
71
  */
71
- tokenSubstitutions: Partial<TokenSubstitutions>;
72
+ readonly tokenSubstitutions: Partial<TokenSubstitutions>;
72
73
  }
73
74
  interface ModuleWithDefaultExport<T> {
74
75
  default: T;
@@ -78,10 +79,6 @@ interface TokenSubstitutions {
78
79
  maxDepthLimitReached: string;
79
80
  toJSONFailed: string;
80
81
  }
81
- /**
82
- * A type that represents a generic object.
83
- */
84
- export type GenericObject = Record<string, unknown>;
85
82
  type KeysWithUndefined<T> = {
86
83
  [K in keyof T]-?: undefined extends T[K] ? K : never;
87
84
  }[keyof T];
@@ -113,6 +110,13 @@ export declare function assignWithNonEnumerableProperties<T extends object, U, V
113
110
  * @returns The target object with the assigned properties.
114
111
  */
115
112
  export declare function assignWithNonEnumerableProperties<T extends object, U, V, W>(target: T, source1: U, source2: V, source3: W): T & U & V & W;
113
+ /**
114
+ * Casts a value to a specific type.
115
+ *
116
+ * @param value - The value to cast.
117
+ * @returns The value as the specified type.
118
+ */
119
+ export declare function castTo<T>(value: unknown): T;
116
120
  /**
117
121
  * Clones an object, including non-enumerable properties.
118
122
  *
@@ -152,6 +152,7 @@ function hasFlag(regExp, flag) {
152
152
  function shouldPickFlag(regExps, flag, strategy) {
153
153
  const count = regExps.filter((regExp) => hasFlag(regExp, flag)).length;
154
154
  switch (strategy) {
155
+ /* v8 ignore stop */
155
156
  case "Intersect" /* Intersect */:
156
157
  return count === regExps.length;
157
158
  case "Throw" /* Throw */:
@@ -205,6 +206,7 @@ function addUnicodeFlags(finalFlags, regExps, strategy) {
205
206
  let shouldUseUFlag;
206
207
  let shouldUseVFlag;
207
208
  switch (strategy) {
209
+ /* v8 ignore stop */
208
210
  case "Intersect" /* Intersect */:
209
211
  shouldUseUFlag = countU === regExps.length;
210
212
  shouldUseVFlag = countV === regExps.length;
@@ -250,4 +252,4 @@ function addUnicodeFlags(finalFlags, regExps, strategy) {
250
252
  isValidRegExp,
251
253
  oneOf
252
254
  });
253
- //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../src/RegExp.ts"],
  "sourcesContent": ["/**\n * @packageDocumentation\n *\n * Contains utility functions for regular expressions.\n */\n\n/**\n * A strategy to use when merging multiple regex flags into one alternation.\n */\nexport enum RegExpMergeFlagsConflictStrategy {\n  /**\n   * Keep only the flags present in all regexes.\n   */\n  Intersect = 'Intersect',\n  /**\n   * Throw an error if the regexes have conflicting flags.\n   */\n  Throw = 'Throw',\n  /**\n   * Keep only the flags present in any regex.\n   */\n  Union = 'Union'\n}\n\n/**\n * Escapes special characters in a string to safely use it within a regular expression.\n *\n * @param str - The string to escape.\n * @returns The escaped string with special characters prefixed with a backslash.\n */\nexport function escapeRegExp(str: string): string {\n  // NOTE: We can't use `replaceAll()` from `String.ts` here because it introduces a circular dependency.\n  return str.replaceAll(/[.*+?^${}()|[\\]\\\\]/g, '\\\\$&');\n}\n\n/**\n * Checks if a string is a valid regular expression.\n *\n * @param str - The string to check.\n * @returns `true` if the string is a valid regular expression, `false` otherwise.\n */\nexport function isValidRegExp(str: string): boolean {\n  try {\n    new RegExp(str);\n    return true;\n  } catch {\n    return false;\n  }\n}\n\nfunction hasFlag(regExp: RegExp, flag: string): boolean {\n  return regExp.flags.includes(flag);\n}\n\nfunction shouldPickFlag(regExps: RegExp[], flag: string, strategy: RegExpMergeFlagsConflictStrategy): boolean {\n  const count = regExps.filter((regExp) => hasFlag(regExp, flag)).length;\n  switch (strategy) {\n    case RegExpMergeFlagsConflictStrategy.Intersect:\n      return count === regExps.length;\n    case RegExpMergeFlagsConflictStrategy.Throw:\n      break;\n    case RegExpMergeFlagsConflictStrategy.Union:\n      return count > 0;\n    default:\n      throw new Error(`Invalid strategy: ${strategy as string}`);\n  }\n\n  const allSame = count === 0 || count === regExps.length;\n  if (!allSame) {\n    throw new Error(`Conflicting flag '${flag}' across patterns.`);\n  }\n  return count === regExps.length;\n}\n\n/**\n * A regular expression that always matches.\n */\nexport const ALWAYS_MATCH_REG_EXP = /(?:)/;\n\n/**\n * A regular expression that never matches.\n */\nexport const NEVER_MATCH_REG_EXP = /.^/;\n\n/**\n * Combine multiple regexes into one alternation, handling flags.\n *\n * @param regExps - The regexes to combine.\n * @param strategy - The strategy to use when merging flags (default: `RegExpMergeFlagsConflictStrategy.Throw`).\n * @returns The combined regex.\n */\nexport function oneOf(\n  regExps: RegExp[],\n  strategy: RegExpMergeFlagsConflictStrategy = RegExpMergeFlagsConflictStrategy.Throw\n): RegExp {\n  if (regExps.length === 0) {\n    return ALWAYS_MATCH_REG_EXP;\n  }\n\n  if (regExps.length === 1 && regExps[0] !== undefined) {\n    return regExps[0];\n  }\n\n  const source = regExps.map((regExp) => `(?:${regExp.source})`).join('|');\n\n  const finalFlags = new Set<string>();\n  addSemanticFlags(finalFlags, regExps, strategy);\n  addUnicodeFlags(finalFlags, regExps, strategy);\n  addMetaFlags(finalFlags, regExps);\n\n  return new RegExp(source, [...finalFlags].join(''));\n}\n\nfunction addMetaFlags(finalFlags: Set<string>, regExps: RegExp[]): void {\n  const META_FLAGS = ['g', 'd'];\n  for (const flag of META_FLAGS) {\n    if (regExps.some((regExp) => hasFlag(regExp, flag))) {\n      finalFlags.add(flag);\n    }\n  }\n}\n\nfunction addSemanticFlags(\n  finalFlags: Set<string>,\n  regExps: RegExp[],\n  strategy: RegExpMergeFlagsConflictStrategy\n): void {\n  const SEMANTIC_FLAGS = ['i', 'm', 's', 'y'];\n  for (const flag of SEMANTIC_FLAGS) {\n    if (shouldPickFlag(regExps, flag, strategy)) {\n      finalFlags.add(flag);\n    }\n  }\n}\n\nfunction addUnicodeFlags(\n  finalFlags: Set<string>,\n  regExps: RegExp[],\n  strategy: RegExpMergeFlagsConflictStrategy\n): void {\n  const countU = regExps.filter((regExp) => hasFlag(regExp, 'u')).length;\n  const countV = regExps.filter((regExp) => hasFlag(regExp, 'v')).length;\n\n  let shouldUseUFlag: boolean;\n  let shouldUseVFlag: boolean;\n\n  switch (strategy) {\n    case RegExpMergeFlagsConflictStrategy.Intersect:\n      shouldUseUFlag = countU === regExps.length;\n      shouldUseVFlag = countV === regExps.length;\n      break;\n    case RegExpMergeFlagsConflictStrategy.Throw: {\n      const allU = countU === regExps.length;\n      const noneU = countU === 0;\n      const allV = countV === regExps.length;\n      const noneV = countV === 0;\n\n      if (!(allU || noneU) || !(allV || noneV)) {\n        throw new Error('Conflicting \\'u\\'/\\'v\\' flags across patterns.');\n      }\n\n      shouldUseUFlag = allU;\n      shouldUseVFlag = allV;\n      break;\n    }\n    case RegExpMergeFlagsConflictStrategy.Union:\n      shouldUseUFlag = countU > 0;\n      shouldUseVFlag = countV > 0;\n      break;\n    default:\n      throw new Error(`Invalid strategy: ${strategy as string}`);\n  }\n\n  if (shouldUseUFlag && shouldUseVFlag) {\n    if (strategy === RegExpMergeFlagsConflictStrategy.Throw) {\n      throw new Error('Cannot combine both \\'u\\'/\\'v\\' flags in one RegExp.');\n    }\n    shouldUseUFlag = false;\n  }\n\n  if (shouldUseUFlag) {\n    finalFlags.add('u');\n  }\n  if (shouldUseVFlag) {\n    finalFlags.add('v');\n  }\n}\n"],
  "mappings": ";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AASO,IAAK,mCAAL,kBAAKA,sCAAL;AAIL,EAAAA,kCAAA,eAAY;AAIZ,EAAAA,kCAAA,WAAQ;AAIR,EAAAA,kCAAA,WAAQ;AAZE,SAAAA;AAAA,GAAA;AAqBL,SAAS,aAAa,KAAqB;AAEhD,SAAO,IAAI,WAAW,uBAAuB,MAAM;AACrD;AAQO,SAAS,cAAc,KAAsB;AAClD,MAAI;AACF,QAAI,OAAO,GAAG;AACd,WAAO;AAAA,EACT,QAAQ;AACN,WAAO;AAAA,EACT;AACF;AAEA,SAAS,QAAQ,QAAgB,MAAuB;AACtD,SAAO,OAAO,MAAM,SAAS,IAAI;AACnC;AAEA,SAAS,eAAe,SAAmB,MAAc,UAAqD;AAC5G,QAAM,QAAQ,QAAQ,OAAO,CAAC,WAAW,QAAQ,QAAQ,IAAI,CAAC,EAAE;AAChE,UAAQ,UAAU;AAAA,IAChB,KAAK;AACH,aAAO,UAAU,QAAQ;AAAA,IAC3B,KAAK;AACH;AAAA,IACF,KAAK;AACH,aAAO,QAAQ;AAAA,IACjB;AACE,YAAM,IAAI,MAAM,qBAAqB,QAAkB,EAAE;AAAA,EAC7D;AAEA,QAAM,UAAU,UAAU,KAAK,UAAU,QAAQ;AACjD,MAAI,CAAC,SAAS;AACZ,UAAM,IAAI,MAAM,qBAAqB,IAAI,oBAAoB;AAAA,EAC/D;AACA,SAAO,UAAU,QAAQ;AAC3B;AAKO,MAAM,uBAAuB;AAK7B,MAAM,sBAAsB;AAS5B,SAAS,MACd,SACA,WAA6C,qBACrC;AACR,MAAI,QAAQ,WAAW,GAAG;AACxB,WAAO;AAAA,EACT;AAEA,MAAI,QAAQ,WAAW,KAAK,QAAQ,CAAC,MAAM,QAAW;AACpD,WAAO,QAAQ,CAAC;AAAA,EAClB;AAEA,QAAM,SAAS,QAAQ,IAAI,CAAC,WAAW,MAAM,OAAO,MAAM,GAAG,EAAE,KAAK,GAAG;AAEvE,QAAM,aAAa,oBAAI,IAAY;AACnC,mBAAiB,YAAY,SAAS,QAAQ;AAC9C,kBAAgB,YAAY,SAAS,QAAQ;AAC7C,eAAa,YAAY,OAAO;AAEhC,SAAO,IAAI,OAAO,QAAQ,CAAC,GAAG,UAAU,EAAE,KAAK,EAAE,CAAC;AACpD;AAEA,SAAS,aAAa,YAAyB,SAAyB;AACtE,QAAM,aAAa,CAAC,KAAK,GAAG;AAC5B,aAAW,QAAQ,YAAY;AAC7B,QAAI,QAAQ,KAAK,CAAC,WAAW,QAAQ,QAAQ,IAAI,CAAC,GAAG;AACnD,iBAAW,IAAI,IAAI;AAAA,IACrB;AAAA,EACF;AACF;AAEA,SAAS,iBACP,YACA,SACA,UACM;AACN,QAAM,iBAAiB,CAAC,KAAK,KAAK,KAAK,GAAG;AAC1C,aAAW,QAAQ,gBAAgB;AACjC,QAAI,eAAe,SAAS,MAAM,QAAQ,GAAG;AAC3C,iBAAW,IAAI,IAAI;AAAA,IACrB;AAAA,EACF;AACF;AAEA,SAAS,gBACP,YACA,SACA,UACM;AACN,QAAM,SAAS,QAAQ,OAAO,CAAC,WAAW,QAAQ,QAAQ,GAAG,CAAC,EAAE;AAChE,QAAM,SAAS,QAAQ,OAAO,CAAC,WAAW,QAAQ,QAAQ,GAAG,CAAC,EAAE;AAEhE,MAAI;AACJ,MAAI;AAEJ,UAAQ,UAAU;AAAA,IAChB,KAAK;AACH,uBAAiB,WAAW,QAAQ;AACpC,uBAAiB,WAAW,QAAQ;AACpC;AAAA,IACF,KAAK,qBAAwC;AAC3C,YAAM,OAAO,WAAW,QAAQ;AAChC,YAAM,QAAQ,WAAW;AACzB,YAAM,OAAO,WAAW,QAAQ;AAChC,YAAM,QAAQ,WAAW;AAEzB,UAAI,EAAE,QAAQ,UAAU,EAAE,QAAQ,QAAQ;AACxC,cAAM,IAAI,MAAM,4CAAgD;AAAA,MAClE;AAEA,uBAAiB;AACjB,uBAAiB;AACjB;AAAA,IACF;AAAA,IACA,KAAK;AACH,uBAAiB,SAAS;AAC1B,uBAAiB,SAAS;AAC1B;AAAA,IACF;AACE,YAAM,IAAI,MAAM,qBAAqB,QAAkB,EAAE;AAAA,EAC7D;AAEA,MAAI,kBAAkB,gBAAgB;AACpC,QAAI,aAAa,qBAAwC;AACvD,YAAM,IAAI,MAAM,kDAAsD;AAAA,IACxE;AACA,qBAAiB;AAAA,EACnB;AAEA,MAAI,gBAAgB;AAClB,eAAW,IAAI,GAAG;AAAA,EACpB;AACA,MAAI,gBAAgB;AAClB,eAAW,IAAI,GAAG;AAAA,EACpB;AACF;",
  "names": ["RegExpMergeFlagsConflictStrategy"]
}

255
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../src/RegExp.ts"],
  "sourcesContent": ["/**\n * @packageDocumentation\n *\n * Contains utility functions for regular expressions.\n */\n\n/**\n * A strategy to use when merging multiple regex flags into one alternation.\n */\nexport enum RegExpMergeFlagsConflictStrategy {\n  /**\n   * Keep only the flags present in all regexes.\n   */\n  Intersect = 'Intersect',\n  /**\n   * Throw an error if the regexes have conflicting flags.\n   */\n  Throw = 'Throw',\n  /**\n   * Keep only the flags present in any regex.\n   */\n  Union = 'Union'\n}\n\n/**\n * Escapes special characters in a string to safely use it within a regular expression.\n *\n * @param str - The string to escape.\n * @returns The escaped string with special characters prefixed with a backslash.\n */\nexport function escapeRegExp(str: string): string {\n  // NOTE: We can't use `replaceAll()` from `String.ts` here because it introduces a circular dependency.\n  return str.replaceAll(/[.*+?^${}()|[\\]\\\\]/g, '\\\\$&');\n}\n\n/**\n * Checks if a string is a valid regular expression.\n *\n * @param str - The string to check.\n * @returns `true` if the string is a valid regular expression, `false` otherwise.\n */\nexport function isValidRegExp(str: string): boolean {\n  try {\n    new RegExp(str);\n    return true;\n  } catch {\n    return false;\n  }\n}\n\nfunction hasFlag(regExp: RegExp, flag: string): boolean {\n  return regExp.flags.includes(flag);\n}\n\nfunction shouldPickFlag(regExps: RegExp[], flag: string, strategy: RegExpMergeFlagsConflictStrategy): boolean {\n  const count = regExps.filter((regExp) => hasFlag(regExp, flag)).length;\n  /* v8 ignore start -- All branches covered but v8 reports switch as partial. */\n  switch (strategy) {\n    /* v8 ignore stop */\n    case RegExpMergeFlagsConflictStrategy.Intersect:\n      return count === regExps.length;\n    case RegExpMergeFlagsConflictStrategy.Throw:\n      break;\n    case RegExpMergeFlagsConflictStrategy.Union:\n      return count > 0;\n    default:\n      /* v8 ignore start -- All enum values are handled above. */\n      throw new Error(`Invalid strategy: ${strategy as string}`);\n      /* v8 ignore stop */\n  }\n\n  const allSame = count === 0 || count === regExps.length;\n  if (!allSame) {\n    throw new Error(`Conflicting flag '${flag}' across patterns.`);\n  }\n  return count === regExps.length;\n}\n\n/**\n * A regular expression that always matches.\n */\nexport const ALWAYS_MATCH_REG_EXP = /(?:)/;\n\n/**\n * A regular expression that never matches.\n */\nexport const NEVER_MATCH_REG_EXP = /.^/;\n\n/**\n * Combine multiple regexes into one alternation, handling flags.\n *\n * @param regExps - The regexes to combine.\n * @param strategy - The strategy to use when merging flags (default: `RegExpMergeFlagsConflictStrategy.Throw`).\n * @returns The combined regex.\n */\nexport function oneOf(\n  regExps: RegExp[],\n  strategy: RegExpMergeFlagsConflictStrategy = RegExpMergeFlagsConflictStrategy.Throw\n): RegExp {\n  if (regExps.length === 0) {\n    return ALWAYS_MATCH_REG_EXP;\n  }\n\n  if (regExps.length === 1 && regExps[0] !== undefined) {\n    return regExps[0];\n  }\n\n  const source = regExps.map((regExp) => `(?:${regExp.source})`).join('|');\n\n  const finalFlags = new Set<string>();\n  addSemanticFlags(finalFlags, regExps, strategy);\n  addUnicodeFlags(finalFlags, regExps, strategy);\n  addMetaFlags(finalFlags, regExps);\n\n  return new RegExp(source, [...finalFlags].join(''));\n}\n\nfunction addMetaFlags(finalFlags: Set<string>, regExps: RegExp[]): void {\n  const META_FLAGS = ['g', 'd'];\n  for (const flag of META_FLAGS) {\n    if (regExps.some((regExp) => hasFlag(regExp, flag))) {\n      finalFlags.add(flag);\n    }\n  }\n}\n\nfunction addSemanticFlags(\n  finalFlags: Set<string>,\n  regExps: RegExp[],\n  strategy: RegExpMergeFlagsConflictStrategy\n): void {\n  const SEMANTIC_FLAGS = ['i', 'm', 's', 'y'];\n  for (const flag of SEMANTIC_FLAGS) {\n    if (shouldPickFlag(regExps, flag, strategy)) {\n      finalFlags.add(flag);\n    }\n  }\n}\n\nfunction addUnicodeFlags(\n  finalFlags: Set<string>,\n  regExps: RegExp[],\n  strategy: RegExpMergeFlagsConflictStrategy\n): void {\n  const countU = regExps.filter((regExp) => hasFlag(regExp, 'u')).length;\n  const countV = regExps.filter((regExp) => hasFlag(regExp, 'v')).length;\n\n  let shouldUseUFlag: boolean;\n  let shouldUseVFlag: boolean;\n\n  /* v8 ignore start -- All branches covered but v8 reports switch as partial. */\n  switch (strategy) {\n    /* v8 ignore stop */\n    case RegExpMergeFlagsConflictStrategy.Intersect:\n      shouldUseUFlag = countU === regExps.length;\n      shouldUseVFlag = countV === regExps.length;\n      break;\n    case RegExpMergeFlagsConflictStrategy.Throw: {\n      const allU = countU === regExps.length;\n      const noneU = countU === 0;\n      const allV = countV === regExps.length;\n      const noneV = countV === 0;\n\n      if (!(allU || noneU) || !(allV || noneV)) {\n        throw new Error('Conflicting \\'u\\'/\\'v\\' flags across patterns.');\n      }\n\n      shouldUseUFlag = allU;\n      shouldUseVFlag = allV;\n      break;\n    }\n    case RegExpMergeFlagsConflictStrategy.Union:\n      shouldUseUFlag = countU > 0;\n      shouldUseVFlag = countV > 0;\n      break;\n    default:\n      /* v8 ignore start -- All enum values are handled above. */\n      throw new Error(`Invalid strategy: ${strategy as string}`);\n      /* v8 ignore stop */\n  }\n\n  if (shouldUseUFlag && shouldUseVFlag) {\n    /* v8 ignore start -- Throw strategy cannot reach here; earlier checks would have thrown. */\n    if (strategy === RegExpMergeFlagsConflictStrategy.Throw) {\n      throw new Error('Cannot combine both \\'u\\'/\\'v\\' flags in one RegExp.');\n    }\n    /* v8 ignore stop */\n    shouldUseUFlag = false;\n  }\n\n  if (shouldUseUFlag) {\n    finalFlags.add('u');\n  }\n  if (shouldUseVFlag) {\n    finalFlags.add('v');\n  }\n}\n"],
  "mappings": ";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AASO,IAAK,mCAAL,kBAAKA,sCAAL;AAIL,EAAAA,kCAAA,eAAY;AAIZ,EAAAA,kCAAA,WAAQ;AAIR,EAAAA,kCAAA,WAAQ;AAZE,SAAAA;AAAA,GAAA;AAqBL,SAAS,aAAa,KAAqB;AAEhD,SAAO,IAAI,WAAW,uBAAuB,MAAM;AACrD;AAQO,SAAS,cAAc,KAAsB;AAClD,MAAI;AACF,QAAI,OAAO,GAAG;AACd,WAAO;AAAA,EACT,QAAQ;AACN,WAAO;AAAA,EACT;AACF;AAEA,SAAS,QAAQ,QAAgB,MAAuB;AACtD,SAAO,OAAO,MAAM,SAAS,IAAI;AACnC;AAEA,SAAS,eAAe,SAAmB,MAAc,UAAqD;AAC5G,QAAM,QAAQ,QAAQ,OAAO,CAAC,WAAW,QAAQ,QAAQ,IAAI,CAAC,EAAE;AAEhE,UAAQ,UAAU;AAAA;AAAA,IAEhB,KAAK;AACH,aAAO,UAAU,QAAQ;AAAA,IAC3B,KAAK;AACH;AAAA,IACF,KAAK;AACH,aAAO,QAAQ;AAAA,IACjB;AAEE,YAAM,IAAI,MAAM,qBAAqB,QAAkB,EAAE;AAAA,EAE7D;AAEA,QAAM,UAAU,UAAU,KAAK,UAAU,QAAQ;AACjD,MAAI,CAAC,SAAS;AACZ,UAAM,IAAI,MAAM,qBAAqB,IAAI,oBAAoB;AAAA,EAC/D;AACA,SAAO,UAAU,QAAQ;AAC3B;AAKO,MAAM,uBAAuB;AAK7B,MAAM,sBAAsB;AAS5B,SAAS,MACd,SACA,WAA6C,qBACrC;AACR,MAAI,QAAQ,WAAW,GAAG;AACxB,WAAO;AAAA,EACT;AAEA,MAAI,QAAQ,WAAW,KAAK,QAAQ,CAAC,MAAM,QAAW;AACpD,WAAO,QAAQ,CAAC;AAAA,EAClB;AAEA,QAAM,SAAS,QAAQ,IAAI,CAAC,WAAW,MAAM,OAAO,MAAM,GAAG,EAAE,KAAK,GAAG;AAEvE,QAAM,aAAa,oBAAI,IAAY;AACnC,mBAAiB,YAAY,SAAS,QAAQ;AAC9C,kBAAgB,YAAY,SAAS,QAAQ;AAC7C,eAAa,YAAY,OAAO;AAEhC,SAAO,IAAI,OAAO,QAAQ,CAAC,GAAG,UAAU,EAAE,KAAK,EAAE,CAAC;AACpD;AAEA,SAAS,aAAa,YAAyB,SAAyB;AACtE,QAAM,aAAa,CAAC,KAAK,GAAG;AAC5B,aAAW,QAAQ,YAAY;AAC7B,QAAI,QAAQ,KAAK,CAAC,WAAW,QAAQ,QAAQ,IAAI,CAAC,GAAG;AACnD,iBAAW,IAAI,IAAI;AAAA,IACrB;AAAA,EACF;AACF;AAEA,SAAS,iBACP,YACA,SACA,UACM;AACN,QAAM,iBAAiB,CAAC,KAAK,KAAK,KAAK,GAAG;AAC1C,aAAW,QAAQ,gBAAgB;AACjC,QAAI,eAAe,SAAS,MAAM,QAAQ,GAAG;AAC3C,iBAAW,IAAI,IAAI;AAAA,IACrB;AAAA,EACF;AACF;AAEA,SAAS,gBACP,YACA,SACA,UACM;AACN,QAAM,SAAS,QAAQ,OAAO,CAAC,WAAW,QAAQ,QAAQ,GAAG,CAAC,EAAE;AAChE,QAAM,SAAS,QAAQ,OAAO,CAAC,WAAW,QAAQ,QAAQ,GAAG,CAAC,EAAE;AAEhE,MAAI;AACJ,MAAI;AAGJ,UAAQ,UAAU;AAAA;AAAA,IAEhB,KAAK;AACH,uBAAiB,WAAW,QAAQ;AACpC,uBAAiB,WAAW,QAAQ;AACpC;AAAA,IACF,KAAK,qBAAwC;AAC3C,YAAM,OAAO,WAAW,QAAQ;AAChC,YAAM,QAAQ,WAAW;AACzB,YAAM,OAAO,WAAW,QAAQ;AAChC,YAAM,QAAQ,WAAW;AAEzB,UAAI,EAAE,QAAQ,UAAU,EAAE,QAAQ,QAAQ;AACxC,cAAM,IAAI,MAAM,4CAAgD;AAAA,MAClE;AAEA,uBAAiB;AACjB,uBAAiB;AACjB;AAAA,IACF;AAAA,IACA,KAAK;AACH,uBAAiB,SAAS;AAC1B,uBAAiB,SAAS;AAC1B;AAAA,IACF;AAEE,YAAM,IAAI,MAAM,qBAAqB,QAAkB,EAAE;AAAA,EAE7D;AAEA,MAAI,kBAAkB,gBAAgB;AAEpC,QAAI,aAAa,qBAAwC;AACvD,YAAM,IAAI,MAAM,kDAAsD;AAAA,IACxE;AAEA,qBAAiB;AAAA,EACnB;AAEA,MAAI,gBAAgB;AAClB,eAAW,IAAI,GAAG;AAAA,EACpB;AACA,MAAI,gBAAgB;AAClB,eAAW,IAAI,GAAG;AAAA,EACpB;AACF;",
  "names": ["RegExpMergeFlagsConflictStrategy"]
}
