Setup command now has three modes:
- Registry mode: interactive wizard to select packages
- Bootstrap mode: clones core-devops first, then wizard
- Repo setup mode: generates .core/{build,release,test}.yaml
Changes:
- setup: add interactive package selection with charmbracelet/huh
- setup: detect project type (go/php/node/wails) and generate configs
- setup: auto-detect GitHub repo from git remote
- ai: fix command examples (core dev -> core ai)
- ci: rename flag to --we-are-go-for-launch
Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
31 lines
1.1 KiB
Go
31 lines
1.1 KiB
Go
// Package setup provides workspace bootstrap and package cloning commands.
|
|
//
|
|
// Two modes of operation:
|
|
//
|
|
// REGISTRY MODE (repos.yaml exists):
|
|
// - Clones all repositories defined in repos.yaml into packages/
|
|
// - Skips repos that already exist
|
|
// - Supports filtering by type with --only
|
|
//
|
|
// BOOTSTRAP MODE (no repos.yaml):
|
|
// - Clones core-devops to set up the workspace foundation
|
|
// - Presents an interactive wizard to select packages (unless --all)
|
|
// - Clones selected packages
|
|
//
|
|
// Flags:
|
|
// - --registry: Path to repos.yaml (auto-detected if not specified)
|
|
// - --only: Filter by repo type (foundation, module, product)
|
|
// - --dry-run: Preview what would be cloned
|
|
// - --all: Skip wizard, clone all packages (non-interactive)
|
|
// - --name: Project directory name for bootstrap mode
|
|
// - --build: Run build after cloning
|
|
//
|
|
// Uses gh CLI with HTTPS when authenticated, falls back to SSH.
|
|
package setup
|
|
|
|
import "github.com/leaanthony/clir"
|
|
|
|
// AddCommands registers the 'setup' command and all subcommands.
|
|
func AddCommands(app *clir.Cli) {
|
|
AddSetupCommand(app)
|
|
}
|