@iloom/cli 0.1.17 → 0.1.19
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/README.md +51 -6
- package/dist/ClaudeContextManager-JKR4WGNU.js +13 -0
- package/dist/ClaudeService-55DQGB7T.js +12 -0
- package/dist/{GitHubService-F7Z3XJOS.js → GitHubService-LWP4GKGH.js} +3 -3
- package/dist/{LoomLauncher-MODG2SEM.js → LoomLauncher-UMMLPIZO.js} +7 -7
- package/dist/{PromptTemplateManager-7FINLRDE.js → PromptTemplateManager-WII75TKH.js} +2 -2
- package/dist/README.md +755 -0
- package/dist/{SettingsManager-VAZF26S2.js → SettingsManager-SKLUVE3K.js} +6 -2
- package/dist/{add-issue-22JBNOML.js → add-issue-X56V3XPB.js} +23 -8
- package/dist/add-issue-X56V3XPB.js.map +1 -0
- package/dist/{chunk-Y7SAGNUT.js → chunk-DEPYQRRB.js} +2 -2
- package/dist/{chunk-WKEWRSDB.js → chunk-ELFT36PV.js} +3 -3
- package/dist/chunk-FXV24OYZ.js +83 -0
- package/dist/chunk-FXV24OYZ.js.map +1 -0
- package/dist/{chunk-HPJJSYNS.js → chunk-H5LDRGVK.js} +6 -8
- package/dist/{chunk-HPJJSYNS.js.map → chunk-H5LDRGVK.js.map} +1 -1
- package/dist/{chunk-QEPVTTHD.js → chunk-IO4WFTL2.js} +17 -11
- package/dist/chunk-IO4WFTL2.js.map +1 -0
- package/dist/{chunk-KQDEK2ZW.js → chunk-JXQXSC45.js} +41 -9
- package/dist/chunk-JXQXSC45.js.map +1 -0
- package/dist/{chunk-JQ7VOSTC.js → chunk-KOCQAD2E.js} +3 -3
- package/dist/{chunk-YYSKGAZT.js → chunk-LAPY6NAE.js} +17 -8
- package/dist/chunk-LAPY6NAE.js.map +1 -0
- package/dist/{chunk-O2QWO64Z.js → chunk-PV3GAXQO.js} +56 -3
- package/dist/chunk-PV3GAXQO.js.map +1 -0
- package/dist/chunk-PVAVNJKS.js +188 -0
- package/dist/chunk-PVAVNJKS.js.map +1 -0
- package/dist/{chunk-CP2NU2JC.js → chunk-Q2KYPAH2.js} +7 -7
- package/dist/{chunk-CP2NU2JC.js.map → chunk-Q2KYPAH2.js.map} +1 -1
- package/dist/{chunk-W3DQTW63.js → chunk-USVVV3FP.js} +4 -4
- package/dist/{chunk-SSR5AVRJ.js → chunk-VCMMAFXQ.js} +21 -8
- package/dist/chunk-VCMMAFXQ.js.map +1 -0
- package/dist/chunk-VVH3ANF2.js +307 -0
- package/dist/chunk-VVH3ANF2.js.map +1 -0
- package/dist/{chunk-JBH2ZYYZ.js → chunk-VYQLLHZ7.js} +22 -3
- package/dist/chunk-VYQLLHZ7.js.map +1 -0
- package/dist/{chunk-SJUQ2NDR.js → chunk-ZMNQBJUI.js} +24 -19
- package/dist/chunk-ZMNQBJUI.js.map +1 -0
- package/dist/{chunk-T7QPXANZ.js → chunk-ZWXJBSUW.js} +17 -17
- package/dist/chunk-ZWXJBSUW.js.map +1 -0
- package/dist/{cleanup-3LUWPSM7.js → cleanup-ZHROIBSQ.js} +12 -16
- package/dist/cleanup-ZHROIBSQ.js.map +1 -0
- package/dist/cli.js +107 -49
- package/dist/cli.js.map +1 -1
- package/dist/contribute-3MQJ3XAQ.js +256 -0
- package/dist/contribute-3MQJ3XAQ.js.map +1 -0
- package/dist/{enhance-XJIQHVPD.js → enhance-VGWUX474.js} +18 -8
- package/dist/enhance-VGWUX474.js.map +1 -0
- package/dist/{feedback-23CLXKFT.js → feedback-ZOUCCHN4.js} +8 -8
- package/dist/{finish-3CQZIULO.js → finish-QJSK6Z7J.js} +36 -313
- package/dist/finish-QJSK6Z7J.js.map +1 -0
- package/dist/{git-LVRZ57GJ.js → git-OUYMVYJX.js} +2 -2
- package/dist/{ignite-WXEF2ID5.js → ignite-HICLZEYU.js} +124 -9
- package/dist/ignite-HICLZEYU.js.map +1 -0
- package/dist/index.d.ts +794 -712
- package/dist/index.js +169 -36
- package/dist/index.js.map +1 -1
- package/dist/init-UMKNHNV5.js +339 -0
- package/dist/init-UMKNHNV5.js.map +1 -0
- package/dist/mcp/github-comment-server.js +12 -9
- package/dist/mcp/github-comment-server.js.map +1 -1
- package/dist/neon-helpers-ZVIRPKCI.js +10 -0
- package/dist/{open-X6BTENPV.js → open-ETZUFSE4.js} +15 -17
- package/dist/{open-X6BTENPV.js.map → open-ETZUFSE4.js.map} +1 -1
- package/dist/prompts/init-prompt.txt +748 -0
- package/dist/prompts/issue-prompt.txt +141 -9
- package/dist/rebase-KBWFDZCN.js +95 -0
- package/dist/rebase-KBWFDZCN.js.map +1 -0
- package/dist/remote-GJEZWRCC.js +14 -0
- package/dist/{run-2JCPQAX3.js → run-4SVQ3WEU.js} +15 -17
- package/dist/{run-2JCPQAX3.js.map → run-4SVQ3WEU.js.map} +1 -1
- package/dist/schema/settings.schema.json +51 -1
- package/dist/{start-LWVRBJ6S.js → start-CT2ZEFP2.js} +54 -53
- package/dist/{start-LWVRBJ6S.js.map → start-CT2ZEFP2.js.map} +1 -1
- package/dist/{test-git-XPF4SZXJ.js → test-git-MKZATGZN.js} +3 -3
- package/dist/{test-prefix-XGFXFAYN.js → test-prefix-ZNLWDI3K.js} +3 -3
- package/dist/{update-DN3FSNKY.js → update-4TDDUR5K.js} +10 -4
- package/dist/{update-DN3FSNKY.js.map → update-4TDDUR5K.js.map} +1 -1
- package/package.json +3 -2
- package/dist/ClaudeContextManager-XOSXQ67R.js +0 -13
- package/dist/ClaudeService-YSZ6EXWP.js +0 -12
- package/dist/NeonProvider-PAGPUH7F.js +0 -12
- package/dist/add-issue-22JBNOML.js.map +0 -1
- package/dist/chunk-37DYYFVK.js +0 -29
- package/dist/chunk-37DYYFVK.js.map +0 -1
- package/dist/chunk-F3XBU2R7.js +0 -110
- package/dist/chunk-F3XBU2R7.js.map +0 -1
- package/dist/chunk-JBH2ZYYZ.js.map +0 -1
- package/dist/chunk-KQDEK2ZW.js.map +0 -1
- package/dist/chunk-O2QWO64Z.js.map +0 -1
- package/dist/chunk-QEPVTTHD.js.map +0 -1
- package/dist/chunk-SJUQ2NDR.js.map +0 -1
- package/dist/chunk-SSR5AVRJ.js.map +0 -1
- package/dist/chunk-T7QPXANZ.js.map +0 -1
- package/dist/chunk-YYSKGAZT.js.map +0 -1
- package/dist/cleanup-3LUWPSM7.js.map +0 -1
- package/dist/enhance-XJIQHVPD.js.map +0 -1
- package/dist/env-MDFL4ZXL.js +0 -23
- package/dist/finish-3CQZIULO.js.map +0 -1
- package/dist/ignite-WXEF2ID5.js.map +0 -1
- package/dist/init-RHACUR4E.js +0 -123
- package/dist/init-RHACUR4E.js.map +0 -1
- /package/dist/{ClaudeContextManager-XOSXQ67R.js.map → ClaudeContextManager-JKR4WGNU.js.map} +0 -0
- /package/dist/{ClaudeService-YSZ6EXWP.js.map → ClaudeService-55DQGB7T.js.map} +0 -0
- /package/dist/{GitHubService-F7Z3XJOS.js.map → GitHubService-LWP4GKGH.js.map} +0 -0
- /package/dist/{LoomLauncher-MODG2SEM.js.map → LoomLauncher-UMMLPIZO.js.map} +0 -0
- /package/dist/{NeonProvider-PAGPUH7F.js.map → PromptTemplateManager-WII75TKH.js.map} +0 -0
- /package/dist/{PromptTemplateManager-7FINLRDE.js.map → SettingsManager-SKLUVE3K.js.map} +0 -0
- /package/dist/{chunk-Y7SAGNUT.js.map → chunk-DEPYQRRB.js.map} +0 -0
- /package/dist/{chunk-WKEWRSDB.js.map → chunk-ELFT36PV.js.map} +0 -0
- /package/dist/{chunk-JQ7VOSTC.js.map → chunk-KOCQAD2E.js.map} +0 -0
- /package/dist/{chunk-W3DQTW63.js.map → chunk-USVVV3FP.js.map} +0 -0
- /package/dist/{feedback-23CLXKFT.js.map → feedback-ZOUCCHN4.js.map} +0 -0
- /package/dist/{SettingsManager-VAZF26S2.js.map → git-OUYMVYJX.js.map} +0 -0
- /package/dist/{env-MDFL4ZXL.js.map → neon-helpers-ZVIRPKCI.js.map} +0 -0
- /package/dist/{git-LVRZ57GJ.js.map → remote-GJEZWRCC.js.map} +0 -0
- /package/dist/{test-git-XPF4SZXJ.js.map → test-git-MKZATGZN.js.map} +0 -0
- /package/dist/{test-prefix-XGFXFAYN.js.map → test-prefix-ZNLWDI3K.js.map} +0 -0
package/dist/cli.js
CHANGED
|
@@ -1,11 +1,11 @@
|
|
|
1
1
|
#!/usr/bin/env node
|
|
2
2
|
import {
|
|
3
3
|
ShellCompletion
|
|
4
|
-
} from "./chunk-
|
|
4
|
+
} from "./chunk-PV3GAXQO.js";
|
|
5
5
|
import {
|
|
6
6
|
GitWorktreeManager
|
|
7
|
-
} from "./chunk-
|
|
8
|
-
import "./chunk-
|
|
7
|
+
} from "./chunk-IO4WFTL2.js";
|
|
8
|
+
import "./chunk-KOCQAD2E.js";
|
|
9
9
|
import {
|
|
10
10
|
logger
|
|
11
11
|
} from "./chunk-GEHQXLEI.js";
|
|
@@ -66,19 +66,66 @@ program.name("iloom").description(packageJson.description).version(packageJson.v
|
|
|
66
66
|
} catch (error) {
|
|
67
67
|
logger.debug(`Settings migration failed: ${error instanceof Error ? error.message : "Unknown"}`);
|
|
68
68
|
}
|
|
69
|
-
await validateSettingsForCommand();
|
|
69
|
+
await validateSettingsForCommand(thisCommand);
|
|
70
70
|
});
|
|
71
|
-
async function validateSettingsForCommand() {
|
|
71
|
+
async function validateSettingsForCommand(command) {
|
|
72
|
+
var _a, _b;
|
|
73
|
+
const commandName = command.args[0] ?? "";
|
|
74
|
+
const bypassCommands = ["help", "init", "update", "contribute"];
|
|
75
|
+
if (bypassCommands.includes(commandName)) {
|
|
76
|
+
return;
|
|
77
|
+
}
|
|
72
78
|
try {
|
|
73
|
-
const { SettingsManager } = await import("./SettingsManager-
|
|
79
|
+
const { SettingsManager } = await import("./SettingsManager-SKLUVE3K.js");
|
|
74
80
|
const settingsManager = new SettingsManager();
|
|
75
|
-
await settingsManager.loadSettings();
|
|
81
|
+
const settings = await settingsManager.loadSettings();
|
|
82
|
+
const { hasMultipleRemotes } = await import("./remote-GJEZWRCC.js");
|
|
83
|
+
const multipleRemotes = await hasMultipleRemotes();
|
|
84
|
+
if (multipleRemotes && !((_b = (_a = settings.issueManagement) == null ? void 0 : _a.github) == null ? void 0 : _b.remote)) {
|
|
85
|
+
await autoLaunchInitForMultipleRemotes();
|
|
86
|
+
return;
|
|
87
|
+
}
|
|
76
88
|
} catch (error) {
|
|
77
89
|
logger.error(`Configuration error: ${error instanceof Error ? error.message : "Unknown error"}`);
|
|
78
90
|
logger.info("Please fix your .iloom/settings.json file and try again.");
|
|
79
91
|
process.exit(1);
|
|
80
92
|
}
|
|
81
93
|
}
|
|
94
|
+
async function autoLaunchInitForMultipleRemotes() {
|
|
95
|
+
var _a, _b;
|
|
96
|
+
logger.info("Multiple git remotes detected, but no GitHub remote is configured.");
|
|
97
|
+
logger.info("");
|
|
98
|
+
logger.info("iloom will now launch an interactive configuration session with Claude");
|
|
99
|
+
logger.info("to help you select which remote to use for GitHub operations.");
|
|
100
|
+
logger.info("");
|
|
101
|
+
const { waitForKeypress } = await import("./prompt-ANTQWHUF.js");
|
|
102
|
+
await waitForKeypress("Press any key to start configuration...");
|
|
103
|
+
logger.info("");
|
|
104
|
+
try {
|
|
105
|
+
const { InitCommand } = await import("./init-UMKNHNV5.js");
|
|
106
|
+
const initCommand = new InitCommand();
|
|
107
|
+
const customInitialMessage = "Help me configure which git remote iloom should use for GitHub operations. I have multiple remotes and need to select the correct one.";
|
|
108
|
+
await initCommand.execute(customInitialMessage);
|
|
109
|
+
logger.info("");
|
|
110
|
+
logger.info("Configuration complete! Continuing with your original command...");
|
|
111
|
+
logger.info("");
|
|
112
|
+
const { SettingsManager } = await import("./SettingsManager-SKLUVE3K.js");
|
|
113
|
+
const settingsManager = new SettingsManager();
|
|
114
|
+
const settings = await settingsManager.loadSettings();
|
|
115
|
+
const { hasMultipleRemotes } = await import("./remote-GJEZWRCC.js");
|
|
116
|
+
const multipleRemotes = await hasMultipleRemotes();
|
|
117
|
+
if (multipleRemotes && !((_b = (_a = settings.issueManagement) == null ? void 0 : _a.github) == null ? void 0 : _b.remote)) {
|
|
118
|
+
logger.error("Configuration incomplete: GitHub remote is still not configured.");
|
|
119
|
+
logger.info('Please run "iloom init" again and configure the GitHub remote setting.');
|
|
120
|
+
process.exit(1);
|
|
121
|
+
}
|
|
122
|
+
return;
|
|
123
|
+
} catch (error) {
|
|
124
|
+
logger.error(`Failed to configure remotes: ${error instanceof Error ? error.message : "Unknown error"}`);
|
|
125
|
+
logger.info('You can manually run "iloom init" to configure settings.');
|
|
126
|
+
process.exit(1);
|
|
127
|
+
}
|
|
128
|
+
}
|
|
82
129
|
var shellCompletion = new ShellCompletion();
|
|
83
130
|
shellCompletion.init();
|
|
84
131
|
program.command("start").alias("create").alias("up").description("Create isolated workspace for an issue/PR").argument("[identifier]", "Issue number, PR number, or branch name (optional - will prompt if not provided)").option("--claude", "Enable Claude integration (default: true)").option("--no-claude", "Disable Claude integration").option("--code", "Enable VSCode (default: true)").option("--no-code", "Disable VSCode").option("--dev-server", "Enable dev server in terminal (default: true)").option("--no-dev-server", "Disable dev server").option("--terminal", "Enable terminal without dev server (default: false)").option("--no-terminal", "Disable terminal").addOption(
|
|
@@ -94,7 +141,7 @@ program.command("start").alias("create").alias("up").description("Create isolate
|
|
|
94
141
|
process.exit(1);
|
|
95
142
|
}
|
|
96
143
|
}
|
|
97
|
-
const { StartCommand } = await import("./start-
|
|
144
|
+
const { StartCommand } = await import("./start-CT2ZEFP2.js");
|
|
98
145
|
const command = new StartCommand();
|
|
99
146
|
await command.execute({ identifier: finalIdentifier, options });
|
|
100
147
|
} catch (error) {
|
|
@@ -104,7 +151,7 @@ program.command("start").alias("create").alias("up").description("Create isolate
|
|
|
104
151
|
});
|
|
105
152
|
program.command("add-issue").alias("a").description("Create and enhance GitHub issue without starting workspace").argument("<description>", "Natural language description of the issue (>50 chars, >2 spaces)").action(async (description) => {
|
|
106
153
|
try {
|
|
107
|
-
const { AddIssueCommand } = await import("./add-issue-
|
|
154
|
+
const { AddIssueCommand } = await import("./add-issue-X56V3XPB.js");
|
|
108
155
|
const command = new AddIssueCommand();
|
|
109
156
|
const issueNumber = await command.execute({
|
|
110
157
|
description,
|
|
@@ -119,7 +166,7 @@ program.command("add-issue").alias("a").description("Create and enhance GitHub i
|
|
|
119
166
|
});
|
|
120
167
|
program.command("feedback").alias("f").description("Submit feedback/bug report to iloom-cli repository").argument("<description>", "Natural language description of feedback (>50 chars, >2 spaces)").action(async (description) => {
|
|
121
168
|
try {
|
|
122
|
-
const { FeedbackCommand } = await import("./feedback-
|
|
169
|
+
const { FeedbackCommand } = await import("./feedback-ZOUCCHN4.js");
|
|
123
170
|
const command = new FeedbackCommand();
|
|
124
171
|
const issueNumber = await command.execute({
|
|
125
172
|
description,
|
|
@@ -134,7 +181,7 @@ program.command("feedback").alias("f").description("Submit feedback/bug report t
|
|
|
134
181
|
});
|
|
135
182
|
program.command("enhance").description("Apply enhancement agent to existing GitHub issue").argument("<issue-number>", "GitHub issue number to enhance", parseInt).option("--no-browser", "Skip browser opening prompt").option("--author <username>", "GitHub username to tag in questions (for CI usage)").action(async (issueNumber, options) => {
|
|
136
183
|
try {
|
|
137
|
-
const { EnhanceCommand } = await import("./enhance-
|
|
184
|
+
const { EnhanceCommand } = await import("./enhance-VGWUX474.js");
|
|
138
185
|
const command = new EnhanceCommand();
|
|
139
186
|
await command.execute({
|
|
140
187
|
issueNumber,
|
|
@@ -152,7 +199,7 @@ program.command("enhance").description("Apply enhancement agent to existing GitH
|
|
|
152
199
|
});
|
|
153
200
|
program.command("finish").alias("dn").description("Merge work and cleanup workspace").argument("[identifier]", "Issue number, PR number, or branch name (auto-detected if omitted)").option("-f, --force", "Skip confirmation prompts").option("-n, --dry-run", "Preview actions without executing").option("--pr <number>", "Treat input as PR number", parseFloat).option("--skip-build", "Skip post-merge build verification").action(async (identifier, options) => {
|
|
154
201
|
try {
|
|
155
|
-
const { FinishCommand } = await import("./finish-
|
|
202
|
+
const { FinishCommand } = await import("./finish-QJSK6Z7J.js");
|
|
156
203
|
const command = new FinishCommand();
|
|
157
204
|
await command.execute({ identifier, options });
|
|
158
205
|
} catch (error) {
|
|
@@ -160,11 +207,21 @@ program.command("finish").alias("dn").description("Merge work and cleanup worksp
|
|
|
160
207
|
process.exit(1);
|
|
161
208
|
}
|
|
162
209
|
});
|
|
210
|
+
program.command("rebase").description("Rebase current branch on main with Claude-assisted conflict resolution").option("-f, --force", "Skip confirmation prompts").option("-n, --dry-run", "Preview actions without executing").action(async (options) => {
|
|
211
|
+
try {
|
|
212
|
+
const { RebaseCommand } = await import("./rebase-KBWFDZCN.js");
|
|
213
|
+
const command = new RebaseCommand();
|
|
214
|
+
await command.execute(options);
|
|
215
|
+
} catch (error) {
|
|
216
|
+
logger.error(`Failed to rebase: ${error instanceof Error ? error.message : "Unknown error"}`);
|
|
217
|
+
process.exit(1);
|
|
218
|
+
}
|
|
219
|
+
});
|
|
163
220
|
program.command("spin").alias("ignite").description("Launch Claude with auto-detected workspace context").addOption(
|
|
164
221
|
new Option("--one-shot <mode>", "One-shot automation mode").choices(["default", "noReview", "bypassPermissions"]).default("default")
|
|
165
222
|
).action(async (options) => {
|
|
166
223
|
try {
|
|
167
|
-
const { IgniteCommand } = await import("./ignite-
|
|
224
|
+
const { IgniteCommand } = await import("./ignite-HICLZEYU.js");
|
|
168
225
|
const command = new IgniteCommand();
|
|
169
226
|
await command.execute(options.oneShot ?? "default");
|
|
170
227
|
} catch (error) {
|
|
@@ -175,7 +232,7 @@ program.command("spin").alias("ignite").description("Launch Claude with auto-det
|
|
|
175
232
|
program.command("open").description("Open workspace in browser or run CLI tool").argument("[identifier]", "Issue number, PR number, or branch name (auto-detected if omitted)").allowUnknownOption().action(async (identifier, _options, command) => {
|
|
176
233
|
try {
|
|
177
234
|
const args = (command == null ? void 0 : command.args) ? command.args.slice(identifier ? 1 : 0) : [];
|
|
178
|
-
const { OpenCommand } = await import("./open-
|
|
235
|
+
const { OpenCommand } = await import("./open-ETZUFSE4.js");
|
|
179
236
|
const cmd = new OpenCommand();
|
|
180
237
|
const input = identifier ? { identifier, args } : { args };
|
|
181
238
|
await cmd.execute(input);
|
|
@@ -187,7 +244,7 @@ program.command("open").description("Open workspace in browser or run CLI tool")
|
|
|
187
244
|
program.command("run").description("Run CLI tool or open workspace in browser").argument("[identifier]", "Issue number, PR number, or branch name (auto-detected if omitted)").allowUnknownOption().action(async (identifier, _options, command) => {
|
|
188
245
|
try {
|
|
189
246
|
const args = (command == null ? void 0 : command.args) ? command.args.slice(identifier ? 1 : 0) : [];
|
|
190
|
-
const { RunCommand } = await import("./run-
|
|
247
|
+
const { RunCommand } = await import("./run-4SVQ3WEU.js");
|
|
191
248
|
const cmd = new RunCommand();
|
|
192
249
|
const input = identifier ? { identifier, args } : { args };
|
|
193
250
|
await cmd.execute(input);
|
|
@@ -198,7 +255,7 @@ program.command("run").description("Run CLI tool or open workspace in browser").
|
|
|
198
255
|
});
|
|
199
256
|
program.command("cleanup").description("Remove workspaces").argument("[identifier]", "Branch name or issue number to cleanup (auto-detected)").option("-l, --list", "List all worktrees").option("-a, --all", "Remove all worktrees (interactive confirmation)").option("-i, --issue <number>", "Cleanup by issue number", parseInt).option("-f, --force", "Skip confirmations and force removal").option("--dry-run", "Show what would be done without doing it").action(async (identifier, options) => {
|
|
200
257
|
try {
|
|
201
|
-
const { CleanupCommand } = await import("./cleanup-
|
|
258
|
+
const { CleanupCommand } = await import("./cleanup-ZHROIBSQ.js");
|
|
202
259
|
const command = new CleanupCommand();
|
|
203
260
|
const input = {
|
|
204
261
|
options: options ?? {}
|
|
@@ -236,9 +293,9 @@ program.command("list").description("Show active workspaces").option("--json", "
|
|
|
236
293
|
process.exit(1);
|
|
237
294
|
}
|
|
238
295
|
});
|
|
239
|
-
program.command("init").description("Initialize iloom configuration and setup shell autocomplete").action(async () => {
|
|
296
|
+
program.command("init").alias("config").description("Initialize iloom configuration and setup shell autocomplete").action(async () => {
|
|
240
297
|
try {
|
|
241
|
-
const { InitCommand } = await import("./init-
|
|
298
|
+
const { InitCommand } = await import("./init-UMKNHNV5.js");
|
|
242
299
|
const command = new InitCommand();
|
|
243
300
|
await command.execute();
|
|
244
301
|
} catch (error) {
|
|
@@ -246,9 +303,19 @@ program.command("init").description("Initialize iloom configuration and setup sh
|
|
|
246
303
|
process.exit(1);
|
|
247
304
|
}
|
|
248
305
|
});
|
|
306
|
+
program.command("contribute").description("Set up local development environment for contributing to iloom").action(async () => {
|
|
307
|
+
try {
|
|
308
|
+
const { ContributeCommand } = await import("./contribute-3MQJ3XAQ.js");
|
|
309
|
+
const command = new ContributeCommand();
|
|
310
|
+
await command.execute();
|
|
311
|
+
} catch (error) {
|
|
312
|
+
logger.error(`Failed to set up contributor environment: ${error instanceof Error ? error.message : "Unknown error"}`);
|
|
313
|
+
process.exit(1);
|
|
314
|
+
}
|
|
315
|
+
});
|
|
249
316
|
program.command("update").description("Update iloom-cli to the latest version").option("--dry-run", "Show what would be done without actually updating").action(async (options) => {
|
|
250
317
|
try {
|
|
251
|
-
const { UpdateCommand } = await import("./update-
|
|
318
|
+
const { UpdateCommand } = await import("./update-4TDDUR5K.js");
|
|
252
319
|
const command = new UpdateCommand();
|
|
253
320
|
await command.execute(options);
|
|
254
321
|
} catch (error) {
|
|
@@ -258,7 +325,7 @@ program.command("update").description("Update iloom-cli to the latest version").
|
|
|
258
325
|
});
|
|
259
326
|
program.command("test-github").description("Test GitHub integration (Issue #3)").argument("<identifier>", "Issue number or PR number").option("--no-claude", "Skip Claude for branch name generation").action(async (identifier, options) => {
|
|
260
327
|
try {
|
|
261
|
-
const { GitHubService } = await import("./GitHubService-
|
|
328
|
+
const { GitHubService } = await import("./GitHubService-LWP4GKGH.js");
|
|
262
329
|
logger.info("Testing GitHub Integration\n");
|
|
263
330
|
const service = new GitHubService(options.claude !== void 0 ? { useClaude: options.claude } : {});
|
|
264
331
|
logger.info("Detecting input type...");
|
|
@@ -314,9 +381,9 @@ program.command("test-github").description("Test GitHub integration (Issue #3)")
|
|
|
314
381
|
program.command("test-claude").description("Test Claude integration (Issue #10)").option("--detect", "Test Claude CLI detection").option("--version", "Get Claude CLI version").option("--branch <title>", "Test branch name generation with given title").option("--issue <number>", "Issue number for branch generation", "123").option("--launch <prompt>", "Launch Claude with a prompt (headless)").option("--interactive", "Launch Claude interactively (requires --launch)").option("--template <name>", "Test template loading").action(async (options) => {
|
|
315
382
|
try {
|
|
316
383
|
const { detectClaudeCli, getClaudeVersion, generateBranchName, launchClaude } = await import("./claude-7LUVDZZ4.js");
|
|
317
|
-
const { PromptTemplateManager } = await import("./PromptTemplateManager-
|
|
318
|
-
const { ClaudeService } = await import("./ClaudeService-
|
|
319
|
-
const { ClaudeContextManager } = await import("./ClaudeContextManager-
|
|
384
|
+
const { PromptTemplateManager } = await import("./PromptTemplateManager-WII75TKH.js");
|
|
385
|
+
const { ClaudeService } = await import("./ClaudeService-55DQGB7T.js");
|
|
386
|
+
const { ClaudeContextManager } = await import("./ClaudeContextManager-JKR4WGNU.js");
|
|
320
387
|
logger.info("Testing Claude Integration\n");
|
|
321
388
|
if (options.detect) {
|
|
322
389
|
logger.info("Detecting Claude CLI...");
|
|
@@ -464,7 +531,7 @@ program.command("test-webserver").description("Test if a web server is running o
|
|
|
464
531
|
});
|
|
465
532
|
program.command("test-git").description("Test Git integration - findMainWorktreePath() function (reads .iloom/settings.json)").action(async () => {
|
|
466
533
|
try {
|
|
467
|
-
const { TestGitCommand } = await import("./test-git-
|
|
534
|
+
const { TestGitCommand } = await import("./test-git-MKZATGZN.js");
|
|
468
535
|
const command = new TestGitCommand();
|
|
469
536
|
await command.execute();
|
|
470
537
|
} catch (error) {
|
|
@@ -490,7 +557,7 @@ program.command("test-tabs").description("Test iTerm2 dual tab functionality - o
|
|
|
490
557
|
});
|
|
491
558
|
program.command("test-prefix").description("Test worktree prefix configuration - preview worktree paths (reads .iloom/settings.json)").action(async () => {
|
|
492
559
|
try {
|
|
493
|
-
const { TestPrefixCommand } = await import("./test-prefix-
|
|
560
|
+
const { TestPrefixCommand } = await import("./test-prefix-ZNLWDI3K.js");
|
|
494
561
|
const command = new TestPrefixCommand();
|
|
495
562
|
await command.execute();
|
|
496
563
|
} catch (error) {
|
|
@@ -502,29 +569,20 @@ program.command("test-prefix").description("Test worktree prefix configuration -
|
|
|
502
569
|
}
|
|
503
570
|
});
|
|
504
571
|
program.command("test-neon").description("Test Neon integration and debug configuration").action(async () => {
|
|
572
|
+
var _a;
|
|
505
573
|
try {
|
|
506
|
-
const {
|
|
507
|
-
const {
|
|
574
|
+
const { SettingsManager } = await import("./SettingsManager-SKLUVE3K.js");
|
|
575
|
+
const { createNeonProviderFromSettings } = await import("./neon-helpers-ZVIRPKCI.js");
|
|
508
576
|
logger.info("Testing Neon Integration\n");
|
|
509
|
-
logger.info("
|
|
510
|
-
const
|
|
511
|
-
|
|
512
|
-
|
|
513
|
-
}
|
|
514
|
-
|
|
515
|
-
logger.success(` Loaded ${Object.keys(envResult.parsed).length} environment variables`);
|
|
516
|
-
} else {
|
|
517
|
-
logger.info(" No .env files found or parsed");
|
|
518
|
-
}
|
|
519
|
-
logger.info("\n1. Environment Variables:");
|
|
520
|
-
logger.info(` NEON_PROJECT_ID: ${process.env.NEON_PROJECT_ID ?? "(not set)"}`);
|
|
521
|
-
logger.info(` NEON_PARENT_BRANCH: ${process.env.NEON_PARENT_BRANCH ?? "(not set)"}`);
|
|
577
|
+
logger.info("1. Settings Configuration:");
|
|
578
|
+
const settingsManager = new SettingsManager();
|
|
579
|
+
const settings = await settingsManager.loadSettings();
|
|
580
|
+
const neonConfig = (_a = settings.databaseProviders) == null ? void 0 : _a.neon;
|
|
581
|
+
logger.info(` projectId: ${(neonConfig == null ? void 0 : neonConfig.projectId) ?? "(not configured)"}`);
|
|
582
|
+
logger.info(` parentBranch: ${(neonConfig == null ? void 0 : neonConfig.parentBranch) ?? "(not configured)"}`);
|
|
522
583
|
logger.info("\n2. Creating NeonProvider...");
|
|
523
584
|
try {
|
|
524
|
-
const neonProvider =
|
|
525
|
-
projectId: process.env.NEON_PROJECT_ID ?? "",
|
|
526
|
-
parentBranch: process.env.NEON_PARENT_BRANCH ?? ""
|
|
527
|
-
});
|
|
585
|
+
const neonProvider = createNeonProviderFromSettings(settings);
|
|
528
586
|
logger.success(" NeonProvider created successfully");
|
|
529
587
|
logger.info("\n3. Testing Neon CLI availability...");
|
|
530
588
|
const isAvailable = await neonProvider.isCliAvailable();
|
|
@@ -544,7 +602,7 @@ program.command("test-neon").description("Test Neon integration and debug config
|
|
|
544
602
|
logger.info(" Run: neon auth");
|
|
545
603
|
return;
|
|
546
604
|
}
|
|
547
|
-
if (
|
|
605
|
+
if (neonConfig == null ? void 0 : neonConfig.projectId) {
|
|
548
606
|
logger.info("\n5. Testing branch listing...");
|
|
549
607
|
try {
|
|
550
608
|
const branches = await neonProvider.listBranches();
|
|
@@ -559,13 +617,13 @@ program.command("test-neon").description("Test Neon integration and debug config
|
|
|
559
617
|
logger.error(` Failed to list branches: ${error instanceof Error ? error.message : "Unknown error"}`);
|
|
560
618
|
}
|
|
561
619
|
} else {
|
|
562
|
-
logger.warn("\n5. Skipping branch listing (
|
|
620
|
+
logger.warn("\n5. Skipping branch listing (Neon not configured in settings)");
|
|
563
621
|
}
|
|
564
622
|
} catch (error) {
|
|
565
623
|
logger.error(` Failed to create NeonProvider: ${error instanceof Error ? error.message : "Unknown error"}`);
|
|
566
|
-
if (error instanceof Error && error.message.includes("
|
|
567
|
-
logger.info("\n This is expected if
|
|
568
|
-
logger.info("
|
|
624
|
+
if (error instanceof Error && error.message.includes("not configured")) {
|
|
625
|
+
logger.info("\n This is expected if Neon is not configured.");
|
|
626
|
+
logger.info(" Configure databaseProviders.neon in .iloom/settings.json to test fully.");
|
|
569
627
|
}
|
|
570
628
|
}
|
|
571
629
|
logger.info("\n" + "=".repeat(50));
|
package/dist/cli.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/cli.ts","../src/utils/package-info.ts"],"sourcesContent":["import { program, Command, Option } from 'commander'\nimport { logger } from './utils/logger.js'\nimport { GitWorktreeManager } from './lib/GitWorktreeManager.js'\nimport { ShellCompletion } from './lib/ShellCompletion.js'\nimport type { StartOptions, CleanupOptions, FinishOptions } from './types/index.js'\nimport { getPackageInfo } from './utils/package-info.js'\nimport { fileURLToPath } from 'url'\n\n// Get package.json for version\nconst __filename = fileURLToPath(import.meta.url)\nconst packageJson = getPackageInfo(__filename)\n\nprogram\n .name('iloom')\n .description(packageJson.description)\n .version(packageJson.version)\n .option('--debug', 'Enable debug output (default: based on ILOOM_DEBUG env var)')\n .option('--completion', 'Output shell completion script for current shell')\n .option('--set <key=value>', 'Override any setting using dot notation (repeatable, e.g., --set workflows.issue.startIde=false)')\n .allowUnknownOption() // Allow --set to be used multiple times\n .hook('preAction', async (thisCommand) => {\n // Set debug mode based on flag or environment variable\n const options = thisCommand.opts()\n // Default to environment variable value, then false if not set\n const envDebug = process.env.ILOOM_DEBUG === 'true'\n const debugEnabled = options.debug !== undefined ? options.debug : envDebug\n logger.setDebug(debugEnabled)\n\n // Handle --completion flag\n if (options.completion) {\n const shellCompletion = new ShellCompletion()\n shellCompletion.printCompletionScript()\n process.exit(0)\n }\n\n // Check for updates before command execution for global installations\n try {\n const { checkAndNotifyUpdate } = await import('./utils/update-notifier.js')\n const { detectInstallationMethod } = await import('./utils/installation-detector.js')\n\n // Detect installation method\n const installMethod = detectInstallationMethod(__filename)\n\n // Check and notify (non-blocking, all errors handled internally)\n await checkAndNotifyUpdate(packageJson.version, packageJson.name, installMethod)\n } catch {\n // Silently fail - update check should never break user experience\n }\n\n // Migrate legacy .hatchbox settings to .iloom (BEFORE settings validation)\n try {\n const { SettingsMigrationManager } = await import('./lib/SettingsMigrationManager.js')\n const migrationManager = new SettingsMigrationManager()\n await migrationManager.migrateSettingsIfNeeded()\n } catch (error) {\n // Log warning but don't fail - migration is best-effort\n logger.debug(`Settings migration failed: ${error instanceof Error ? error.message : 'Unknown'}`)\n }\n\n // Validate settings for all commands\n await validateSettingsForCommand()\n })\n\n// Helper function to validate settings at startup\nasync function validateSettingsForCommand(): Promise<void> {\n try {\n const { SettingsManager } = await import('./lib/SettingsManager.js')\n const settingsManager = new SettingsManager()\n\n // Attempt to load settings - this will throw on validation errors\n // Missing file is OK (returns {})\n await settingsManager.loadSettings()\n } catch (error) {\n logger.error(`Configuration error: ${error instanceof Error ? error.message : 'Unknown error'}`)\n logger.info('Please fix your .iloom/settings.json file and try again.')\n process.exit(1)\n }\n}\n\n// Initialize shell completion (must be after program setup, before parseAsync)\nconst shellCompletion = new ShellCompletion()\nshellCompletion.init()\n\nprogram\n .command('start')\n .alias('create')\n .alias('up')\n .description('Create isolated workspace for an issue/PR')\n .argument('[identifier]', 'Issue number, PR number, or branch name (optional - will prompt if not provided)')\n .option('--claude', 'Enable Claude integration (default: true)')\n .option('--no-claude', 'Disable Claude integration')\n .option('--code', 'Enable VSCode (default: true)')\n .option('--no-code', 'Disable VSCode')\n .option('--dev-server', 'Enable dev server in terminal (default: true)')\n .option('--no-dev-server', 'Disable dev server')\n .option('--terminal', 'Enable terminal without dev server (default: false)')\n .option('--no-terminal', 'Disable terminal')\n .addOption(\n new Option('--one-shot <mode>', 'One-shot automation mode')\n .choices(['default', 'noReview', 'bypassPermissions'])\n .default('default')\n )\n .action(async (identifier: string | undefined, options: StartOptions) => {\n try {\n let finalIdentifier = identifier\n\n // Interactive prompting when no identifier provided\n if (!finalIdentifier) {\n const { promptInput } = await import('./utils/prompt.js')\n finalIdentifier = await promptInput('Enter issue number, PR number (pr/123), or branch name')\n\n // Validate non-empty after prompting\n if (!finalIdentifier?.trim()) {\n logger.error('Identifier is required')\n process.exit(1)\n }\n }\n\n const { StartCommand } = await import('./commands/start.js')\n const command = new StartCommand()\n await command.execute({ identifier: finalIdentifier, options })\n } catch (error) {\n logger.error(`Failed to start workspace: ${error instanceof Error ? error.message : 'Unknown error'}`)\n process.exit(1)\n }\n })\n\nprogram\n .command('add-issue')\n .alias('a')\n .description('Create and enhance GitHub issue without starting workspace')\n .argument('<description>', 'Natural language description of the issue (>50 chars, >2 spaces)')\n .action(async (description: string) => {\n try {\n const { AddIssueCommand } = await import('./commands/add-issue.js')\n const command = new AddIssueCommand()\n const issueNumber = await command.execute({\n description,\n options: {}\n })\n logger.success(`Issue #${issueNumber} created successfully`)\n process.exit(0)\n } catch (error) {\n logger.error(`Failed to create issue: ${error instanceof Error ? error.message : 'Unknown error'}`)\n process.exit(1)\n }\n })\n\nprogram\n .command('feedback')\n .alias('f')\n .description('Submit feedback/bug report to iloom-cli repository')\n .argument('<description>', 'Natural language description of feedback (>50 chars, >2 spaces)')\n .action(async (description: string) => {\n try {\n const { FeedbackCommand } = await import('./commands/feedback.js')\n const command = new FeedbackCommand()\n const issueNumber = await command.execute({\n description,\n options: {}\n })\n logger.success(`Feedback submitted as issue #${issueNumber} in iloom-cli repository`)\n process.exit(0)\n } catch (error) {\n logger.error(`Failed to submit feedback: ${error instanceof Error ? error.message : 'Unknown error'}`)\n process.exit(1)\n }\n })\n\nprogram\n .command('enhance')\n .description('Apply enhancement agent to existing GitHub issue')\n .argument('<issue-number>', 'GitHub issue number to enhance', parseInt)\n .option('--no-browser', 'Skip browser opening prompt')\n .option('--author <username>', 'GitHub username to tag in questions (for CI usage)')\n .action(async (issueNumber: number, options: { browser?: boolean; author?: string }) => {\n try {\n const { EnhanceCommand } = await import('./commands/enhance.js')\n const command = new EnhanceCommand()\n await command.execute({\n issueNumber,\n options: {\n noBrowser: options.browser === false,\n ...(options.author && { author: options.author })\n }\n })\n logger.success(`Enhancement process completed for issue #${issueNumber}`)\n process.exit(0)\n } catch (error) {\n logger.error(`Failed to enhance issue: ${error instanceof Error ? error.message : 'Unknown error'}`)\n process.exit(1)\n }\n })\n\nprogram\n .command('finish')\n .alias('dn')\n .description('Merge work and cleanup workspace')\n .argument('[identifier]', 'Issue number, PR number, or branch name (auto-detected if omitted)')\n .option('-f, --force', 'Skip confirmation prompts')\n .option('-n, --dry-run', 'Preview actions without executing')\n .option('--pr <number>', 'Treat input as PR number', parseFloat)\n .option('--skip-build', 'Skip post-merge build verification')\n .action(async (identifier: string | undefined, options: FinishOptions) => {\n try {\n const { FinishCommand } = await import('./commands/finish.js')\n const command = new FinishCommand()\n await command.execute({ identifier, options })\n } catch (error) {\n logger.error(`Failed to finish workspace: ${error instanceof Error ? error.message : 'Unknown error'}`)\n process.exit(1)\n }\n })\n\nprogram\n .command('spin')\n .alias('ignite')\n .description('Launch Claude with auto-detected workspace context')\n .addOption(\n new Option('--one-shot <mode>', 'One-shot automation mode')\n .choices(['default', 'noReview', 'bypassPermissions'])\n .default('default')\n )\n .action(async (options: { oneShot?: import('./types/index.js').OneShotMode }) => {\n try {\n const { IgniteCommand } = await import('./commands/ignite.js')\n const command = new IgniteCommand()\n await command.execute(options.oneShot ?? 'default')\n } catch (error) {\n logger.error(`Failed to spin up loom: ${error instanceof Error ? error.message : 'Unknown error'}`)\n process.exit(1)\n }\n })\n\nprogram\n .command('open')\n .description('Open workspace in browser or run CLI tool')\n .argument('[identifier]', 'Issue number, PR number, or branch name (auto-detected if omitted)')\n .allowUnknownOption()\n .action(async (identifier?: string, _options?: Record<string, unknown>, command?: Command) => {\n try {\n // Extract additional arguments - everything after identifier\n const args = command?.args ? command.args.slice(identifier ? 1 : 0) : []\n\n const { OpenCommand } = await import('./commands/open.js')\n const cmd = new OpenCommand()\n const input = identifier ? { identifier, args } : { args }\n await cmd.execute(input)\n } catch (error) {\n logger.error(`Failed to open: ${error instanceof Error ? error.message : 'Unknown error'}`)\n process.exit(1)\n }\n })\n\nprogram\n .command('run')\n .description('Run CLI tool or open workspace in browser')\n .argument('[identifier]', 'Issue number, PR number, or branch name (auto-detected if omitted)')\n .allowUnknownOption()\n .action(async (identifier?: string, _options?: Record<string, unknown>, command?: Command) => {\n try {\n // Extract additional arguments - everything after identifier\n const args = command?.args ? command.args.slice(identifier ? 1 : 0) : []\n\n const { RunCommand } = await import('./commands/run.js')\n const cmd = new RunCommand()\n const input = identifier ? { identifier, args } : { args }\n await cmd.execute(input)\n } catch (error) {\n logger.error(`Failed to run: ${error instanceof Error ? error.message : 'Unknown error'}`)\n process.exit(1)\n }\n })\n\nprogram\n .command('cleanup')\n .description('Remove workspaces')\n .argument('[identifier]', 'Branch name or issue number to cleanup (auto-detected)')\n .option('-l, --list', 'List all worktrees')\n .option('-a, --all', 'Remove all worktrees (interactive confirmation)')\n .option('-i, --issue <number>', 'Cleanup by issue number', parseInt)\n .option('-f, --force', 'Skip confirmations and force removal')\n .option('--dry-run', 'Show what would be done without doing it')\n .action(async (identifier?: string, options?: CleanupOptions) => {\n try {\n const { CleanupCommand } = await import('./commands/cleanup.js')\n const command = new CleanupCommand()\n const input: { identifier?: string; options: CleanupOptions } = {\n options: options ?? {}\n }\n if (identifier) {\n input.identifier = identifier\n }\n await command.execute(input)\n } catch (error) {\n logger.error(`Failed to cleanup worktrees: ${error instanceof Error ? error.message : 'Unknown error'}`)\n process.exit(1)\n }\n })\n\nprogram\n .command('list')\n .description('Show active workspaces')\n .option('--json', 'Output as JSON')\n .action(async (options: { json?: boolean }) => {\n try {\n const manager = new GitWorktreeManager()\n const worktrees = await manager.listWorktrees({ porcelain: true })\n\n if (options.json) {\n console.log(JSON.stringify(worktrees, null, 2))\n return\n }\n\n if (worktrees.length === 0) {\n logger.info('No worktrees found')\n return\n }\n\n logger.info('Active workspaces:')\n for (const worktree of worktrees) {\n const formatted = manager.formatWorktree(worktree)\n logger.info(` ${formatted.title}`)\n logger.info(` Path: ${formatted.path}`)\n logger.info(` Commit: ${formatted.commit}`)\n }\n } catch (error) {\n logger.error(`Failed to list worktrees: ${error instanceof Error ? error.message : 'Unknown error'}`)\n process.exit(1)\n }\n })\n\n\nprogram\n .command('init')\n .description('Initialize iloom configuration and setup shell autocomplete')\n .action(async () => {\n try {\n const { InitCommand } = await import('./commands/init.js')\n const command = new InitCommand()\n await command.execute()\n } catch (error) {\n logger.error(`Failed to initialize: ${error instanceof Error ? error.message : 'Unknown error'}`)\n process.exit(1)\n }\n })\n\nprogram\n .command('update')\n .description('Update iloom-cli to the latest version')\n .option('--dry-run', 'Show what would be done without actually updating')\n .action(async (options: { dryRun?: boolean }) => {\n try {\n const { UpdateCommand } = await import('./commands/update.js')\n const command = new UpdateCommand()\n await command.execute(options)\n } catch (error) {\n logger.error(`Failed to update: ${error instanceof Error ? error.message : 'Unknown error'}`)\n process.exit(1)\n }\n })\n\n// Test command for GitHub integration\nprogram\n .command('test-github')\n .description('Test GitHub integration (Issue #3)')\n .argument('<identifier>', 'Issue number or PR number')\n .option('--no-claude', 'Skip Claude for branch name generation')\n .action(async (identifier: string, options: { claude?: boolean }) => {\n try {\n const { GitHubService } = await import('./lib/GitHubService.js')\n\n logger.info('Testing GitHub Integration\\n')\n\n const service = new GitHubService(options.claude !== undefined ? { useClaude: options.claude } : {})\n\n // Test 1: Input detection\n logger.info('Detecting input type...')\n const detection = await service.detectInputType(identifier)\n logger.info(` Type: ${detection.type}`)\n logger.info(` Number: ${detection.number}`) \n\n if (detection.type === 'unknown') {\n logger.error('Could not detect if input is an issue or PR')\n process.exit(1)\n }\n\n // Test 2: Fetch the issue/PR\n logger.info('Fetching from GitHub...')\n if (detection.type === 'issue') {\n if (!detection.number) {\n throw new Error('Issue number not detected')\n }\n const issue = await service.fetchIssue(detection.number)\n logger.success(` Issue #${issue.number}: ${issue.title}`)\n logger.info(` State: ${issue.state}`)\n logger.info(` Labels: ${issue.labels.join(', ') || 'none'}`)\n logger.info(` URL: ${issue.url}`)\n\n // Test 3: Generate branch name\n \n logger.info('Generating branch name...')\n const branchName = await service.generateBranchName({\n issueNumber: issue.number,\n title: issue.title\n })\n logger.success(` Branch: ${branchName}`)\n\n // Test 4: Extract context\n \n logger.info('Extracting context for Claude...')\n const context = service.extractContext(issue)\n logger.info(` ${context.split('\\n').join('\\n ')}`)\n\n } else {\n if (!detection.number) {\n throw new Error('PR number not detected')\n }\n const pr = await service.fetchPR(detection.number)\n logger.success(` PR #${pr.number}: ${pr.title}`)\n logger.info(` State: ${pr.state}`)\n logger.info(` Branch: ${pr.branch}`)\n logger.info(` Base: ${pr.baseBranch}`)\n logger.info(` URL: ${pr.url}`)\n\n // Test 3: Extract context\n \n logger.info('Extracting context for Claude...')\n const context = service.extractContext(pr)\n logger.info(` ${context.split('\\n').join('\\n ')}`)\n }\n\n \n logger.success('All GitHub integration tests passed!')\n\n } catch (error) {\n logger.error(`Test failed: ${error instanceof Error ? error.message : 'Unknown error'}`)\n if (error instanceof Error && error.stack) {\n logger.debug(error.stack)\n }\n process.exit(1)\n }\n })\n\n// Test command for Claude integration\nprogram\n .command('test-claude')\n .description('Test Claude integration (Issue #10)')\n .option('--detect', 'Test Claude CLI detection')\n .option('--version', 'Get Claude CLI version')\n .option('--branch <title>', 'Test branch name generation with given title')\n .option('--issue <number>', 'Issue number for branch generation', '123')\n .option('--launch <prompt>', 'Launch Claude with a prompt (headless)')\n .option('--interactive', 'Launch Claude interactively (requires --launch)')\n .option('--template <name>', 'Test template loading')\n .action(async (options: {\n detect?: boolean\n version?: boolean\n branch?: string\n issue?: string\n launch?: string\n interactive?: boolean\n template?: 'issue' | 'pr' | 'regular'\n }) => {\n try {\n const { detectClaudeCli, getClaudeVersion, generateBranchName, launchClaude } = await import('./utils/claude.js')\n const { PromptTemplateManager } = await import('./lib/PromptTemplateManager.js')\n const { ClaudeService } = await import('./lib/ClaudeService.js')\n const { ClaudeContextManager } = await import('./lib/ClaudeContextManager.js')\n\n logger.info('Testing Claude Integration\\n')\n\n // Test 1: Detection\n if (options.detect) {\n logger.info('Detecting Claude CLI...')\n const isAvailable = await detectClaudeCli()\n if (isAvailable) {\n logger.success(' Claude CLI is available')\n } else {\n logger.error(' Claude CLI not found')\n }\n }\n\n // Test 2: Version\n if (options.version) {\n logger.info('Getting Claude version...')\n const version = await getClaudeVersion()\n if (version) {\n logger.success(` Version: ${version}`)\n } else {\n logger.error(' Could not get version')\n }\n }\n\n // Test 3: Branch name generation\n if (options.branch) {\n logger.info('Generating branch name...')\n const issueNumber = parseInt(options.issue ?? '123')\n logger.info(` Issue #${issueNumber}: ${options.branch}`)\n const branchName = await generateBranchName(options.branch, issueNumber)\n logger.success(` Generated: ${branchName}`)\n }\n\n // Test 4: Launch Claude\n if (options.launch) {\n logger.info('Launching Claude...')\n logger.info(` Prompt: \"${options.launch}\"`)\n logger.info(` Mode: ${options.interactive ? 'Interactive' : 'Headless'}`)\n\n if (options.interactive) {\n logger.info(' Launching Claude in new terminal...')\n await launchClaude(options.launch, { headless: false })\n logger.info(' (Claude should open in a separate process)')\n } else {\n logger.info(' Waiting for response...')\n const result = await launchClaude(options.launch, { headless: true })\n if (result) {\n logger.success(' Response:')\n logger.info(` ${result.split('\\n').join('\\n ')}`)\n }\n }\n }\n\n // Test 5: Template loading\n if (options.template) {\n logger.info('Loading template...')\n logger.info(` Template: ${options.template}`)\n const manager = new PromptTemplateManager()\n try {\n const content = await manager.loadTemplate(options.template)\n logger.success(' Template loaded successfully')\n logger.info(' First 200 chars:')\n logger.info(` ${content.substring(0, 200).split('\\n').join('\\n ')}...`)\n } catch (error) {\n logger.error(` Failed: ${error instanceof Error ? error.message : 'Unknown error'}`)\n }\n }\n\n // Run all tests in sequence when no specific options provided\n if (!options.detect && !options.version && !options.branch && !options.launch && !options.template) {\n logger.info('Running full Claude integration test suite...\\n')\n\n // Test 1: Detection\n logger.info('1. Testing Claude CLI detection...')\n const isAvailable = await detectClaudeCli()\n if (isAvailable) {\n logger.success(' Claude CLI is available')\n } else {\n logger.error(' Claude CLI not found')\n logger.info('\\nSkipping remaining tests since Claude CLI is not available')\n return\n }\n\n // Test 2: Version\n logger.info('\\n2. Getting Claude version...')\n const version = await getClaudeVersion()\n if (version) {\n logger.success(` Version: ${version}`)\n } else {\n logger.error(' Could not get version')\n }\n\n // Test 3: Branch name generation\n logger.info('\\n3. Testing branch name generation...')\n const testIssueNumber = 123\n const testTitle = 'Add user authentication feature'\n logger.info(` Issue #${testIssueNumber}: ${testTitle}`)\n const branchName = await generateBranchName(testTitle, testIssueNumber)\n logger.success(` Generated: ${branchName}`)\n\n // Test 4: Service initialization\n logger.info('\\n4. Testing ClaudeService initialization...')\n new ClaudeService() // Just verify it can be instantiated\n logger.success(' Service initialized')\n\n // Test 5: Context manager\n logger.info('\\n5. Testing ClaudeContextManager...')\n const contextManager = new ClaudeContextManager()\n await contextManager.prepareContext({\n type: 'issue',\n identifier: 123,\n title: 'Test issue',\n workspacePath: process.cwd(),\n port: 3123\n })\n logger.success(' Context prepared')\n\n // Test 6: Template loading\n logger.info('\\n6. Testing template loading...')\n const templateManager = new PromptTemplateManager()\n const templates: Array<'issue' | 'pr' | 'regular'> = ['issue', 'pr', 'regular']\n let templateCount = 0\n for (const template of templates) {\n try {\n await templateManager.loadTemplate(template)\n logger.success(` ${template} template loaded`)\n templateCount++\n } catch {\n logger.warn(` ${template} template not found`)\n }\n }\n logger.info(` Loaded ${templateCount}/${templates.length} templates`)\n\n // Test 7: Launch Claude headless (quick test)\n logger.info('\\n7. Testing Claude launch (headless)...')\n logger.info(' Sending test prompt: \"Say hello\"')\n try {\n const result = await launchClaude('Say hello', { headless: true })\n if (result) {\n logger.success(' Claude responded successfully')\n logger.info(` Response preview: ${result.substring(0, 100)}...`)\n } else {\n logger.warn(' No response received')\n }\n } catch (error) {\n logger.error(` Launch failed: ${error instanceof Error ? error.message : 'Unknown error'}`)\n }\n\n logger.info('\\n' + '='.repeat(50))\n logger.success('All Claude integration tests complete!')\n logger.info('Summary: All core Claude features are working correctly')\n }\n\n } catch (error) {\n logger.error(`Test failed: ${error instanceof Error ? error.message : 'Unknown error'}`)\n if (error instanceof Error && error.stack) {\n logger.debug(error.stack)\n }\n process.exit(1)\n }\n })\n\n// Test command for webserver detection\nprogram\n .command('test-webserver')\n .description('Test if a web server is running on a workspace port')\n .argument('<issue-number>', 'Issue number (port will be calculated as 3000 + issue number)', parseInt)\n .option('--kill', 'Kill the web server if detected')\n .action(async (issueNumber: number, options: { kill?: boolean }) => {\n try {\n const { TestWebserverCommand } = await import('./commands/test-webserver.js')\n const command = new TestWebserverCommand()\n await command.execute({ issueNumber, options })\n } catch (error) {\n logger.error(`Test webserver failed: ${error instanceof Error ? error.message : 'Unknown error'}`)\n if (error instanceof Error && error.stack) {\n logger.debug(error.stack)\n }\n process.exit(1)\n }\n })\n\n// Test command for Git integration\nprogram\n .command('test-git')\n .description('Test Git integration - findMainWorktreePath() function (reads .iloom/settings.json)')\n .action(async () => {\n try {\n const { TestGitCommand } = await import('./commands/test-git.js')\n const command = new TestGitCommand()\n await command.execute()\n } catch (error) {\n logger.error(`Test git failed: ${error instanceof Error ? error.message : 'Unknown error'}`)\n if (error instanceof Error && error.stack) {\n logger.debug(error.stack)\n }\n process.exit(1)\n }\n })\n\n// Test command for iTerm2 dual tab functionality\nprogram\n .command('test-tabs')\n .description('Test iTerm2 dual tab functionality - opens two tabs with test commands')\n .action(async () => {\n try {\n const { TestTabsCommand } = await import('./commands/test-tabs.js')\n const command = new TestTabsCommand()\n await command.execute()\n } catch (error) {\n logger.error(`Test tabs failed: ${error instanceof Error ? error.message : 'Unknown error'}`)\n if (error instanceof Error && error.stack) {\n logger.debug(error.stack)\n }\n process.exit(1)\n }\n })\n\n// Test command for worktree prefix configuration\nprogram\n .command('test-prefix')\n .description('Test worktree prefix configuration - preview worktree paths (reads .iloom/settings.json)')\n .action(async () => {\n try {\n const { TestPrefixCommand } = await import('./commands/test-prefix.js')\n const command = new TestPrefixCommand()\n await command.execute()\n } catch (error) {\n logger.error(`Test prefix failed: ${error instanceof Error ? error.message : 'Unknown error'}`)\n if (error instanceof Error && error.stack) {\n logger.debug(error.stack)\n }\n process.exit(1)\n }\n })\n\n// Test command for Neon integration\nprogram\n .command('test-neon')\n .description('Test Neon integration and debug configuration')\n .action(async () => {\n try {\n const { NeonProvider } = await import('./lib/providers/NeonProvider.js')\n const { loadEnvIntoProcess } = await import('./utils/env.js')\n\n logger.info('Testing Neon Integration\\n')\n\n // Load environment variables\n logger.info('0. Loading environment variables...')\n const envResult = loadEnvIntoProcess()\n if (envResult.error) {\n logger.warn(` Warning: ${envResult.error.message}`)\n }\n if (envResult.parsed) {\n logger.success(` Loaded ${Object.keys(envResult.parsed).length} environment variables`)\n } else {\n logger.info(' No .env files found or parsed')\n }\n\n // Test 1: Environment variables\n logger.info('\\n1. Environment Variables:')\n logger.info(` NEON_PROJECT_ID: ${process.env.NEON_PROJECT_ID ?? '(not set)'}`)\n logger.info(` NEON_PARENT_BRANCH: ${process.env.NEON_PARENT_BRANCH ?? '(not set)'}`)\n\n // Test 2: Create provider and test initialization\n logger.info('\\n2. Creating NeonProvider...')\n try {\n const neonProvider = new NeonProvider({\n projectId: process.env.NEON_PROJECT_ID ?? '',\n parentBranch: process.env.NEON_PARENT_BRANCH ?? '',\n })\n logger.success(' NeonProvider created successfully')\n\n // Test 3: CLI availability\n logger.info('\\n3. Testing Neon CLI availability...')\n const isAvailable = await neonProvider.isCliAvailable()\n if (isAvailable) {\n logger.success(' Neon CLI is available')\n } else {\n logger.error(' Neon CLI not found')\n logger.info(' Install with: npm install -g @neon/cli')\n return\n }\n\n // Test 4: Authentication\n logger.info('\\n4. Testing Neon CLI authentication...')\n const isAuthenticated = await neonProvider.isAuthenticated()\n if (isAuthenticated) {\n logger.success(' Neon CLI is authenticated')\n } else {\n logger.error(' Neon CLI not authenticated')\n logger.info(' Run: neon auth')\n return\n }\n\n // Test 5: List branches (if config is valid)\n if (process.env.NEON_PROJECT_ID) {\n logger.info('\\n5. Testing branch listing...')\n try {\n const branches = await neonProvider.listBranches()\n logger.success(` Found ${branches.length} branches:`)\n for (const branch of branches.slice(0, 5)) { // Show first 5\n logger.info(` - ${branch}`)\n }\n if (branches.length > 5) {\n logger.info(` ... and ${branches.length - 5} more`)\n }\n } catch (error) {\n logger.error(` Failed to list branches: ${error instanceof Error ? error.message : 'Unknown error'}`)\n }\n } else {\n logger.warn('\\n5. Skipping branch listing (NEON_PROJECT_ID not set)')\n }\n\n } catch (error) {\n logger.error(` Failed to create NeonProvider: ${error instanceof Error ? error.message : 'Unknown error'}`)\n if (error instanceof Error && error.message.includes('NEON_PROJECT_ID')) {\n logger.info('\\n This is expected if NEON_PROJECT_ID is not set.')\n logger.info(' Set NEON_PROJECT_ID and NEON_PARENT_BRANCH environment variables to test fully.')\n }\n }\n\n logger.info('\\n' + '='.repeat(50))\n logger.success('Neon integration test complete!')\n\n } catch (error) {\n logger.error(`Test failed: ${error instanceof Error ? error.message : 'Unknown error'}`)\n if (error instanceof Error && error.stack) {\n logger.debug(error.stack)\n }\n process.exit(1)\n }\n })\n\n// Add custom help command in order to get preAction to run (update check handled by preAction hook)\nprogram\n .command('help')\n .description('Display help information')\n .argument('[command]', 'Show help for specific command')\n .action(async (command?: string) => {\n // Show help (update check already ran in preAction)\n if (command) {\n // Show help for specific command\n const subCommand = program.commands.find(cmd => cmd.name() === command)\n if (subCommand) {\n subCommand.outputHelp()\n } else {\n logger.error(`Unknown command: ${command}`)\n program.outputHelp()\n }\n } else {\n program.outputHelp()\n }\n\n process.exit(0)\n })\n\n// Parse CLI arguments\ntry {\n await program.parseAsync()\n} catch (error) {\n if (error instanceof Error) {\n logger.error(`Error: ${error.message}`)\n process.exit(1)\n }\n}\n","import { readFileSync } from 'fs'\nimport { fileURLToPath } from 'url'\nimport { dirname, join } from 'path'\n\n/**\n * Package information from package.json\n */\nexport interface PackageInfo {\n name: string\n version: string\n description: string\n [key: string]: unknown\n}\n\n/**\n * Get package.json information\n *\n * @param scriptPath - Optional path to use for finding package.json (defaults to current file location)\n * @returns Parsed package.json contents\n * @throws Error if package.json cannot be read or parsed\n */\nexport function getPackageInfo(scriptPath?: string): PackageInfo {\n try {\n // Determine the base path to use\n let basePath: string\n if (scriptPath) {\n basePath = scriptPath\n } else {\n // Use import.meta.url to get the current file path\n const __filename = fileURLToPath(import.meta.url)\n basePath = __filename\n }\n\n // Navigate from current file to package.json\n // The compiled CLI runs from dist/cli.js, so we need dist/../package.json (one level up)\n const __dirname = dirname(basePath)\n const packageJsonPath = join(__dirname, '..', 'package.json')\n\n // Read and parse package.json\n const packageJsonContent = readFileSync(packageJsonPath, 'utf8')\n const packageJson = JSON.parse(packageJsonContent) as PackageInfo\n\n return packageJson\n } catch (error) {\n throw new Error(\n `Failed to read package.json: ${error instanceof Error ? error.message : 'Unknown error'}`\n )\n }\n}\n"],"mappings":"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","names":["__filename","packageJson","fileURLToPath","shellCompletion"]}
|
|
1
|
+
{"version":3,"sources":["../src/cli.ts","../src/utils/package-info.ts"],"sourcesContent":["import { program, Command, Option } from 'commander'\nimport { logger } from './utils/logger.js'\nimport { GitWorktreeManager } from './lib/GitWorktreeManager.js'\nimport { ShellCompletion } from './lib/ShellCompletion.js'\nimport type { StartOptions, CleanupOptions, FinishOptions } from './types/index.js'\nimport { getPackageInfo } from './utils/package-info.js'\nimport { fileURLToPath } from 'url'\n\n// Get package.json for version\nconst __filename = fileURLToPath(import.meta.url)\nconst packageJson = getPackageInfo(__filename)\n\nprogram\n .name('iloom')\n .description(packageJson.description)\n .version(packageJson.version)\n .option('--debug', 'Enable debug output (default: based on ILOOM_DEBUG env var)')\n .option('--completion', 'Output shell completion script for current shell')\n .option('--set <key=value>', 'Override any setting using dot notation (repeatable, e.g., --set workflows.issue.startIde=false)')\n .allowUnknownOption() // Allow --set to be used multiple times\n .hook('preAction', async (thisCommand) => {\n // Set debug mode based on flag or environment variable\n const options = thisCommand.opts()\n // Default to environment variable value, then false if not set\n const envDebug = process.env.ILOOM_DEBUG === 'true'\n const debugEnabled = options.debug !== undefined ? options.debug : envDebug\n logger.setDebug(debugEnabled)\n\n // Handle --completion flag\n if (options.completion) {\n const shellCompletion = new ShellCompletion()\n shellCompletion.printCompletionScript()\n process.exit(0)\n }\n\n // Check for updates before command execution for global installations\n try {\n const { checkAndNotifyUpdate } = await import('./utils/update-notifier.js')\n const { detectInstallationMethod } = await import('./utils/installation-detector.js')\n\n // Detect installation method\n const installMethod = detectInstallationMethod(__filename)\n\n // Check and notify (non-blocking, all errors handled internally)\n await checkAndNotifyUpdate(packageJson.version, packageJson.name, installMethod)\n } catch {\n // Silently fail - update check should never break user experience\n }\n\n // Migrate legacy .hatchbox settings to .iloom (BEFORE settings validation)\n try {\n const { SettingsMigrationManager } = await import('./lib/SettingsMigrationManager.js')\n const migrationManager = new SettingsMigrationManager()\n await migrationManager.migrateSettingsIfNeeded()\n } catch (error) {\n // Log warning but don't fail - migration is best-effort\n logger.debug(`Settings migration failed: ${error instanceof Error ? error.message : 'Unknown'}`)\n }\n\n // Validate settings for all commands\n await validateSettingsForCommand(thisCommand)\n })\n\n// Helper function to validate settings at startup\nasync function validateSettingsForCommand(command: Command): Promise<void> {\n const commandName = command.args[0] ?? ''\n\n // Tier 1: Commands that bypass ALL validation\n const bypassCommands = ['help', 'init', 'update', 'contribute']\n\n if (bypassCommands.includes(commandName)) {\n return\n }\n\n // Tier 2: All other commands require FULL validation (settings + multi-remote)\n // Commands: start, add-issue, enhance, finish, list, cleanup, open, run, etc.\n try {\n const { SettingsManager } = await import('./lib/SettingsManager.js')\n const settingsManager = new SettingsManager()\n\n // Attempt to load settings - this will throw on validation errors\n // Missing file is OK (returns {})\n const settings = await settingsManager.loadSettings()\n\n // Check for multi-remote configuration requirement\n const { hasMultipleRemotes } = await import('./utils/remote.js')\n const multipleRemotes = await hasMultipleRemotes()\n\n if (multipleRemotes && !settings.issueManagement?.github?.remote) {\n // Auto-launch init command to configure remotes\n // After init completes, function returns and Commander.js continues with original command\n await autoLaunchInitForMultipleRemotes()\n return // Settings now configured, let preAction complete\n }\n } catch (error) {\n logger.error(`Configuration error: ${error instanceof Error ? error.message : 'Unknown error'}`)\n logger.info('Please fix your .iloom/settings.json file and try again.')\n process.exit(1)\n }\n}\n\n/**\n * Auto-launch init command when multiple remotes are detected but not configured\n * Shows message, waits for keypress, launches interactive Claude configuration,\n * then returns to let Commander.js continue with the original command\n */\nasync function autoLaunchInitForMultipleRemotes(): Promise<void> {\n logger.info('Multiple git remotes detected, but no GitHub remote is configured.')\n logger.info('')\n logger.info('iloom will now launch an interactive configuration session with Claude')\n logger.info('to help you select which remote to use for GitHub operations.')\n logger.info('')\n\n // Wait for keypress to continue\n const { waitForKeypress } = await import('./utils/prompt.js')\n await waitForKeypress('Press any key to start configuration...')\n\n logger.info('')\n\n try {\n // Launch init command with focused initial message\n const { InitCommand } = await import('./commands/init.js')\n const initCommand = new InitCommand()\n\n // Custom initial message that focuses on multi-remote configuration\n const customInitialMessage = 'Help me configure which git remote iloom should use for GitHub operations. I have multiple remotes and need to select the correct one.'\n\n await initCommand.execute(customInitialMessage)\n\n logger.info('')\n logger.info('Configuration complete! Continuing with your original command...')\n logger.info('')\n\n // Re-validate settings after init to ensure multi-remote is now configured\n const { SettingsManager } = await import('./lib/SettingsManager.js')\n const settingsManager = new SettingsManager()\n const settings = await settingsManager.loadSettings()\n\n const { hasMultipleRemotes } = await import('./utils/remote.js')\n const multipleRemotes = await hasMultipleRemotes()\n\n // Verify the issue is resolved\n if (multipleRemotes && !settings.issueManagement?.github?.remote) {\n logger.error('Configuration incomplete: GitHub remote is still not configured.')\n logger.info('Please run \"iloom init\" again and configure the GitHub remote setting.')\n process.exit(1)\n }\n\n // Configuration verified - simply return to let Commander.js continue\n // with the original command (preAction hook will complete normally)\n return\n\n } catch (error) {\n logger.error(`Failed to configure remotes: ${error instanceof Error ? error.message : 'Unknown error'}`)\n logger.info('You can manually run \"iloom init\" to configure settings.')\n process.exit(1)\n }\n}\n\n// Initialize shell completion (must be after program setup, before parseAsync)\nconst shellCompletion = new ShellCompletion()\nshellCompletion.init()\n\nprogram\n .command('start')\n .alias('create')\n .alias('up')\n .description('Create isolated workspace for an issue/PR')\n .argument('[identifier]', 'Issue number, PR number, or branch name (optional - will prompt if not provided)')\n .option('--claude', 'Enable Claude integration (default: true)')\n .option('--no-claude', 'Disable Claude integration')\n .option('--code', 'Enable VSCode (default: true)')\n .option('--no-code', 'Disable VSCode')\n .option('--dev-server', 'Enable dev server in terminal (default: true)')\n .option('--no-dev-server', 'Disable dev server')\n .option('--terminal', 'Enable terminal without dev server (default: false)')\n .option('--no-terminal', 'Disable terminal')\n .addOption(\n new Option('--one-shot <mode>', 'One-shot automation mode')\n .choices(['default', 'noReview', 'bypassPermissions'])\n .default('default')\n )\n .action(async (identifier: string | undefined, options: StartOptions) => {\n try {\n let finalIdentifier = identifier\n\n // Interactive prompting when no identifier provided\n if (!finalIdentifier) {\n const { promptInput } = await import('./utils/prompt.js')\n finalIdentifier = await promptInput('Enter issue number, PR number (pr/123), or branch name')\n\n // Validate non-empty after prompting\n if (!finalIdentifier?.trim()) {\n logger.error('Identifier is required')\n process.exit(1)\n }\n }\n\n const { StartCommand } = await import('./commands/start.js')\n const command = new StartCommand()\n await command.execute({ identifier: finalIdentifier, options })\n } catch (error) {\n logger.error(`Failed to start workspace: ${error instanceof Error ? error.message : 'Unknown error'}`)\n process.exit(1)\n }\n })\n\nprogram\n .command('add-issue')\n .alias('a')\n .description('Create and enhance GitHub issue without starting workspace')\n .argument('<description>', 'Natural language description of the issue (>50 chars, >2 spaces)')\n .action(async (description: string) => {\n try {\n const { AddIssueCommand } = await import('./commands/add-issue.js')\n const command = new AddIssueCommand()\n const issueNumber = await command.execute({\n description,\n options: {}\n })\n logger.success(`Issue #${issueNumber} created successfully`)\n process.exit(0)\n } catch (error) {\n logger.error(`Failed to create issue: ${error instanceof Error ? error.message : 'Unknown error'}`)\n process.exit(1)\n }\n })\n\nprogram\n .command('feedback')\n .alias('f')\n .description('Submit feedback/bug report to iloom-cli repository')\n .argument('<description>', 'Natural language description of feedback (>50 chars, >2 spaces)')\n .action(async (description: string) => {\n try {\n const { FeedbackCommand } = await import('./commands/feedback.js')\n const command = new FeedbackCommand()\n const issueNumber = await command.execute({\n description,\n options: {}\n })\n logger.success(`Feedback submitted as issue #${issueNumber} in iloom-cli repository`)\n process.exit(0)\n } catch (error) {\n logger.error(`Failed to submit feedback: ${error instanceof Error ? error.message : 'Unknown error'}`)\n process.exit(1)\n }\n })\n\nprogram\n .command('enhance')\n .description('Apply enhancement agent to existing GitHub issue')\n .argument('<issue-number>', 'GitHub issue number to enhance', parseInt)\n .option('--no-browser', 'Skip browser opening prompt')\n .option('--author <username>', 'GitHub username to tag in questions (for CI usage)')\n .action(async (issueNumber: number, options: { browser?: boolean; author?: string }) => {\n try {\n const { EnhanceCommand } = await import('./commands/enhance.js')\n const command = new EnhanceCommand()\n await command.execute({\n issueNumber,\n options: {\n noBrowser: options.browser === false,\n ...(options.author && { author: options.author })\n }\n })\n logger.success(`Enhancement process completed for issue #${issueNumber}`)\n process.exit(0)\n } catch (error) {\n logger.error(`Failed to enhance issue: ${error instanceof Error ? error.message : 'Unknown error'}`)\n process.exit(1)\n }\n })\n\nprogram\n .command('finish')\n .alias('dn')\n .description('Merge work and cleanup workspace')\n .argument('[identifier]', 'Issue number, PR number, or branch name (auto-detected if omitted)')\n .option('-f, --force', 'Skip confirmation prompts')\n .option('-n, --dry-run', 'Preview actions without executing')\n .option('--pr <number>', 'Treat input as PR number', parseFloat)\n .option('--skip-build', 'Skip post-merge build verification')\n .action(async (identifier: string | undefined, options: FinishOptions) => {\n try {\n const { FinishCommand } = await import('./commands/finish.js')\n const command = new FinishCommand()\n await command.execute({ identifier, options })\n } catch (error) {\n logger.error(`Failed to finish workspace: ${error instanceof Error ? error.message : 'Unknown error'}`)\n process.exit(1)\n }\n })\n\nprogram\n .command('rebase')\n .description('Rebase current branch on main with Claude-assisted conflict resolution')\n .option('-f, --force', 'Skip confirmation prompts')\n .option('-n, --dry-run', 'Preview actions without executing')\n .action(async (options: { force?: boolean; dryRun?: boolean }) => {\n try {\n const { RebaseCommand } = await import('./commands/rebase.js')\n const command = new RebaseCommand()\n await command.execute(options)\n } catch (error) {\n logger.error(`Failed to rebase: ${error instanceof Error ? error.message : 'Unknown error'}`)\n process.exit(1)\n }\n })\n\nprogram\n .command('spin')\n .alias('ignite')\n .description('Launch Claude with auto-detected workspace context')\n .addOption(\n new Option('--one-shot <mode>', 'One-shot automation mode')\n .choices(['default', 'noReview', 'bypassPermissions'])\n .default('default')\n )\n .action(async (options: { oneShot?: import('./types/index.js').OneShotMode }) => {\n try {\n const { IgniteCommand } = await import('./commands/ignite.js')\n const command = new IgniteCommand()\n await command.execute(options.oneShot ?? 'default')\n } catch (error) {\n logger.error(`Failed to spin up loom: ${error instanceof Error ? error.message : 'Unknown error'}`)\n process.exit(1)\n }\n })\n\nprogram\n .command('open')\n .description('Open workspace in browser or run CLI tool')\n .argument('[identifier]', 'Issue number, PR number, or branch name (auto-detected if omitted)')\n .allowUnknownOption()\n .action(async (identifier?: string, _options?: Record<string, unknown>, command?: Command) => {\n try {\n // Extract additional arguments - everything after identifier\n const args = command?.args ? command.args.slice(identifier ? 1 : 0) : []\n\n const { OpenCommand } = await import('./commands/open.js')\n const cmd = new OpenCommand()\n const input = identifier ? { identifier, args } : { args }\n await cmd.execute(input)\n } catch (error) {\n logger.error(`Failed to open: ${error instanceof Error ? error.message : 'Unknown error'}`)\n process.exit(1)\n }\n })\n\nprogram\n .command('run')\n .description('Run CLI tool or open workspace in browser')\n .argument('[identifier]', 'Issue number, PR number, or branch name (auto-detected if omitted)')\n .allowUnknownOption()\n .action(async (identifier?: string, _options?: Record<string, unknown>, command?: Command) => {\n try {\n // Extract additional arguments - everything after identifier\n const args = command?.args ? command.args.slice(identifier ? 1 : 0) : []\n\n const { RunCommand } = await import('./commands/run.js')\n const cmd = new RunCommand()\n const input = identifier ? { identifier, args } : { args }\n await cmd.execute(input)\n } catch (error) {\n logger.error(`Failed to run: ${error instanceof Error ? error.message : 'Unknown error'}`)\n process.exit(1)\n }\n })\n\nprogram\n .command('cleanup')\n .description('Remove workspaces')\n .argument('[identifier]', 'Branch name or issue number to cleanup (auto-detected)')\n .option('-l, --list', 'List all worktrees')\n .option('-a, --all', 'Remove all worktrees (interactive confirmation)')\n .option('-i, --issue <number>', 'Cleanup by issue number', parseInt)\n .option('-f, --force', 'Skip confirmations and force removal')\n .option('--dry-run', 'Show what would be done without doing it')\n .action(async (identifier?: string, options?: CleanupOptions) => {\n try {\n const { CleanupCommand } = await import('./commands/cleanup.js')\n const command = new CleanupCommand()\n const input: { identifier?: string; options: CleanupOptions } = {\n options: options ?? {}\n }\n if (identifier) {\n input.identifier = identifier\n }\n await command.execute(input)\n } catch (error) {\n logger.error(`Failed to cleanup worktrees: ${error instanceof Error ? error.message : 'Unknown error'}`)\n process.exit(1)\n }\n })\n\nprogram\n .command('list')\n .description('Show active workspaces')\n .option('--json', 'Output as JSON')\n .action(async (options: { json?: boolean }) => {\n try {\n const manager = new GitWorktreeManager()\n const worktrees = await manager.listWorktrees({ porcelain: true })\n\n if (options.json) {\n console.log(JSON.stringify(worktrees, null, 2))\n return\n }\n\n if (worktrees.length === 0) {\n logger.info('No worktrees found')\n return\n }\n\n logger.info('Active workspaces:')\n for (const worktree of worktrees) {\n const formatted = manager.formatWorktree(worktree)\n logger.info(` ${formatted.title}`)\n logger.info(` Path: ${formatted.path}`)\n logger.info(` Commit: ${formatted.commit}`)\n }\n } catch (error) {\n logger.error(`Failed to list worktrees: ${error instanceof Error ? error.message : 'Unknown error'}`)\n process.exit(1)\n }\n })\n\n\nprogram\n .command('init')\n .alias('config')\n .description('Initialize iloom configuration and setup shell autocomplete')\n .action(async () => {\n try {\n const { InitCommand } = await import('./commands/init.js')\n const command = new InitCommand()\n await command.execute()\n } catch (error) {\n logger.error(`Failed to initialize: ${error instanceof Error ? error.message : 'Unknown error'}`)\n process.exit(1)\n }\n })\n\nprogram\n .command('contribute')\n .description('Set up local development environment for contributing to iloom')\n .action(async () => {\n try {\n const { ContributeCommand } = await import('./commands/contribute.js')\n const command = new ContributeCommand()\n await command.execute()\n } catch (error) {\n logger.error(`Failed to set up contributor environment: ${error instanceof Error ? error.message : 'Unknown error'}`)\n process.exit(1)\n }\n })\n\nprogram\n .command('update')\n .description('Update iloom-cli to the latest version')\n .option('--dry-run', 'Show what would be done without actually updating')\n .action(async (options: { dryRun?: boolean }) => {\n try {\n const { UpdateCommand } = await import('./commands/update.js')\n const command = new UpdateCommand()\n await command.execute(options)\n } catch (error) {\n logger.error(`Failed to update: ${error instanceof Error ? error.message : 'Unknown error'}`)\n process.exit(1)\n }\n })\n\n// Test command for GitHub integration\nprogram\n .command('test-github')\n .description('Test GitHub integration (Issue #3)')\n .argument('<identifier>', 'Issue number or PR number')\n .option('--no-claude', 'Skip Claude for branch name generation')\n .action(async (identifier: string, options: { claude?: boolean }) => {\n try {\n const { GitHubService } = await import('./lib/GitHubService.js')\n\n logger.info('Testing GitHub Integration\\n')\n\n const service = new GitHubService(options.claude !== undefined ? { useClaude: options.claude } : {})\n\n // Test 1: Input detection\n logger.info('Detecting input type...')\n const detection = await service.detectInputType(identifier)\n logger.info(` Type: ${detection.type}`)\n logger.info(` Number: ${detection.number}`) \n\n if (detection.type === 'unknown') {\n logger.error('Could not detect if input is an issue or PR')\n process.exit(1)\n }\n\n // Test 2: Fetch the issue/PR\n logger.info('Fetching from GitHub...')\n if (detection.type === 'issue') {\n if (!detection.number) {\n throw new Error('Issue number not detected')\n }\n const issue = await service.fetchIssue(detection.number)\n logger.success(` Issue #${issue.number}: ${issue.title}`)\n logger.info(` State: ${issue.state}`)\n logger.info(` Labels: ${issue.labels.join(', ') || 'none'}`)\n logger.info(` URL: ${issue.url}`)\n\n // Test 3: Generate branch name\n \n logger.info('Generating branch name...')\n const branchName = await service.generateBranchName({\n issueNumber: issue.number,\n title: issue.title\n })\n logger.success(` Branch: ${branchName}`)\n\n // Test 4: Extract context\n \n logger.info('Extracting context for Claude...')\n const context = service.extractContext(issue)\n logger.info(` ${context.split('\\n').join('\\n ')}`)\n\n } else {\n if (!detection.number) {\n throw new Error('PR number not detected')\n }\n const pr = await service.fetchPR(detection.number)\n logger.success(` PR #${pr.number}: ${pr.title}`)\n logger.info(` State: ${pr.state}`)\n logger.info(` Branch: ${pr.branch}`)\n logger.info(` Base: ${pr.baseBranch}`)\n logger.info(` URL: ${pr.url}`)\n\n // Test 3: Extract context\n \n logger.info('Extracting context for Claude...')\n const context = service.extractContext(pr)\n logger.info(` ${context.split('\\n').join('\\n ')}`)\n }\n\n \n logger.success('All GitHub integration tests passed!')\n\n } catch (error) {\n logger.error(`Test failed: ${error instanceof Error ? error.message : 'Unknown error'}`)\n if (error instanceof Error && error.stack) {\n logger.debug(error.stack)\n }\n process.exit(1)\n }\n })\n\n// Test command for Claude integration\nprogram\n .command('test-claude')\n .description('Test Claude integration (Issue #10)')\n .option('--detect', 'Test Claude CLI detection')\n .option('--version', 'Get Claude CLI version')\n .option('--branch <title>', 'Test branch name generation with given title')\n .option('--issue <number>', 'Issue number for branch generation', '123')\n .option('--launch <prompt>', 'Launch Claude with a prompt (headless)')\n .option('--interactive', 'Launch Claude interactively (requires --launch)')\n .option('--template <name>', 'Test template loading')\n .action(async (options: {\n detect?: boolean\n version?: boolean\n branch?: string\n issue?: string\n launch?: string\n interactive?: boolean\n template?: 'issue' | 'pr' | 'regular'\n }) => {\n try {\n const { detectClaudeCli, getClaudeVersion, generateBranchName, launchClaude } = await import('./utils/claude.js')\n const { PromptTemplateManager } = await import('./lib/PromptTemplateManager.js')\n const { ClaudeService } = await import('./lib/ClaudeService.js')\n const { ClaudeContextManager } = await import('./lib/ClaudeContextManager.js')\n\n logger.info('Testing Claude Integration\\n')\n\n // Test 1: Detection\n if (options.detect) {\n logger.info('Detecting Claude CLI...')\n const isAvailable = await detectClaudeCli()\n if (isAvailable) {\n logger.success(' Claude CLI is available')\n } else {\n logger.error(' Claude CLI not found')\n }\n }\n\n // Test 2: Version\n if (options.version) {\n logger.info('Getting Claude version...')\n const version = await getClaudeVersion()\n if (version) {\n logger.success(` Version: ${version}`)\n } else {\n logger.error(' Could not get version')\n }\n }\n\n // Test 3: Branch name generation\n if (options.branch) {\n logger.info('Generating branch name...')\n const issueNumber = parseInt(options.issue ?? '123')\n logger.info(` Issue #${issueNumber}: ${options.branch}`)\n const branchName = await generateBranchName(options.branch, issueNumber)\n logger.success(` Generated: ${branchName}`)\n }\n\n // Test 4: Launch Claude\n if (options.launch) {\n logger.info('Launching Claude...')\n logger.info(` Prompt: \"${options.launch}\"`)\n logger.info(` Mode: ${options.interactive ? 'Interactive' : 'Headless'}`)\n\n if (options.interactive) {\n logger.info(' Launching Claude in new terminal...')\n await launchClaude(options.launch, { headless: false })\n logger.info(' (Claude should open in a separate process)')\n } else {\n logger.info(' Waiting for response...')\n const result = await launchClaude(options.launch, { headless: true })\n if (result) {\n logger.success(' Response:')\n logger.info(` ${result.split('\\n').join('\\n ')}`)\n }\n }\n }\n\n // Test 5: Template loading\n if (options.template) {\n logger.info('Loading template...')\n logger.info(` Template: ${options.template}`)\n const manager = new PromptTemplateManager()\n try {\n const content = await manager.loadTemplate(options.template)\n logger.success(' Template loaded successfully')\n logger.info(' First 200 chars:')\n logger.info(` ${content.substring(0, 200).split('\\n').join('\\n ')}...`)\n } catch (error) {\n logger.error(` Failed: ${error instanceof Error ? error.message : 'Unknown error'}`)\n }\n }\n\n // Run all tests in sequence when no specific options provided\n if (!options.detect && !options.version && !options.branch && !options.launch && !options.template) {\n logger.info('Running full Claude integration test suite...\\n')\n\n // Test 1: Detection\n logger.info('1. Testing Claude CLI detection...')\n const isAvailable = await detectClaudeCli()\n if (isAvailable) {\n logger.success(' Claude CLI is available')\n } else {\n logger.error(' Claude CLI not found')\n logger.info('\\nSkipping remaining tests since Claude CLI is not available')\n return\n }\n\n // Test 2: Version\n logger.info('\\n2. Getting Claude version...')\n const version = await getClaudeVersion()\n if (version) {\n logger.success(` Version: ${version}`)\n } else {\n logger.error(' Could not get version')\n }\n\n // Test 3: Branch name generation\n logger.info('\\n3. Testing branch name generation...')\n const testIssueNumber = 123\n const testTitle = 'Add user authentication feature'\n logger.info(` Issue #${testIssueNumber}: ${testTitle}`)\n const branchName = await generateBranchName(testTitle, testIssueNumber)\n logger.success(` Generated: ${branchName}`)\n\n // Test 4: Service initialization\n logger.info('\\n4. Testing ClaudeService initialization...')\n new ClaudeService() // Just verify it can be instantiated\n logger.success(' Service initialized')\n\n // Test 5: Context manager\n logger.info('\\n5. Testing ClaudeContextManager...')\n const contextManager = new ClaudeContextManager()\n await contextManager.prepareContext({\n type: 'issue',\n identifier: 123,\n title: 'Test issue',\n workspacePath: process.cwd(),\n port: 3123\n })\n logger.success(' Context prepared')\n\n // Test 6: Template loading\n logger.info('\\n6. Testing template loading...')\n const templateManager = new PromptTemplateManager()\n const templates: Array<'issue' | 'pr' | 'regular'> = ['issue', 'pr', 'regular']\n let templateCount = 0\n for (const template of templates) {\n try {\n await templateManager.loadTemplate(template)\n logger.success(` ${template} template loaded`)\n templateCount++\n } catch {\n logger.warn(` ${template} template not found`)\n }\n }\n logger.info(` Loaded ${templateCount}/${templates.length} templates`)\n\n // Test 7: Launch Claude headless (quick test)\n logger.info('\\n7. Testing Claude launch (headless)...')\n logger.info(' Sending test prompt: \"Say hello\"')\n try {\n const result = await launchClaude('Say hello', { headless: true })\n if (result) {\n logger.success(' Claude responded successfully')\n logger.info(` Response preview: ${result.substring(0, 100)}...`)\n } else {\n logger.warn(' No response received')\n }\n } catch (error) {\n logger.error(` Launch failed: ${error instanceof Error ? error.message : 'Unknown error'}`)\n }\n\n logger.info('\\n' + '='.repeat(50))\n logger.success('All Claude integration tests complete!')\n logger.info('Summary: All core Claude features are working correctly')\n }\n\n } catch (error) {\n logger.error(`Test failed: ${error instanceof Error ? error.message : 'Unknown error'}`)\n if (error instanceof Error && error.stack) {\n logger.debug(error.stack)\n }\n process.exit(1)\n }\n })\n\n// Test command for webserver detection\nprogram\n .command('test-webserver')\n .description('Test if a web server is running on a workspace port')\n .argument('<issue-number>', 'Issue number (port will be calculated as 3000 + issue number)', parseInt)\n .option('--kill', 'Kill the web server if detected')\n .action(async (issueNumber: number, options: { kill?: boolean }) => {\n try {\n const { TestWebserverCommand } = await import('./commands/test-webserver.js')\n const command = new TestWebserverCommand()\n await command.execute({ issueNumber, options })\n } catch (error) {\n logger.error(`Test webserver failed: ${error instanceof Error ? error.message : 'Unknown error'}`)\n if (error instanceof Error && error.stack) {\n logger.debug(error.stack)\n }\n process.exit(1)\n }\n })\n\n// Test command for Git integration\nprogram\n .command('test-git')\n .description('Test Git integration - findMainWorktreePath() function (reads .iloom/settings.json)')\n .action(async () => {\n try {\n const { TestGitCommand } = await import('./commands/test-git.js')\n const command = new TestGitCommand()\n await command.execute()\n } catch (error) {\n logger.error(`Test git failed: ${error instanceof Error ? error.message : 'Unknown error'}`)\n if (error instanceof Error && error.stack) {\n logger.debug(error.stack)\n }\n process.exit(1)\n }\n })\n\n// Test command for iTerm2 dual tab functionality\nprogram\n .command('test-tabs')\n .description('Test iTerm2 dual tab functionality - opens two tabs with test commands')\n .action(async () => {\n try {\n const { TestTabsCommand } = await import('./commands/test-tabs.js')\n const command = new TestTabsCommand()\n await command.execute()\n } catch (error) {\n logger.error(`Test tabs failed: ${error instanceof Error ? error.message : 'Unknown error'}`)\n if (error instanceof Error && error.stack) {\n logger.debug(error.stack)\n }\n process.exit(1)\n }\n })\n\n// Test command for worktree prefix configuration\nprogram\n .command('test-prefix')\n .description('Test worktree prefix configuration - preview worktree paths (reads .iloom/settings.json)')\n .action(async () => {\n try {\n const { TestPrefixCommand } = await import('./commands/test-prefix.js')\n const command = new TestPrefixCommand()\n await command.execute()\n } catch (error) {\n logger.error(`Test prefix failed: ${error instanceof Error ? error.message : 'Unknown error'}`)\n if (error instanceof Error && error.stack) {\n logger.debug(error.stack)\n }\n process.exit(1)\n }\n })\n\n// Test command for Neon integration\nprogram\n .command('test-neon')\n .description('Test Neon integration and debug configuration')\n .action(async () => {\n try {\n const { SettingsManager } = await import('./lib/SettingsManager.js')\n const { createNeonProviderFromSettings } = await import('./utils/neon-helpers.js')\n\n logger.info('Testing Neon Integration\\n')\n\n // Test 1: Settings Configuration\n logger.info('1. Settings Configuration:')\n const settingsManager = new SettingsManager()\n const settings = await settingsManager.loadSettings()\n const neonConfig = settings.databaseProviders?.neon\n logger.info(` projectId: ${neonConfig?.projectId ?? '(not configured)'}`)\n logger.info(` parentBranch: ${neonConfig?.parentBranch ?? '(not configured)'}`)\n\n // Test 2: Create provider and test initialization\n logger.info('\\n2. Creating NeonProvider...')\n try {\n const neonProvider = createNeonProviderFromSettings(settings)\n logger.success(' NeonProvider created successfully')\n\n // Test 3: CLI availability\n logger.info('\\n3. Testing Neon CLI availability...')\n const isAvailable = await neonProvider.isCliAvailable()\n if (isAvailable) {\n logger.success(' Neon CLI is available')\n } else {\n logger.error(' Neon CLI not found')\n logger.info(' Install with: npm install -g @neon/cli')\n return\n }\n\n // Test 4: Authentication\n logger.info('\\n4. Testing Neon CLI authentication...')\n const isAuthenticated = await neonProvider.isAuthenticated()\n if (isAuthenticated) {\n logger.success(' Neon CLI is authenticated')\n } else {\n logger.error(' Neon CLI not authenticated')\n logger.info(' Run: neon auth')\n return\n }\n\n // Test 5: List branches (if config is valid)\n if (neonConfig?.projectId) {\n logger.info('\\n5. Testing branch listing...')\n try {\n const branches = await neonProvider.listBranches()\n logger.success(` Found ${branches.length} branches:`)\n for (const branch of branches.slice(0, 5)) { // Show first 5\n logger.info(` - ${branch}`)\n }\n if (branches.length > 5) {\n logger.info(` ... and ${branches.length - 5} more`)\n }\n } catch (error) {\n logger.error(` Failed to list branches: ${error instanceof Error ? error.message : 'Unknown error'}`)\n }\n } else {\n logger.warn('\\n5. Skipping branch listing (Neon not configured in settings)')\n }\n\n } catch (error) {\n logger.error(` Failed to create NeonProvider: ${error instanceof Error ? error.message : 'Unknown error'}`)\n if (error instanceof Error && error.message.includes('not configured')) {\n logger.info('\\n This is expected if Neon is not configured.')\n logger.info(' Configure databaseProviders.neon in .iloom/settings.json to test fully.')\n }\n }\n\n logger.info('\\n' + '='.repeat(50))\n logger.success('Neon integration test complete!')\n\n } catch (error) {\n logger.error(`Test failed: ${error instanceof Error ? error.message : 'Unknown error'}`)\n if (error instanceof Error && error.stack) {\n logger.debug(error.stack)\n }\n process.exit(1)\n }\n })\n\n// Add custom help command in order to get preAction to run (update check handled by preAction hook)\nprogram\n .command('help')\n .description('Display help information')\n .argument('[command]', 'Show help for specific command')\n .action(async (command?: string) => {\n // Show help (update check already ran in preAction)\n if (command) {\n // Show help for specific command\n const subCommand = program.commands.find(cmd => cmd.name() === command)\n if (subCommand) {\n subCommand.outputHelp()\n } else {\n logger.error(`Unknown command: ${command}`)\n program.outputHelp()\n }\n } else {\n program.outputHelp()\n }\n\n process.exit(0)\n })\n\n// Parse CLI arguments\ntry {\n await program.parseAsync()\n} catch (error) {\n if (error instanceof Error) {\n logger.error(`Error: ${error.message}`)\n process.exit(1)\n }\n}\n","import { readFileSync } from 'fs'\nimport { fileURLToPath } from 'url'\nimport { dirname, join } from 'path'\n\n/**\n * Package information from package.json\n */\nexport interface PackageInfo {\n name: string\n version: string\n description: string\n [key: string]: unknown\n}\n\n/**\n * Get package.json information\n *\n * @param scriptPath - Optional path to use for finding package.json (defaults to current file location)\n * @returns Parsed package.json contents\n * @throws Error if package.json cannot be read or parsed\n */\nexport function getPackageInfo(scriptPath?: string): PackageInfo {\n try {\n // Determine the base path to use\n let basePath: string\n if (scriptPath) {\n basePath = scriptPath\n } else {\n // Use import.meta.url to get the current file path\n const __filename = fileURLToPath(import.meta.url)\n basePath = __filename\n }\n\n // Navigate from current file to package.json\n // The compiled CLI runs from dist/cli.js, so we need dist/../package.json (one level up)\n const __dirname = dirname(basePath)\n const packageJsonPath = join(__dirname, '..', 'package.json')\n\n // Read and parse package.json\n const packageJsonContent = readFileSync(packageJsonPath, 'utf8')\n const packageJson = JSON.parse(packageJsonContent) as PackageInfo\n\n return packageJson\n } catch (error) {\n throw new Error(\n `Failed to read package.json: ${error instanceof Error ? error.message : 'Unknown error'}`\n )\n }\n}\n"],"mappings":"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","names":["__filename","packageJson","fileURLToPath","shellCompletion"]}
|