Implements defence in depth through build variants - only compiled code
exists in the binary. Commands now self-register via cli.RegisterCommands()
in their init() functions, mirroring the i18n.RegisterLocales() pattern.
Structure changes:
- cmd/{ai,build,ci,dev,docs,doctor,go,php,pkg,sdk,setup,test,vm}/ → pkg/*/cmd_*.go
- cmd/core_dev.go, cmd/core_ci.go → cmd/variants/{full,ci,php,minimal}.go
- Added pkg/cli/commands.go with RegisterCommands API
- Updated pkg/cli/runtime.go to attach registered commands
Build variants:
- go build → full (21MB, all 13 command groups)
- go build -tags ci → ci (18MB, build/ci/sdk/doctor)
- go build -tags php → php (14MB, php/doctor)
- go build -tags minimal → minimal (11MB, doctor only)
Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
38 lines
1.2 KiB
Go
38 lines
1.2 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/host-uk/core/pkg/cli"
|
|
"github.com/spf13/cobra"
|
|
)
|
|
|
|
func init() {
|
|
cli.RegisterCommands(AddSetupCommands)
|
|
}
|
|
|
|
// AddSetupCommands registers the 'setup' command and all subcommands.
|
|
func AddSetupCommands(root *cobra.Command) {
|
|
AddSetupCommand(root)
|
|
}
|