public/Open-WtwWorkspace.ps1
|
function Open-WtwWorkspace { <# .SYNOPSIS Open a workspace file in the configured editor. .DESCRIPTION Opens the VS Code workspace file for the given target. Falls back to opening the directory if no workspace file exists. Auto-detects the target from cwd when no name is provided. .PARAMETER Name Target repo alias or task name (default: detected from cwd). .PARAMETER Repo Specify the parent repo when the name alone is ambiguous. .PARAMETER Editor Override the editor command (defaults to config or "code"). .EXAMPLE wtw open auth Open the workspace for the "auth" worktree in the default editor. #> [CmdletBinding()] param( [Parameter(Position = 0)] [string] $Name, [string] $Repo, [string] $Editor ) # If no name given, detect from cwd if (-not $Name) { $Name = Resolve-WtwCurrentTarget if (-not $Name) { Write-Error "Not inside a registered repo. Specify a target or cd into a repo." return } Write-Host " Detected: $Name" -ForegroundColor DarkGray } $config = Get-WtwConfig $editorCmd = if ($Editor) { $Editor } elseif ($config.editor) { $config.editor } else { 'code' } $target = Resolve-WtwTarget $Name if (-not $target) { return } if ($target.WorktreeEntry) { $wsFile = $target.WorktreeEntry.workspace } else { $wsFile = $target.RepoEntry.templateWorkspace } # Workspace file found — open it if ($wsFile -and (Test-Path $wsFile)) { Write-Host " Opening in ${editorCmd}: $wsFile" -ForegroundColor Green & $editorCmd $wsFile return } # No workspace file — fall back to opening the directory $dir = if ($target.WorktreeEntry) { $target.WorktreeEntry.path } else { $target.RepoEntry.mainPath } if ($dir -and (Test-Path $dir)) { Write-Host " Opening in ${editorCmd}: $dir" -ForegroundColor Green & $editorCmd $dir } else { Write-Error "No workspace or directory found for '$Name'." } } |