@datamitsu/datamitsu 0.0.3-alpha-21 → 0.0.3-alpha-22

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/lib/index.d.ts ADDED
@@ -0,0 +1,196 @@
1
+ //#region src/types.d.ts
2
+ interface GroupJSON {
3
+ parallelGroups: ParallelGroupJSON[];
4
+ priority: number;
5
+ }
6
+ interface ParallelGroupJSON {
7
+ canRunInParallel: boolean;
8
+ tasks: TaskJSON[];
9
+ }
10
+ interface PlanJSON {
11
+ cwdPath: string;
12
+ groups: GroupJSON[];
13
+ operation: string;
14
+ rootPath: string;
15
+ }
16
+ interface SpawnRaw {
17
+ exitCode: number;
18
+ failed: boolean;
19
+ stderr: string;
20
+ stdout: string;
21
+ }
22
+ interface TaskJSON {
23
+ app: string;
24
+ args: string[];
25
+ batch: boolean;
26
+ fileCount: number;
27
+ files: string[];
28
+ globs: string[];
29
+ scope: string;
30
+ toolName: string;
31
+ workingDir: string;
32
+ }
33
+ //#endregion
34
+ //#region src/tool-command.d.ts
35
+ interface BaseOptions {
36
+ beforeConfig?: string[];
37
+ config?: string[];
38
+ explain?: boolean | "detailed" | "json" | "summary" | "text";
39
+ files?: string[];
40
+ fileScoped?: boolean;
41
+ skipGitRoot?: boolean;
42
+ tools?: string[];
43
+ }
44
+ interface ToolCommandOptions extends BaseOptions {
45
+ cwd?: string;
46
+ stdio?: "pipe" | "inherit";
47
+ }
48
+ type ToolCommandResult = {
49
+ exitCode: number;
50
+ raw: SpawnRaw;
51
+ success: true;
52
+ } | {
53
+ output: string;
54
+ raw: SpawnRaw;
55
+ success: true;
56
+ } | {
57
+ plan: PlanJSON;
58
+ raw: SpawnRaw;
59
+ success: true;
60
+ } | {
61
+ error: string;
62
+ exitCode: number;
63
+ raw: SpawnRaw;
64
+ success: false;
65
+ };
66
+ //#endregion
67
+ //#region src/commands/check.d.ts
68
+ type CheckOptions = ToolCommandOptions;
69
+ type CheckResult = {
70
+ error: string;
71
+ exitCode: number;
72
+ raw: SpawnRaw;
73
+ success: false;
74
+ } | {
75
+ exitCode: number;
76
+ raw: SpawnRaw;
77
+ success: true;
78
+ } | {
79
+ output: string;
80
+ raw: SpawnRaw;
81
+ success: true;
82
+ } | {
83
+ plan: PlanJSON;
84
+ plans: PlanJSON[];
85
+ raw: SpawnRaw;
86
+ success: true;
87
+ };
88
+ declare function check(options?: CheckOptions): Promise<CheckResult>;
89
+ //#endregion
90
+ //#region src/commands/exec.d.ts
91
+ interface ExecOptions {
92
+ args?: string[];
93
+ beforeConfig?: string[];
94
+ config?: string[];
95
+ cwd?: string;
96
+ skipGitRoot?: boolean;
97
+ stdio?: "inherit" | "pipe";
98
+ }
99
+ type ExecResult = {
100
+ error: string;
101
+ exitCode: number;
102
+ raw: SpawnRaw;
103
+ success: false;
104
+ } | {
105
+ exitCode: number;
106
+ raw: SpawnRaw;
107
+ stderr: string;
108
+ stdout: string;
109
+ success: true;
110
+ } | {
111
+ raw: SpawnRaw;
112
+ success: true;
113
+ tools: ToolInfo[];
114
+ };
115
+ interface ToolInfo {
116
+ details: string;
117
+ name: string;
118
+ type: string;
119
+ }
120
+ declare function exec(appName?: string, options?: ExecOptions): Promise<ExecResult>;
121
+ declare function parseToolList(output: string): ToolInfo[];
122
+ //#endregion
123
+ //#region src/commands/version.d.ts
124
+ type VersionResult = {
125
+ error: string;
126
+ exitCode: number;
127
+ raw: SpawnRaw;
128
+ success: false;
129
+ } | {
130
+ raw: SpawnRaw;
131
+ success: true;
132
+ version: string;
133
+ };
134
+ declare function version(): Promise<VersionResult>;
135
+ //#endregion
136
+ //#region src/commands/cache.d.ts
137
+ interface CacheClearOptions {
138
+ all?: boolean;
139
+ cwd?: string;
140
+ dryRun?: boolean;
141
+ }
142
+ type CacheClearResult = {
143
+ error: string;
144
+ exitCode: number;
145
+ raw: SpawnRaw;
146
+ success: false;
147
+ } | {
148
+ message: string;
149
+ raw: SpawnRaw;
150
+ success: true;
151
+ };
152
+ interface CachePathProjectOptions {
153
+ cwd?: string;
154
+ }
155
+ type CachePathResult = {
156
+ error: string;
157
+ exitCode: number;
158
+ raw: SpawnRaw;
159
+ success: false;
160
+ } | {
161
+ path: string;
162
+ raw: SpawnRaw;
163
+ success: true;
164
+ };
165
+ declare const cache: {
166
+ readonly clear: (options?: CacheClearOptions) => Promise<CacheClearResult>;
167
+ readonly path: () => Promise<CachePathResult>;
168
+ readonly pathProject: (options?: CachePathProjectOptions) => Promise<CachePathResult>;
169
+ };
170
+ //#endregion
171
+ //#region src/commands/fix.d.ts
172
+ type FixOptions = ToolCommandOptions;
173
+ type FixResult = ToolCommandResult;
174
+ declare const fix: (options?: ToolCommandOptions) => Promise<ToolCommandResult>;
175
+ //#endregion
176
+ //#region src/commands/lint.d.ts
177
+ type LintOptions = ToolCommandOptions;
178
+ type LintResult = ToolCommandResult;
179
+ declare const lint: (options?: ToolCommandOptions) => Promise<ToolCommandResult>;
180
+ //#endregion
181
+ //#region src/index.d.ts
182
+ declare const _default: {
183
+ cache: {
184
+ readonly clear: (options?: CacheClearOptions) => Promise<CacheClearResult>;
185
+ readonly path: () => Promise<CachePathResult>;
186
+ readonly pathProject: (options?: CachePathProjectOptions) => Promise<CachePathResult>;
187
+ };
188
+ check: typeof check;
189
+ exec: typeof exec;
190
+ fix: (options?: ToolCommandOptions) => Promise<ToolCommandResult>;
191
+ lint: (options?: ToolCommandOptions) => Promise<ToolCommandResult>;
192
+ version: typeof version;
193
+ };
194
+ //#endregion
195
+ export { type CacheClearOptions, type CacheClearResult, type CachePathProjectOptions, type CachePathResult, type CheckOptions, type CheckResult, type ExecOptions, type ExecResult, type FixOptions, type FixResult, type GroupJSON, type LintOptions, type LintResult, type ParallelGroupJSON, type PlanJSON, type SpawnRaw, type TaskJSON, type ToolInfo, type VersionResult, cache, check, _default as default, exec, fix, lint, parseToolList, version };
196
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","names":[],"sources":["../src/types.ts","../src/tool-command.ts","../src/commands/check.ts","../src/commands/exec.ts","../src/commands/version.ts","../src/commands/cache.ts","../src/commands/fix.ts","../src/commands/lint.ts","../src/index.ts"],"mappings":"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"}
package/lib/index.js ADDED
@@ -0,0 +1,351 @@
1
+ import { createRequire } from "node:module";
2
+ import { execa } from "execa";
3
+ import { existsSync } from "node:fs";
4
+ import { join } from "node:path";
5
+ //#region ../../packaging/npm/datamitsu/get-exe.js
6
+ function getExePath() {
7
+ const platform = getPlatform();
8
+ const arch = getArch();
9
+ const ext = platform === "win32" ? ".exe" : "";
10
+ const packageName = `@datamitsu/datamitsu-${platform}-${arch}`;
11
+ const exeName = `datamitsu${ext}`;
12
+ try {
13
+ const exePath = join(join(createRequire(import.meta.url).resolve(`${packageName}/package.json`), ".."), exeName);
14
+ if (existsSync(exePath)) return exePath;
15
+ } catch {}
16
+ throw new Error(`datamitsu binary not found for platform ${platform}-${arch}.\nPlease make sure the package "${packageName}" is installed.\nIf you're seeing this error, try reinstalling datamitsu: npm install @datamitsu/datamitsu`);
17
+ }
18
+ function getArch() {
19
+ const arch = process.arch;
20
+ if (arch === "x64") return "x64";
21
+ if (arch === "arm64" || arch === "aarch64") return "arm64";
22
+ return arch;
23
+ }
24
+ function getPlatform() {
25
+ const platform = process.platform;
26
+ if (platform === "cygwin") return "win32";
27
+ return platform;
28
+ }
29
+ //#endregion
30
+ //#region src/spawn.ts
31
+ async function spawn(args, options = {}) {
32
+ const { cwd, stdio = "pipe" } = options;
33
+ const binaryPath = getExePath();
34
+ const fullArgs = [
35
+ "--binary-command",
36
+ "datamitsu",
37
+ ...args
38
+ ];
39
+ let result;
40
+ try {
41
+ result = await execa(binaryPath, fullArgs, {
42
+ cwd,
43
+ reject: false,
44
+ stdio
45
+ });
46
+ } catch (error) {
47
+ throw new Error(`Failed to execute datamitsu binary at ${binaryPath}: ${error.message}`, { cause: error });
48
+ }
49
+ return {
50
+ exitCode: result.exitCode ?? 1,
51
+ failed: result.failed,
52
+ stderr: result.stderr ?? "",
53
+ stdout: result.stdout ?? ""
54
+ };
55
+ }
56
+ //#endregion
57
+ //#region src/commands/cache.ts
58
+ const cache = {
59
+ async clear(options = {}) {
60
+ const { all = false, cwd, dryRun = false } = options;
61
+ const args = ["cache", "clear"];
62
+ if (all) args.push("--all");
63
+ if (dryRun) args.push("--dry-run");
64
+ const raw = await spawn(args, cwd ? { cwd } : {});
65
+ if (raw.failed) return {
66
+ error: raw.stderr || raw.stdout,
67
+ exitCode: raw.exitCode,
68
+ raw,
69
+ success: false
70
+ };
71
+ return {
72
+ message: raw.stdout.trim(),
73
+ raw,
74
+ success: true
75
+ };
76
+ },
77
+ async path() {
78
+ const raw = await spawn(["cache", "path"]);
79
+ if (raw.failed) return {
80
+ error: raw.stderr || raw.stdout,
81
+ exitCode: raw.exitCode,
82
+ raw,
83
+ success: false
84
+ };
85
+ return {
86
+ path: raw.stdout.trim(),
87
+ raw,
88
+ success: true
89
+ };
90
+ },
91
+ async pathProject(options = {}) {
92
+ const { cwd } = options;
93
+ const raw = await spawn([
94
+ "cache",
95
+ "path",
96
+ "project"
97
+ ], cwd ? { cwd } : {});
98
+ if (raw.failed) return {
99
+ error: raw.stderr || raw.stdout,
100
+ exitCode: raw.exitCode,
101
+ raw,
102
+ success: false
103
+ };
104
+ return {
105
+ path: raw.stdout.trim(),
106
+ raw,
107
+ success: true
108
+ };
109
+ }
110
+ };
111
+ //#endregion
112
+ //#region src/json.ts
113
+ function extractAllJSON(output) {
114
+ if (!output) return [];
115
+ const results = [];
116
+ let pos = 0;
117
+ while (pos < output.length) {
118
+ const start = output.indexOf("{", pos);
119
+ if (start === -1) break;
120
+ const end = findJSONEnd(output, start);
121
+ if (end === -1) break;
122
+ results.push(output.slice(start, end + 1));
123
+ pos = end + 1;
124
+ }
125
+ return results;
126
+ }
127
+ function extractJSON(output) {
128
+ if (!output) return null;
129
+ const start = output.indexOf("{");
130
+ if (start === -1) return null;
131
+ const end = findJSONEnd(output, start);
132
+ if (end === -1) return null;
133
+ return output.slice(start, end + 1);
134
+ }
135
+ function findJSONEnd(output, start) {
136
+ let depth = 0;
137
+ let inString = false;
138
+ let escape = false;
139
+ for (let i = start; i < output.length; i++) {
140
+ const ch = output[i];
141
+ if (escape) escape = false;
142
+ else if (inString) {
143
+ if (ch === "\\") escape = true;
144
+ else if (ch === "\"") inString = false;
145
+ } else switch (ch) {
146
+ case "\"":
147
+ inString = true;
148
+ break;
149
+ case "{":
150
+ depth++;
151
+ break;
152
+ case "}":
153
+ depth--;
154
+ if (depth === 0) return i;
155
+ break;
156
+ }
157
+ }
158
+ return -1;
159
+ }
160
+ //#endregion
161
+ //#region src/tool-command.ts
162
+ function buildArgs$1(commandName, options = {}) {
163
+ const { beforeConfig = [], config = [], explain = false, files = [], fileScoped = false, skipGitRoot = false, tools = [] } = options;
164
+ const args = [commandName];
165
+ if (explain === true) args.push("--explain");
166
+ else if (explain) args.push(`--explain=${explain}`);
167
+ if (fileScoped) args.push("--file-scoped");
168
+ if (tools.length > 0) args.push("--tools", tools.join(","));
169
+ for (const c of config) args.push("--config", c);
170
+ for (const bc of beforeConfig) args.push("--before-config", bc);
171
+ if (skipGitRoot) args.push("--skip-git-root");
172
+ args.push(...files);
173
+ return args;
174
+ }
175
+ function createToolCommand(commandName) {
176
+ return async function(options = {}) {
177
+ const { explain = false } = options;
178
+ const args = buildArgs$1(commandName, options);
179
+ const spawnOptions = {};
180
+ if (options.cwd !== void 0) spawnOptions.cwd = options.cwd;
181
+ if (options.stdio !== void 0) spawnOptions.stdio = options.stdio;
182
+ const raw = await spawn(args, spawnOptions);
183
+ if (raw.failed) return {
184
+ error: raw.stderr || raw.stdout,
185
+ exitCode: raw.exitCode,
186
+ raw,
187
+ success: false
188
+ };
189
+ if (explain === "json") try {
190
+ const jsonStr = extractJSON(raw.stdout) || raw.stdout;
191
+ return {
192
+ plan: JSON.parse(jsonStr),
193
+ raw,
194
+ success: true
195
+ };
196
+ } catch {
197
+ return {
198
+ error: `Failed to parse JSON output: ${raw.stdout}`,
199
+ exitCode: raw.exitCode,
200
+ raw,
201
+ success: false
202
+ };
203
+ }
204
+ if (explain) return {
205
+ output: raw.stdout,
206
+ raw,
207
+ success: true
208
+ };
209
+ return {
210
+ exitCode: raw.exitCode,
211
+ raw,
212
+ success: true
213
+ };
214
+ };
215
+ }
216
+ //#endregion
217
+ //#region src/commands/check.ts
218
+ const baseCheck = createToolCommand("check");
219
+ async function check(options = {}) {
220
+ if (options.explain !== "json") return baseCheck(options);
221
+ const args = buildArgs$1("check", options);
222
+ const spawnOptions = {};
223
+ if (options.cwd !== void 0) spawnOptions.cwd = options.cwd;
224
+ if (options.stdio !== void 0) spawnOptions.stdio = options.stdio;
225
+ const raw = await spawn(args, spawnOptions);
226
+ if (raw.failed) return {
227
+ error: raw.stderr || raw.stdout,
228
+ exitCode: raw.exitCode,
229
+ raw,
230
+ success: false
231
+ };
232
+ try {
233
+ const jsonStrings = extractAllJSON(raw.stdout);
234
+ if (jsonStrings.length === 0) throw new Error("No JSON found");
235
+ const plans = jsonStrings.map((s) => JSON.parse(s));
236
+ return {
237
+ plan: plans[0],
238
+ plans,
239
+ raw,
240
+ success: true
241
+ };
242
+ } catch {
243
+ return {
244
+ error: `Failed to parse JSON output: ${raw.stdout}`,
245
+ exitCode: raw.exitCode,
246
+ raw,
247
+ success: false
248
+ };
249
+ }
250
+ }
251
+ //#endregion
252
+ //#region src/commands/exec.ts
253
+ async function exec(appName, options = {}) {
254
+ const spawnArgs = buildArgs(appName, options);
255
+ const spawnOpts = {};
256
+ if (options.cwd !== void 0) spawnOpts.cwd = options.cwd;
257
+ if (options.stdio !== void 0) spawnOpts.stdio = options.stdio;
258
+ const raw = await spawn(spawnArgs, spawnOpts);
259
+ if (!appName) {
260
+ if (raw.failed) return {
261
+ error: raw.stderr || raw.stdout,
262
+ exitCode: raw.exitCode,
263
+ raw,
264
+ success: false
265
+ };
266
+ return {
267
+ raw,
268
+ success: true,
269
+ tools: parseToolList(raw.stdout)
270
+ };
271
+ }
272
+ if (raw.failed) return {
273
+ error: raw.stderr || raw.stdout,
274
+ exitCode: raw.exitCode,
275
+ raw,
276
+ success: false
277
+ };
278
+ return {
279
+ exitCode: raw.exitCode,
280
+ raw,
281
+ stderr: raw.stderr,
282
+ stdout: raw.stdout,
283
+ success: true
284
+ };
285
+ }
286
+ const ANSI_PATTERN = new RegExp(`${String.fromCodePoint(27)}\\[[0-9;]*m`, "g");
287
+ function parseToolList(output) {
288
+ if (!output || !output.trim()) return [];
289
+ const tools = [];
290
+ let currentType = null;
291
+ const typePattern = /^\[(binary|uv|fnm|jvm|shell)\]$/;
292
+ const toolPattern = /^ {2}(\S+)(?:\s{2,}(.+))?$/;
293
+ for (const line of output.split("\n").map((l) => l.replace(ANSI_PATTERN, ""))) {
294
+ const typeMatch = line.match(typePattern);
295
+ if (typeMatch?.[1]) currentType = typeMatch[1];
296
+ else if (currentType) {
297
+ const toolMatch = line.match(toolPattern);
298
+ if (toolMatch?.[1]) tools.push({
299
+ details: toolMatch[2] || "",
300
+ name: toolMatch[1],
301
+ type: currentType
302
+ });
303
+ }
304
+ }
305
+ return tools;
306
+ }
307
+ function buildArgs(appName, options = {}) {
308
+ const { args = [], beforeConfig = [], config = [], skipGitRoot = false } = options;
309
+ const spawnArgs = ["exec"];
310
+ for (const c of config) spawnArgs.push("--config", c);
311
+ for (const bc of beforeConfig) spawnArgs.push("--before-config", bc);
312
+ if (skipGitRoot) spawnArgs.push("--skip-git-root");
313
+ if (appName) spawnArgs.push(appName, ...args);
314
+ return spawnArgs;
315
+ }
316
+ //#endregion
317
+ //#region src/commands/fix.ts
318
+ const fix = createToolCommand("fix");
319
+ //#endregion
320
+ //#region src/commands/lint.ts
321
+ const lint = createToolCommand("lint");
322
+ //#endregion
323
+ //#region src/commands/version.ts
324
+ async function version() {
325
+ const raw = await spawn(["version"]);
326
+ if (raw.failed) return {
327
+ error: raw.stderr || raw.stdout,
328
+ exitCode: raw.exitCode,
329
+ raw,
330
+ success: false
331
+ };
332
+ return {
333
+ raw,
334
+ success: true,
335
+ version: (raw.stdout.trim().split("\n")[0] ?? "").replace(/^.*version\s+/, "")
336
+ };
337
+ }
338
+ //#endregion
339
+ //#region src/index.ts
340
+ var src_default = {
341
+ cache,
342
+ check,
343
+ exec,
344
+ fix,
345
+ lint,
346
+ version
347
+ };
348
+ //#endregion
349
+ export { cache, check, src_default as default, exec, fix, lint, parseToolList, version };
350
+
351
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","names":["buildArgs","buildArgs"],"sources":["../../../packaging/npm/datamitsu/get-exe.js","../src/spawn.ts","../src/commands/cache.ts","../src/json.ts","../src/tool-command.ts","../src/commands/check.ts","../src/commands/exec.ts","../src/commands/fix.ts","../src/commands/lint.ts","../src/commands/version.ts","../src/index.ts"],"sourcesContent":["import { existsSync } from \"node:fs\";\nimport { createRequire } from \"node:module\";\nimport { join } from \"node:path\";\n\nexport function getExePath() {\n const platform = getPlatform();\n const arch = getArch();\n const ext = platform === \"win32\" ? \".exe\" : \"\";\n\n const packageName = `@datamitsu/datamitsu-${platform}-${arch}`;\n const exeName = `datamitsu${ext}`;\n\n try {\n // Try to resolve the platform-specific package using createRequire for ES modules\n const require = createRequire(import.meta.url);\n const packagePath = require.resolve(`${packageName}/package.json`);\n const packageDir = join(packagePath, \"..\");\n const exePath = join(packageDir, exeName);\n\n if (existsSync(exePath)) {\n return exePath;\n }\n } catch {\n // Package not found\n }\n\n throw new Error(\n `datamitsu binary not found for platform ${platform}-${arch}.\\n` +\n `Please make sure the package \"${packageName}\" is installed.\\n` +\n `If you're seeing this error, try reinstalling datamitsu: npm install @datamitsu/datamitsu`,\n );\n}\n\nfunction getArch() {\n const arch = process.arch;\n // Normalize architecture names\n if (arch === \"x64\") {\n return \"x64\";\n }\n if (arch === \"arm64\" || arch === \"aarch64\") {\n return \"arm64\";\n }\n return arch;\n}\n\nfunction getPlatform() {\n const platform = process.platform;\n // Keep win32 as-is to match package names\n if (platform === \"cygwin\") {\n return \"win32\";\n }\n return platform;\n}\n","import { execa } from \"execa\";\n\nimport { getExePath } from \"@datamitsu/datamitsu/get-exe.js\";\n\nimport type { SpawnRaw } from \"./types.js\";\n\nexport interface SpawnOptions {\n cwd?: string;\n stdio?: \"pipe\" | \"inherit\";\n}\n\nexport async function spawn(args: string[], options: SpawnOptions = {}): Promise<SpawnRaw> {\n const { cwd, stdio = \"pipe\" } = options;\n\n const binaryPath = getExePath();\n const fullArgs = [\"--binary-command\", \"datamitsu\", ...args];\n\n let result;\n try {\n result = await execa(binaryPath, fullArgs, {\n cwd,\n reject: false,\n stdio,\n });\n } catch (error) {\n throw new Error(`Failed to execute datamitsu binary at ${binaryPath}: ${(error as Error).message}`, {\n cause: error,\n });\n }\n\n return {\n exitCode: result.exitCode ?? 1,\n failed: result.failed,\n stderr: result.stderr ?? \"\",\n stdout: result.stdout ?? \"\",\n };\n}\n","import { spawn } from \"../spawn.js\";\nimport type { SpawnRaw } from \"../types.js\";\n\nexport interface CacheClearOptions {\n all?: boolean;\n cwd?: string;\n dryRun?: boolean;\n}\n\nexport type CacheClearResult =\n | { error: string; exitCode: number; raw: SpawnRaw; success: false }\n | { message: string; raw: SpawnRaw; success: true };\n\nexport interface CachePathProjectOptions {\n cwd?: string;\n}\n\nexport type CachePathResult =\n | { error: string; exitCode: number; raw: SpawnRaw; success: false }\n | { path: string; raw: SpawnRaw; success: true };\n\nexport const cache = {\n async clear(options: CacheClearOptions = {}): Promise<CacheClearResult> {\n const { all = false, cwd, dryRun = false } = options;\n const args = [\"cache\", \"clear\"];\n\n if (all) {\n args.push(\"--all\");\n }\n\n if (dryRun) {\n args.push(\"--dry-run\");\n }\n\n const raw = await spawn(args, cwd ? { cwd } : {});\n\n if (raw.failed) {\n return {\n error: raw.stderr || raw.stdout,\n exitCode: raw.exitCode,\n raw,\n success: false,\n };\n }\n\n return {\n message: raw.stdout.trim(),\n raw,\n success: true,\n };\n },\n\n async path(): Promise<CachePathResult> {\n const raw = await spawn([\"cache\", \"path\"]);\n\n if (raw.failed) {\n return {\n error: raw.stderr || raw.stdout,\n exitCode: raw.exitCode,\n raw,\n success: false,\n };\n }\n\n return {\n path: raw.stdout.trim(),\n raw,\n success: true,\n };\n },\n\n async pathProject(options: CachePathProjectOptions = {}): Promise<CachePathResult> {\n const { cwd } = options;\n const raw = await spawn([\"cache\", \"path\", \"project\"], cwd ? { cwd } : {});\n\n if (raw.failed) {\n return {\n error: raw.stderr || raw.stdout,\n exitCode: raw.exitCode,\n raw,\n success: false,\n };\n }\n\n return {\n path: raw.stdout.trim(),\n raw,\n success: true,\n };\n },\n} as const;\n","export function extractAllJSON(output: string): string[] {\n if (!output) {\n return [];\n }\n const results: string[] = [];\n let pos = 0;\n while (pos < output.length) {\n const start = output.indexOf(\"{\", pos);\n if (start === -1) {\n break;\n }\n const end = findJSONEnd(output, start);\n if (end === -1) {\n break;\n }\n results.push(output.slice(start, end + 1));\n pos = end + 1;\n }\n return results;\n}\n\nexport function extractJSON(output: string): string | null {\n if (!output) {\n return null;\n }\n const start = output.indexOf(\"{\");\n if (start === -1) {\n return null;\n }\n const end = findJSONEnd(output, start);\n if (end === -1) {\n return null;\n }\n return output.slice(start, end + 1);\n}\n\nfunction findJSONEnd(output: string, start: number): number {\n let depth = 0;\n let inString = false;\n let escape = false;\n for (let i = start; i < output.length; i++) {\n const ch = output[i];\n if (escape) {\n escape = false;\n } else if (inString) {\n if (ch === \"\\\\\") {\n escape = true;\n } else if (ch === '\"') {\n inString = false;\n }\n } else {\n switch (ch) {\n case '\"': {\n inString = true;\n\n break;\n }\n case \"{\": {\n depth++;\n\n break;\n }\n case \"}\": {\n depth--;\n if (depth === 0) {\n return i;\n }\n\n break;\n }\n // No default\n }\n }\n }\n return -1;\n}\n","import { extractJSON } from \"./json.js\";\nimport { spawn } from \"./spawn.js\";\nimport type { PlanJSON, SpawnRaw } from \"./types.js\";\n\nexport interface BaseOptions {\n beforeConfig?: string[];\n config?: string[];\n explain?: boolean | \"detailed\" | \"json\" | \"summary\" | \"text\";\n files?: string[];\n fileScoped?: boolean;\n skipGitRoot?: boolean;\n tools?: string[];\n}\n\nexport interface ToolCommandOptions extends BaseOptions {\n cwd?: string;\n stdio?: \"pipe\" | \"inherit\";\n}\n\nexport type ToolCommandResult =\n | { exitCode: number; raw: SpawnRaw; success: true }\n | { output: string; raw: SpawnRaw; success: true }\n | { plan: PlanJSON; raw: SpawnRaw; success: true }\n | { error: string; exitCode: number; raw: SpawnRaw; success: false };\n\nexport function buildArgs(commandName: string, options: BaseOptions = {}): string[] {\n const {\n beforeConfig = [],\n config = [],\n explain = false,\n files = [],\n fileScoped = false,\n skipGitRoot = false,\n tools = [],\n } = options;\n\n const args: string[] = [commandName];\n\n if (explain === true) {\n args.push(\"--explain\");\n } else if (explain) {\n args.push(`--explain=${explain}`);\n }\n\n if (fileScoped) {\n args.push(\"--file-scoped\");\n }\n\n if (tools.length > 0) {\n args.push(\"--tools\", tools.join(\",\"));\n }\n\n for (const c of config) {\n args.push(\"--config\", c);\n }\n\n for (const bc of beforeConfig) {\n args.push(\"--before-config\", bc);\n }\n\n if (skipGitRoot) {\n args.push(\"--skip-git-root\");\n }\n\n args.push(...files);\n\n return args;\n}\n\nexport function createToolCommand(commandName: string): (options?: ToolCommandOptions) => Promise<ToolCommandResult> {\n return async function (options: ToolCommandOptions = {}): Promise<ToolCommandResult> {\n const { explain = false } = options;\n const args = buildArgs(commandName, options);\n const spawnOptions: { cwd?: string; stdio?: \"pipe\" | \"inherit\" } = {};\n if (options.cwd !== undefined) {\n spawnOptions.cwd = options.cwd;\n }\n if (options.stdio !== undefined) {\n spawnOptions.stdio = options.stdio;\n }\n const raw = await spawn(args, spawnOptions);\n\n if (raw.failed) {\n return {\n error: raw.stderr || raw.stdout,\n exitCode: raw.exitCode,\n raw,\n success: false,\n };\n }\n\n if (explain === \"json\") {\n try {\n const jsonStr = extractJSON(raw.stdout) || raw.stdout;\n const plan: PlanJSON = JSON.parse(jsonStr);\n return { plan, raw, success: true };\n } catch {\n return {\n error: `Failed to parse JSON output: ${raw.stdout}`,\n exitCode: raw.exitCode,\n raw,\n success: false,\n };\n }\n }\n\n if (explain) {\n return { output: raw.stdout, raw, success: true };\n }\n\n return { exitCode: raw.exitCode, raw, success: true };\n };\n}\n","import { extractAllJSON } from \"../json.js\";\nimport { spawn } from \"../spawn.js\";\nimport type { PlanJSON, SpawnRaw } from \"../types.js\";\nimport { buildArgs, createToolCommand, type ToolCommandOptions } from \"../tool-command.js\";\n\nexport type CheckOptions = ToolCommandOptions;\n\nexport type CheckResult =\n | { error: string; exitCode: number; raw: SpawnRaw; success: false }\n | { exitCode: number; raw: SpawnRaw; success: true }\n | { output: string; raw: SpawnRaw; success: true }\n | { plan: PlanJSON; plans: PlanJSON[]; raw: SpawnRaw; success: true };\n\nconst baseCheck = createToolCommand(\"check\");\n\nexport async function check(options: CheckOptions = {}): Promise<CheckResult> {\n if (options.explain !== \"json\") {\n return baseCheck(options) as Promise<CheckResult>;\n }\n\n const args = buildArgs(\"check\", options);\n const spawnOptions: { cwd?: string; stdio?: \"pipe\" | \"inherit\" } = {};\n if (options.cwd !== undefined) {\n spawnOptions.cwd = options.cwd;\n }\n if (options.stdio !== undefined) {\n spawnOptions.stdio = options.stdio;\n }\n const raw = await spawn(args, spawnOptions);\n\n if (raw.failed) {\n return {\n error: raw.stderr || raw.stdout,\n exitCode: raw.exitCode,\n raw,\n success: false,\n };\n }\n\n try {\n const jsonStrings = extractAllJSON(raw.stdout);\n if (jsonStrings.length === 0) {\n throw new Error(\"No JSON found\");\n }\n const plans: PlanJSON[] = jsonStrings.map((s) => JSON.parse(s));\n return { plan: plans[0]!, plans, raw, success: true };\n } catch {\n return {\n error: `Failed to parse JSON output: ${raw.stdout}`,\n exitCode: raw.exitCode,\n raw,\n success: false,\n };\n }\n}\n","import { spawn } from \"../spawn.js\";\nimport type { SpawnRaw } from \"../types.js\";\n\nexport interface ExecOptions {\n args?: string[];\n beforeConfig?: string[];\n config?: string[];\n cwd?: string;\n skipGitRoot?: boolean;\n stdio?: \"inherit\" | \"pipe\";\n}\n\nexport type ExecResult =\n | { error: string; exitCode: number; raw: SpawnRaw; success: false }\n | { exitCode: number; raw: SpawnRaw; stderr: string; stdout: string; success: true }\n | { raw: SpawnRaw; success: true; tools: ToolInfo[] };\n\nexport interface ToolInfo {\n details: string;\n name: string;\n type: string;\n}\n\nexport async function exec(appName?: string, options: ExecOptions = {}): Promise<ExecResult> {\n const spawnArgs = buildArgs(appName, options);\n const spawnOpts: { cwd?: string; stdio?: \"pipe\" | \"inherit\" } = {};\n if (options.cwd !== undefined) {\n spawnOpts.cwd = options.cwd;\n }\n if (options.stdio !== undefined) {\n spawnOpts.stdio = options.stdio;\n }\n const raw = await spawn(spawnArgs, spawnOpts);\n\n if (!appName) {\n if (raw.failed) {\n return {\n error: raw.stderr || raw.stdout,\n exitCode: raw.exitCode,\n raw,\n success: false,\n };\n }\n const tools = parseToolList(raw.stdout);\n return { raw, success: true, tools };\n }\n\n if (raw.failed) {\n return {\n error: raw.stderr || raw.stdout,\n exitCode: raw.exitCode,\n raw,\n success: false,\n };\n }\n\n return {\n exitCode: raw.exitCode,\n raw,\n stderr: raw.stderr,\n stdout: raw.stdout,\n success: true,\n };\n}\n\nconst ESC = String.fromCodePoint(0x1b);\nconst ANSI_PATTERN = new RegExp(`${ESC}\\\\[[0-9;]*m`, \"g\");\n\nexport function parseToolList(output: string): ToolInfo[] {\n if (!output || !output.trim()) {\n return [];\n }\n\n const tools: ToolInfo[] = [];\n let currentType: string | null = null;\n const typePattern = /^\\[(binary|uv|fnm|jvm|shell)\\]$/;\n const toolPattern = /^ {2}(\\S+)(?:\\s{2,}(.+))?$/;\n\n for (const line of output.split(\"\\n\").map((l) => l.replace(ANSI_PATTERN, \"\"))) {\n const typeMatch = line.match(typePattern);\n if (typeMatch?.[1]) {\n currentType = typeMatch[1];\n } else if (currentType) {\n const toolMatch = line.match(toolPattern);\n if (toolMatch?.[1]) {\n tools.push({\n details: toolMatch[2] || \"\",\n name: toolMatch[1],\n type: currentType,\n });\n }\n }\n }\n\n return tools;\n}\n\nfunction buildArgs(appName: string | undefined, options: ExecOptions = {}): string[] {\n const { args = [], beforeConfig = [], config = [], skipGitRoot = false } = options;\n\n const spawnArgs = [\"exec\"];\n\n for (const c of config) {\n spawnArgs.push(\"--config\", c);\n }\n\n for (const bc of beforeConfig) {\n spawnArgs.push(\"--before-config\", bc);\n }\n\n if (skipGitRoot) {\n spawnArgs.push(\"--skip-git-root\");\n }\n\n if (appName) {\n spawnArgs.push(appName, ...args);\n }\n\n return spawnArgs;\n}\n","import { createToolCommand, type ToolCommandOptions, type ToolCommandResult } from \"../tool-command.js\";\n\nexport type FixOptions = ToolCommandOptions;\nexport type FixResult = ToolCommandResult;\n\nexport const fix = createToolCommand(\"fix\");\n","import { createToolCommand, type ToolCommandOptions, type ToolCommandResult } from \"../tool-command.js\";\n\nexport type LintOptions = ToolCommandOptions;\nexport type LintResult = ToolCommandResult;\n\nexport const lint = createToolCommand(\"lint\");\n","import { spawn } from \"../spawn.js\";\nimport type { SpawnRaw } from \"../types.js\";\n\nexport type VersionResult =\n | { error: string; exitCode: number; raw: SpawnRaw; success: false }\n | { raw: SpawnRaw; success: true; version: string };\n\nexport async function version(): Promise<VersionResult> {\n const raw = await spawn([\"version\"]);\n\n if (raw.failed) {\n return {\n error: raw.stderr || raw.stdout,\n exitCode: raw.exitCode,\n raw,\n success: false,\n };\n }\n\n const output = raw.stdout.trim().split(\"\\n\")[0] ?? \"\";\n const versionStr = output.replace(/^.*version\\s+/, \"\");\n return {\n raw,\n success: true,\n version: versionStr,\n };\n}\n","import { cache } from \"./commands/cache.js\";\nimport { check } from \"./commands/check.js\";\nimport { exec } from \"./commands/exec.js\";\nimport { fix } from \"./commands/fix.js\";\nimport { lint } from \"./commands/lint.js\";\nimport { version } from \"./commands/version.js\";\n\nexport default { cache, check, exec, fix, lint, version };\nexport { cache } from \"./commands/cache.js\";\nexport type {\n CacheClearOptions,\n CacheClearResult,\n CachePathProjectOptions,\n CachePathResult,\n} from \"./commands/cache.js\";\nexport { check } from \"./commands/check.js\";\nexport type { CheckOptions, CheckResult } from \"./commands/check.js\";\nexport { exec, parseToolList } from \"./commands/exec.js\";\nexport type { ExecOptions, ExecResult, ToolInfo } from \"./commands/exec.js\";\nexport { fix } from \"./commands/fix.js\";\nexport type { FixOptions, FixResult } from \"./commands/fix.js\";\nexport { lint } from \"./commands/lint.js\";\nexport type { LintOptions, LintResult } from \"./commands/lint.js\";\nexport { version } from \"./commands/version.js\";\nexport type { VersionResult } from \"./commands/version.js\";\nexport type { GroupJSON, ParallelGroupJSON, PlanJSON, SpawnRaw, TaskJSON } from \"./types.js\";\n"],"mappings":"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"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@datamitsu/datamitsu",
3
- "version": "0.0.3-alpha-21",
3
+ "version": "0.0.3-alpha-22",
4
4
  "description": "Configuration management and binary distribution tool. JavaScript-configurable tool orchestration written in Go.",
