@aku11i/phantom 0.3.0 → 0.4.0

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.
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
- "sources": ["../src/bin/phantom.ts", "../src/commands/create.ts", "../src/git/libs/add-worktree.ts", "../src/git/libs/get-git-root.ts", "../src/commands/shell.ts", "../src/commands/where.ts", "../src/commands/delete.ts", "../src/commands/exec.ts", "../src/commands/list.ts", "../package.json", "../src/commands/version.ts"],
4
- "sourcesContent": ["#!/usr/bin/env node\n\nimport { argv, exit } from \"node:process\";\nimport { createHandler } from \"../commands/create.ts\";\nimport { deleteHandler } from \"../commands/delete.ts\";\nimport { execHandler } from \"../commands/exec.ts\";\nimport { listHandler } from \"../commands/list.ts\";\nimport { shellHandler } from \"../commands/shell.ts\";\nimport { versionHandler } from \"../commands/version.ts\";\nimport { whereHandler } from \"../commands/where.ts\";\n\ninterface Command {\n name: string;\n description: string;\n subcommands?: Command[];\n handler?: (args: string[]) => void | Promise<void>;\n}\n\nconst commands: Command[] = [\n {\n name: \"create\",\n description: \"Create a new worktree [--shell to open shell]\",\n handler: createHandler,\n },\n {\n name: \"list\",\n description: \"List all worktrees\",\n handler: listHandler,\n },\n {\n name: \"where\",\n description: \"Output the path of a specific worktree\",\n handler: whereHandler,\n },\n {\n name: \"delete\",\n description: \"Delete a worktree (use --force for uncommitted changes)\",\n handler: deleteHandler,\n },\n {\n name: \"exec\",\n description: \"Execute a command in a worktree directory\",\n handler: execHandler,\n },\n {\n name: \"shell\",\n description: \"Open interactive shell in a worktree directory\",\n handler: shellHandler,\n },\n {\n name: \"version\",\n description: \"Display phantom version\",\n handler: versionHandler,\n },\n];\n\nfunction printHelp(commands: Command[]) {\n console.log(\"Usage: phantom <command> [options]\\n\");\n console.log(\"Commands:\");\n for (const cmd of commands) {\n console.log(` ${cmd.name.padEnd(12)} ${cmd.description}`);\n }\n}\n\nfunction findCommand(\n args: string[],\n commands: Command[],\n): { command: Command | null; remainingArgs: string[] } {\n if (args.length === 0) {\n return { command: null, remainingArgs: [] };\n }\n\n const [cmdName, ...rest] = args;\n const command = commands.find((cmd) => cmd.name === cmdName);\n\n if (!command) {\n return { command: null, remainingArgs: args };\n }\n\n if (command.subcommands && rest.length > 0) {\n const { command: subcommand, remainingArgs } = findCommand(\n rest,\n command.subcommands,\n );\n if (subcommand) {\n return { command: subcommand, remainingArgs };\n }\n }\n\n return { command, remainingArgs: rest };\n}\n\nconst args = argv.slice(2);\n\nif (args.length === 0 || args[0] === \"-h\" || args[0] === \"--help\") {\n printHelp(commands);\n exit(0);\n}\n\nif (args[0] === \"--version\" || args[0] === \"-v\") {\n versionHandler();\n exit(0);\n}\n\nconst { command, remainingArgs } = findCommand(args, commands);\n\nif (!command || !command.handler) {\n console.error(`Error: Unknown command '${args.join(\" \")}'\\n`);\n printHelp(commands);\n exit(1);\n}\n\ntry {\n await command.handler(remainingArgs);\n} catch (error) {\n console.error(\n \"Error:\",\n error instanceof Error ? error.message : String(error),\n );\n exit(1);\n}\n", "import { access, mkdir } from \"node:fs/promises\";\nimport { join } from \"node:path\";\nimport { exit } from \"node:process\";\nimport { addWorktree } from \"../git/libs/add-worktree.ts\";\nimport { getGitRoot } from \"../git/libs/get-git-root.ts\";\nimport { shellInWorktree } from \"./shell.ts\";\n\nexport async function createWorktree(name: string): Promise<{\n success: boolean;\n message: string;\n path?: string;\n}> {\n if (!name) {\n return { success: false, message: \"Error: worktree name required\" };\n }\n\n try {\n const gitRoot = await getGitRoot();\n const worktreesPath = join(gitRoot, \".git\", \"phantom\", \"worktrees\");\n const worktreePath = join(worktreesPath, name);\n\n try {\n await access(worktreesPath);\n } catch {\n await mkdir(worktreesPath, { recursive: true });\n }\n\n try {\n await access(worktreePath);\n return {\n success: false,\n message: `Error: worktree '${name}' already exists`,\n };\n } catch {\n // Path doesn't exist, which is what we want\n }\n\n await addWorktree({\n path: worktreePath,\n branch: name,\n commitish: \"HEAD\",\n });\n\n return {\n success: true,\n message: `Created worktree '${name}' at ${worktreePath}`,\n path: worktreePath,\n };\n } catch (error) {\n const errorMessage = error instanceof Error ? error.message : String(error);\n return {\n success: false,\n message: `Error creating worktree: ${errorMessage}`,\n };\n }\n}\n\nexport async function createHandler(args: string[]): Promise<void> {\n const name = args[0];\n const openShell = args.includes(\"--shell\");\n\n const result = await createWorktree(name);\n\n if (!result.success) {\n console.error(result.message);\n exit(1);\n }\n\n console.log(result.message);\n\n if (openShell && result.path) {\n console.log(`\\nEntering worktree '${name}' at ${result.path}`);\n console.log(\"Type 'exit' to return to your original directory\\n\");\n\n const shellResult = await shellInWorktree(name);\n\n if (!shellResult.success) {\n if (shellResult.message) {\n console.error(shellResult.message);\n }\n exit(shellResult.exitCode ?? 1);\n }\n\n exit(shellResult.exitCode ?? 0);\n }\n}\n", "import { exec } from \"node:child_process\";\nimport { promisify } from \"node:util\";\n\nconst execAsync = promisify(exec);\n\nexport interface AddWorktreeOptions {\n path: string;\n branch: string;\n commitish?: string;\n}\n\nexport async function addWorktree(options: AddWorktreeOptions): Promise<void> {\n const { path, branch, commitish = \"HEAD\" } = options;\n\n await execAsync(`git worktree add \"${path}\" -b \"${branch}\" ${commitish}`);\n}\n", "import { exec } from \"node:child_process\";\nimport { promisify } from \"node:util\";\n\nconst execAsync = promisify(exec);\n\nexport async function getGitRoot(): Promise<string> {\n const { stdout } = await execAsync(\"git rev-parse --show-toplevel\");\n return stdout.trim();\n}\n", "import { spawn } from \"node:child_process\";\nimport { exit } from \"node:process\";\nimport { whereWorktree } from \"./where.ts\";\n\nexport async function shellInWorktree(worktreeName: string): Promise<{\n success: boolean;\n message?: string;\n exitCode?: number;\n}> {\n if (!worktreeName) {\n return { success: false, message: \"Error: worktree name required\" };\n }\n\n // Validate worktree exists and get its path\n const worktreeResult = await whereWorktree(worktreeName);\n if (!worktreeResult.success) {\n return { success: false, message: worktreeResult.message };\n }\n\n const worktreePath = worktreeResult.path as string;\n // Use user's preferred shell or fallback to /bin/sh\n const shell = process.env.SHELL || \"/bin/sh\";\n\n return new Promise((resolve) => {\n const childProcess = spawn(shell, [], {\n cwd: worktreePath,\n stdio: \"inherit\",\n env: {\n ...process.env,\n // Add environment variable to indicate we're in a worktree\n WORKTREE_NAME: worktreeName,\n WORKTREE_PATH: worktreePath,\n },\n });\n\n childProcess.on(\"error\", (error) => {\n resolve({\n success: false,\n message: `Error starting shell: ${error.message}`,\n });\n });\n\n childProcess.on(\"exit\", (code, signal) => {\n if (signal) {\n resolve({\n success: false,\n message: `Shell terminated by signal: ${signal}`,\n exitCode: 128 + (signal === \"SIGTERM\" ? 15 : 1),\n });\n } else {\n const exitCode = code ?? 0;\n resolve({\n success: exitCode === 0,\n exitCode,\n });\n }\n });\n });\n}\n\nexport async function shellHandler(args: string[]): Promise<void> {\n if (args.length < 1) {\n console.error(\"Usage: phantom shell <worktree-name>\");\n exit(1);\n }\n\n const worktreeName = args[0];\n\n // Get worktree path for display\n const worktreeResult = await whereWorktree(worktreeName);\n if (!worktreeResult.success) {\n console.error(worktreeResult.message);\n exit(1);\n }\n\n // Display entering message\n console.log(`Entering worktree '${worktreeName}' at ${worktreeResult.path}`);\n console.log(\"Type 'exit' to return to your original directory\\n\");\n\n const result = await shellInWorktree(worktreeName);\n\n if (!result.success) {\n if (result.message) {\n console.error(result.message);\n }\n exit(result.exitCode ?? 1);\n }\n\n // Exit with the same code as the shell\n exit(result.exitCode ?? 0);\n}\n", "import { access } from \"node:fs/promises\";\nimport { join } from \"node:path\";\nimport { exit } from \"node:process\";\nimport { getGitRoot } from \"../git/libs/get-git-root.ts\";\n\nexport async function whereWorktree(name: string): Promise<{\n success: boolean;\n message?: string;\n path?: string;\n}> {\n if (!name) {\n return { success: false, message: \"Error: worktree name required\" };\n }\n\n try {\n const gitRoot = await getGitRoot();\n const worktreesPath = join(gitRoot, \".git\", \"phantom\", \"worktrees\");\n const worktreePath = join(worktreesPath, name);\n\n // Check if worktree exists\n try {\n await access(worktreePath);\n } catch {\n return {\n success: false,\n message: `Error: Worktree '${name}' does not exist`,\n };\n }\n\n return {\n success: true,\n path: worktreePath,\n };\n } catch (error) {\n const errorMessage = error instanceof Error ? error.message : String(error);\n return {\n success: false,\n message: `Error locating worktree: ${errorMessage}`,\n };\n }\n}\n\nexport async function whereHandler(args: string[]): Promise<void> {\n const name = args[0];\n const result = await whereWorktree(name);\n\n if (!result.success) {\n console.error(result.message);\n exit(1);\n }\n\n console.log(result.path);\n}\n", "import { exec } from \"node:child_process\";\nimport { access } from \"node:fs/promises\";\nimport { join } from \"node:path\";\nimport { exit } from \"node:process\";\nimport { promisify } from \"node:util\";\nimport { getGitRoot } from \"../git/libs/get-git-root.ts\";\n\nconst execAsync = promisify(exec);\n\nexport async function deleteWorktree(\n name: string,\n options: { force?: boolean } = {},\n): Promise<{\n success: boolean;\n message: string;\n hasUncommittedChanges?: boolean;\n changedFiles?: number;\n}> {\n if (!name) {\n return { success: false, message: \"Error: worktree name required\" };\n }\n\n const { force = false } = options;\n\n try {\n const gitRoot = await getGitRoot();\n const worktreesPath = join(gitRoot, \".git\", \"phantom\", \"worktrees\");\n const worktreePath = join(worktreesPath, name);\n\n // Check if worktree exists\n try {\n await access(worktreePath);\n } catch {\n return {\n success: false,\n message: `Error: Worktree '${name}' does not exist`,\n };\n }\n\n // Check for uncommitted changes\n let hasUncommittedChanges = false;\n let changedFiles = 0;\n try {\n const { stdout } = await execAsync(\"git status --porcelain\", {\n cwd: worktreePath,\n });\n const changes = stdout.trim();\n if (changes) {\n hasUncommittedChanges = true;\n changedFiles = changes.split(\"\\n\").length;\n }\n } catch {\n // If git status fails, assume no changes\n hasUncommittedChanges = false;\n }\n\n // If worktree has uncommitted changes and --force is not specified, refuse deletion\n if (hasUncommittedChanges && !force) {\n return {\n success: false,\n message: `Error: Worktree '${name}' has uncommitted changes (${changedFiles} files). Use --force to delete anyway.`,\n hasUncommittedChanges: true,\n changedFiles,\n };\n }\n\n // Remove git worktree\n try {\n await execAsync(`git worktree remove \"${worktreePath}\"`, {\n cwd: gitRoot,\n });\n } catch (error) {\n // If worktree remove fails, try force removal\n try {\n await execAsync(`git worktree remove --force \"${worktreePath}\"`, {\n cwd: gitRoot,\n });\n } catch {\n return {\n success: false,\n message: `Error: Failed to remove worktree '${name}'`,\n };\n }\n }\n\n // Delete associated branch\n const branchName = `phantom/worktrees/${name}`;\n try {\n await execAsync(`git branch -D \"${branchName}\"`, {\n cwd: gitRoot,\n });\n } catch {\n // Branch might not exist or already deleted - this is not an error\n // We'll still report success for the worktree removal\n }\n\n let message = `Deleted worktree '${name}' and its branch '${branchName}'`;\n if (hasUncommittedChanges) {\n message = `Warning: Worktree '${name}' had uncommitted changes (${changedFiles} files)\\n${message}`;\n }\n\n return {\n success: true,\n message,\n hasUncommittedChanges,\n changedFiles: hasUncommittedChanges ? changedFiles : undefined,\n };\n } catch (error) {\n const errorMessage = error instanceof Error ? error.message : String(error);\n return {\n success: false,\n message: `Error deleting worktree: ${errorMessage}`,\n };\n }\n}\n\nexport async function deleteHandler(args: string[]): Promise<void> {\n // Parse arguments for --force flag\n const forceIndex = args.indexOf(\"--force\");\n const force = forceIndex !== -1;\n\n // Remove --force from args to get the worktree name\n const filteredArgs = args.filter((arg) => arg !== \"--force\");\n const name = filteredArgs[0];\n\n const result = await deleteWorktree(name, { force });\n\n if (!result.success) {\n console.error(result.message);\n exit(1);\n }\n\n console.log(result.message);\n}\n", "import { spawn } from \"node:child_process\";\nimport { exit } from \"node:process\";\nimport { whereWorktree } from \"./where.ts\";\n\nexport async function execInWorktree(\n worktreeName: string,\n command: string[],\n): Promise<{\n success: boolean;\n message?: string;\n exitCode?: number;\n}> {\n if (!worktreeName) {\n return { success: false, message: \"Error: worktree name required\" };\n }\n\n if (!command || command.length === 0) {\n return { success: false, message: \"Error: command required\" };\n }\n\n // Validate worktree exists and get its path\n const worktreeResult = await whereWorktree(worktreeName);\n if (!worktreeResult.success) {\n return { success: false, message: worktreeResult.message };\n }\n\n const worktreePath = worktreeResult.path as string;\n const [cmd, ...args] = command;\n\n return new Promise((resolve) => {\n const childProcess = spawn(cmd, args, {\n cwd: worktreePath,\n stdio: \"inherit\",\n });\n\n childProcess.on(\"error\", (error) => {\n resolve({\n success: false,\n message: `Error executing command: ${error.message}`,\n });\n });\n\n childProcess.on(\"exit\", (code, signal) => {\n if (signal) {\n resolve({\n success: false,\n message: `Command terminated by signal: ${signal}`,\n exitCode: 128 + (signal === \"SIGTERM\" ? 15 : 1),\n });\n } else {\n const exitCode = code ?? 0;\n resolve({\n success: exitCode === 0,\n exitCode,\n });\n }\n });\n });\n}\n\nexport async function execHandler(args: string[]): Promise<void> {\n if (args.length < 2) {\n console.error(\"Usage: phantom exec <worktree-name> <command> [args...]\");\n exit(1);\n }\n\n const worktreeName = args[0];\n const command = args.slice(1);\n\n const result = await execInWorktree(worktreeName, command);\n\n if (!result.success) {\n if (result.message) {\n console.error(result.message);\n }\n exit(result.exitCode ?? 1);\n }\n\n // For successful commands, exit with the same code as the child process\n exit(result.exitCode ?? 0);\n}\n", "import { exec } from \"node:child_process\";\nimport { access, readdir } from \"node:fs/promises\";\nimport { join } from \"node:path\";\nimport { promisify } from \"node:util\";\nimport { getGitRoot } from \"../git/libs/get-git-root.ts\";\n\nconst execAsync = promisify(exec);\n\nexport interface WorktreeInfo {\n name: string;\n branch: string;\n status: \"clean\" | \"dirty\";\n changedFiles?: number;\n}\n\nexport async function listWorktrees(): Promise<{\n success: boolean;\n message?: string;\n worktrees?: WorktreeInfo[];\n}> {\n try {\n const gitRoot = await getGitRoot();\n const worktreesPath = join(gitRoot, \".git\", \"phantom\", \"worktrees\");\n\n // Check if worktrees directory exists\n try {\n await access(worktreesPath);\n } catch {\n return {\n success: true,\n worktrees: [],\n message: \"No worktrees found (worktrees directory doesn't exist)\",\n };\n }\n\n // Read worktrees directory\n let worktreeNames: string[];\n try {\n const entries = await readdir(worktreesPath);\n // Filter entries to only include directories\n const validEntries = await Promise.all(\n entries.map(async (entry) => {\n try {\n const entryPath = join(worktreesPath, entry);\n await access(entryPath);\n return entry;\n } catch {\n return null;\n }\n }),\n );\n worktreeNames = validEntries.filter(\n (entry): entry is string => entry !== null,\n );\n } catch {\n return {\n success: true,\n worktrees: [],\n message: \"No worktrees found (unable to read worktrees directory)\",\n };\n }\n\n if (worktreeNames.length === 0) {\n return {\n success: true,\n worktrees: [],\n message: \"No worktrees found\",\n };\n }\n\n // Get detailed information for each worktree\n const worktrees: WorktreeInfo[] = await Promise.all(\n worktreeNames.map(async (name) => {\n const worktreePath = join(worktreesPath, name);\n\n // Get current branch\n let branch = \"unknown\";\n try {\n const { stdout } = await execAsync(\"git branch --show-current\", {\n cwd: worktreePath,\n });\n branch = stdout.trim() || \"detached HEAD\";\n } catch {\n branch = \"unknown\";\n }\n\n // Get working directory status\n let status: \"clean\" | \"dirty\" = \"clean\";\n let changedFiles: number | undefined;\n try {\n const { stdout } = await execAsync(\"git status --porcelain\", {\n cwd: worktreePath,\n });\n const changes = stdout.trim();\n if (changes) {\n status = \"dirty\";\n changedFiles = changes.split(\"\\n\").length;\n }\n } catch {\n // If git status fails, assume unknown status\n status = \"clean\";\n }\n\n return {\n name,\n branch,\n status,\n changedFiles,\n };\n }),\n );\n\n return {\n success: true,\n worktrees,\n };\n } catch (error) {\n const errorMessage = error instanceof Error ? error.message : String(error);\n return {\n success: false,\n message: `Error listing worktrees: ${errorMessage}`,\n };\n }\n}\n\nexport async function listHandler(): Promise<void> {\n const result = await listWorktrees();\n\n if (!result.success) {\n console.error(result.message);\n return;\n }\n\n if (!result.worktrees || result.worktrees.length === 0) {\n console.log(result.message || \"No worktrees found\");\n return;\n }\n\n console.log(\"Worktrees:\");\n for (const worktree of result.worktrees) {\n const statusText =\n worktree.status === \"clean\"\n ? \"[clean]\"\n : `[dirty: ${worktree.changedFiles} files]`;\n\n console.log(\n ` ${worktree.name.padEnd(20)} (branch: ${worktree.branch.padEnd(20)}) ${statusText}`,\n );\n }\n\n console.log(`\\nTotal: ${result.worktrees.length} worktrees`);\n}\n", "{\n \"name\": \"@aku11i/phantom\",\n \"packageManager\": \"pnpm@10.8.1\",\n \"version\": \"0.3.0\",\n \"description\": \"A powerful CLI tool for managing Git worktrees for parallel development\",\n \"keywords\": [\n \"git\",\n \"worktree\",\n \"cli\",\n \"phantom\",\n \"workspace\",\n \"development\",\n \"parallel\"\n ],\n \"homepage\": \"https://github.com/aku11i/phantom#readme\",\n \"bugs\": {\n \"url\": \"https://github.com/aku11i/phantom/issues\"\n },\n \"repository\": {\n \"type\": \"git\",\n \"url\": \"git+https://github.com/aku11i/phantom.git\"\n },\n \"license\": \"MIT\",\n \"author\": \"aku11i\",\n \"type\": \"module\",\n \"bin\": {\n \"phantom\": \"./dist/phantom.js\"\n },\n \"scripts\": {\n \"start\": \"node ./src/bin/phantom.ts\",\n \"phantom\": \"node ./src/bin/phantom.ts\",\n \"build\": \"node build.ts\",\n \"type-check\": \"tsc --noEmit\",\n \"test\": \"node --test --experimental-strip-types --experimental-test-module-mocks src/**/*.test.ts\",\n \"lint\": \"biome check .\",\n \"fix\": \"biome check --write .\",\n \"ready\": \"pnpm fix && pnpm type-check && pnpm test\",\n \"ready:check\": \"pnpm lint && pnpm type-check && pnpm test\",\n \"prepublishOnly\": \"pnpm ready:check && pnpm build\"\n },\n \"engines\": {\n \"node\": \">=22.0.0\"\n },\n \"files\": [\n \"dist/\",\n \"README.md\",\n \"LICENSE\"\n ],\n \"devDependencies\": {\n \"@biomejs/biome\": \"^1.9.4\",\n \"@types/node\": \"^22.15.29\",\n \"esbuild\": \"^0.25.5\",\n \"typescript\": \"^5.8.3\"\n }\n}\n", "import packageJson from \"../../package.json\" with { type: \"json\" };\n\nexport function getVersion(): string {\n return packageJson.version;\n}\n\nexport function versionHandler(): void {\n const version = getVersion();\n console.log(`Phantom v${version}`);\n}\n"],
5
- "mappings": "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",
6
- "names": ["exit", "access", "join", "exit", "exec", "promisify", "execAsync", "exit", "args", "args", "exit", "join", "access", "args", "exit", "exec", "access", "join", "exit", "promisify", "execAsync", "promisify", "exec", "join", "access", "args", "exit", "spawn", "exit", "command", "args", "spawn", "exit", "exec", "access", "join", "promisify", "execAsync", "promisify", "exec", "join", "access", "commands", "args", "command", "remainingArgs", "exit"]
3
+ "sources": ["../src/bin/phantom.ts", "../src/cli/handlers/create.ts", "../src/core/git/executor.ts", "../src/core/git/libs/get-git-root.ts", "../src/core/types/result.ts", "../src/core/worktree/errors.ts", "../src/core/worktree/validate.ts", "../src/core/paths.ts", "../src/core/process/spawn.ts", "../src/core/process/errors.ts", "../src/core/process/exec.ts", "../src/core/process/shell.ts", "../src/core/worktree/create.ts", "../src/core/git/libs/add-worktree.ts", "../src/cli/output.ts", "../src/cli/errors.ts", "../src/cli/handlers/delete.ts", "../src/core/worktree/delete.ts", "../src/cli/handlers/exec.ts", "../src/cli/handlers/list.ts", "../src/core/worktree/list.ts", "../src/cli/handlers/shell.ts", "../src/cli/handlers/version.ts", "../package.json", "../src/core/version.ts", "../src/cli/handlers/where.ts", "../src/core/worktree/where.ts"],
4
+ "sourcesContent": ["#!/usr/bin/env node\n\nimport { argv, exit } from \"node:process\";\nimport { createHandler } from \"../cli/handlers/create.ts\";\nimport { deleteHandler } from \"../cli/handlers/delete.ts\";\nimport { execHandler } from \"../cli/handlers/exec.ts\";\nimport { listHandler } from \"../cli/handlers/list.ts\";\nimport { shellHandler } from \"../cli/handlers/shell.ts\";\nimport { versionHandler } from \"../cli/handlers/version.ts\";\nimport { whereHandler } from \"../cli/handlers/where.ts\";\n\ninterface Command {\n name: string;\n description: string;\n subcommands?: Command[];\n handler?: (args: string[]) => void | Promise<void>;\n}\n\nconst commands: Command[] = [\n {\n name: \"create\",\n description: \"Create a new worktree [--shell | --exec <command>]\",\n handler: createHandler,\n },\n {\n name: \"list\",\n description: \"List all worktrees\",\n handler: listHandler,\n },\n {\n name: \"where\",\n description: \"Output the path of a specific worktree\",\n handler: whereHandler,\n },\n {\n name: \"delete\",\n description: \"Delete a worktree (use --force for uncommitted changes)\",\n handler: deleteHandler,\n },\n {\n name: \"exec\",\n description: \"Execute a command in a worktree directory\",\n handler: execHandler,\n },\n {\n name: \"shell\",\n description: \"Open interactive shell in a worktree directory\",\n handler: shellHandler,\n },\n {\n name: \"version\",\n description: \"Display phantom version\",\n handler: versionHandler,\n },\n];\n\nfunction printHelp(commands: Command[]) {\n console.log(\"Usage: phantom <command> [options]\\n\");\n console.log(\"Commands:\");\n for (const cmd of commands) {\n console.log(` ${cmd.name.padEnd(12)} ${cmd.description}`);\n }\n}\n\nfunction findCommand(\n args: string[],\n commands: Command[],\n): { command: Command | null; remainingArgs: string[] } {\n if (args.length === 0) {\n return { command: null, remainingArgs: [] };\n }\n\n const [cmdName, ...rest] = args;\n const command = commands.find((cmd) => cmd.name === cmdName);\n\n if (!command) {\n return { command: null, remainingArgs: args };\n }\n\n if (command.subcommands && rest.length > 0) {\n const { command: subcommand, remainingArgs } = findCommand(\n rest,\n command.subcommands,\n );\n if (subcommand) {\n return { command: subcommand, remainingArgs };\n }\n }\n\n return { command, remainingArgs: rest };\n}\n\nconst args = argv.slice(2);\n\nif (args.length === 0 || args[0] === \"-h\" || args[0] === \"--help\") {\n printHelp(commands);\n exit(0);\n}\n\nif (args[0] === \"--version\" || args[0] === \"-v\") {\n versionHandler();\n exit(0);\n}\n\nconst { command, remainingArgs } = findCommand(args, commands);\n\nif (!command || !command.handler) {\n console.error(`Error: Unknown command '${args.join(\" \")}'\\n`);\n printHelp(commands);\n exit(1);\n}\n\ntry {\n await command.handler(remainingArgs);\n} catch (error) {\n console.error(\n \"Error:\",\n error instanceof Error ? error.message : String(error),\n );\n exit(1);\n}\n", "import { parseArgs } from \"node:util\";\nimport { getGitRoot } from \"../../core/git/libs/get-git-root.ts\";\nimport { execInWorktree } from \"../../core/process/exec.ts\";\nimport { shellInWorktree } from \"../../core/process/shell.ts\";\nimport { isErr, isOk } from \"../../core/types/result.ts\";\nimport { createWorktree as createWorktreeCore } from \"../../core/worktree/create.ts\";\nimport { WorktreeAlreadyExistsError } from \"../../core/worktree/errors.ts\";\nimport { exitCodes, exitWithError, exitWithSuccess } from \"../errors.ts\";\nimport { output } from \"../output.ts\";\n\nexport async function createHandler(args: string[]): Promise<void> {\n const { values, positionals } = parseArgs({\n args,\n options: {\n shell: {\n type: \"boolean\",\n short: \"s\",\n },\n exec: {\n type: \"string\",\n short: \"x\",\n },\n },\n strict: true,\n allowPositionals: true,\n });\n\n if (positionals.length === 0) {\n exitWithError(\n \"Please provide a name for the new worktree\",\n exitCodes.validationError,\n );\n }\n\n const worktreeName = positionals[0];\n const openShell = values.shell ?? false;\n const execCommand = values.exec;\n\n if (openShell && execCommand) {\n exitWithError(\n \"Cannot use --shell and --exec together\",\n exitCodes.validationError,\n );\n }\n\n try {\n const gitRoot = await getGitRoot();\n const result = await createWorktreeCore(gitRoot, worktreeName);\n\n if (isErr(result)) {\n const exitCode =\n result.error instanceof WorktreeAlreadyExistsError\n ? exitCodes.validationError\n : exitCodes.generalError;\n exitWithError(result.error.message, exitCode);\n }\n\n output.log(result.value.message);\n\n if (execCommand && isOk(result)) {\n output.log(\n `\\nExecuting command in worktree '${worktreeName}': ${execCommand}`,\n );\n\n const shell = process.env.SHELL || \"/bin/sh\";\n const execResult = await execInWorktree(gitRoot, worktreeName, [\n shell,\n \"-c\",\n execCommand,\n ]);\n\n if (isErr(execResult)) {\n output.error(execResult.error.message);\n const exitCode =\n \"exitCode\" in execResult.error\n ? (execResult.error.exitCode ?? exitCodes.generalError)\n : exitCodes.generalError;\n exitWithError(\"\", exitCode);\n }\n\n process.exit(execResult.value.exitCode ?? 0);\n }\n\n if (openShell && isOk(result)) {\n output.log(\n `\\nEntering worktree '${worktreeName}' at ${result.value.path}`,\n );\n output.log(\"Type 'exit' to return to your original directory\\n\");\n\n const shellResult = await shellInWorktree(gitRoot, worktreeName);\n\n if (isErr(shellResult)) {\n output.error(shellResult.error.message);\n const exitCode =\n \"exitCode\" in shellResult.error\n ? (shellResult.error.exitCode ?? exitCodes.generalError)\n : exitCodes.generalError;\n exitWithError(\"\", exitCode);\n }\n\n process.exit(shellResult.value.exitCode ?? 0);\n }\n\n exitWithSuccess();\n } catch (error) {\n exitWithError(\n error instanceof Error ? error.message : String(error),\n exitCodes.generalError,\n );\n }\n}\n", "import { execFile as execFileCallback } from \"node:child_process\";\nimport { promisify } from \"node:util\";\n\nconst execFile = promisify(execFileCallback);\n\nexport interface GitExecutorOptions {\n cwd?: string;\n env?: NodeJS.ProcessEnv;\n}\n\nexport interface GitExecutorResult {\n stdout: string;\n stderr: string;\n}\n\n/**\n * Execute a git command with consistent error handling\n */\nexport async function executeGitCommand(\n args: string[],\n options: GitExecutorOptions = {},\n): Promise<GitExecutorResult> {\n try {\n const result = await execFile(\"git\", args, {\n cwd: options.cwd,\n env: options.env || process.env,\n encoding: \"utf8\",\n });\n\n return {\n stdout: result.stdout.trim(),\n stderr: result.stderr.trim(),\n };\n } catch (error) {\n // Git commands often return non-zero exit codes for normal operations\n // (e.g., `git diff` returns 1 when there are differences)\n // So we need to handle errors carefully\n if (\n error &&\n typeof error === \"object\" &&\n \"stdout\" in error &&\n \"stderr\" in error\n ) {\n const execError = error as {\n stdout: string;\n stderr: string;\n code?: number;\n };\n\n // If we have stderr content, it's likely a real error\n if (execError.stderr?.trim()) {\n throw new Error(execError.stderr.trim());\n }\n\n // Otherwise, return the output even though the exit code was non-zero\n return {\n stdout: execError.stdout?.trim() || \"\",\n stderr: execError.stderr?.trim() || \"\",\n };\n }\n\n throw error;\n }\n}\n\n/**\n * Execute a git command in a specific directory\n */\nexport async function executeGitCommandInDirectory(\n directory: string,\n args: string[],\n): Promise<GitExecutorResult> {\n return executeGitCommand([\"-C\", directory, ...args], {});\n}\n", "import { executeGitCommand } from \"../executor.ts\";\n\nexport async function getGitRoot(): Promise<string> {\n const { stdout } = await executeGitCommand([\"rev-parse\", \"--show-toplevel\"]);\n return stdout;\n}\n", "/**\n * Represents a value that is either successful (Ok) or contains an error (Err).\n * This type is inspired by Rust's Result type and provides type-safe error handling.\n *\n * @template T - The type of the success value\n * @template E - The type of the error value (defaults to Error)\n */\nexport type Result<T, E = Error> =\n | { ok: true; value: T }\n | { ok: false; error: E };\n\n/**\n * Creates a successful Result containing the given value.\n *\n * @template T - The type of the success value\n * @param value - The success value to wrap\n * @returns A Result in the Ok state containing the value\n *\n * @example\n * const result = ok(42);\n * // result: Result<number, never> = { ok: true, value: 42 }\n */\nexport const ok = <T>(value: T): Result<T, never> => ({\n ok: true,\n value,\n});\n\n/**\n * Creates a failed Result containing the given error.\n *\n * @template E - The type of the error value\n * @param error - The error value to wrap\n * @returns A Result in the Err state containing the error\n *\n * @example\n * const result = err(new Error(\"Something went wrong\"));\n * // result: Result<never, Error> = { ok: false, error: Error(...) }\n */\nexport const err = <E>(error: E): Result<never, E> => ({\n ok: false,\n error,\n});\n\n/**\n * Type guard that checks if a Result is in the Ok state.\n *\n * @template T - The type of the success value\n * @template E - The type of the error value\n * @param result - The Result to check\n * @returns True if the Result is Ok, false otherwise\n *\n * @example\n * if (isOk(result)) {\n * console.log(result.value); // TypeScript knows result.value exists\n * }\n */\nexport const isOk = <T, E>(\n result: Result<T, E>,\n): result is { ok: true; value: T } => result.ok;\n\n/**\n * Type guard that checks if a Result is in the Err state.\n *\n * @template T - The type of the success value\n * @template E - The type of the error value\n * @param result - The Result to check\n * @returns True if the Result is Err, false otherwise\n *\n * @example\n * if (isErr(result)) {\n * console.error(result.error); // TypeScript knows result.error exists\n * }\n */\nexport const isErr = <T, E>(\n result: Result<T, E>,\n): result is { ok: false; error: E } => !result.ok;\n", "export class WorktreeError extends Error {\n constructor(message: string) {\n super(message);\n this.name = \"WorktreeError\";\n }\n}\n\nexport class WorktreeNotFoundError extends WorktreeError {\n constructor(name: string) {\n super(`Worktree '${name}' not found`);\n this.name = \"WorktreeNotFoundError\";\n }\n}\n\nexport class WorktreeAlreadyExistsError extends WorktreeError {\n constructor(name: string) {\n super(`Worktree '${name}' already exists`);\n this.name = \"WorktreeAlreadyExistsError\";\n }\n}\n\nexport class InvalidWorktreeNameError extends WorktreeError {\n constructor(name: string) {\n super(`Invalid worktree name: '${name}'`);\n this.name = \"InvalidWorktreeNameError\";\n }\n}\n\nexport class GitOperationError extends WorktreeError {\n constructor(operation: string, details: string) {\n super(`Git ${operation} failed: ${details}`);\n this.name = \"GitOperationError\";\n }\n}\n", "import fs from \"node:fs/promises\";\nimport { getPhantomDirectory, getWorktreePath } from \"../paths.ts\";\n\nexport interface ValidationResult {\n exists: boolean;\n path?: string;\n message?: string;\n}\n\nexport async function validateWorktreeExists(\n gitRoot: string,\n name: string,\n): Promise<ValidationResult> {\n const worktreePath = getWorktreePath(gitRoot, name);\n\n try {\n await fs.access(worktreePath);\n return {\n exists: true,\n path: worktreePath,\n };\n } catch {\n return {\n exists: false,\n message: `Worktree '${name}' does not exist`,\n };\n }\n}\n\nexport async function validateWorktreeDoesNotExist(\n gitRoot: string,\n name: string,\n): Promise<ValidationResult> {\n const worktreePath = getWorktreePath(gitRoot, name);\n\n try {\n await fs.access(worktreePath);\n return {\n exists: true,\n message: `Worktree '${name}' already exists`,\n };\n } catch {\n return {\n exists: false,\n path: worktreePath,\n };\n }\n}\n\nexport async function validatePhantomDirectoryExists(\n gitRoot: string,\n): Promise<boolean> {\n const phantomDir = getPhantomDirectory(gitRoot);\n\n try {\n await fs.access(phantomDir);\n return true;\n } catch {\n return false;\n }\n}\n\nexport async function listValidWorktrees(gitRoot: string): Promise<string[]> {\n const phantomDir = getPhantomDirectory(gitRoot);\n\n if (!(await validatePhantomDirectoryExists(gitRoot))) {\n return [];\n }\n\n try {\n const entries = await fs.readdir(phantomDir);\n const validWorktrees: string[] = [];\n\n for (const entry of entries) {\n const result = await validateWorktreeExists(gitRoot, entry);\n if (result.exists) {\n validWorktrees.push(entry);\n }\n }\n\n return validWorktrees;\n } catch {\n return [];\n }\n}\n", "import { join } from \"node:path\";\n\nexport function getPhantomDirectory(gitRoot: string): string {\n return join(gitRoot, \".git\", \"phantom\", \"worktrees\");\n}\n\nexport function getWorktreePath(gitRoot: string, name: string): string {\n return join(getPhantomDirectory(gitRoot), name);\n}\n", "import {\n type ChildProcess,\n type SpawnOptions,\n spawn as nodeSpawn,\n} from \"node:child_process\";\nimport { type Result, err, ok } from \"../types/result.ts\";\nimport {\n type ProcessError,\n ProcessExecutionError,\n ProcessSignalError,\n ProcessSpawnError,\n} from \"./errors.ts\";\n\nexport interface SpawnSuccess {\n exitCode: number;\n}\n\nexport interface SpawnConfig {\n command: string;\n args?: string[];\n options?: SpawnOptions;\n}\n\nexport async function spawnProcess(\n config: SpawnConfig,\n): Promise<Result<SpawnSuccess, ProcessError>> {\n return new Promise((resolve) => {\n const { command, args = [], options = {} } = config;\n\n const childProcess: ChildProcess = nodeSpawn(command, args, {\n stdio: \"inherit\",\n ...options,\n });\n\n childProcess.on(\"error\", (error) => {\n resolve(err(new ProcessSpawnError(command, error.message)));\n });\n\n childProcess.on(\"exit\", (code, signal) => {\n if (signal) {\n resolve(err(new ProcessSignalError(signal)));\n } else {\n const exitCode = code ?? 0;\n if (exitCode === 0) {\n resolve(ok({ exitCode }));\n } else {\n resolve(err(new ProcessExecutionError(command, exitCode)));\n }\n }\n });\n });\n}\n", "export class ProcessError extends Error {\n public readonly exitCode?: number;\n\n constructor(message: string, exitCode?: number) {\n super(message);\n this.name = \"ProcessError\";\n this.exitCode = exitCode;\n }\n}\n\nexport class ProcessExecutionError extends ProcessError {\n constructor(command: string, exitCode: number) {\n super(`Command '${command}' failed with exit code ${exitCode}`, exitCode);\n this.name = \"ProcessExecutionError\";\n }\n}\n\nexport class ProcessSignalError extends ProcessError {\n constructor(signal: string) {\n const exitCode = 128 + (signal === \"SIGTERM\" ? 15 : 1);\n super(`Command terminated by signal: ${signal}`, exitCode);\n this.name = \"ProcessSignalError\";\n }\n}\n\nexport class ProcessSpawnError extends ProcessError {\n constructor(command: string, details: string) {\n super(`Error executing command '${command}': ${details}`);\n this.name = \"ProcessSpawnError\";\n }\n}\n", "import { type Result, err } from \"../types/result.ts\";\nimport { WorktreeNotFoundError } from \"../worktree/errors.ts\";\nimport { validateWorktreeExists } from \"../worktree/validate.ts\";\nimport type { ProcessError } from \"./errors.ts\";\nimport { type SpawnSuccess, spawnProcess } from \"./spawn.ts\";\n\nexport type ExecInWorktreeSuccess = SpawnSuccess;\n\nexport async function execInWorktree(\n gitRoot: string,\n worktreeName: string,\n command: string[],\n): Promise<\n Result<ExecInWorktreeSuccess, WorktreeNotFoundError | ProcessError>\n> {\n const validation = await validateWorktreeExists(gitRoot, worktreeName);\n if (!validation.exists) {\n return err(new WorktreeNotFoundError(worktreeName));\n }\n\n const worktreePath = validation.path as string;\n const [cmd, ...args] = command;\n\n return spawnProcess({\n command: cmd,\n args,\n options: {\n cwd: worktreePath,\n },\n });\n}\n", "import { type Result, err } from \"../types/result.ts\";\nimport { WorktreeNotFoundError } from \"../worktree/errors.ts\";\nimport { validateWorktreeExists } from \"../worktree/validate.ts\";\nimport type { ProcessError } from \"./errors.ts\";\nimport { type SpawnSuccess, spawnProcess } from \"./spawn.ts\";\n\nexport type ShellInWorktreeSuccess = SpawnSuccess;\n\nexport async function shellInWorktree(\n gitRoot: string,\n worktreeName: string,\n): Promise<\n Result<ShellInWorktreeSuccess, WorktreeNotFoundError | ProcessError>\n> {\n const validation = await validateWorktreeExists(gitRoot, worktreeName);\n if (!validation.exists) {\n return err(new WorktreeNotFoundError(worktreeName));\n }\n\n const worktreePath = validation.path as string;\n const shell = process.env.SHELL || \"/bin/sh\";\n\n return spawnProcess({\n command: shell,\n args: [],\n options: {\n cwd: worktreePath,\n env: {\n ...process.env,\n PHANTOM: \"1\",\n PHANTOM_NAME: worktreeName,\n PHANTOM_PATH: worktreePath,\n },\n },\n });\n}\n", "import fs from \"node:fs/promises\";\nimport { addWorktree } from \"../git/libs/add-worktree.ts\";\nimport { getPhantomDirectory, getWorktreePath } from \"../paths.ts\";\nimport { type Result, err, ok } from \"../types/result.ts\";\nimport { GitOperationError, WorktreeAlreadyExistsError } from \"./errors.ts\";\nimport { validateWorktreeDoesNotExist } from \"./validate.ts\";\n\nexport interface CreateWorktreeOptions {\n branch?: string;\n commitish?: string;\n}\n\nexport interface CreateWorktreeSuccess {\n message: string;\n path: string;\n}\n\nexport async function createWorktree(\n gitRoot: string,\n name: string,\n options: CreateWorktreeOptions = {},\n): Promise<\n Result<CreateWorktreeSuccess, WorktreeAlreadyExistsError | GitOperationError>\n> {\n const { branch = name, commitish = \"HEAD\" } = options;\n\n const worktreesPath = getPhantomDirectory(gitRoot);\n const worktreePath = getWorktreePath(gitRoot, name);\n\n try {\n await fs.access(worktreesPath);\n } catch {\n await fs.mkdir(worktreesPath, { recursive: true });\n }\n\n const validation = await validateWorktreeDoesNotExist(gitRoot, name);\n if (validation.exists) {\n return err(new WorktreeAlreadyExistsError(name));\n }\n\n try {\n await addWorktree({\n path: worktreePath,\n branch,\n commitish,\n });\n\n return ok({\n message: `Created worktree '${name}' at ${worktreePath}`,\n path: worktreePath,\n });\n } catch (error) {\n const errorMessage = error instanceof Error ? error.message : String(error);\n return err(new GitOperationError(\"worktree add\", errorMessage));\n }\n}\n", "import { executeGitCommand } from \"../executor.ts\";\n\nexport interface AddWorktreeOptions {\n path: string;\n branch: string;\n commitish?: string;\n}\n\nexport async function addWorktree(options: AddWorktreeOptions): Promise<void> {\n const { path, branch, commitish = \"HEAD\" } = options;\n\n await executeGitCommand([\"worktree\", \"add\", path, \"-b\", branch, commitish]);\n}\n", "import type { ChildProcess } from \"node:child_process\";\n\nexport const output = {\n log: (message: string) => {\n console.log(message);\n },\n\n error: (message: string) => {\n console.error(message);\n },\n\n table: (data: unknown) => {\n console.table(data);\n },\n\n processOutput: (proc: ChildProcess) => {\n proc.stdout?.pipe(process.stdout);\n proc.stderr?.pipe(process.stderr);\n },\n};\n", "import { output } from \"./output.ts\";\n\nexport const exitCodes = {\n success: 0,\n generalError: 1,\n notFound: 2,\n validationError: 3,\n} as const;\n\nexport function handleError(\n error: unknown,\n exitCode: number = exitCodes.generalError,\n): never {\n if (error instanceof Error) {\n output.error(error.message);\n } else {\n output.error(String(error));\n }\n process.exit(exitCode);\n}\n\nexport function exitWithSuccess(): never {\n process.exit(exitCodes.success);\n}\n\nexport function exitWithError(\n message: string,\n exitCode: number = exitCodes.generalError,\n): never {\n output.error(message);\n process.exit(exitCode);\n}\n", "import { parseArgs } from \"node:util\";\nimport { getGitRoot } from \"../../core/git/libs/get-git-root.ts\";\nimport { isErr } from \"../../core/types/result.ts\";\nimport { deleteWorktree as deleteWorktreeCore } from \"../../core/worktree/delete.ts\";\nimport {\n WorktreeError,\n WorktreeNotFoundError,\n} from \"../../core/worktree/errors.ts\";\nimport { exitCodes, exitWithError, exitWithSuccess } from \"../errors.ts\";\nimport { output } from \"../output.ts\";\n\nexport async function deleteHandler(args: string[]): Promise<void> {\n const { values, positionals } = parseArgs({\n args,\n options: {\n force: {\n type: \"boolean\",\n short: \"f\",\n },\n },\n strict: true,\n allowPositionals: true,\n });\n\n if (positionals.length === 0) {\n exitWithError(\n \"Please provide a worktree name to delete\",\n exitCodes.validationError,\n );\n }\n\n const worktreeName = positionals[0];\n const forceDelete = values.force ?? false;\n\n try {\n const gitRoot = await getGitRoot();\n const result = await deleteWorktreeCore(gitRoot, worktreeName, {\n force: forceDelete,\n });\n\n if (isErr(result)) {\n const exitCode =\n result.error instanceof WorktreeNotFoundError\n ? exitCodes.validationError\n : result.error instanceof WorktreeError &&\n result.error.message.includes(\"uncommitted changes\")\n ? exitCodes.validationError\n : exitCodes.generalError;\n exitWithError(result.error.message, exitCode);\n }\n\n output.log(result.value.message);\n exitWithSuccess();\n } catch (error) {\n exitWithError(\n error instanceof Error ? error.message : String(error),\n exitCodes.generalError,\n );\n }\n}\n", "import {\n executeGitCommand,\n executeGitCommandInDirectory,\n} from \"../git/executor.ts\";\nimport { type Result, err, isOk, ok } from \"../types/result.ts\";\nimport {\n GitOperationError,\n WorktreeError,\n WorktreeNotFoundError,\n} from \"./errors.ts\";\nimport { validateWorktreeExists } from \"./validate.ts\";\n\nexport interface DeleteWorktreeOptions {\n force?: boolean;\n}\n\nexport interface DeleteWorktreeSuccess {\n message: string;\n hasUncommittedChanges?: boolean;\n changedFiles?: number;\n}\n\nexport interface WorktreeStatus {\n hasUncommittedChanges: boolean;\n changedFiles: number;\n}\n\nexport async function getWorktreeStatus(\n worktreePath: string,\n): Promise<WorktreeStatus> {\n try {\n const { stdout } = await executeGitCommandInDirectory(worktreePath, [\n \"status\",\n \"--porcelain\",\n ]);\n if (stdout) {\n return {\n hasUncommittedChanges: true,\n changedFiles: stdout.split(\"\\n\").length,\n };\n }\n } catch {\n // If git status fails, assume no changes\n }\n return {\n hasUncommittedChanges: false,\n changedFiles: 0,\n };\n}\n\nexport async function removeWorktree(\n gitRoot: string,\n worktreePath: string,\n force = false,\n): Promise<void> {\n try {\n await executeGitCommand([\"worktree\", \"remove\", worktreePath], {\n cwd: gitRoot,\n });\n } catch (error) {\n // Always try force removal if the regular removal fails\n try {\n await executeGitCommand([\"worktree\", \"remove\", \"--force\", worktreePath], {\n cwd: gitRoot,\n });\n } catch {\n throw new Error(\"Failed to remove worktree\");\n }\n }\n}\n\nexport async function deleteBranch(\n gitRoot: string,\n branchName: string,\n): Promise<Result<boolean, GitOperationError>> {\n try {\n await executeGitCommand([\"branch\", \"-D\", branchName], { cwd: gitRoot });\n return ok(true);\n } catch (error) {\n const errorMessage = error instanceof Error ? error.message : String(error);\n return err(new GitOperationError(\"branch delete\", errorMessage));\n }\n}\n\nexport async function deleteWorktree(\n gitRoot: string,\n name: string,\n options: DeleteWorktreeOptions = {},\n): Promise<\n Result<\n DeleteWorktreeSuccess,\n WorktreeNotFoundError | WorktreeError | GitOperationError\n >\n> {\n const { force = false } = options;\n\n const validation = await validateWorktreeExists(gitRoot, name);\n if (!validation.exists) {\n return err(new WorktreeNotFoundError(name));\n }\n\n const worktreePath = validation.path as string;\n\n const status = await getWorktreeStatus(worktreePath);\n\n if (status.hasUncommittedChanges && !force) {\n return err(\n new WorktreeError(\n `Worktree '${name}' has uncommitted changes (${status.changedFiles} files). Use --force to delete anyway.`,\n ),\n );\n }\n\n try {\n await removeWorktree(gitRoot, worktreePath, force);\n\n const branchName = name;\n const branchResult = await deleteBranch(gitRoot, branchName);\n\n let message: string;\n if (isOk(branchResult)) {\n message = `Deleted worktree '${name}' and its branch '${branchName}'`;\n } else {\n message = `Deleted worktree '${name}'`;\n message += `\\nNote: Branch '${branchName}' could not be deleted: ${branchResult.error.message}`;\n }\n\n if (status.hasUncommittedChanges) {\n message = `Warning: Worktree '${name}' had uncommitted changes (${status.changedFiles} files)\\n${message}`;\n }\n\n return ok({\n message,\n hasUncommittedChanges: status.hasUncommittedChanges,\n changedFiles: status.hasUncommittedChanges\n ? status.changedFiles\n : undefined,\n });\n } catch (error) {\n const errorMessage = error instanceof Error ? error.message : String(error);\n return err(new GitOperationError(\"worktree remove\", errorMessage));\n }\n}\n", "import { parseArgs } from \"node:util\";\nimport { getGitRoot } from \"../../core/git/libs/get-git-root.ts\";\nimport { execInWorktree as execInWorktreeCore } from \"../../core/process/exec.ts\";\nimport { isErr } from \"../../core/types/result.ts\";\nimport { WorktreeNotFoundError } from \"../../core/worktree/errors.ts\";\nimport { exitCodes, exitWithError } from \"../errors.ts\";\n\nexport async function execHandler(args: string[]): Promise<void> {\n const { positionals } = parseArgs({\n args,\n options: {},\n strict: true,\n allowPositionals: true,\n });\n\n if (positionals.length < 2) {\n exitWithError(\n \"Usage: phantom exec <worktree-name> <command> [args...]\",\n exitCodes.validationError,\n );\n }\n\n const [worktreeName, ...commandArgs] = positionals;\n\n try {\n const gitRoot = await getGitRoot();\n const result = await execInWorktreeCore(gitRoot, worktreeName, commandArgs);\n\n if (isErr(result)) {\n const exitCode =\n result.error instanceof WorktreeNotFoundError\n ? exitCodes.notFound\n : result.error.exitCode || exitCodes.generalError;\n exitWithError(result.error.message, exitCode);\n }\n\n process.exit(result.value.exitCode);\n } catch (error) {\n exitWithError(\n error instanceof Error ? error.message : String(error),\n exitCodes.generalError,\n );\n }\n}\n", "import { parseArgs } from \"node:util\";\nimport { getGitRoot } from \"../../core/git/libs/get-git-root.ts\";\nimport { isErr } from \"../../core/types/result.ts\";\nimport { listWorktrees as listWorktreesCore } from \"../../core/worktree/list.ts\";\nimport { exitCodes, exitWithError } from \"../errors.ts\";\nimport { output } from \"../output.ts\";\n\nexport async function listHandler(args: string[] = []): Promise<void> {\n parseArgs({\n args,\n options: {},\n strict: true,\n allowPositionals: false,\n });\n try {\n const gitRoot = await getGitRoot();\n const result = await listWorktreesCore(gitRoot);\n\n if (isErr(result)) {\n exitWithError(\"Failed to list worktrees\", exitCodes.generalError);\n }\n\n const { worktrees, message } = result.value;\n\n if (worktrees.length === 0) {\n output.log(message || \"No worktrees found.\");\n process.exit(exitCodes.success);\n }\n\n const maxNameLength = Math.max(...worktrees.map((wt) => wt.name.length));\n\n for (const worktree of worktrees) {\n const paddedName = worktree.name.padEnd(maxNameLength + 2);\n const branchInfo = worktree.branch ? `(${worktree.branch})` : \"\";\n const status = !worktree.isClean ? \" [dirty]\" : \"\";\n\n output.log(`${paddedName} ${branchInfo}${status}`);\n }\n\n process.exit(exitCodes.success);\n } catch (error) {\n exitWithError(\n error instanceof Error ? error.message : String(error),\n exitCodes.generalError,\n );\n }\n}\n", "import { executeGitCommandInDirectory } from \"../git/executor.ts\";\nimport { getWorktreePath } from \"../paths.ts\";\nimport { type Result, ok } from \"../types/result.ts\";\nimport {\n listValidWorktrees,\n validatePhantomDirectoryExists,\n} from \"./validate.ts\";\n\nexport interface WorktreeInfo {\n name: string;\n path: string;\n branch: string;\n isClean: boolean;\n}\n\nexport interface ListWorktreesSuccess {\n worktrees: WorktreeInfo[];\n message?: string;\n}\n\nexport async function getWorktreeBranch(worktreePath: string): Promise<string> {\n try {\n const { stdout } = await executeGitCommandInDirectory(worktreePath, [\n \"branch\",\n \"--show-current\",\n ]);\n return stdout || \"(detached HEAD)\";\n } catch {\n return \"unknown\";\n }\n}\n\nexport async function getWorktreeStatus(\n worktreePath: string,\n): Promise<boolean> {\n try {\n const { stdout } = await executeGitCommandInDirectory(worktreePath, [\n \"status\",\n \"--porcelain\",\n ]);\n return !stdout; // Clean if no output\n } catch {\n // If git status fails, assume clean\n return true;\n }\n}\n\nexport async function getWorktreeInfo(\n gitRoot: string,\n name: string,\n): Promise<WorktreeInfo> {\n const worktreePath = getWorktreePath(gitRoot, name);\n\n const [branch, isClean] = await Promise.all([\n getWorktreeBranch(worktreePath),\n getWorktreeStatus(worktreePath),\n ]);\n\n return {\n name,\n path: worktreePath,\n branch,\n isClean,\n };\n}\n\nexport async function listWorktrees(\n gitRoot: string,\n): Promise<Result<ListWorktreesSuccess, never>> {\n if (!(await validatePhantomDirectoryExists(gitRoot))) {\n return ok({\n worktrees: [],\n message: \"No worktrees found (worktrees directory doesn't exist)\",\n });\n }\n\n const worktreeNames = await listValidWorktrees(gitRoot);\n\n if (worktreeNames.length === 0) {\n return ok({\n worktrees: [],\n message: \"No worktrees found\",\n });\n }\n\n try {\n const worktrees = await Promise.all(\n worktreeNames.map((name) => getWorktreeInfo(gitRoot, name)),\n );\n\n return ok({\n worktrees,\n });\n } catch (error) {\n const errorMessage = error instanceof Error ? error.message : String(error);\n throw new Error(`Failed to list worktrees: ${errorMessage}`);\n }\n}\n", "import { parseArgs } from \"node:util\";\nimport { getGitRoot } from \"../../core/git/libs/get-git-root.ts\";\nimport { shellInWorktree as shellInWorktreeCore } from \"../../core/process/shell.ts\";\nimport { isErr } from \"../../core/types/result.ts\";\nimport { WorktreeNotFoundError } from \"../../core/worktree/errors.ts\";\nimport { validateWorktreeExists } from \"../../core/worktree/validate.ts\";\nimport { exitCodes, exitWithError } from \"../errors.ts\";\nimport { output } from \"../output.ts\";\n\nexport async function shellHandler(args: string[]): Promise<void> {\n const { positionals } = parseArgs({\n args,\n options: {},\n strict: true,\n allowPositionals: true,\n });\n\n if (positionals.length === 0) {\n exitWithError(\n \"Usage: phantom shell <worktree-name>\",\n exitCodes.validationError,\n );\n }\n\n const worktreeName = positionals[0];\n\n try {\n const gitRoot = await getGitRoot();\n\n // Get worktree path for display\n const validation = await validateWorktreeExists(gitRoot, worktreeName);\n if (!validation.exists) {\n exitWithError(\n validation.message || `Worktree '${worktreeName}' not found`,\n exitCodes.generalError,\n );\n }\n\n output.log(`Entering worktree '${worktreeName}' at ${validation.path}`);\n output.log(\"Type 'exit' to return to your original directory\\n\");\n\n const result = await shellInWorktreeCore(gitRoot, worktreeName);\n\n if (isErr(result)) {\n const exitCode =\n result.error instanceof WorktreeNotFoundError\n ? exitCodes.notFound\n : result.error.exitCode || exitCodes.generalError;\n exitWithError(result.error.message, exitCode);\n }\n\n process.exit(result.value.exitCode);\n } catch (error) {\n exitWithError(\n error instanceof Error ? error.message : String(error),\n exitCodes.generalError,\n );\n }\n}\n", "import { parseArgs } from \"node:util\";\nimport { getVersion } from \"../../core/version.ts\";\nimport { exitWithSuccess } from \"../errors.ts\";\nimport { output } from \"../output.ts\";\n\nexport function versionHandler(args: string[] = []): void {\n parseArgs({\n args,\n options: {},\n strict: true,\n allowPositionals: false,\n });\n const version = getVersion();\n output.log(`Phantom v${version}`);\n exitWithSuccess();\n}\n", "{\n \"name\": \"@aku11i/phantom\",\n \"packageManager\": \"pnpm@10.8.1\",\n \"version\": \"0.4.0\",\n \"description\": \"A powerful CLI tool for managing Git worktrees for parallel development\",\n \"keywords\": [\n \"git\",\n \"worktree\",\n \"cli\",\n \"phantom\",\n \"workspace\",\n \"development\",\n \"parallel\"\n ],\n \"homepage\": \"https://github.com/aku11i/phantom#readme\",\n \"bugs\": {\n \"url\": \"https://github.com/aku11i/phantom/issues\"\n },\n \"repository\": {\n \"type\": \"git\",\n \"url\": \"git+https://github.com/aku11i/phantom.git\"\n },\n \"license\": \"MIT\",\n \"author\": \"aku11i\",\n \"type\": \"module\",\n \"bin\": {\n \"phantom\": \"./dist/phantom.js\"\n },\n \"scripts\": {\n \"start\": \"node ./src/bin/phantom.ts\",\n \"phantom\": \"node ./src/bin/phantom.ts\",\n \"build\": \"node build.ts\",\n \"type-check\": \"tsgo --noEmit\",\n \"test\": \"node --test --experimental-strip-types --experimental-test-module-mocks src/**/*.test.ts\",\n \"lint\": \"biome check .\",\n \"fix\": \"biome check --write .\",\n \"ready\": \"pnpm fix && pnpm type-check && pnpm test\",\n \"ready:check\": \"pnpm lint && pnpm type-check && pnpm test\",\n \"prepublishOnly\": \"pnpm ready:check && pnpm build\"\n },\n \"engines\": {\n \"node\": \">=22.0.0\"\n },\n \"files\": [\n \"dist/\",\n \"README.md\",\n \"LICENSE\"\n ],\n \"devDependencies\": {\n \"@biomejs/biome\": \"^1.9.4\",\n \"@types/node\": \"^22.15.29\",\n \"@typescript/native-preview\": \"7.0.0-dev.20250602.1\",\n \"esbuild\": \"^0.25.5\",\n \"typescript\": \"^5.8.3\"\n }\n}\n", "import packageJson from \"../../package.json\" with { type: \"json\" };\n\nexport function getVersion(): string {\n return packageJson.version;\n}\n", "import { parseArgs } from \"node:util\";\nimport { getGitRoot } from \"../../core/git/libs/get-git-root.ts\";\nimport { isErr } from \"../../core/types/result.ts\";\nimport { whereWorktree as whereWorktreeCore } from \"../../core/worktree/where.ts\";\nimport { exitCodes, exitWithError, exitWithSuccess } from \"../errors.ts\";\nimport { output } from \"../output.ts\";\n\nexport async function whereHandler(args: string[]): Promise<void> {\n const { positionals } = parseArgs({\n args,\n options: {},\n strict: true,\n allowPositionals: true,\n });\n\n if (positionals.length === 0) {\n exitWithError(\"Please provide a worktree name\", exitCodes.validationError);\n }\n\n const worktreeName = positionals[0];\n\n try {\n const gitRoot = await getGitRoot();\n const result = await whereWorktreeCore(gitRoot, worktreeName);\n\n if (isErr(result)) {\n exitWithError(result.error.message, exitCodes.notFound);\n }\n\n output.log(result.value.path);\n exitWithSuccess();\n } catch (error) {\n exitWithError(\n error instanceof Error ? error.message : String(error),\n exitCodes.generalError,\n );\n }\n}\n", "import { type Result, err, ok } from \"../types/result.ts\";\nimport { WorktreeNotFoundError } from \"./errors.ts\";\nimport { validateWorktreeExists } from \"./validate.ts\";\n\nexport interface WhereWorktreeSuccess {\n path: string;\n}\n\nexport async function whereWorktree(\n gitRoot: string,\n name: string,\n): Promise<Result<WhereWorktreeSuccess, WorktreeNotFoundError>> {\n const validation = await validateWorktreeExists(gitRoot, name);\n\n if (!validation.exists) {\n return err(new WorktreeNotFoundError(name));\n }\n\n return ok({\n path: validation.path as string,\n });\n}\n"],
5
+ "mappings": "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",
6
+ "names": ["args", "command", "command", "args", "command", "args", "fs", "fs", "args", "parseArgs", "args", "parseArgs", "parseArgs", "args", "parseArgs", "parseArgs", "getWorktreeStatus", "args", "parseArgs", "parseArgs", "args", "parseArgs", "parseArgs", "args", "parseArgs", "parseArgs", "args", "parseArgs", "commands", "args", "command", "remainingArgs"]
7
7
  }
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@aku11i/phantom",
3
- "version": "0.3.0",
3
+ "version": "0.4.0",
4
4
  "description": "A powerful CLI tool for managing Git worktrees for parallel development",
5
5
  "keywords": [
6
6
  "git",
@@ -36,6 +36,7 @@
36
36
  "devDependencies": {
37
37
  "@biomejs/biome": "^1.9.4",
38
38
  "@types/node": "^22.15.29",
39
+ "@typescript/native-preview": "7.0.0-dev.20250602.1",
39
40
  "esbuild": "^0.25.5",
40
41
  "typescript": "^5.8.3"
41
42
  },
@@ -43,7 +44,7 @@
43
44
  "start": "node ./src/bin/phantom.ts",
44
45
  "phantom": "node ./src/bin/phantom.ts",
45
46
  "build": "node build.ts",
46
- "type-check": "tsc --noEmit",
47
+ "type-check": "tsgo --noEmit",
47
48
  "test": "node --test --experimental-strip-types --experimental-test-module-mocks src/**/*.test.ts",
48
49
  "lint": "biome check .",
49
50
  "fix": "biome check --write .",