obsidian-dev-utils 51.0.1 → 51.1.7
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.
- package/CHANGELOG.md +34 -0
- package/dist/lib/cjs/async.cjs +2 -2
- package/dist/lib/cjs/blob.cjs +2 -2
- package/dist/lib/cjs/debug.cjs +7 -8
- package/dist/lib/cjs/library.cjs +1 -1
- package/dist/lib/cjs/object-utils.cjs +23 -23
- package/dist/lib/cjs/obsidian/app.cjs +4 -3
- package/dist/lib/cjs/obsidian/components/setting-components/multiple-file-component.cjs +3 -2
- package/dist/lib/cjs/obsidian/components/setting-components/typed-text-component.cjs +1 -1
- package/dist/lib/cjs/obsidian/components/setting-components/validator-component.cjs +2 -2
- package/dist/lib/cjs/obsidian/constructors/getDomEventsHandlersConstructor.cjs +1 -1
- package/dist/lib/cjs/obsidian/constructors/getDomEventsHandlersConstructor.d.cts +3 -1
- package/dist/lib/cjs/obsidian/dataview-link.cjs +1 -1
- package/dist/lib/cjs/obsidian/dataview-link.d.cts +1 -1
- package/dist/lib/cjs/obsidian/file-change.cjs +1 -1
- package/dist/lib/cjs/obsidian/file-system.cjs +2 -2
- package/dist/lib/cjs/obsidian/i18n/custom-type-options-base.cjs +1 -1
- package/dist/lib/cjs/obsidian/i18n/custom-type-options-base.d.cts +12 -6
- package/dist/lib/cjs/obsidian/index.cjs +4 -1
- package/dist/lib/cjs/obsidian/index.d.cts +1 -0
- package/dist/lib/cjs/obsidian/is-in-obsidian.cjs +143 -0
- package/dist/lib/cjs/obsidian/is-in-obsidian.d.cts +11 -0
- package/dist/lib/cjs/obsidian/link.cjs +37 -37
- package/dist/lib/cjs/obsidian/markdown.cjs +1 -1
- package/dist/lib/cjs/obsidian/plugin/obsidian-plugin-repo-paths.cjs +2 -2
- package/dist/lib/cjs/obsidian/plugin/obsidian-plugin-repo-paths.d.cts +1 -1
- package/dist/lib/cjs/obsidian/plugin/path-settings.cjs +4 -5
- package/dist/lib/cjs/obsidian/plugin/plugin-settings-manager-base.cjs +2 -2
- package/dist/lib/cjs/obsidian/rename-delete-handler.cjs +2 -2
- package/dist/lib/cjs/obsidian/resource-url.cjs +3 -2
- package/dist/lib/cjs/obsidian/vault.cjs +2 -2
- package/dist/lib/cjs/reg-exp.cjs +5 -6
- package/dist/lib/cjs/script-utils/build.cjs +5 -5
- package/dist/lib/cjs/script-utils/bundlers/esbuild-impl/changeExtensionPlugin.cjs +3 -3
- package/dist/lib/cjs/script-utils/bundlers/esbuild-impl/copyToObsidianPluginsFolderPlugin.cjs +12 -11
- package/dist/lib/cjs/script-utils/bundlers/esbuild-impl/dependency.cjs +4 -4
- package/dist/lib/cjs/script-utils/bundlers/esbuild-impl/fixSourceMapsPlugin.cjs +6 -5
- package/dist/lib/cjs/script-utils/bundlers/esbuild-impl/obsidian-plugin-builder.cjs +15 -12
- package/dist/lib/cjs/script-utils/bundlers/esbuild-impl/preprocessPlugin.cjs +3 -3
- package/dist/lib/cjs/script-utils/bundlers/esbuild-impl/renameCssPlugin.cjs +5 -4
- package/dist/lib/cjs/script-utils/bundlers/esbuild.cjs +1 -1
- package/dist/lib/cjs/script-utils/cli-utils.cjs +14 -4
- package/dist/lib/cjs/script-utils/code-generator.cjs +3 -3
- package/dist/lib/cjs/script-utils/commitlint-config.cjs +134 -0
- package/dist/lib/cjs/script-utils/commitlint-config.d.cts +10 -0
- package/dist/lib/cjs/script-utils/exec.cjs +99 -10
- package/dist/lib/cjs/script-utils/exec.d.cts +35 -6
- package/dist/lib/cjs/script-utils/formatters/dprint.cjs +8 -6
- package/dist/lib/cjs/script-utils/formatters/dprint.d.cts +15 -2
- package/dist/lib/cjs/script-utils/fs.cjs +8 -11
- package/dist/lib/cjs/script-utils/fs.d.cts +1 -1
- package/dist/lib/cjs/script-utils/index.cjs +7 -4
- package/dist/lib/cjs/script-utils/index.d.cts +2 -1
- package/dist/lib/cjs/script-utils/json.cjs +9 -8
- package/dist/lib/cjs/script-utils/linters/cspell.cjs +5 -3
- package/dist/lib/cjs/script-utils/linters/cspell.d.cts +14 -1
- package/dist/lib/cjs/script-utils/linters/eslint-config.cjs +32 -20
- package/dist/lib/cjs/script-utils/linters/eslint-rules/index.cjs +142 -0
- package/dist/lib/cjs/script-utils/linters/eslint-rules/index.d.cts +1 -0
- package/dist/lib/cjs/script-utils/linters/eslint-rules/no-used-underscore-params.cjs +174 -0
- package/dist/lib/cjs/script-utils/linters/eslint-rules/no-used-underscore-params.d.cts +12 -0
- package/dist/lib/cjs/script-utils/linters/eslint-types/@types/@eslint-community__eslint-plugin-eslint-comments__configs.d.cts +4 -2
- package/dist/lib/cjs/script-utils/linters/eslint.cjs +9 -6
- package/dist/lib/cjs/script-utils/linters/eslint.d.cts +15 -2
- package/dist/lib/cjs/script-utils/linters/index.cjs +4 -1
- package/dist/lib/cjs/script-utils/linters/index.d.cts +1 -0
- package/dist/lib/cjs/script-utils/linters/markdownlint.cjs +13 -10
- package/dist/lib/cjs/script-utils/linters/markdownlint.d.cts +15 -2
- package/dist/lib/cjs/script-utils/nano-staged-config.cjs +143 -0
- package/dist/lib/cjs/script-utils/nano-staged-config.d.cts +14 -0
- package/dist/lib/cjs/script-utils/npm-publish.cjs +16 -5
- package/dist/lib/cjs/script-utils/obsidian-dev-utils-repo-paths.cjs +2 -1
- package/dist/lib/cjs/script-utils/obsidian-dev-utils-repo-paths.d.cts +2 -0
- package/dist/lib/cjs/script-utils/root.cjs +3 -3
- package/dist/lib/cjs/script-utils/root.d.cts +3 -7
- package/dist/lib/cjs/script-utils/test-runners/vitest.cjs +6 -3
- package/dist/lib/cjs/script-utils/test-runners/vitest.d.cts +12 -1
- package/dist/lib/cjs/script-utils/version.cjs +22 -31
- package/dist/lib/cjs/string.cjs +4 -13
- package/dist/lib/cjs/string.d.cts +2 -2
- package/dist/lib/cjs/type-guards.cjs +8 -1
- package/dist/lib/cjs/type-guards.d.cts +11 -1
- package/dist/lib/esm/async.mjs +6 -3
- package/dist/lib/esm/blob.mjs +2 -2
- package/dist/lib/esm/debug.mjs +5 -6
- package/dist/lib/esm/library.mjs +1 -1
- package/dist/lib/esm/object-utils.mjs +24 -23
- package/dist/lib/esm/obsidian/app.mjs +4 -3
- package/dist/lib/esm/obsidian/components/setting-components/multiple-file-component.mjs +3 -2
- package/dist/lib/esm/obsidian/components/setting-components/typed-text-component.mjs +1 -1
- package/dist/lib/esm/obsidian/components/setting-components/validator-component.mjs +2 -2
- package/dist/lib/esm/obsidian/constructors/getDomEventsHandlersConstructor.d.mts +3 -1
- package/dist/lib/esm/obsidian/constructors/getDomEventsHandlersConstructor.mjs +1 -1
- package/dist/lib/esm/obsidian/dataview-link.d.mts +1 -1
- package/dist/lib/esm/obsidian/dataview-link.mjs +1 -1
- package/dist/lib/esm/obsidian/file-change.mjs +1 -1
- package/dist/lib/esm/obsidian/file-system.mjs +3 -2
- package/dist/lib/esm/obsidian/i18n/custom-type-options-base.d.mts +12 -6
- package/dist/lib/esm/obsidian/i18n/custom-type-options-base.mjs +1 -1
- package/dist/lib/esm/obsidian/index.d.mts +1 -0
- package/dist/lib/esm/obsidian/index.mjs +3 -1
- package/dist/lib/esm/obsidian/is-in-obsidian.d.mts +11 -0
- package/dist/lib/esm/obsidian/is-in-obsidian.mjs +39 -0
- package/dist/lib/esm/obsidian/link.mjs +38 -41
- package/dist/lib/esm/obsidian/markdown.mjs +1 -1
- package/dist/lib/esm/obsidian/plugin/obsidian-plugin-repo-paths.d.mts +1 -1
- package/dist/lib/esm/obsidian/plugin/obsidian-plugin-repo-paths.mjs +2 -2
- package/dist/lib/esm/obsidian/plugin/path-settings.mjs +4 -5
- package/dist/lib/esm/obsidian/plugin/plugin-settings-manager-base.mjs +3 -2
- package/dist/lib/esm/obsidian/rename-delete-handler.mjs +6 -3
- package/dist/lib/esm/obsidian/resource-url.mjs +3 -2
- package/dist/lib/esm/obsidian/vault.mjs +3 -2
- package/dist/lib/esm/reg-exp.mjs +5 -6
- package/dist/lib/esm/script-utils/build.mjs +6 -6
- package/dist/lib/esm/script-utils/bundlers/esbuild-impl/changeExtensionPlugin.mjs +2 -2
- package/dist/lib/esm/script-utils/bundlers/esbuild-impl/copyToObsidianPluginsFolderPlugin.mjs +8 -8
- package/dist/lib/esm/script-utils/bundlers/esbuild-impl/dependency.mjs +5 -5
- package/dist/lib/esm/script-utils/bundlers/esbuild-impl/fixSourceMapsPlugin.mjs +5 -5
- package/dist/lib/esm/script-utils/bundlers/esbuild-impl/obsidian-plugin-builder.mjs +10 -11
- package/dist/lib/esm/script-utils/bundlers/esbuild-impl/preprocessPlugin.mjs +2 -2
- package/dist/lib/esm/script-utils/bundlers/esbuild-impl/renameCssPlugin.mjs +3 -5
- package/dist/lib/esm/script-utils/bundlers/esbuild.mjs +1 -1
- package/dist/lib/esm/script-utils/cli-utils.mjs +2 -2
- package/dist/lib/esm/script-utils/code-generator.mjs +2 -2
- package/dist/lib/esm/script-utils/commitlint-config.d.mts +10 -0
- package/dist/lib/esm/script-utils/commitlint-config.mjs +28 -0
- package/dist/lib/esm/script-utils/exec.d.mts +35 -6
- package/dist/lib/esm/script-utils/exec.mjs +84 -8
- package/dist/lib/esm/script-utils/formatters/dprint.d.mts +15 -2
- package/dist/lib/esm/script-utils/formatters/dprint.mjs +6 -4
- package/dist/lib/esm/script-utils/fs.d.mts +1 -1
- package/dist/lib/esm/script-utils/fs.mjs +5 -8
- package/dist/lib/esm/script-utils/index.d.mts +2 -1
- package/dist/lib/esm/script-utils/index.mjs +5 -3
- package/dist/lib/esm/script-utils/json.mjs +7 -5
- package/dist/lib/esm/script-utils/linters/cspell.d.mts +14 -1
- package/dist/lib/esm/script-utils/linters/cspell.mjs +5 -3
- package/dist/lib/esm/script-utils/linters/eslint-config.mjs +32 -20
- package/dist/lib/esm/script-utils/linters/eslint-rules/index.d.mts +1 -0
- package/dist/lib/esm/script-utils/linters/eslint-rules/index.mjs +26 -0
- package/dist/lib/esm/script-utils/linters/eslint-rules/no-used-underscore-params.d.mts +12 -0
- package/dist/lib/esm/script-utils/linters/eslint-rules/no-used-underscore-params.mjs +68 -0
- package/dist/lib/esm/script-utils/linters/eslint-types/@types/@eslint-community__eslint-plugin-eslint-comments__configs.d.mts +4 -2
- package/dist/lib/esm/script-utils/linters/eslint.d.mts +15 -2
- package/dist/lib/esm/script-utils/linters/eslint.mjs +7 -7
- package/dist/lib/esm/script-utils/linters/index.d.mts +1 -0
- package/dist/lib/esm/script-utils/linters/index.mjs +3 -1
- package/dist/lib/esm/script-utils/linters/markdownlint.d.mts +15 -2
- package/dist/lib/esm/script-utils/linters/markdownlint.mjs +13 -11
- package/dist/lib/esm/script-utils/nano-staged-config.d.mts +14 -0
- package/dist/lib/esm/script-utils/nano-staged-config.mjs +37 -0
- package/dist/lib/esm/script-utils/npm-publish.mjs +3 -6
- package/dist/lib/esm/script-utils/obsidian-dev-utils-repo-paths.d.mts +2 -0
- package/dist/lib/esm/script-utils/obsidian-dev-utils-repo-paths.mjs +2 -1
- package/dist/lib/esm/script-utils/root.d.mts +3 -7
- package/dist/lib/esm/script-utils/root.mjs +2 -2
- package/dist/lib/esm/script-utils/test-runners/vitest.d.mts +12 -1
- package/dist/lib/esm/script-utils/test-runners/vitest.mjs +6 -3
- package/dist/lib/esm/script-utils/version.mjs +16 -27
- package/dist/lib/esm/string.d.mts +2 -2
- package/dist/lib/esm/string.mjs +7 -13
- package/dist/lib/esm/type-guards.d.mts +11 -1
- package/dist/lib/esm/type-guards.mjs +7 -1
- package/dist/scripts/build/build-clean.ts +4 -0
- package/dist/scripts/build/build-compile-svelte.ts +4 -0
- package/dist/scripts/build/build-compile-typescript.ts +4 -0
- package/dist/scripts/build/build-compile.ts +4 -0
- package/dist/scripts/build/build-static.ts +4 -0
- package/dist/scripts/bundlers/esbuild/build.ts +4 -0
- package/dist/scripts/bundlers/esbuild/dev.ts +4 -0
- package/dist/scripts/formatters/dprint/format-check.ts +8 -0
- package/dist/scripts/formatters/dprint/format.ts +8 -0
- package/dist/scripts/linters/cspell/spellcheck.ts +8 -0
- package/dist/scripts/linters/eslint/lint-fix.ts +8 -0
- package/dist/scripts/linters/eslint/lint.ts +8 -0
- package/dist/scripts/linters/markdownlint/lint-md-fix.ts +8 -0
- package/dist/scripts/linters/markdownlint/lint-md.ts +8 -0
- package/dist/scripts/test-runners/vitest/test-coverage.ts +4 -0
- package/dist/scripts/test-runners/vitest/test-watch.ts +4 -0
- package/dist/scripts/test-runners/vitest/test.ts +4 -0
- package/dist/scripts/version/version.ts +7 -0
- package/obsidian/is-in-obsidian/package.json +6 -0
- package/package.json +33 -6
- package/script-utils/commitlint-config/package.json +6 -0
- package/script-utils/linters/eslint-rules/index/package.json +6 -0
- package/script-utils/linters/eslint-rules/no-used-underscore-params/package.json +6 -0
- package/script-utils/linters/eslint-rules/package.json +6 -0
- package/script-utils/nano-staged-config/package.json +6 -0
- package/scripts/postinstall.mjs +29 -0
- package/dist/lib/cjs/script-utils/linters/eslint-types/@types/@guardian__eslint-plugin-tsdoc-required.d.cts +0 -14
- package/dist/lib/cjs/script-utils/node-modules.cjs +0 -207
- package/dist/lib/cjs/script-utils/node-modules.d.cts +0 -17
- package/dist/lib/esm/script-utils/linters/eslint-types/@types/@guardian__eslint-plugin-tsdoc-required.d.mts +0 -14
- package/dist/lib/esm/script-utils/node-modules.d.mts +0 -17
- package/dist/lib/esm/script-utils/node-modules.mjs +0 -92
- package/dist/scripts/default/build-clean.ts +0 -5
- package/dist/scripts/default/build-compile-svelte.ts +0 -5
- package/dist/scripts/default/build-compile-typescript.ts +0 -5
- package/dist/scripts/default/build-compile.ts +0 -5
- package/dist/scripts/default/build-static.ts +0 -5
- package/dist/scripts/default/build.ts +0 -9
- package/dist/scripts/default/dev.ts +0 -10
- package/dist/scripts/default/format-check.ts +0 -5
- package/dist/scripts/default/format.ts +0 -5
- package/dist/scripts/default/lint-fix.ts +0 -5
- package/dist/scripts/default/lint.ts +0 -5
- package/dist/scripts/default/publish.ts +0 -5
- package/dist/scripts/default/spellcheck.ts +0 -5
- package/dist/scripts/default/version.ts +0 -5
- package/dist/scripts/examples/build.customPlugin.ts +0 -38
- package/dist/scripts/examples/build.svelteConditions.ts +0 -18
- package/dist/scripts/examples/eslint.config.extend.mts +0 -14
- package/dist/scripts/examples/eslint.config.no-dev-utils.mts +0 -15
- package/dist/scripts/examples/format.prettier.ts +0 -25
- package/script-utils/linters/eslint-types/@types/@guardian__eslint-plugin-tsdoc-required/package.json +0 -4
- package/script-utils/node-modules/package.json +0 -6
|
@@ -102,9 +102,11 @@ if you want to view the source, please visit the github repository of this plugi
|
|
|
102
102
|
})();
|
|
103
103
|
|
|
104
104
|
"use strict";
|
|
105
|
+
var __create = Object.create;
|
|
105
106
|
var __defProp = Object.defineProperty;
|
|
106
107
|
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
107
108
|
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
109
|
+
var __getProtoOf = Object.getPrototypeOf;
|
|
108
110
|
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
109
111
|
var __export = (target, all) => {
|
|
110
112
|
for (var name in all)
|
|
@@ -118,34 +120,59 @@ var __copyProps = (to, from, except, desc) => {
|
|
|
118
120
|
}
|
|
119
121
|
return to;
|
|
120
122
|
};
|
|
123
|
+
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
|
|
124
|
+
// If the importer is in node compatibility mode or this is not an ESM
|
|
125
|
+
// file that has been converted to a CommonJS file using a Babel-
|
|
126
|
+
// compatible transform (i.e. "__esModule" has not been set), then set
|
|
127
|
+
// "default" to the CommonJS "module.exports" for node compatibility.
|
|
128
|
+
isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
|
|
129
|
+
mod
|
|
130
|
+
));
|
|
121
131
|
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
122
132
|
var exec_exports = {};
|
|
123
133
|
__export(exec_exports, {
|
|
124
134
|
exec: () => exec
|
|
125
135
|
});
|
|
126
136
|
module.exports = __toCommonJS(exec_exports);
|
|
137
|
+
var import_node_child_process = require('node:child_process');
|
|
138
|
+
var import_node_process = __toESM(__extractDefault(require('node:process')), 1);
|
|
127
139
|
var import_debug = require('../debug.cjs');
|
|
128
140
|
var import_string = require('../string.cjs');
|
|
141
|
+
var import_type_guards = require('../type-guards.cjs');
|
|
129
142
|
var import_cli_utils = require('./cli-utils.cjs');
|
|
130
|
-
var import_node_modules = require('./node-modules.cjs');
|
|
131
143
|
function exec(command, options = {}) {
|
|
144
|
+
if (Array.isArray(command)) {
|
|
145
|
+
const batchResult = handleBatchedCommand(command, options);
|
|
146
|
+
if (batchResult) {
|
|
147
|
+
return batchResult;
|
|
148
|
+
}
|
|
149
|
+
command = (0, import_cli_utils.toCommandLine)(command.filter((part) => typeof part === "string"));
|
|
150
|
+
}
|
|
151
|
+
const maxCommandLength = getMaxCommandLength();
|
|
152
|
+
if (command.length > maxCommandLength) {
|
|
153
|
+
return Promise.reject(
|
|
154
|
+
new Error(
|
|
155
|
+
`Command line is too long (${String(command.length)} chars, max ${String(maxCommandLength)} on ${import_node_process.default.platform}). Consider splitting into smaller batches or use ExecArg.`
|
|
156
|
+
)
|
|
157
|
+
);
|
|
158
|
+
}
|
|
159
|
+
return execString(command, options);
|
|
160
|
+
}
|
|
161
|
+
function execString(command, options = {}) {
|
|
132
162
|
const {
|
|
133
|
-
cwd =
|
|
163
|
+
cwd = import_node_process.default.cwd(),
|
|
134
164
|
isQuiet: quiet = false,
|
|
135
165
|
shouldIgnoreExitCode: ignoreExitCode = false,
|
|
136
166
|
shouldIncludeDetails: withDetails = false,
|
|
137
167
|
stdin = ""
|
|
138
168
|
} = options;
|
|
139
|
-
if (Array.isArray(command)) {
|
|
140
|
-
command = (0, import_cli_utils.toCommandLine)(command);
|
|
141
|
-
}
|
|
142
169
|
return new Promise((resolve, reject) => {
|
|
143
170
|
(0, import_debug.getLibDebugger)("Exec")(`Executing command: ${command}`);
|
|
144
|
-
const child = (0,
|
|
171
|
+
const child = (0, import_node_child_process.spawn)(command, [], {
|
|
145
172
|
cwd,
|
|
146
173
|
env: {
|
|
147
174
|
DEBUG_COLORS: "1",
|
|
148
|
-
...
|
|
175
|
+
...import_node_process.default.env
|
|
149
176
|
},
|
|
150
177
|
shell: true,
|
|
151
178
|
stdio: "pipe"
|
|
@@ -156,7 +183,7 @@ function exec(command, options = {}) {
|
|
|
156
183
|
child.stdin.end();
|
|
157
184
|
child.stdout.on("data", (data) => {
|
|
158
185
|
if (!quiet) {
|
|
159
|
-
|
|
186
|
+
import_node_process.default.stdout.write(data);
|
|
160
187
|
}
|
|
161
188
|
stdout += data.toString("utf-8");
|
|
162
189
|
});
|
|
@@ -165,7 +192,7 @@ function exec(command, options = {}) {
|
|
|
165
192
|
});
|
|
166
193
|
child.stderr.on("data", (data) => {
|
|
167
194
|
if (!quiet) {
|
|
168
|
-
|
|
195
|
+
import_node_process.default.stderr.write(data);
|
|
169
196
|
}
|
|
170
197
|
stderr += data.toString("utf-8");
|
|
171
198
|
});
|
|
@@ -207,8 +234,70 @@ ${stderr}`));
|
|
|
207
234
|
});
|
|
208
235
|
});
|
|
209
236
|
}
|
|
237
|
+
async function executeBatches(baseCommand, batches, options) {
|
|
238
|
+
const results = [];
|
|
239
|
+
for (const batch of batches) {
|
|
240
|
+
const batchCommand = `${baseCommand} ${batch.join(" ")}`;
|
|
241
|
+
const result = await execString(batchCommand, options);
|
|
242
|
+
if (typeof result === "string") {
|
|
243
|
+
results.push(result);
|
|
244
|
+
}
|
|
245
|
+
}
|
|
246
|
+
if (options.shouldIncludeDetails) {
|
|
247
|
+
return { exitCode: 0, exitSignal: null, stderr: "", stdout: results.join("\n") };
|
|
248
|
+
}
|
|
249
|
+
return results.join("\n");
|
|
250
|
+
}
|
|
251
|
+
function getMaxCommandLength() {
|
|
252
|
+
const WINDOWS_MAX_COMMAND_LENGTH = 8191;
|
|
253
|
+
const UNIX_MAX_COMMAND_LENGTH = 131072;
|
|
254
|
+
return import_node_process.default.platform === "win32" ? WINDOWS_MAX_COMMAND_LENGTH : UNIX_MAX_COMMAND_LENGTH;
|
|
255
|
+
}
|
|
256
|
+
function handleBatchedCommand(parts, options) {
|
|
257
|
+
const execArgs = parts.filter(isExecArg);
|
|
258
|
+
if (execArgs.length === 0) {
|
|
259
|
+
return void 0;
|
|
260
|
+
}
|
|
261
|
+
if (execArgs.length > 1) {
|
|
262
|
+
return Promise.reject(new Error("Only one ExecArg with batchedArgs is allowed per command"));
|
|
263
|
+
}
|
|
264
|
+
const execArg = execArgs[0];
|
|
265
|
+
(0, import_type_guards.assertNonNullable)(execArg);
|
|
266
|
+
const staticParts = parts.filter((part) => typeof part === "string");
|
|
267
|
+
const baseCommand = (0, import_cli_utils.toCommandLine)(staticParts);
|
|
268
|
+
const maxCommandLength = getMaxCommandLength();
|
|
269
|
+
const fullCommand = `${baseCommand} ${execArg.batchedArgs.join(" ")}`;
|
|
270
|
+
if (fullCommand.length <= maxCommandLength) {
|
|
271
|
+
return execString(fullCommand, options);
|
|
272
|
+
}
|
|
273
|
+
const batches = [];
|
|
274
|
+
let currentBatch = [];
|
|
275
|
+
for (const arg of execArg.batchedArgs) {
|
|
276
|
+
const tentative = `${baseCommand} ${[...currentBatch, arg].join(" ")}`;
|
|
277
|
+
if (tentative.length > maxCommandLength) {
|
|
278
|
+
if (currentBatch.length === 0) {
|
|
279
|
+
return Promise.reject(
|
|
280
|
+
new Error(
|
|
281
|
+
`Cannot split command into batches: a single argument (${String(arg.length)} chars) plus the base command (${String(baseCommand.length)} chars) exceeds the max command length (${String(maxCommandLength)}).`
|
|
282
|
+
)
|
|
283
|
+
);
|
|
284
|
+
}
|
|
285
|
+
batches.push(currentBatch);
|
|
286
|
+
currentBatch = [arg];
|
|
287
|
+
} else {
|
|
288
|
+
currentBatch.push(arg);
|
|
289
|
+
}
|
|
290
|
+
}
|
|
291
|
+
if (currentBatch.length > 0) {
|
|
292
|
+
batches.push(currentBatch);
|
|
293
|
+
}
|
|
294
|
+
return executeBatches(baseCommand, batches, options);
|
|
295
|
+
}
|
|
296
|
+
function isExecArg(part) {
|
|
297
|
+
return typeof part === "object" && "batchedArgs" in part;
|
|
298
|
+
}
|
|
210
299
|
// Annotate the CommonJS export names for ESM import in node:
|
|
211
300
|
0 && (module.exports = {
|
|
212
301
|
exec
|
|
213
302
|
});
|
|
214
|
-
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../../src/script-utils/exec.ts"],
  "sourcesContent": ["/**\n * @packageDocumentation\n *\n * Contains utility functions for executing commands.\n */\n\nimport { getLibDebugger } from '../debug.ts';\nimport { trimEnd } from '../string.ts';\nimport { toCommandLine } from './cli-utils.ts';\nimport {\n  process,\n  spawn\n} from './node-modules.ts';\n\n/**\n * Options for executing a command.\n */\nexport interface ExecOption {\n  /**\n   * A current working folder for the command execution.\n   */\n  readonly cwd?: string;\n\n  /**\n   * If `true`, suppresses the output of the command.\n   */\n  readonly isQuiet?: boolean;\n\n  /**\n   * If `true`, throws an error if the command fails.\n   */\n  readonly shouldFailIfCalledFromOutsideRoot?: boolean;\n\n  /**\n   * If `true`, ignores the exit code of the command.\n   */\n  readonly shouldIgnoreExitCode?: boolean;\n\n  /**\n   * If `false`, only returns the output of the command.\n   */\n  readonly shouldIncludeDetails?: boolean;\n\n  /**\n   * An input to be passed to the command.\n   */\n  readonly stdin?: string;\n}\n\n/**\n * A result of {@link exec}.\n */\nexport interface ExecResult {\n  /**\n   * An exit code of the command. A value of `null` indicates that the process did not exit normally.\n   */\n  exitCode: null | number;\n\n  /**\n   * A signal that caused the process to be terminated. A value of `null` indicates that no signal was received.\n   */\n  exitSignal: NodeJS.Signals | null;\n\n  /**\n   * A standard error output from the command.\n   */\n  stderr: string;\n\n  /**\n   * A standard output from the command.\n   */\n  stdout: string;\n}\n\n/**\n * Executes a command.\n *\n * @param command - The command to execute. It can be a string or an array of strings.\n * @param options - The options for the execution.\n * @returns A {@link Promise} that resolves with the output of the command.\n * @throws If the command fails with a non-zero exit code and ignoreExitCode is `false`.\n *         The error message includes the exit code and stderr.\n *         If an error occurs during the execution and ignoreExitCode is `true`,\n *         the error is resolved with the stdout and stderr.\n */\nexport async function exec(command: string | string[], options?: { withDetails?: false } & ExecOption): Promise<string>;\n/**\n * Executes a command.\n *\n * @param command - The command to execute. It can be a string or an array of strings.\n * @param options - The options for the execution.\n * @returns A {@link Promise} that resolves with ExecResult object.\n *          The ExecResult object contains the exit code, exit signal, stderr, and stdout.\n * @throws If the command fails with a non-zero exit code and ignoreExitCode is `false`.\n *         The error message includes the exit code and stderr.\n *         If an error occurs during the execution and ignoreExitCode is `true`,\n *         the error is resolved with the stdout and stderr.\n */\nexport function exec(command: string | string[], options: { withDetails: true } & ExecOption): Promise<ExecResult>;\n/**\n * Executes a command.\n *\n * @param command - The command to execute. It can be a string or an array of strings.\n * @param options - The options for the execution.\n * @returns A {@link Promise} that resolves with the output of the command or an ExecResult object.\n *          The ExecResult object contains the exit code, exit signal, stderr, and stdout.\n * @throws If the command fails with a non-zero exit code and ignoreExitCode is `false`.\n *         The error message includes the exit code and stderr.\n *         If an error occurs during the execution and ignoreExitCode is `true`,\n *         the error is resolved with the stdout and stderr.\n */\nexport function exec(command: string | string[], options: ExecOption = {}): Promise<ExecResult | string> {\n  const {\n    cwd = process.cwd(),\n    isQuiet: quiet = false,\n    shouldIgnoreExitCode: ignoreExitCode = false,\n    shouldIncludeDetails: withDetails = false,\n    stdin = ''\n  } = options;\n  if (Array.isArray(command)) {\n    command = toCommandLine(command);\n  }\n\n  return new Promise((resolve, reject) => {\n    getLibDebugger('Exec')(`Executing command: ${command}`);\n\n    const child = spawn(command, [], {\n      cwd,\n      env: {\n        DEBUG_COLORS: '1',\n        ...process.env\n      },\n      shell: true,\n      stdio: 'pipe'\n    });\n\n    let stdout = '';\n    let stderr = '';\n\n    child.stdin.write(stdin);\n    child.stdin.end();\n\n    child.stdout.on('data', (data: Buffer) => {\n      if (!quiet) {\n        process.stdout.write(data);\n      }\n      stdout += data.toString('utf-8');\n    });\n\n    child.stdout.on('end', () => {\n      stdout = trimEnd(stdout, '\\n');\n    });\n\n    child.stderr.on('data', (data: Buffer) => {\n      if (!quiet) {\n        process.stderr.write(data);\n      }\n      stderr += data.toString('utf-8');\n    });\n\n    child.stderr.on('end', () => {\n      stderr = trimEnd(stderr, '\\n');\n    });\n\n    child.on('close', (exitCode, exitSignal) => {\n      if (exitCode !== 0 && !ignoreExitCode) {\n        reject(new Error(`Command failed with exit code ${exitCode ? String(exitCode) : '(null)'}\\n${stderr}`));\n        return;\n      }\n\n      if (!withDetails) {\n        resolve(stdout);\n        return;\n      }\n      resolve({\n        exitCode,\n        exitSignal,\n        stderr,\n        stdout\n      });\n    });\n\n    child.on('error', (err) => {\n      if (!ignoreExitCode) {\n        reject(err);\n        return;\n      }\n\n      if (!withDetails) {\n        resolve(stdout);\n        return;\n      }\n\n      resolve({\n        exitCode: null,\n        exitSignal: null,\n        stderr,\n        stdout\n      });\n    });\n  });\n}\n"],
  "mappings": ";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAMA,mBAA+B;AAC/B,oBAAwB;AACxB,uBAA8B;AAC9B,0BAGO;AAmGA,SAAS,KAAK,SAA4B,UAAsB,CAAC,GAAiC;AACvG,QAAM;AAAA,IACJ,MAAM,4BAAQ,IAAI;AAAA,IAClB,SAAS,QAAQ;AAAA,IACjB,sBAAsB,iBAAiB;AAAA,IACvC,sBAAsB,cAAc;AAAA,IACpC,QAAQ;AAAA,EACV,IAAI;AACJ,MAAI,MAAM,QAAQ,OAAO,GAAG;AAC1B,kBAAU,gCAAc,OAAO;AAAA,EACjC;AAEA,SAAO,IAAI,QAAQ,CAAC,SAAS,WAAW;AACtC,qCAAe,MAAM,EAAE,sBAAsB,OAAO,EAAE;AAEtD,UAAM,YAAQ,2BAAM,SAAS,CAAC,GAAG;AAAA,MAC/B;AAAA,MACA,KAAK;AAAA,QACH,cAAc;AAAA,QACd,GAAG,4BAAQ;AAAA,MACb;AAAA,MACA,OAAO;AAAA,MACP,OAAO;AAAA,IACT,CAAC;AAED,QAAI,SAAS;AACb,QAAI,SAAS;AAEb,UAAM,MAAM,MAAM,KAAK;AACvB,UAAM,MAAM,IAAI;AAEhB,UAAM,OAAO,GAAG,QAAQ,CAAC,SAAiB;AACxC,UAAI,CAAC,OAAO;AACV,oCAAQ,OAAO,MAAM,IAAI;AAAA,MAC3B;AACA,gBAAU,KAAK,SAAS,OAAO;AAAA,IACjC,CAAC;AAED,UAAM,OAAO,GAAG,OAAO,MAAM;AAC3B,mBAAS,uBAAQ,QAAQ,IAAI;AAAA,IAC/B,CAAC;AAED,UAAM,OAAO,GAAG,QAAQ,CAAC,SAAiB;AACxC,UAAI,CAAC,OAAO;AACV,oCAAQ,OAAO,MAAM,IAAI;AAAA,MAC3B;AACA,gBAAU,KAAK,SAAS,OAAO;AAAA,IACjC,CAAC;AAED,UAAM,OAAO,GAAG,OAAO,MAAM;AAC3B,mBAAS,uBAAQ,QAAQ,IAAI;AAAA,IAC/B,CAAC;AAED,UAAM,GAAG,SAAS,CAAC,UAAU,eAAe;AAC1C,UAAI,aAAa,KAAK,CAAC,gBAAgB;AACrC,eAAO,IAAI,MAAM,iCAAiC,WAAW,OAAO,QAAQ,IAAI,QAAQ;AAAA,EAAK,MAAM,EAAE,CAAC;AACtG;AAAA,MACF;AAEA,UAAI,CAAC,aAAa;AAChB,gBAAQ,MAAM;AACd;AAAA,MACF;AACA,cAAQ;AAAA,QACN;AAAA,QACA;AAAA,QACA;AAAA,QACA;AAAA,MACF,CAAC;AAAA,IACH,CAAC;AAED,UAAM,GAAG,SAAS,CAAC,QAAQ;AACzB,UAAI,CAAC,gBAAgB;AACnB,eAAO,GAAG;AACV;AAAA,MACF;AAEA,UAAI,CAAC,aAAa;AAChB,gBAAQ,MAAM;AACd;AAAA,MACF;AAEA,cAAQ;AAAA,QACN,UAAU;AAAA,QACV,YAAY;AAAA,QACZ;AAAA,QACA;AAAA,MACF,CAAC;AAAA,IACH,CAAC;AAAA,EACH,CAAC;AACH;",
  "names": []
}

|
|
303
|
+
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../../src/script-utils/exec.ts"],
  "sourcesContent": ["/**\n * @packageDocumentation\n *\n * Contains utility functions for executing commands.\n */\n\nimport { spawn } from 'node:child_process';\nimport process from 'node:process';\n\nimport { getLibDebugger } from '../debug.ts';\nimport { trimEnd } from '../string.ts';\nimport { assertNonNullable } from '../type-guards.ts';\nimport { toCommandLine } from './cli-utils.ts';\n\n/**\n * A command part: either a plain string or an {@link ExecArg} with batched arguments.\n */\nexport type CommandPart = ExecArg | string;\n\n/**\n * A command argument that contains a list of args to be batched.\n * If the expanded command exceeds the platform's max command length,\n * the batched args are split into sequential executions.\n */\nexport interface ExecArg {\n  /**\n   * The arguments to batch.\n   */\n  batchedArgs: string[];\n}\n\n/**\n * Options for {@link exec} that return detailed results.\n */\nexport interface ExecDetailedOptions extends ExecOption {\n  /**\n   * Must be `true` to receive detailed results.\n   */\n  withDetails: true;\n}\n\n/**\n * Options for executing a command.\n */\nexport interface ExecOption {\n  /**\n   * A current working folder for the command execution.\n   */\n  readonly cwd?: string;\n\n  /**\n   * If `true`, suppresses the output of the command.\n   */\n  readonly isQuiet?: boolean;\n\n  /**\n   * If `true`, throws an error if the command fails.\n   */\n  readonly shouldFailIfCalledFromOutsideRoot?: boolean;\n\n  /**\n   * If `true`, ignores the exit code of the command.\n   */\n  readonly shouldIgnoreExitCode?: boolean;\n\n  /**\n   * If `false`, only returns the output of the command.\n   */\n  readonly shouldIncludeDetails?: boolean;\n\n  /**\n   * An input to be passed to the command.\n   */\n  readonly stdin?: string;\n}\n\n/**\n * A result of {@link exec}.\n */\nexport interface ExecResult {\n  /**\n   * An exit code of the command. A value of `null` indicates that the process did not exit normally.\n   */\n  exitCode: null | number;\n\n  /**\n   * A signal that caused the process to be terminated. A value of `null` indicates that no signal was received.\n   */\n  exitSignal: NodeJS.Signals | null;\n\n  /**\n   * A standard error output from the command.\n   */\n  stderr: string;\n\n  /**\n   * A standard output from the command.\n   */\n  stdout: string;\n}\n\n/**\n * Options for {@link exec} that return only stdout.\n */\nexport interface ExecSimpleOptions extends ExecOption {\n  /**\n   * Must be `false` or omitted to receive only stdout.\n   */\n  withDetails?: false;\n}\n\n/**\n * Executes a command.\n *\n * @param command - The command to execute. It can be a string or an array of strings.\n * @param options - The options for the execution.\n * @returns A {@link Promise} that resolves with the output of the command.\n * @throws If the command fails with a non-zero exit code and ignoreExitCode is `false`.\n *         The error message includes the exit code and stderr.\n *         If an error occurs during the execution and ignoreExitCode is `true`,\n *         the error is resolved with the stdout and stderr.\n */\nexport async function exec(command: CommandPart[] | string, options?: ExecSimpleOptions): Promise<string>;\n/**\n * Executes a command.\n *\n * @param command - The command to execute. It can be a string or an array of strings.\n * @param options - The options for the execution.\n * @returns A {@link Promise} that resolves with ExecResult object.\n *          The ExecResult object contains the exit code, exit signal, stderr, and stdout.\n * @throws If the command fails with a non-zero exit code and ignoreExitCode is `false`.\n *         The error message includes the exit code and stderr.\n *         If an error occurs during the execution and ignoreExitCode is `true`,\n *         the error is resolved with the stdout and stderr.\n */\nexport function exec(command: CommandPart[] | string, options: ExecDetailedOptions): Promise<ExecResult>;\n/**\n * Executes a command.\n *\n * @param command - The command to execute. It can be a string or an array of strings.\n * @param options - The options for the execution.\n * @returns A {@link Promise} that resolves with the output of the command or an ExecResult object.\n *          The ExecResult object contains the exit code, exit signal, stderr, and stdout.\n * @throws If the command fails with a non-zero exit code and ignoreExitCode is `false`.\n *         The error message includes the exit code and stderr.\n *         If an error occurs during the execution and ignoreExitCode is `true`,\n *         the error is resolved with the stdout and stderr.\n */\nexport function exec(command: CommandPart[] | string, options: ExecOption = {}): Promise<ExecResult | string> {\n  if (Array.isArray(command)) {\n    const batchResult = handleBatchedCommand(command, options);\n    if (batchResult) {\n      return batchResult;\n    }\n    command = toCommandLine(command.filter((part): part is string => typeof part === 'string'));\n  }\n\n  const maxCommandLength = getMaxCommandLength();\n  if (command.length > maxCommandLength) {\n    return Promise.reject(\n      new Error(\n        `Command line is too long (${String(command.length)} chars, max ${\n          String(maxCommandLength)\n        } on ${process.platform}). Consider splitting into smaller batches or use ExecArg.`\n      )\n    );\n  }\n\n  return execString(command, options);\n}\n\n/**\n * Executes a single string command.\n *\n * @param command - The command string.\n * @param options - The exec options.\n * @returns A Promise resolving to the result.\n */\nfunction execString(command: string, options: ExecOption = {}): Promise<ExecResult | string> {\n  const {\n    cwd = process.cwd(),\n    isQuiet: quiet = false,\n    shouldIgnoreExitCode: ignoreExitCode = false,\n    shouldIncludeDetails: withDetails = false,\n    stdin = ''\n  } = options;\n\n  return new Promise((resolve, reject) => {\n    getLibDebugger('Exec')(`Executing command: ${command}`);\n\n    const child = spawn(command, [], {\n      cwd,\n      env: {\n        DEBUG_COLORS: '1',\n        ...process.env\n      },\n      shell: true,\n      stdio: 'pipe'\n    });\n\n    let stdout = '';\n    let stderr = '';\n\n    child.stdin.write(stdin);\n    child.stdin.end();\n\n    child.stdout.on('data', (data: Buffer) => {\n      if (!quiet) {\n        process.stdout.write(data);\n      }\n      stdout += data.toString('utf-8');\n    });\n\n    child.stdout.on('end', () => {\n      stdout = trimEnd(stdout, '\\n');\n    });\n\n    child.stderr.on('data', (data: Buffer) => {\n      if (!quiet) {\n        process.stderr.write(data);\n      }\n      stderr += data.toString('utf-8');\n    });\n\n    child.stderr.on('end', () => {\n      stderr = trimEnd(stderr, '\\n');\n    });\n\n    child.on('close', (exitCode, exitSignal) => {\n      if (exitCode !== 0 && !ignoreExitCode) {\n        reject(new Error(`Command failed with exit code ${exitCode ? String(exitCode) : '(null)'}\\n${stderr}`));\n        return;\n      }\n\n      if (!withDetails) {\n        resolve(stdout);\n        return;\n      }\n      resolve({\n        exitCode,\n        exitSignal,\n        stderr,\n        stdout\n      });\n    });\n\n    child.on('error', (err) => {\n      if (!ignoreExitCode) {\n        reject(err);\n        return;\n      }\n\n      if (!withDetails) {\n        resolve(stdout);\n        return;\n      }\n\n      resolve({\n        exitCode: null,\n        exitSignal: null,\n        stderr,\n        stdout\n      });\n    });\n  });\n}\n\n/**\n * Executes batched commands sequentially and concatenates stdout.\n *\n * @param baseCommand - The base command without batched args.\n * @param batches - The batches of args.\n * @param options - The exec options.\n * @returns A Promise resolving to the concatenated result.\n */\nasync function executeBatches(baseCommand: string, batches: string[][], options: ExecOption): Promise<ExecResult | string> {\n  const results: string[] = [];\n\n  for (const batch of batches) {\n    const batchCommand = `${baseCommand} ${batch.join(' ')}`;\n    const result = await execString(batchCommand, options);\n    if (typeof result === 'string') {\n      results.push(result);\n    }\n  }\n\n  if (options.shouldIncludeDetails) {\n    return { exitCode: 0, exitSignal: null, stderr: '', stdout: results.join('\\n') };\n  }\n\n  return results.join('\\n');\n}\n\n/**\n * Returns the platform-specific max command line length.\n *\n * @returns The max command length in characters.\n */\nfunction getMaxCommandLength(): number {\n  const WINDOWS_MAX_COMMAND_LENGTH = 8191;\n  const UNIX_MAX_COMMAND_LENGTH = 131072;\n  return process.platform === 'win32' ? WINDOWS_MAX_COMMAND_LENGTH : UNIX_MAX_COMMAND_LENGTH;\n}\n\n/**\n * Handles a command array that may contain an {@link ExecArg}.\n * Returns a Promise if batching is needed, or `undefined` if the command\n * has no ExecArg and should be processed normally.\n *\n * @param parts - The command parts.\n * @param options - The exec options.\n * @returns A Promise if batching is handled, or `undefined`.\n */\nfunction handleBatchedCommand(parts: CommandPart[], options: ExecOption): Promise<ExecResult | string> | undefined {\n  const execArgs = parts.filter(isExecArg);\n  if (execArgs.length === 0) {\n    return undefined;\n  }\n  if (execArgs.length > 1) {\n    return Promise.reject(new Error('Only one ExecArg with batchedArgs is allowed per command'));\n  }\n\n  const execArg = execArgs[0];\n  assertNonNullable(execArg);\n  const staticParts = parts.filter((part): part is string => typeof part === 'string');\n  const baseCommand = toCommandLine(staticParts);\n  const maxCommandLength = getMaxCommandLength();\n\n  // Try expanding all args inline\n  const fullCommand = `${baseCommand} ${execArg.batchedArgs.join(' ')}`;\n  if (fullCommand.length <= maxCommandLength) {\n    return execString(fullCommand, options);\n  }\n\n  // Split into batches\n  const batches: string[][] = [];\n  let currentBatch: string[] = [];\n\n  for (const arg of execArg.batchedArgs) {\n    const tentative = `${baseCommand} ${[...currentBatch, arg].join(' ')}`;\n    if (tentative.length > maxCommandLength) {\n      if (currentBatch.length === 0) {\n        return Promise.reject(\n          new Error(\n            `Cannot split command into batches: a single argument (${String(arg.length)} chars) plus the base command (${\n              String(baseCommand.length)\n            } chars) exceeds the max command length (${String(maxCommandLength)}).`\n          )\n        );\n      }\n      batches.push(currentBatch);\n      currentBatch = [arg];\n    } else {\n      currentBatch.push(arg);\n    }\n  }\n  /* v8 ignore start -- Always true after the loop; batchedArgs is non-empty at this point. */\n  if (currentBatch.length > 0) {\n    /* v8 ignore stop */\n    batches.push(currentBatch);\n  }\n\n  return executeBatches(baseCommand, batches, options);\n}\n\n/**\n * Checks if a command part is an {@link ExecArg}.\n *\n * @param part - The command part to check.\n * @returns Whether the part is an ExecArg.\n */\nfunction isExecArg(part: CommandPart): part is ExecArg {\n  return typeof part === 'object' && 'batchedArgs' in part;\n}\n"],
  "mappings": "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",
  "names": ["process"]
}

|
|
@@ -3,6 +3,30 @@
|
|
|
3
3
|
*
|
|
4
4
|
* Contains utility functions for executing commands.
|
|
5
5
|
*/
|
|
6
|
+
/**
|
|
7
|
+
* A command part: either a plain string or an {@link ExecArg} with batched arguments.
|
|
8
|
+
*/
|
|
9
|
+
export type CommandPart = ExecArg | string;
|
|
10
|
+
/**
|
|
11
|
+
* A command argument that contains a list of args to be batched.
|
|
12
|
+
* If the expanded command exceeds the platform's max command length,
|
|
13
|
+
* the batched args are split into sequential executions.
|
|
14
|
+
*/
|
|
15
|
+
export interface ExecArg {
|
|
16
|
+
/**
|
|
17
|
+
* The arguments to batch.
|
|
18
|
+
*/
|
|
19
|
+
batchedArgs: string[];
|
|
20
|
+
}
|
|
21
|
+
/**
|
|
22
|
+
* Options for {@link exec} that return detailed results.
|
|
23
|
+
*/
|
|
24
|
+
export interface ExecDetailedOptions extends ExecOption {
|
|
25
|
+
/**
|
|
26
|
+
* Must be `true` to receive detailed results.
|
|
27
|
+
*/
|
|
28
|
+
withDetails: true;
|
|
29
|
+
}
|
|
6
30
|
/**
|
|
7
31
|
* Options for executing a command.
|
|
8
32
|
*/
|
|
@@ -53,6 +77,15 @@ export interface ExecResult {
|
|
|
53
77
|
*/
|
|
54
78
|
stdout: string;
|
|
55
79
|
}
|
|
80
|
+
/**
|
|
81
|
+
* Options for {@link exec} that return only stdout.
|
|
82
|
+
*/
|
|
83
|
+
export interface ExecSimpleOptions extends ExecOption {
|
|
84
|
+
/**
|
|
85
|
+
* Must be `false` or omitted to receive only stdout.
|
|
86
|
+
*/
|
|
87
|
+
withDetails?: false;
|
|
88
|
+
}
|
|
56
89
|
/**
|
|
57
90
|
* Executes a command.
|
|
58
91
|
*
|
|
@@ -64,9 +97,7 @@ export interface ExecResult {
|
|
|
64
97
|
* If an error occurs during the execution and ignoreExitCode is `true`,
|
|
65
98
|
* the error is resolved with the stdout and stderr.
|
|
66
99
|
*/
|
|
67
|
-
export declare function exec(command:
|
|
68
|
-
withDetails?: false;
|
|
69
|
-
} & ExecOption): Promise<string>;
|
|
100
|
+
export declare function exec(command: CommandPart[] | string, options?: ExecSimpleOptions): Promise<string>;
|
|
70
101
|
/**
|
|
71
102
|
* Executes a command.
|
|
72
103
|
*
|
|
@@ -79,6 +110,4 @@ export declare function exec(command: string | string[], options?: {
|
|
|
79
110
|
* If an error occurs during the execution and ignoreExitCode is `true`,
|
|
80
111
|
* the error is resolved with the stdout and stderr.
|
|
81
112
|
*/
|
|
82
|
-
export declare function exec(command:
|
|
83
|
-
withDetails: true;
|
|
84
|
-
} & ExecOption): Promise<ExecResult>;
|
|
113
|
+
export declare function exec(command: CommandPart[] | string, options: ExecDetailedOptions): Promise<ExecResult>;
|
|
@@ -124,9 +124,9 @@ __export(dprint_exports, {
|
|
|
124
124
|
format: () => format
|
|
125
125
|
});
|
|
126
126
|
module.exports = __toCommonJS(dprint_exports);
|
|
127
|
+
var import_node_fs = require('node:fs');
|
|
127
128
|
var import_path = require('../../path.cjs');
|
|
128
129
|
var import_type_guards = require('../../type-guards.cjs');
|
|
129
|
-
var import_node_modules = require('../node-modules.cjs');
|
|
130
130
|
var import_obsidian_dev_utils_repo_paths = require('../obsidian-dev-utils-repo-paths.cjs');
|
|
131
131
|
var import_root = require('../root.cjs');
|
|
132
132
|
var __import_meta_url = globalThis["import.meta.url"] ?? (() => {
|
|
@@ -142,23 +142,25 @@ var __import_meta_url = globalThis["import.meta.url"] ?? (() => {
|
|
|
142
142
|
}
|
|
143
143
|
return "";
|
|
144
144
|
})();
|
|
145
|
-
async function format(
|
|
145
|
+
async function format(params) {
|
|
146
|
+
const { paths, rewrite = true } = params ?? {};
|
|
146
147
|
const rootFolder = (0, import_root.getRootFolder)();
|
|
147
148
|
(0, import_type_guards.assertNonNullable)(rootFolder, "Root folder not found");
|
|
148
149
|
let dprintJsonPath = (0, import_root.resolvePathFromRootSafe)(import_obsidian_dev_utils_repo_paths.ObsidianDevUtilsRepoPaths.DprintJson);
|
|
149
|
-
if (!(0,
|
|
150
|
+
if (!(0, import_node_fs.existsSync)(dprintJsonPath)) {
|
|
150
151
|
const packageFolder = (0, import_root.getRootFolder)((0, import_path.getFolderName)(__import_meta_url));
|
|
151
152
|
(0, import_type_guards.assertNonNullable)(packageFolder, "Could not find package folder.");
|
|
152
153
|
dprintJsonPath = (0, import_root.resolvePathFromRootSafe)((0, import_path.join)(import_obsidian_dev_utils_repo_paths.ObsidianDevUtilsRepoPaths.Dist, import_obsidian_dev_utils_repo_paths.ObsidianDevUtilsRepoPaths.DprintJson), packageFolder);
|
|
153
154
|
}
|
|
154
|
-
if (!(0,
|
|
155
|
+
if (!(0, import_node_fs.existsSync)(dprintJsonPath)) {
|
|
155
156
|
throw new Error("dprint.json not found");
|
|
156
157
|
}
|
|
157
158
|
const command = rewrite ? "fmt" : "check";
|
|
158
|
-
|
|
159
|
+
const targets = paths?.length ? paths : ["**/*"];
|
|
160
|
+
await (0, import_root.execFromRoot)(["npx", "dprint", command, "--config", dprintJsonPath, { batchedArgs: targets }]);
|
|
159
161
|
}
|
|
160
162
|
// Annotate the CommonJS export names for ESM import in node:
|
|
161
163
|
0 && (module.exports = {
|
|
162
164
|
format
|
|
163
165
|
});
|
|
164
|
-
//# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vLi4vLi4vc3JjL3NjcmlwdC11dGlscy9mb3JtYXR0ZXJzL2RwcmludC50cyJdLAogICJzb3VyY2VzQ29udGVudCI6IFsidmFyIF9faW1wb3J0X21ldGFfdXJsID0gZ2xvYmFsVGhpc1snaW1wb3J0Lm1ldGEudXJsJ10gPz8gKCgpID0+
|
|
166
|
+
//# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vLi4vLi4vc3JjL3NjcmlwdC11dGlscy9mb3JtYXR0ZXJzL2RwcmludC50cyJdLAogICJzb3VyY2VzQ29udGVudCI6IFsidmFyIF9faW1wb3J0X21ldGFfdXJsID0gZ2xvYmFsVGhpc1snaW1wb3J0Lm1ldGEudXJsJ10gPz8gKCgpID0+IHtcbiAgICAgIGlmICh0eXBlb2YgX19maWxlbmFtZSA9PT0gJ3N0cmluZycpIHtcbiAgICAgICAgY29uc3QgbG9jYWxSZXF1aXJlID0gcmVxdWlyZTtcbiAgICAgICAgY29uc3QgdXJsID0gbG9jYWxSZXF1aXJlKCdub2RlOnVybCcpO1xuICAgICAgICBpZiAodHlwZW9mIHVybC5wYXRoVG9GaWxlVVJMID09PSAnZnVuY3Rpb24nKSB7XG4gICAgICAgICAgcmV0dXJuIHVybC5wYXRoVG9GaWxlVVJMKF9fZmlsZW5hbWUpLmhyZWY7XG4gICAgICAgIH1cbiAgICAgIH1cblxuICAgICAgaWYgKHR5cGVvZiB3aW5kb3cgIT09ICd1bmRlZmluZWQnKSB7XG4gICAgICAgIHJldHVybiB3aW5kb3cubG9jYXRpb24uaHJlZjtcbiAgICAgIH1cblxuICAgICAgLy8gRmFsbGJhY2sgdG8gYW4gZW1wdHkgc3RyaW5nIGlmIHRoZSBlbnZpcm9ubWVudCBpcyB1bmtub3duXG4gICAgICByZXR1cm4gJyc7XG4gICAgfSkoKTtcbi8qKlxuICogQHBhY2thZ2VEb2N1bWVudGF0aW9uXG4gKlxuICogRm9ybWF0IHRoZSBzb3VyY2UgY29kZS5cbiAqL1xuXG5pbXBvcnQgeyBleGlzdHNTeW5jIH0gZnJvbSAnbm9kZTpmcyc7XG5cbmltcG9ydCB7XG4gIGdldEZvbGRlck5hbWUsXG4gIGpvaW5cbn0gZnJvbSAnLi4vLi4vcGF0aC50cyc7XG5pbXBvcnQgeyBhc3NlcnROb25OdWxsYWJsZSB9IGZyb20gJy4uLy4uL3R5cGUtZ3VhcmRzLnRzJztcbmltcG9ydCB7IE9ic2lkaWFuRGV2VXRpbHNSZXBvUGF0aHMgfSBmcm9tICcuLi9vYnNpZGlhbi1kZXYtdXRpbHMtcmVwby1wYXRocy50cyc7XG5pbXBvcnQge1xuICBleGVjRnJvbVJvb3QsXG4gIGdldFJvb3RGb2xkZXIsXG4gIHJlc29sdmVQYXRoRnJvbVJvb3RTYWZlXG59IGZyb20gJy4uL3Jvb3QudHMnO1xuXG4vKipcbiAqIFBhcmFtZXRlcnMgZm9yIHRoZSB7QGxpbmsgZm9ybWF0fSBmdW5jdGlvbi5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBGb3JtYXRQYXJhbXMge1xuICAvKipcbiAgICogT3B0aW9uYWwgZmlsZSBwYXRocyB0byBmb3JtYXQuIElmIG9taXR0ZWQsIGZvcm1hdHMgdGhlIGVudGlyZSBwcm9qZWN0LlxuICAgKi9cbiAgcGF0aHM/OiBzdHJpbmdbXSB8IHVuZGVmaW5lZDtcblxuICAvKipcbiAgICogV2hldGhlciB0byByZXdyaXRlIHRoZSBzb3VyY2UgY29kZS5cbiAgICovXG4gIHJld3JpdGU/OiBib29sZWFuIHwgdW5kZWZpbmVkO1xufVxuXG4vKipcbiAqIEZvcm1hdCB0aGUgc291cmNlIGNvZGUuXG4gKlxuICogQHBhcmFtIHBhcmFtcyAtIFRoZSB7QGxpbmsgRm9ybWF0UGFyYW1zfS5cbiAqIEByZXR1cm5zIEEge0BsaW5rIFByb21pc2V9IHRoYXQgcmVzb2x2ZXMgd2hlbiB0aGUgc291cmNlIGNvZGUgaGFzIGJlZW4gZm9ybWF0dGVkLlxuICovXG5leHBvcnQgYXN5bmMgZnVuY3Rpb24gZm9ybWF0KHBhcmFtcz86IEZvcm1hdFBhcmFtcyk6IFByb21pc2U8dm9pZD4ge1xuICBjb25zdCB7IHBhdGhzLCByZXdyaXRlID0gdHJ1ZSB9ID0gcGFyYW1zID8/IHt9O1xuICBjb25zdCByb290Rm9sZGVyID0gZ2V0Um9vdEZvbGRlcigpO1xuICBhc3NlcnROb25OdWxsYWJsZShyb290Rm9sZGVyLCAnUm9vdCBmb2xkZXIgbm90IGZvdW5kJyk7XG4gIGxldCBkcHJpbnRKc29uUGF0aCA9IHJlc29sdmVQYXRoRnJvbVJvb3RTYWZlKE9ic2lkaWFuRGV2VXRpbHNSZXBvUGF0aHMuRHByaW50SnNvbik7XG4gIGlmICghZXhpc3RzU3luYyhkcHJpbnRKc29uUGF0aCkpIHtcbiAgICBjb25zdCBwYWNrYWdlRm9sZGVyID0gZ2V0Um9vdEZvbGRlcihnZXRGb2xkZXJOYW1lKGltcG9ydC5tZXRhLnVybCkpO1xuICAgIGFzc2VydE5vbk51bGxhYmxlKHBhY2thZ2VGb2xkZXIsICdDb3VsZCBub3QgZmluZCBwYWNrYWdlIGZvbGRlci4nKTtcbiAgICBkcHJpbnRKc29uUGF0aCA9IHJlc29sdmVQYXRoRnJvbVJvb3RTYWZlKGpvaW4oT2JzaWRpYW5EZXZVdGlsc1JlcG9QYXRocy5EaXN0LCBPYnNpZGlhbkRldlV0aWxzUmVwb1BhdGhzLkRwcmludEpzb24pLCBwYWNrYWdlRm9sZGVyKTtcbiAgfVxuXG4gIGlmICghZXhpc3RzU3luYyhkcHJpbnRKc29uUGF0aCkpIHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoJ2RwcmludC5qc29uIG5vdCBmb3VuZCcpO1xuICB9XG5cbiAgY29uc3QgY29tbWFuZCA9IHJld3JpdGUgPyAnZm10JyA6ICdjaGVjayc7XG4gIC8qIHY4IGlnbm9yZSBzdGFydCAtLSBUaGUgcGF0aHMtcHJvdmlkZWQgYnJhbmNoIGlzIG9ubHkgZXhlcmNpc2VkIGJ5IGNvbnN1bWVyIHByb2plY3RzIHBhc3NpbmcgZmlsZSBsaXN0cy4gKi9cbiAgY29uc3QgdGFyZ2V0cyA9IHBhdGhzPy5sZW5ndGggPyBwYXRocyA6IFsnKiovKiddO1xuICAvKiB2OCBpZ25vcmUgc3RvcCAqL1xuICBhd2FpdCBleGVjRnJvbVJvb3QoWyducHgnLCAnZHByaW50JywgY29tbWFuZCwgJy0tY29uZmlnJywgZHByaW50SnNvblBhdGgsIHsgYmF0Y2hlZEFyZ3M6IHRhcmdldHMgfV0pO1xufVxuIl0sCiAgIm1hcHBpbmdzIjogIjs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFzQkEscUJBQTJCO0FBRTNCLGtCQUdPO0FBQ1AseUJBQWtDO0FBQ2xDLDJDQUEwQztBQUMxQyxrQkFJTztBQWxDUCxJQUFJLG9CQUFvQixXQUFXLGlCQUFpQixNQUFNLE1BQU07QUFDMUQsTUFBSSxPQUFPLGVBQWUsVUFBVTtBQUNsQyxVQUFNLGVBQWU7QUFDckIsVUFBTSxNQUFNLGFBQWEsVUFBVTtBQUNuQyxRQUFJLE9BQU8sSUFBSSxrQkFBa0IsWUFBWTtBQUMzQyxhQUFPLElBQUksY0FBYyxVQUFVLEVBQUU7QUFBQSxJQUN2QztBQUFBLEVBQ0Y7QUFFQSxNQUFJLE9BQU8sV0FBVyxhQUFhO0FBQ2pDLFdBQU8sT0FBTyxTQUFTO0FBQUEsRUFDekI7QUFHQSxTQUFPO0FBQ1QsR0FBRztBQTBDUCxlQUFzQixPQUFPLFFBQXNDO0FBQ2pFLFFBQU0sRUFBRSxPQUFPLFVBQVUsS0FBSyxJQUFJLFVBQVUsQ0FBQztBQUM3QyxRQUFNLGlCQUFhLDJCQUFjO0FBQ2pDLDRDQUFrQixZQUFZLHVCQUF1QjtBQUNyRCxNQUFJLHFCQUFpQixxQ0FBd0IsK0RBQTBCLFVBQVU7QUFDakYsTUFBSSxLQUFDLDJCQUFXLGNBQWMsR0FBRztBQUMvQixVQUFNLG9CQUFnQiwrQkFBYywyQkFBYyxpQkFBZSxDQUFDO0FBQ2xFLDhDQUFrQixlQUFlLGdDQUFnQztBQUNqRSx5QkFBaUIseUNBQXdCLGtCQUFLLCtEQUEwQixNQUFNLCtEQUEwQixVQUFVLEdBQUcsYUFBYTtBQUFBLEVBQ3BJO0FBRUEsTUFBSSxLQUFDLDJCQUFXLGNBQWMsR0FBRztBQUMvQixVQUFNLElBQUksTUFBTSx1QkFBdUI7QUFBQSxFQUN6QztBQUVBLFFBQU0sVUFBVSxVQUFVLFFBQVE7QUFFbEMsUUFBTSxVQUFVLE9BQU8sU0FBUyxRQUFRLENBQUMsTUFBTTtBQUUvQyxZQUFNLDBCQUFhLENBQUMsT0FBTyxVQUFVLFNBQVMsWUFBWSxnQkFBZ0IsRUFBRSxhQUFhLFFBQVEsQ0FBQyxDQUFDO0FBQ3JHOyIsCiAgIm5hbWVzIjogW10KfQo=
|
|
@@ -3,10 +3,23 @@
|
|
|
3
3
|
*
|
|
4
4
|
* Format the source code.
|
|
5
5
|
*/
|
|
6
|
+
/**
|
|
7
|
+
* Parameters for the {@link format} function.
|
|
8
|
+
*/
|
|
9
|
+
export interface FormatParams {
|
|
10
|
+
/**
|
|
11
|
+
* Optional file paths to format. If omitted, formats the entire project.
|
|
12
|
+
*/
|
|
13
|
+
paths?: string[] | undefined;
|
|
14
|
+
/**
|
|
15
|
+
* Whether to rewrite the source code.
|
|
16
|
+
*/
|
|
17
|
+
rewrite?: boolean | undefined;
|
|
18
|
+
}
|
|
6
19
|
/**
|
|
7
20
|
* Format the source code.
|
|
8
21
|
*
|
|
9
|
-
* @param
|
|
22
|
+
* @param params - The {@link FormatParams}.
|
|
10
23
|
* @returns A {@link Promise} that resolves when the source code has been formatted.
|
|
11
24
|
*/
|
|
12
|
-
export declare function format(
|
|
25
|
+
export declare function format(params?: FormatParams): Promise<void>;
|
|
@@ -124,18 +124,19 @@ __export(fs_exports, {
|
|
|
124
124
|
readdirPosix: () => readdirPosix
|
|
125
125
|
});
|
|
126
126
|
module.exports = __toCommonJS(fs_exports);
|
|
127
|
+
var import_promises = require('node:fs/promises');
|
|
127
128
|
var import_path = require('../path.cjs');
|
|
128
|
-
var
|
|
129
|
+
var import_type_guards = require('../type-guards.cjs');
|
|
129
130
|
async function readdirPosix(path, options = {}) {
|
|
130
131
|
if (isStringResultOptions(options)) {
|
|
131
|
-
const paths = await (0,
|
|
132
|
+
const paths = await (0, import_promises.readdir)(path, options);
|
|
132
133
|
return paths.map(import_path.toPosixPath);
|
|
133
134
|
}
|
|
134
135
|
if (isBufferResultOptions(options)) {
|
|
135
|
-
const buffers = await (0,
|
|
136
|
+
const buffers = await (0, import_promises.readdir)(path, options);
|
|
136
137
|
return buffers.map(import_path.toPosixBuffer);
|
|
137
138
|
}
|
|
138
|
-
const dirents = await (0,
|
|
139
|
+
const dirents = await (0, import_promises.readdir)(path, options);
|
|
139
140
|
for (const dirent of dirents) {
|
|
140
141
|
dirent.name = (0, import_path.toPosixPath)(dirent.name);
|
|
141
142
|
dirent.parentPath = (0, import_path.toPosixPath)(dirent.parentPath);
|
|
@@ -143,9 +144,7 @@ async function readdirPosix(path, options = {}) {
|
|
|
143
144
|
return dirents;
|
|
144
145
|
}
|
|
145
146
|
function isBufferResultOptions(options) {
|
|
146
|
-
|
|
147
|
-
return false;
|
|
148
|
-
}
|
|
147
|
+
(0, import_type_guards.assertNonNullable)(options);
|
|
149
148
|
if (options === "buffer") {
|
|
150
149
|
return true;
|
|
151
150
|
}
|
|
@@ -159,9 +158,7 @@ function isBufferResultOptions(options) {
|
|
|
159
158
|
return true;
|
|
160
159
|
}
|
|
161
160
|
function isStringResultOptions(options) {
|
|
162
|
-
|
|
163
|
-
return true;
|
|
164
|
-
}
|
|
161
|
+
(0, import_type_guards.assertNonNullable)(options);
|
|
165
162
|
if (options === "buffer") {
|
|
166
163
|
return false;
|
|
167
164
|
}
|
|
@@ -178,4 +175,4 @@ function isStringResultOptions(options) {
|
|
|
178
175
|
0 && (module.exports = {
|
|
179
176
|
readdirPosix
|
|
180
177
|
});
|
|
181
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
178
|
+
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../../src/script-utils/fs.ts"],
  "sourcesContent": ["/**\n * @packageDocumentation\n *\n * Contains utility functions for file system operations.\n */\n\nimport type {\n  Dirent,\n  ObjectEncodingOptions,\n  PathLike\n} from 'node:fs';\n\nimport { readdir } from 'node:fs/promises';\n\nimport {\n  toPosixBuffer,\n  toPosixPath\n} from '../path.ts';\nimport { assertNonNullable } from '../type-guards.ts';\n\n/**\n * Options for controlling the format of the result when returning buffers.\n *\n * `directory` is used instead of `folder` to preserve compatibility with `node:fs` module.\n */\nexport type BufferResultOptions = 'buffer' | {\n  /**\n   * Should be set to \"buffer\" to return buffers.\n   */\n  readonly encoding: 'buffer';\n\n  /**\n   * Whether to include subdirectories when reading the directory. If not provided, defaults to `false`.\n   */\n  readonly recursive?: boolean;\n\n  /**\n   * Should be set to `false` to return buffers.\n   */\n  readonly withFileTypes?: false;\n};\n\n/**\n * Options for controlling the format of the result when returning Dirent objects.\n */\nexport type DirentResultOptions = {\n  /**\n   * Whether to include subdirectories when reading the directory. If not provided, defaults to `false`.\n   */\n  readonly recursive?: boolean;\n\n  /**\n   * Should be set to `true` to return Dirent objects.\n   */\n  readonly withFileTypes: true;\n} & ObjectEncodingOptions;\n\n/**\n * Options for controlling the format of the result when returning strings.\n */\nexport type StringResultOptions =\n  | {\n    /**\n     * Whether to include subdirectories when reading the directory. If not provided, defaults to `false`.\n     */\n    readonly recursive?: boolean;\n\n    /**\n     * Should be set to `false` to return strings.\n     */\n    readonly withFileTypes?: false;\n  } & ObjectEncodingOptions\n  | undefined;\n\n/**\n * Common options for controlling the format of the result.\n */\ninterface CommonOptions {\n  /**\n   * Encoding to use when returning strings.\n   */\n  readonly encoding?: 'buffer' | NodeJS.BufferEncoding;\n\n  /**\n   * Set `true` to return Dirent objects or `false` to return strings or buffers.\n   */\n  readonly withFileTypes?: boolean;\n}\n\n/**\n * Reads the contents of a directory and returns an array of strings with POSIX paths.\n *\n * @param path - The path to the directory.\n * @param options - Options to control the format of the result. If not provided, returns strings.\n * @returns A {@link Promise} that resolves with an array of POSIX-formatted file paths.\n */\nexport async function readdirPosix(path: PathLike, options?: StringResultOptions): Promise<string[]>;\n/**\n * Reads the contents of a directory and returns an array of buffers with POSIX paths.\n *\n * @param path - The path to the directory.\n * @param options - Options to control the format of the result. Specify \"buffer\" to return buffers.\n * @returns A {@link Promise} that resolves with an array of POSIX-formatted buffers.\n */\nexport async function readdirPosix(path: PathLike, options: BufferResultOptions): Promise<Buffer[]>;\n/**\n * Reads the contents of a directory and returns an array of Dirent objects with POSIX paths.\n *\n * @param path - The path to the directory.\n * @param options - Options to control the format of the result. Specify `withFileTypes: true` to return Dirent objects.\n * @returns A {@link Promise} that resolves with an array of POSIX-formatted Dirent objects.\n */\nexport async function readdirPosix(path: PathLike, options: DirentResultOptions): Promise<Dirent[]>;\n/**\n * Reads the contents of a directory and converts file paths or buffer results to POSIX format.\n *\n * @param path - The path to the directory.\n * @param options - Options to control the format of the result.\n * @returns A {@link Promise} that resolves with an array of POSIX-formatted file paths, buffers, or Dirent objects.\n */\nexport async function readdirPosix(\n  path: PathLike,\n  options: BufferResultOptions | DirentResultOptions | StringResultOptions = {}\n): Promise<Buffer[] | Dirent[] | string[]> {\n  if (isStringResultOptions(options)) {\n    const paths = await readdir(path, options);\n    return paths.map(toPosixPath);\n  }\n\n  if (isBufferResultOptions(options)) {\n    const buffers = await readdir(path, options);\n    return buffers.map(toPosixBuffer);\n  }\n\n  const dirents = await readdir(path, options);\n  for (const dirent of dirents) {\n    dirent.name = toPosixPath(dirent.name);\n    dirent.parentPath = toPosixPath(dirent.parentPath);\n  }\n\n  return dirents;\n}\n\n/**\n * Type guard to check if the options are for returning buffers.\n *\n * @param options - The options to check.\n * @returns `true` if the options are for returning buffers, otherwise `false`.\n */\nfunction isBufferResultOptions(options: BufferResultOptions | DirentResultOptions | StringResultOptions): options is BufferResultOptions {\n  assertNonNullable(options);\n\n  if (options === 'buffer') {\n    return true;\n  }\n\n  const commonOptions = options as CommonOptions;\n\n  if (commonOptions.withFileTypes === true) {\n    return false;\n  }\n\n  /* v8 ignore start -- Dead code: isStringResultOptions already handles non-buffer encoding before this is called. */\n  if (commonOptions.encoding !== 'buffer') {\n    return false;\n  }\n  /* v8 ignore stop */\n\n  return true;\n}\n\n/**\n * Type guard to check if the options are for returning strings.\n *\n * @param options - The options to check.\n * @returns `true` if the options are for returning strings, otherwise `false`.\n */\nfunction isStringResultOptions(options: BufferResultOptions | DirentResultOptions | StringResultOptions): options is StringResultOptions {\n  assertNonNullable(options);\n\n  if (options === 'buffer') {\n    return false;\n  }\n\n  const commonOptions = options as CommonOptions;\n\n  if (commonOptions.encoding === 'buffer') {\n    return false;\n  }\n\n  if (commonOptions.withFileTypes === true) {\n    return false;\n  }\n\n  return true;\n}\n"],
  "mappings": ";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAYA,sBAAwB;AAExB,kBAGO;AACP,yBAAkC;AAsGlC,eAAsB,aACpB,MACA,UAA2E,CAAC,GACnC;AACzC,MAAI,sBAAsB,OAAO,GAAG;AAClC,UAAM,QAAQ,UAAM,yBAAQ,MAAM,OAAO;AACzC,WAAO,MAAM,IAAI,uBAAW;AAAA,EAC9B;AAEA,MAAI,sBAAsB,OAAO,GAAG;AAClC,UAAM,UAAU,UAAM,yBAAQ,MAAM,OAAO;AAC3C,WAAO,QAAQ,IAAI,yBAAa;AAAA,EAClC;AAEA,QAAM,UAAU,UAAM,yBAAQ,MAAM,OAAO;AAC3C,aAAW,UAAU,SAAS;AAC5B,WAAO,WAAO,yBAAY,OAAO,IAAI;AACrC,WAAO,iBAAa,yBAAY,OAAO,UAAU;AAAA,EACnD;AAEA,SAAO;AACT;AAQA,SAAS,sBAAsB,SAA0G;AACvI,4CAAkB,OAAO;AAEzB,MAAI,YAAY,UAAU;AACxB,WAAO;AAAA,EACT;AAEA,QAAM,gBAAgB;AAEtB,MAAI,cAAc,kBAAkB,MAAM;AACxC,WAAO;AAAA,EACT;AAGA,MAAI,cAAc,aAAa,UAAU;AACvC,WAAO;AAAA,EACT;AAGA,SAAO;AACT;AAQA,SAAS,sBAAsB,SAA0G;AACvI,4CAAkB,OAAO;AAEzB,MAAI,YAAY,UAAU;AACxB,WAAO;AAAA,EACT;AAEA,QAAM,gBAAgB;AAEtB,MAAI,cAAc,aAAa,UAAU;AACvC,WAAO;AAAA,EACT;AAEA,MAAI,cAAc,kBAAkB,MAAM;AACxC,WAAO;AAAA,EACT;AAEA,SAAO;AACT;",
  "names": []
}

|
|
@@ -3,7 +3,7 @@
|
|
|
3
3
|
*
|
|
4
4
|
* Contains utility functions for file system operations.
|
|
5
5
|
*/
|
|
6
|
-
import type { Dirent, ObjectEncodingOptions, PathLike } from '
|
|
6
|
+
import type { Dirent, ObjectEncodingOptions, PathLike } from 'node:fs';
|
|
7
7
|
/**
|
|
8
8
|
* Options for controlling the format of the result when returning buffers.
|
|
9
9
|
*
|
|
@@ -135,12 +135,13 @@ __export(script_utils_exports, {
|
|
|
135
135
|
bundlers: () => bundlers,
|
|
136
136
|
cli_utils: () => cli_utils,
|
|
137
137
|
code_generator: () => code_generator,
|
|
138
|
+
commitlint_config: () => commitlint_config,
|
|
138
139
|
exec: () => exec,
|
|
139
140
|
formatters: () => formatters,
|
|
140
141
|
fs: () => fs,
|
|
141
142
|
json: () => json,
|
|
142
143
|
linters: () => linters,
|
|
143
|
-
|
|
144
|
+
nano_staged_config: () => nano_staged_config,
|
|
144
145
|
npm: () => npm,
|
|
145
146
|
npm_publish: () => npm_publish,
|
|
146
147
|
npm_run: () => npm_run,
|
|
@@ -155,12 +156,13 @@ var build = __toESM(__extractDefault(require('./build.cjs')), 1);
|
|
|
155
156
|
var bundlers = __toESM(__extractDefault(require('./bundlers/index.cjs')), 1);
|
|
156
157
|
var cli_utils = __toESM(__extractDefault(require('./cli-utils.cjs')), 1);
|
|
157
158
|
var code_generator = __toESM(__extractDefault(require('./code-generator.cjs')), 1);
|
|
159
|
+
var commitlint_config = __toESM(__extractDefault(require('./commitlint-config.cjs')), 1);
|
|
158
160
|
var exec = __toESM(__extractDefault(require('./exec.cjs')), 1);
|
|
159
161
|
var formatters = __toESM(__extractDefault(require('./formatters/index.cjs')), 1);
|
|
160
162
|
var fs = __toESM(__extractDefault(require('./fs.cjs')), 1);
|
|
161
163
|
var json = __toESM(__extractDefault(require('./json.cjs')), 1);
|
|
162
164
|
var linters = __toESM(__extractDefault(require('./linters/index.cjs')), 1);
|
|
163
|
-
var
|
|
165
|
+
var nano_staged_config = __toESM(__extractDefault(require('./nano-staged-config.cjs')), 1);
|
|
164
166
|
var npm_publish = __toESM(__extractDefault(require('./npm-publish.cjs')), 1);
|
|
165
167
|
var npm_run = __toESM(__extractDefault(require('./npm-run.cjs')), 1);
|
|
166
168
|
var npm = __toESM(__extractDefault(require('./npm.cjs')), 1);
|
|
@@ -175,12 +177,13 @@ var version = __toESM(__extractDefault(require('./version.cjs')), 1);
|
|
|
175
177
|
bundlers,
|
|
176
178
|
cli_utils,
|
|
177
179
|
code_generator,
|
|
180
|
+
commitlint_config,
|
|
178
181
|
exec,
|
|
179
182
|
formatters,
|
|
180
183
|
fs,
|
|
181
184
|
json,
|
|
182
185
|
linters,
|
|
183
|
-
|
|
186
|
+
nano_staged_config,
|
|
184
187
|
npm,
|
|
185
188
|
npm_publish,
|
|
186
189
|
npm_run,
|
|
@@ -190,4 +193,4 @@ var version = __toESM(__extractDefault(require('./version.cjs')), 1);
|
|
|
190
193
|
test_runners,
|
|
191
194
|
version
|
|
192
195
|
});
|
|
193
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
196
|
+
//# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vLi4vc3JjL3NjcmlwdC11dGlscy9pbmRleC50cyJdLAogICJzb3VyY2VzQ29udGVudCI6IFsiLyogVEhJUyBJUyBBIEdFTkVSQVRFRC9CVU5ETEVEIEZJTEUgQlkgQlVJTEQgU0NSSVBUICovXG5cbmV4cG9ydCAqIGFzIGJ1aWxkIGZyb20gJy4vYnVpbGQudHMnO1xuZXhwb3J0ICogYXMgYnVuZGxlcnMgZnJvbSAnLi9idW5kbGVycy9pbmRleC50cyc7XG5leHBvcnQgKiBhcyBjbGlfdXRpbHMgZnJvbSAnLi9jbGktdXRpbHMudHMnO1xuZXhwb3J0ICogYXMgY29kZV9nZW5lcmF0b3IgZnJvbSAnLi9jb2RlLWdlbmVyYXRvci50cyc7XG5leHBvcnQgKiBhcyBjb21taXRsaW50X2NvbmZpZyBmcm9tICcuL2NvbW1pdGxpbnQtY29uZmlnLnRzJztcbmV4cG9ydCAqIGFzIGV4ZWMgZnJvbSAnLi9leGVjLnRzJztcbmV4cG9ydCAqIGFzIGZvcm1hdHRlcnMgZnJvbSAnLi9mb3JtYXR0ZXJzL2luZGV4LnRzJztcbmV4cG9ydCAqIGFzIGZzIGZyb20gJy4vZnMudHMnO1xuZXhwb3J0ICogYXMganNvbiBmcm9tICcuL2pzb24udHMnO1xuZXhwb3J0ICogYXMgbGludGVycyBmcm9tICcuL2xpbnRlcnMvaW5kZXgudHMnO1xuZXhwb3J0ICogYXMgbmFub19zdGFnZWRfY29uZmlnIGZyb20gJy4vbmFuby1zdGFnZWQtY29uZmlnLnRzJztcbmV4cG9ydCAqIGFzIG5wbV9wdWJsaXNoIGZyb20gJy4vbnBtLXB1Ymxpc2gudHMnO1xuZXhwb3J0ICogYXMgbnBtX3J1biBmcm9tICcuL25wbS1ydW4udHMnO1xuZXhwb3J0ICogYXMgbnBtIGZyb20gJy4vbnBtLnRzJztcbmV4cG9ydCAqIGFzIG9ic2lkaWFuX2NsaSBmcm9tICcuL29ic2lkaWFuLWNsaS50cyc7XG5leHBvcnQgKiBhcyBvYnNpZGlhbl9kZXZfdXRpbHNfcmVwb19wYXRocyBmcm9tICcuL29ic2lkaWFuLWRldi11dGlscy1yZXBvLXBhdGhzLnRzJztcbmV4cG9ydCAqIGFzIHJvb3QgZnJvbSAnLi9yb290LnRzJztcbmV4cG9ydCAqIGFzIHRlc3RfcnVubmVycyBmcm9tICcuL3Rlc3QtcnVubmVycy9pbmRleC50cyc7XG5leHBvcnQgKiBhcyB2ZXJzaW9uIGZyb20gJy4vdmVyc2lvbi50cyc7XG4iXSwKICAibWFwcGluZ3MiOiAiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFFQSxZQUF1QjtBQUN2QixlQUEwQjtBQUMxQixnQkFBMkI7QUFDM0IscUJBQWdDO0FBQ2hDLHdCQUFtQztBQUNuQyxXQUFzQjtBQUN0QixpQkFBNEI7QUFDNUIsU0FBb0I7QUFDcEIsV0FBc0I7QUFDdEIsY0FBeUI7QUFDekIseUJBQW9DO0FBQ3BDLGtCQUE2QjtBQUM3QixjQUF5QjtBQUN6QixVQUFxQjtBQUNyQixtQkFBOEI7QUFDOUIsb0NBQStDO0FBQy9DLFdBQXNCO0FBQ3RCLG1CQUE4QjtBQUM5QixjQUF5QjsiLAogICJuYW1lcyI6IFtdCn0K
|
|
@@ -2,12 +2,13 @@ export * as build from './build.cjs';
|
|
|
2
2
|
export * as bundlers from './bundlers/index.cjs';
|
|
3
3
|
export * as cli_utils from './cli-utils.cjs';
|
|
4
4
|
export * as code_generator from './code-generator.cjs';
|
|
5
|
+
export * as commitlint_config from './commitlint-config.cjs';
|
|
5
6
|
export * as exec from './exec.cjs';
|
|
6
7
|
export * as formatters from './formatters/index.cjs';
|
|
7
8
|
export * as fs from './fs.cjs';
|
|
8
9
|
export * as json from './json.cjs';
|
|
9
10
|
export * as linters from './linters/index.cjs';
|
|
10
|
-
export * as
|
|
11
|
+
export * as nano_staged_config from './nano-staged-config.cjs';
|
|
11
12
|
export * as npm_publish from './npm-publish.cjs';
|
|
12
13
|
export * as npm_run from './npm-run.cjs';
|
|
13
14
|
export * as npm from './npm.cjs';
|