5
5
  "keywords": [
6
6
  "datamitsu",
@@ -24,25 +24,41 @@
24
24
  "license": "MIT",
25
25
  "author": "Alexander Svinarev <shibanet0@gmail.com> (shibanet0.com)",
26
26
  "type": "module",
27
+ "exports": {
28
+ ".": {
29
+ "types": "./lib/index.d.ts",
30
+ "default": "./lib/index.js"
31
+ },
32
+ "./get-exe.js": "./get-exe.js",
33
+ "./package.json": "./package.json"
34
+ },
35
+ "main": "./lib/index.js",
36
+ "types": "./lib/index.d.ts",
27
37
  "bin": {
28
38
  "datamitsu": "bin/index.js"
29
39
  },
30
40
  "files": [
31
41
  "bin",
42
+ "lib",
32
43
  "get-exe.js"
33
44
  ],
34
- "scripts": {},
45
+ "scripts": {
46
+ "test": "pnpm --filter @datamitsu/programmable-api-js test"
47
+ },
48
+ "dependencies": {
49
+ "execa": "^9.6.1"
50
+ },
35
51
  "devDependencies": {
36
52
  "@shibanet0/datamitsu-config": "0.0.3-alpha-21"
37
53
  },
38
54
  "optionalDependencies": {
39
- "@datamitsu/datamitsu-darwin-arm64": "0.0.3-alpha-21",
40
- "@datamitsu/datamitsu-darwin-x64": "0.0.3-alpha-21",
41
- "@datamitsu/datamitsu-freebsd-arm64": "0.0.3-alpha-21",
42
- "@datamitsu/datamitsu-freebsd-x64": "0.0.3-alpha-21",
43
- "@datamitsu/datamitsu-linux-arm64": "0.0.3-alpha-21",
44
- "@datamitsu/datamitsu-linux-x64": "0.0.3-alpha-21",
45
- "@datamitsu/datamitsu-win32-arm64": "0.0.3-alpha-21",
46
- "@datamitsu/datamitsu-win32-x64": "0.0.3-alpha-21"
55
+ "@datamitsu/datamitsu-darwin-arm64": "0.0.3-alpha-22",
56
+ "@datamitsu/datamitsu-darwin-x64": "0.0.3-alpha-22",
57
+ "@datamitsu/datamitsu-freebsd-arm64": "0.0.3-alpha-22",
58
+ "@datamitsu/datamitsu-freebsd-x64": "0.0.3-alpha-22",
59
+ "@datamitsu/datamitsu-linux-arm64": "0.0.3-alpha-22",
60
+ "@datamitsu/datamitsu-linux-x64": "0.0.3-alpha-22",
61
+ "@datamitsu/datamitsu-win32-arm64": "0.0.3-alpha-22",
62
+ "@datamitsu/datamitsu-win32-x64": "0.0.3-alpha-22"
47
63
  }
48
64
  }