Changelog
All notable changes to Homeboy CLI are documented in this file.
(This file is embedded into the CLI binary and is also viewable via homeboy changelog.)
[0.56.1] – 2026-03-05
Added
- include-fragment coverage handling and bulk JSON recipes (#468)
- changed-since impact-scoped test execution (#448)
Changed
- decompose core deploy orchestration into focused modules (#458)
Fixed
- include explicit ids in component list output (#455)
- honor flag-only project/component args and improve selection errors (#454)
- support [Next] alias for unreleased section (#456)
- fix(test-drift): tighten safe literal token filtering for auto-fix
- prevent homeboy flags leaking into test runners (#446)
- remove duplicate Next section from changelog
[0.56.0] – 2026-03-04
Added
- test scaffold — generate test stubs from source file conventions (#422)
- extract generic codebase scanner with variant discovery for refactor rename
- cross-separator variant generation and improved boundary detection for refactor rename
- scope audit to changed files with –changed-since flag (#416)
- test drift detection — cross-reference production changes with test files (#423)
- refactor transform — regex find/replace across codebases (#410)
- test failure analysis — cluster by root cause and suggest fixes (#421)
- test baseline ratchet — CI floor for pass/fail counts (#411)
- baseline/ratchet integration for docs audit and cleanup (#417)
- add generic baseline/ratchet primitive to utils (#413)
Changed
- extract shared CLI arg groups via Clap flatten (#436)
- run audit job independently + fix formatting drift
- use homeboy-action with source build for audit + auto-issue
Fixed
- resolve merge conflict between shared arg groups and test scaffold
- resolve Rust 1.93 clippy warnings and formatting drift
- build homeboy from source in CI audit instead of downloading release binary (#418)
- prevent release pipeline from publishing without binaries
[0.55.0] – 2026-03-03
Added
- add fleet exec — run commands across all projects via SSH
Fixed
- docs audit now classifies example paths as Example confidence, not Unclear
- enable audit baseline comparison in CI — only fail on new drift
- hide –serial flag (reserved for future parallel mode) and fix description
[0.54.1] – 2026-03-03
Fixed
- fall back to two-dot diff when three-dot fails in shallow CI clones (#397)
- resolve upgrade panic by looking up binary on PATH instead of /proc/self/exe (#398)
[0.54.0] – 2026-03-03
Changed
- update audit baseline for v0.53.0 (459 findings, 70% alignment)
- add pre-release quality gate to release workflow
Fixed
- deterministic duplication fingerprints for stable baselines (#394)
- make release step idempotent for cargo-dist v0.31.0
[0.53.0] – 2026-03-03
Added
- add –coverage and –coverage-min flags (#392)
- auto-pull and version verification before deploy (#381)
- add pre-release code quality gate (lint + test) (#375)
- add –path flag for CI-friendly path override (#379)
- add –changed-since flag for CI-friendly changed-file linting (#377)
Changed
- remove docs scaffold subcommand (#389)
- Add structural test coverage gap detection (#373) (#388)
- Add dead code detection to audit pipeline (#384) (#387)
- add audit baseline ratchet — only fail on NEW findings (#383)
- add PR workflow with build/test + homeboy audit dogfooding (#380)
Fixed
- fix build.rs raw string delimiter for docs with special characters (#390)
- fix release workflow cargo-dist version mismatch (#390)
[0.52.1] – 2026-03-02
- fix(test): –path and –fix flags now correctly parsed by test command (#366)
[0.52.0] – 2026-03-02
Added
- Add refactor propagate subcommand for struct field propagation
- Add docs map command with mechanical markdown generation from source code
- Add deploy integration test suite with 29 tests covering safety chain, template rendering, and error messages
- Add planned/skipped counts to ProjectsSummary for accurate multi-project deploy reporting
Changed
- Improve docs map output quality — module naming, cross-references, large module splitting
- Rewrite SKILL.md as agent bootstrap with discovery-first approach
- Add group size threshold, skip constructors, and dynamic namespace detection in code audit
Fixed
- Add deploy safety guard — prevent deploying to shared parent directories (#353)
- Improve ‘no components configured’ error with actionable details and skipped component info (#329)
- Fix dry-run and check modes reporting ‘deployed’ status instead of ‘planned’ in multi-project deploys (#359)
- Improve fleet/multi-project deploy resilience — skip unknown projects instead of aborting
[0.51.0] – 2026-02-28
Added
- Add refactor rename command with case-variant awareness and word-boundary matching (#283)
- Add –literal mode for refactor rename — exact string matching without boundary detection (#299)
- Add collision detection in refactor rename dry-run — warns on duplicate identifiers and file conflicts (#292)
- Add snake_case compound matching in refactor rename — matches terms inside snake_case identifiers (#291)
- Add extension versioning with semver constraint matching (^, ~, >=, etc.) and auto-update checks on startup (#285)
- Add extension-powered language extractors — fingerprinting moved from built-in to extensions (#286)
- Add smart import detection for code audit — grouped imports, path equivalence, usage checking
- Add ImportAdd fix kind for auto-resolving missing import findings in code audit
Changed
- Rename modules to extensions across entire codebase — CLI, config, docs, extensions repo (#284)
- Rename HOMEBOY_MODULE_PATH/ID env vars to HOMEBOY_EXTENSION_PATH/ID (#296)
- SKIP_DIRS (build, dist, target) only skipped at root level — nested dirs like scripts/build/ are now scanned (#297)
- Update README with new repo description, refactoring section, and extension versioning
- Normalize CmdResult type alias and dispatch pattern across all command modules
- Deprecate version set in favor of version bump (#259)
Fixed
- Fix PHP method regex to handle multi-keyword modifiers in code audit
- Fix import regex to capture grouped imports correctly in code audit
- Fix false ‘unconfigured version target’ warning for already-configured PHP constants (#261)
- Fix version bump error messages to include field name and problem (#258)
- Handle cargo-dist subdirectory layout in upgrade script (#256)
- Clean target directory before archive extraction to prevent stale files (#257)
- Allow multiple version targets per file (#262)
- Surface post-release hook failures to stderr with non-zero exit code (#255)
- Normalize mut parameter modifier in signature comparison for code audit (#275)
[0.50.1] – 2026-02-28
Changed
- Replace scp -r with rsync for directory deploys (mirrors source exactly)
Fixed
- Deploy uses rsync –delete to clean up stale files on target servers (#253)
- Detect local IPs on deploy to skip SSH when agent runs on the same server (#236)
[0.50.0] – 2026-02-27
Added
Add code audit system with auto-discovery, convention detection, and drift analysis
Add portable homeboy.json config with post:release hooks
Add audit –fix with smart stub generation, naming/plural tolerance, and confidence filtering
Add audit –baseline for drift comparison over time
Add audit interface/trait compliance, cross-directory convention, signature consistency, and namespace/import detection
Changed
- Suggest fix when version bump fails due to missing changelog target
Fixed
- Fix version set –path not committing/tagging in correct repo
- Fix version set silently skipping changelog update
- Fix deploy artifact name mismatch with HOMEBOY_COMPONENT_ID env var
[0.49.1] – 2026-02-25
Changed
- Batch 3: remove 11 dead functions, narrow visibility across codebase
- Batch 2: unify ProjectsSummary, remove dead code, narrow visibility
- Batch cleanup: dead fns, to_details helper, serialize_with_id, deploy failed() constructor, visibility fixes
- Extract deploy_components() into focused single-concern functions
- Remove dead utility functions (~182 LOC)
- Remove –from-repo flag and build_from_repo_spec (~137 LOC)
- Standardize rename and delete_safe as universal entity primitives
- Adopt consistent logging with log_status! macro and to_json_string helper
- Replace all Error::other() escape hatches with specific error codes
- Add CWD auto-discovery for unregistered repos with homeboy.json
- Layer portable homeboy.json as live runtime defaults on component load
- Extract shared DynamicSetArgs processing, migrate project set
- Make global config writes atomic + warn on parse failures
- Replace production unwrap() calls with proper error handling (#192)
- Code quality sweep: consolidate duplicates, fix safety issues (#191)
[0.49.0] – 2026-02-25
Added
- Remote hook execution for post:deploy hooks via SSH with template variable expansion
- Extension dependency validation with actionable install error messages
- Path override flag for build, lint, test, and version commands
- Portable homeboy.json config for component creation from repo root
Changed
- Improve extensions section in README and clarify local_path vs deploy target docs
Fixed
- CLI create commands losing component id during serde serialization
- Extension install from monorepo URL creating ghost state
[0.48.0] – 2026-02-25
Added
- Cleanup command for config health checks (missing extensions, invalid paths, stale version targets)
- Startup update check with 24h cache notifies when newer version available
- Sibling section inference in docs generate auto-detects heading patterns from adjacent files
- Extension exec command for direct tool access without component context
- Replace @since placeholder tags during version bump
- Step and skip flags for extension run step filtering
- Docs audit supports direct filesystem paths without component registration
- Local flag on logs commands for agent/on-server mode
- Dedicated flags on component set for common fields
Changed
- Extension manifests use nested capability groups (deploy, audit, executable, platform) — breaking JSON schema change
- Remove RawModuleManifest bridge (270 lines); capability structs deserialize directly
- General hook system replaces per-lifecycle hook executors (pre:version:bump, post:version:bump, post:release, post:deploy)
- entity_crud! macro generates standard CRUD wrappers, replacing per-entity output structs
- Remove Box::leak from dynamic extension CLI registration
Fixed
- Entity set commands replace array fields by default instead of merging
- Lint changed-only passes absolute paths to extension runners
- Enable multiline mode for version target regex patterns
- Dynamic key-value flags on entity set commands fail with JSON parse error
- Fetch tags before baseline detection to prevent stale baseline_ref
- Skip redundant builds during deploy and detect self-deploy
- Swap ahead/behind parsing in remote_sync check
- Default to excluding CHANGELOG.md from docs audit
[0.47.1] – 2026-02-23
Changed
- Omit zero-value feature coverage fields from docs audit JSON output
Fixed
- Filter Windows filesystem paths (e.g., AppDataRoaming) from class name extraction in docs audit
- Improve example context detection for ‘this creates’, ‘would create’, ‘typically:’ patterns
[0.47.0] – 2026-02-23
Added
- Add total_features and documented_features counts to docs audit summary for coverage reporting
- Include doc_context (surrounding lines) in broken reference output for faster remediation
- Add claim confidence classification (real/example/unclear) to docs audit, with code-block awareness and placeholder name detection
Changed
- Rewrite docs audit action strings with source-of-truth framing (code is authoritative, docs must be updated to match)
[0.46.0] – 2026-02-23
Added
- Dedicated
statuscommand for focused, actionable component overview with filtering flags (--uncommitted,--needs-bump,--ready,--docs-only,--all) (#121, #119) transfercommand supports local-to-remote (push) and remote-to-local (pull) in addition to server-to-server (#115)- Post-deploy cleanup of build dependencies via extension-defined
cleanup_pathsand componentauto_cleanupflag (#105) - Configurable
docs_diranddocs_dirsfields for component documentation audit - Multi-directory docs scanning with automatic README inclusion
remote_ownerchown support in deploy for explicit file ownership
Fixed
component setnow rejects unknown fields instead of silently dropping them; prevents false success when usingextension(singular) instead ofextensions(plural) (#124)- Deploy command accepts component-only target like build command (#120)
- Double-escaped backslashes in version patterns are normalized at both parse and load time (#116)
- Audit feature patterns now scan all source files, not just changed ones
- Git-deploy components skip artifact resolution (#108)
Improved
- Missing-extension errors on lint/test/build now include remediation hint: "Add a extension: homeboy component set –extension <extension_id>" (#123)
- Init detects missing extension configuration as a config gap with auto-suggested extension type
- Clearer error message when changelog is not configured (#117)
- Usage examples added to
changelog add --help(#118)
[0.45.2] – 2026-02-17
Fixed
- fix: allow git-deploy components without build artifacts
[0.45.1] – 2026-02-17
Added
- Undocumented feature detection in docs audit via extension audit_feature_patterns (#104)
[0.45.0] – 2026-02-16
Added
- Extension flag for component create and set (–extension)
- Auto-detect extension from component context in homeboy test
Removed
- Fleet sync command deprecated — use homeboy deploy instead
- 800+ lines of hardcoded OpenClaw-specific sync logic removed from core
Fixed
- docs_audit absolute path verification bug — Path::join with absolute paths bypassed source tree check
[0.44.4] – 2026-02-16
Fixed
- SSH non-interactive commands now use BatchMode, ConnectTimeout, and ServerAliveInterval to prevent hangs (#88)
- Version target patterns are validated at create time — rejects template syntax and missing capture groups (#90)
- component set now supports –version-target flag like component create (#91)
[0.44.3] – 2026-02-15
Fixed
- version bump: run pre_version_bump_commands after bump to keep generated artifacts (e.g. Cargo.lock) in the release commit
- deploy: upload to temp file + atomic mv to avoid scp ‘Text file busy’ when replacing running binaries
[0.44.2] – 2026-02-15
Fixed
- ssh: allow multi-arg non-interactive commands; improve non-TTY guidance
[0.44.1] – 2026-02-15
Fixed
- Update Cargo.lock after 0.44.0 release
[0.44.0] – 2026-02-14
Added
- Fleet sync command (homeboy fleet sync) — sync OpenClaw agent configs, skills, and tools across fleet servers with manifest-driven categories, JSON merging, auto-detection of OpenClaw home paths, ownership fixing, and dry-run support
[0.43.1] – 2026-02-13
Fixed
Handle uncommitted changelog gracefully in version bump (#78)
fix: scope –allow-root injection to wordpress extension only
Better error message for missing unreleased changelog section
Revert Stdio::null on git commands (broke HTTPS credential helper)
[0.43.0] – 2026-02-13
Added
- Support aliases for components, projects, and servers (#34)
- Detect and warn about outdated extensions in homeboy init (#26)
- Automatic retry with backoff for transient SSH failures (#51)
- Release –recover for interrupted releases (#38)
- Git-based deployment strategy (#52)
Fixed
- Clarify local file permissions message with path and chmod modes (#9)
- Expand {{extension_path}} in project CLI command templates (#44)
- Fix environment-dependent docs audit test
[0.42.0] – 2026-02-13
Added
- support aliases for components, projects, and servers
- add transfer command for server-to-server file transfer (#67)
- add file download command (SCP remote-to-local)
- add class name detection to audit, fix scaffold false positives, document generate spec
Fixed
- use non-existent path in docs audit test
- expand {{extension_path}} in project CLI command templates
- clarify local file permissions message with path and modes
[0.41.2] – 2026-02-10
Added
- Cross-compilation guide documenting platform requirements
[0.41.1] – 2026-02-10
Added
- OpenClaw skill for AI agent usage (skills/homeboy/)
[0.41.0] – 2026-02-10
Added
- Fleet management: create, list, show, delete, add, remove projects from fleets
- fleet status: check versions across all projects in a fleet
- fleet check: drift detection across fleet using deploy –check
- deploy –fleet: deploy component to all projects in a fleet
- deploy –shared: deploy to all projects using a component (auto-detect)
- component shared: show which projects use a component
[0.40.4] – 2026-02-10
Added
- Extension manifest: add Desktop runtime fields (dependencies, playwrightBrowsers, builtin actions)
Fixed
- Parser: trim content in replace_all to match extract_all behavior (fixes version bump on files with trailing newlines)
[0.40.3] – 2026-02-09
- Add cargo-dist release workflow for automatic homebrew tap updates
[0.40.2] – 2026-02-09
Added
- agnostic source directory detection for scaffold (#57)
[0.40.1] – 2026-02-03
Added
- add preflight remote sync check to version bump to prevent push conflicts
Fixed
- source cargo env for source installs
[0.40.0] – 2026-02-02
Added
- filter merge commits from changelog auto-generation
- add –projects flag for multi-project deployment
[0.39.5] – 2026-02-01
- inject –allow-root for root SSH deploy overrides
[0.39.4] – 2026-01-31
Added
- auto-inject –allow-root for root SSH users
[0.39.3] – 2026-01-31
Added
- support glob patterns in build_artifact
[0.39.2] – 2026-01-31
Added
- capture command output in JSON response
[0.39.1] – 2026-01-28
Added
- Display human-readable success summary after version bump/release
- Transform docs-audit from link checker to content alignment tool
[0.39.0] – 2026-01-28
- add ValidationCollector for aggregated error reporting in version bump
[0.38.6] – 2026-01-28
Added
- validate conflicting version targets for same file
- add –fix flag for auto-fixing lint issues
Fixed
- fix(docs-audit): filter false positives via extension-level ignore patterns
[0.38.5] – 2026-01-28
- Fixing my fuck-up with version bumping
[0.38.4] – 2026-01-28
- Make documentation guidance audit-driven with concrete commands
[0.38.3] – 2026-01-28
- Stream test/lint output directly to terminal instead of capturing in JSON
[0.38.2] – 2026-01-27
- Fix version bump race condition where changelog was finalized before all version targets were validated, causing ‘No changelog items found’ on retry after validation failure
[0.38.1] – 2026-01-26
- Add flag-style aliases for version and changelog commands (#13, #32)
[0.38.0] – 2026-01-26
Added
- auto-generate changelog entries from conventional commits (#25)
[0.37.5] – 2026-01-26
Added
- Add –base64 flag to component/server set commands to bypass shell escaping (#24)
Fixed
- Fix quote-aware argument splitting in normalize_args() for WP-CLI eval commands (#30)
[0.37.4] – 2026-01-26
Fixed
- Add –component option alias for changelog add (#32)
[0.37.3] – 2026-01-26
Fixed
- Graceful version bump when changelog already finalized for target version
[0.37.2] – 2026-01-26
Fixed
- Case-insensitive enum arguments for –type and BUMP_TYPE (closes #29)
[0.37.1] – 2026-01-26
Fixed
- Allow uncommitted changelog and version files during release (fixes #28)
[0.37.0] – 2026-01-25
- Add configurable lint and test script paths via extension manifest (lint.extension_script, test.extension_script)
[0.36.4] – 2026-01-24
Removed
- Remove –force flag from version bump and release commands (bypassing validation defeats its purpose)
[0.36.3] – 2026-01-23
- Add success_summary to pipeline output for human-readable release summaries
[0.36.2] – 2026-01-23
- Fix error message visibility in internal_unexpected errors
[0.36.1] – 2026-01-23
Added
- Add changelog entry awareness to changes command
[0.36.0] – 2026-01-23
- feat: distinguish docs-only commits from code changes in init command (#16)
[0.35.1] – 2026-01-23
- Add clean working tree hint to changelog validation errors
[0.35.0] – 2026-01-23
- feat: entity suggestion for unrecognized subcommands
[0.34.1] – 2026-01-22
- fix: require clean working tree for version bump (removes pre-release commit behavior)
[0.34.0] – 2026-01-22
- Add shared project/component argument resolution primitive (utils/resolve.rs)
- Add project-level build support with –all flag
- Support flexible argument order in changes command
- Add hooks system documentation
- Update agent system reminder wording
[0.33.12] – 2026-01-22
- feat: add extension-defined CLI help configuration
[0.33.11] – 2026-01-22
- fix: normalize quoted CLI args at entry point (closes #11)
[0.33.10] – 2026-01-21
- Add post_release_commands support to release pipeline
[0.33.9] – 2026-01-21
- Add context-aware component suggestions for version bump command
[0.33.8] – 2026-01-21
- feat: Add project:subtarget colon syntax for CLI tools (both ‘extra-chill:events’ and ‘extra-chill events’ now work)
[0.33.7] – 2026-01-21
- fix: is_workdir_clean() now correctly identifies clean repositories (fixes #6)
[0.33.6] – 2026-01-21
Added
- Add
component add-version-targetcommand for adding version targets without full JSON spec
Changed
- Auto-insert
--separator for trailing_var_arg commands (component set,server set,test) – intuitive syntax now works without explicit separator
[0.33.5] – 2026-01-21
- Create engine/ directory with pipeline and executor extensions
- Move base_path.rs and slugify.rs to utils/
[0.33.4] – 2026-01-21
- Remove ReleaseConfig – publish targets now derived purely from extensions with release.publish action
[0.33.3] – 2026-01-21
- Fix publish step extension lookup by parsing prefix once in from_str (single source of truth)
- Add cleanup step to release pipeline to remove target/distrib/ after publish
[0.33.2] – 2026-01-21
- Release Pipeline: Fixed architecture to use extension’s
release.packageaction for artifact creation instead of direct build
[0.33.1] – 2026-01-21
- fix: add missing Build step to release pipeline
[0.33.0] – 2026-01-21
- Refactor release system: built-in core steps (commit, tag, push) with config-driven publish targets
[0.32.7] – 2026-01-21
- Fix release config-first: component release.steps now respected instead of overwritten with generated defaults
- Remove –no-tag, –no-push, –no-commit flags from release command (use git primitives for partial workflows)
[0.32.6] – 2026-01-21
- Add –deploy flag to release command for automatic deployment to all projects using the component
- Add –force flag to deploy command to allow deployment with uncommitted changes
- Fix version commit detection to recognize ‘Version X.Y.Z’ and ‘Version bump to X.Y.Z’ commit formats
[0.32.5] – 2026-01-20
- Add ‘homeboy extension show’ command for detailed extension inspection
[0.32.4] – 2026-01-20
- Add build-time local_path validation with clear error messages
- Add tilde expansion (~/) support for component local_path
- Add gap_details to init output for inline config gap explanations
- Add project auto-detection for deploy when only component ID provided
- Add normalize_args() to handle both quoted and unquoted CLI tool arguments
[0.32.3] – 2026-01-20
- Consolidate release runner, fix step ordering
[0.32.2] – 2026-01-20
Added
- Add validate_local_path with self-healing hints for misconfigured components
[0.32.1] – 2026-01-20
Refactored
- Refactor release extension into cleaner extension structure
[0.32.0] – 2026-01-20
Added
- Add
version bumpcommand as alias for release (e.g.,homeboy version bump homeboy minor) - Add
--no-commitflag to release command to skip auto-committing uncommitted changes - Add
--commit-messageflag to release command for custom pre-release commit messages - Add version show shorthand:
homeboy version <component>now works ashomeboy version show <component>
Changed
- Release command now auto-commits uncommitted changes by default (use
--no-committo opt-out) - Improve build verification before release
[0.31.1] – 2026-01-20
- Consolidate I/O primitives and option chains for cleaner code
[0.31.0] – 2026-01-20
Added
- Add release command flags: –dry-run (preview), –local (skip push/publish), –publish (force full pipeline), –no-tag, –no-push
Changed
- Unify release command: ‘homeboy release <patch|minor|major>’ now handles version bump, commit, tag, and optional push/publish in one flow
Removed
- Remove ‘version bump’ command – use ‘homeboy release patch|minor|major’ instead
- Remove ‘release run’ and ‘release plan’ subcommands – use ‘homeboy release patch|minor|major [–dry-run]’ instead
[0.30.16] – 2026-01-20
Added
- Add –project/-p flag to deploy command for explicit project specification
Refactored
- Add utils/io extension with read_file and write_file helpers for consistent error handling
Refactored
- Add json_path_str helper for nested JSON value extraction
[0.30.15] – 2026-01-20
Added
- Add Refactored changelog entry type with Refactor alias
- Add stage_files function for targeted git staging operations
- Auto-stage changelog changes before version bump clean-tree check
- Add lines_to_vec helper for common string-to-vec-lines pattern
Changed
- Replace manual error checking with validation helper utilities across codebase
- Use String::from instead of .to_string() for owned string conversions
Fixed
- Improve orphaned tag auto-fix messaging in release pipeline
[0.30.14] – 2026-01-20
Changed
- Consolidate utils and create command primitives
Fixed
- Fix changelog init –configure circular error
- Accept changelog_targets as alias for changelog_target
[0.30.13] – 2026-01-20
- Auto-fix orphaned tags in git.tag step instead of failing with hints
[0.30.12] – 2026-01-20
- Add pre_version_bump_commands for staging build artifacts before clean-tree check
- Improve orphaned tag hint with one-liner fix command
- Enhance version bump commit failure error with recovery guidance
[0.30.11] – 2026-01-20
- Migrate changelog, init, and deploy to use parser utilities for version extraction and path resolution
[0.30.10] – 2026-01-20
- Wire up version-aware baseline detection in changes() to fix stale tag mismatch
- Add unconfigured version pattern detection to init warnings
- Clarify init command help text and documentation
[0.30.9] – 2026-01-20
Added
- Added: Comprehensive schema, architecture, and developer guide documentation
[0.30.8] – 2026-01-20
- Make release git.tag step idempotent to work with version bump tags
- Add release pipeline hint after version bump tagging
[0.30.7] – 2026-01-20
Changed
- Improve version bump error hints to explain why working tree must be clean
[0.30.6] – 2026-01-20
Added
- Require clean working tree before version bump with helpful hints
[0.30.5] – 2026-01-20
Added
- Add automatic git tag creation after version bump commits
[0.30.4] – 2026-01-20
- Accept –json flag as no-op on commands that return JSON by default (init, test, lint, release, upgrade)
[0.30.3] – 2026-01-20
- Add plural aliases for entity commands (servers, components, extensions)
[0.30.2] – 2026-01-20
- Fixed: Version baseline detection now correctly identifies stale tags and falls back to release commits for accurate commit counts
[0.30.1] – 2026-01-20
Added
- Added:
statusalias forinitcommand
Removed
- Removed:
contextcommand (useinitinstead)
[0.30.0] – 2026-01-19
- Added component auto-detection in
homeboy changes– auto-uses detected component when exactly one matched - Added version/baseline alignment warning in
homeboy initwhen source file version differs from git baseline - Renamed
GitSnapshot.version_baselinetobaseline_reffor consistency withchangesoutput
[0.29.3] – 2026-01-19
- Remove redundant fields from init JSON output (context.contained_components, context.components, context.command)
- Add gaps field to components array in init output for parent context
- Make version block conditional on managed context in init output
- Skip empty settings HashMap serialization in extension configs
- Skip null suggestion field serialization in context output
[0.29.2] – 2026-01-19
- Add per-component release_state to init output (commits_since_version, has_uncommitted_changes, baseline_ref)
[0.29.1] – 2026-01-19
- Add –status as visible alias for deploy –check
[0.29.0] – 2026-01-19
- Add docs audit subcommand for link validation and staleness detection
- Change docs scaffold to require component_id for consistency with other commands
- Fix docs topic parsing to not consume flags as part of topic path
- Add agent_context_files to init output showing git-tracked markdown files
[0.28.1] – 2026-01-19
- Add capability hints to lint and test commands for better discoverability
[0.28.0] – 2026-01-19
- Add release state tracking to init and deploy –check for detecting unreleased work
[0.27.13] – 2026-01-19
- Fix passthrough arguments documentation to be generic
[0.27.12] – 2026-01-19
- Add shell quoting documentation to wp command docs
- Display subtargets in homeboy init output for project discoverability
- Support both argument orders for deploy command (project-first or component-first)
- Add CLI tool suggestions to homeboy init next_steps when extensions have CLI tools
[0.27.11] – 2026-01-19
Added
- Added lint summary header showing error/warning counts at top of output
- Added –sniffs, –exclude-sniffs, and –category flags for lint filtering
Changed
- Enhanced –summary to show top violations by sniff type
Fixed
- Fixed custom fixers ignoring –file and –glob targets
[0.27.10] – 2026-01-19
Added
- Add –level flag as alternative to positional bump type in version bump command
Fixed
- Make –changed-only flag language-agnostic (removes hardcoded .php filter)
[0.27.9] – 2026-01-19
Added
- Add –changed-only flag to lint command for focusing on modified PHP files
- Add prerequisites validation to release plan (warns about empty changelog)
[0.27.8] – 2026-01-19
Fixed
- Pass HOMEBOY_MODULE_PATH environment variable to build commands
[0.27.7] – 2026-01-19
Fixed
- Fixed: version set no longer validates/finalizes changelog (version-only operation)
- Fixed: version show now displays all configured version targets, not just the primary
[0.27.6] – 2026-01-19
- Fixed: settings_flags now applied during direct execution for local CLI tools
[0.27.5] – 2026-01-19
Added
- Add ExtensionRunner builder for unified test/lint script orchestration
- Add ReleaseStepType enum for typed release pipeline steps
Changed
- Refactor lint and test commands to use ExtensionRunner, reducing code duplication
- Simplify deploy, version, and SSH commands with shared utilities
[0.27.4] – 2026-01-18
Added
- Immediate ‘homeboy is working…’ feedback for TTY sessions
[0.27.3] – 2026-01-18
Security
- Fix heredoc injection vulnerability in file write operations
- Fix infinite loop in pattern replacement when pattern appears in replacement
- Fix grep failing on single files (was always using recursive flag)
- Fix non-portable –max-depth in grep (now uses find|xargs)
- Fix race condition in file prepend operations (now uses mktemp)
- Fix inconsistent echo behavior in append/prepend (now uses printf)
Added
- Add –raw flag to
file readfor output without JSON wrapper
Changed
- Separate stdout/stderr in lint and test command output
[0.27.2] – 2026-01-18
- Add granular lint options: –file, –glob, and –errors-only flags for targeted linting
[0.27.1] – 2026-01-18
- Add –summary flag to lint command for compact output
[0.27.0] – 2026-01-18
- feat: make build_artifact optional—extensions can provide artifact_pattern for automatic resolution
- feat: deploy command supports –project flag as alternative to positional argument
- feat: context gaps now detect missing buildArtifact when remotePath is configured
- fix: version parsing now trims content for VERSION files with trailing newlines
- docs: comprehensive README overhaul with workflow examples and extension system documentation
[0.26.7] – 2026-01-18
- Add
homeboy lintcommand for standalone code linting via extension scripts - Add
--skip-lintflag tohomeboy testto run tests without linting - Add
pre_build_scripthook to extension BuildConfig for pre-build validation
[0.26.6] – 2026-01-18
Added
- NullableUpdate<T> type alias for three-state update semantics in CLI commands
Changed
- refactor extension.rs into extension/ directory with focused submodules (manifest, execution, scope, lifecycle, exec_context)
- replace .unwrap() calls with .expect() for safer error handling across codebase
- extract duplicate template variable building into DbContext::base_template_vars()
- unify scp_file and scp_recursive into shared scp_transfer() function
- use OnceLock for lazy regex compilation in template resolution
Fixed
- load_all_modules() calls now use unwrap_or_default() to handle errors gracefully
[0.26.5] – 2026-01-18
- feat: add –stream and –no-stream flags to extension run command for explicit output control
- feat: add HOMEBOY_COMPONENT_PATH environment variable to test runners
- feat: make ExtensionExecutionMode enum public for extension integration
[0.26.4] – 2026-01-18
- feat: new test command for running component test suites with extension-based infrastructure
[0.26.3] – 2026-01-18
- feat: enhanced extension list JSON output with CLI tool info, available actions, and runtime status flags
- feat: added context-aware error hints suggesting ‘homeboy init’ when project context is missing
[0.26.2] – 2026-01-18
- Test dry-run validation
[0.26.1] – 2026-01-18
Fixed
- version bump command now accepts bump type as positional argument without requiring — separator
[0.26.0] – 2026-01-18
Added
- Added: automatic docs topic resolution with fallback prefixes for common shortcuts (e.g., ‘version’ → ‘commands/version’, ‘generation’ → ‘documentation/generation’)
Changed
- Changed: config directory moved to universal ~/.config/homeboy/ on all platforms (previously ~/Library/Application Support/homeboy on macOS). Users may need to migrate config files manually.
[0.25.4] – 2026-01-18
- Fixed: changelog init now checks for existing changelog files before creating new ones, preventing duplicates
[0.25.1] – 2026-01-17
- Enforce changelog hygiene: version set/bump require clean changelog, release rejects unreleased content
[0.25.0] – 2026-01-17
Fixed
- Require explicit subtarget when project has subtargets configured, preventing unintended main site operations in multisite networks
[0.24.3] – 2026-01-17
- feat: homeboy version show defaults to binary version when no component_id provided
[0.24.2] – 2026-01-17
- fix: upgrade restart command now uses –version instead of version show to avoid component_id error
[0.24.1] – 2026-01-17
- fix: Improve error message when
homeboy changesruns without component ID
[0.24.0] – 2026-01-17
- feat: Add extension-provided build script support with priority-based command resolution
[0.23.0] – 2026-01-16
- feat: Add settings_flags to CLI extensions for automatic flag injection from project settings
[0.22.10] – 2026-01-16
- fix: Release pipeline always creates annotated tags ensuring git push –follow-tags works correctly
[0.22.9] – 2026-01-16
Fixed
- Release pipeline amends previous release commit instead of creating duplicates
[0.22.8] – 2026-01-16
- fix: release pipeline pushes commits with tags and skips duplicate commits
[0.22.7] – 2026-01-16
- Make path optional in logs show – shows all pinned logs when omitted
[0.22.6] – 2026-01-16
- Add changelog show subcommand with optional component_id support
[0.22.5] – 2026-01-16
- Allow
homeboy release <component>as shorthand forhomeboy release run <component>
[0.22.4] – 2026-01-16
- Support –patch/–minor/–major flag syntax for version bump command
[0.22.3] – 2026-01-16
Added
- Add –type flag to changelog add command for Keep a Changelog subsection placement
Fixed
- Improve deploy error message when component ID provided instead of project ID
[0.22.2] – 2026-01-16
- Add –changelog-target flag to component create command
- Make build_artifact and remote_path optional in component create for library projects
- Improve git.tag error handling with contextual hints for tag conflicts
[0.22.1] – 2026-01-16
- Update documentation to remove all –cwd references
[0.22.0] – 2026-01-16
- BREAKING: Remove
--cwdflag entirely from CLI – component IDs are THE way to use Homeboy (decouples commands from directory location) - BREAKING:
version bumpnow auto-commits version changes. Use--no-committo opt out. - Add
--dry-runflag toversion bumpfor simulating version changes - Add changelog warning when Next section is empty during version bump
- Add template variable syntax support for both
{var}and{{var}}in extract commands - Add deploy override visibility in dry-run mode with "Would…" messaging
- Create unified template variables reference documentation
[0.21.0] – 2026-01-16
- Add generic extension-based deploy override system for platform-specific install commands
- Add
heckcrate for automatic camelCase/snake_case key normalization in config merges - Fix SIGPIPE panic when piping CLI output to commands like
head - Fix
success: truemissing from component set single-item responses - Fix deploy error messages to include exit code and fall back to stdout when stderr is empty
[0.20.9] – 2026-01-15
- Omit empty Unreleased section when finalizing releases
[0.20.8] – 2026-01-15
- Add init snapshots for version, git status, last release, and changelog preview
- Surface extension readiness details with failure reason and output
- Omit empty Unreleased section when finalizing releases
[0.20.7] – 2026-01-15
- Add -m flag for changelog add command (consistent with git commit/tag)
- Support bulk changelog entries via repeatable -m flags
- Add git.tag and git.push steps to release pipeline
[0.20.6] – 2026-01-15
- add init next_steps guidance for agents
[0.20.5] – 2026-01-15
- Add git.commit as core release step (auto-inserted before git.tag)
- Add pre-flight validation to fail early on uncommitted changes
- Add PartialSuccess pipeline status with summary output
- Remove GitHub Actions release workflow (replaced by local system)
[0.20.4] – 2026-01-15
- Add release workflow guidance across docs and README
- Expose database template vars for db CLI commands
[0.20.3] – 2026-01-15
- Release system now fully replaces GitHub Actions – Complete local release pipeline with package, GitHub release, Homebrew tap, and crates.io publishing
- Fix extension template variable to use snake_case convention (
extension_path) - Fix macOS bash 3.x compatibility in extension publish scripts (replace
readarraywith POSIXwhile read) - Add
dist-manifest.jsonto .gitignore for cleaner working directory
[0.20.2] – 2026-01-15
- Prepare release pipeline for extension-driven publishing
[0.20.1] – 2026-01-15
- Fix release pipeline executor and extension action runtime
[0.20.0] – 2026-01-15
- Add parallel pipeline planner/executor for releases
- Add component-scoped release planner and runner
- Support extension actions for release payloads and command execution
- Add extension-driven release payload context (version/tag/notes/artifacts)
- Add git include/exclude file scoping
- Add config replace option for set commands
- Improve changelog CLI help and detection
[0.19.3] – 2026-01-15
- Remove agent-instructions directory – docs are the single source of truth
- Simplify build.rs to only embed docs/
- Update README with streamlined agent setup instructions
[0.19.2] – 2026-01-15
- Add post_version_bump_commands hook to run commands after version bumps
- Run cargo publish with –locked to prevent lockfile drift in releases
[0.19.1] – 2026-01-15
- fix:
homeboy changessurfaces noisy untracked hints and respects.gitignore
[0.19.0] – 2026-01-15
- feat: add
homeboy configcommand for global configuration - feat: configurable SCP flags, permissions, version detection patterns
- feat: configurable install method detection and upgrade commands
- fix:
homeboy docsuses raw markdown output only, removes –list flag
[0.18.0] – 2026-01-15
- Add belt & suspenders permission fixing (before build + after extraction)
- Add -O flag for SCP legacy protocol compatibility (OpenSSH 9.x)
- Add verbose output for deploy steps (mkdir/upload/extract)
- Add SSH auto-cd to project base_path when project is resolved
- Fix changelog finalization error propagation with helpful hints
- Inherit changelog settings from project when component has single project
0.17.0
- Agnostic local/remote command execution – db, logs, files now work for local projects
- Init command returns structured JSON with context, servers, projects, components, and extensions
- New executor.rs provides unified command routing based on project config
- Renamed remote_files extension to files (environment-agnostic)
0.16.0
- BREAKING: JSON output now uses native snake_case field names (e.g., project_id, server_id, base_path)
- Remove all serde camelCase conversion annotations
- Consolidate json extension into config and output extensions
0.15.0
- Added bulk merge support for component/project/server set commands
- Improved coding-agent UX: auto-detect commit message vs JSON, better fuzzy matching, and fixed –cwd parsing
- Refactored create flow into a single unified function
- Removed dry-run mode and related behavior
- Improved auto-detection tests
- Included pending context and documentation changes
0.14.0
- Merge workspace into single crate for crates.io publishing
- Add src/core/ architectural boundary separating library from CLI
- Library users get ergonomic imports via re-exports (homeboy::config instead of homeboy::core::config)
0.13.0
- Add –staged-only flag to git commit for committing only pre-staged changes
- Add –files flag to git commit for staging and committing specific files
- Add commit_from_json() for unified JSON input with auto-detect single vs bulk format
- Align git commit JSON input pattern with component set (positional spec, stdin, @file support)
0.12.0
- Add
homeboy upgradecommand for self-updates - Improve
homeboy contextoutput for monorepo roots (show contained components) - Fix
homeboy changessingle-target JSON output envelope - Clarify recommended release workflow in docs
0.11.0
- Add universal fuzzy matching for entity not-found errors
- Align changes output examples with implementation
0.10.0
- Refactor ID resolution and standardize resolving IDs from directory names
- Add
homeboy extension setto merge extension manifest JSON - Centralize config entity rename logic
- Refactor project pin/unpin API with unified options
0.9.0
- Add remote find and grep commands for server file search
- Add helpful hints to not-found error messages
- Refactor git extension for cleaner baseline detection
- Add slugify extension
- Documentation updates across commands
0.8.0
- Refactor JSON output envelope (remove warnings payload; simplify command JSON mapping)
- Unify bulk command outputs under BulkResult/ItemOutcome with success/failure summaries
- Remove per-project extension enablement checks; use global extension manifests for build/deploy/db/version defaults
- Deploy output: rename components -> results and add total to summary
0.7.5
- Fix Homebrew formula name: cargo-dist now generates homeboy.rb instead of homeboy-cli.rb
0.7.4
- Update skill documentation with changelog ops, version set, and bulk JSON syntax
- Support positional component filtering in changes command
0.7.3
- Support positional message argument for changelog add and git commit commands
- Add version set command for direct version assignment
0.7.2
- Add tiered fallback for changes command when no tags exist (version commits → last 10 commits)
0.7.1
- Align homeboy init docs source with agent-instructions
- Simplify changelog add –json format to match other bulk commands
0.7.0
- Refactor CLI commands to delegate business logic to the core library
- Add core git extension for component-scoped git operations
- Add core version extension for version target read/update utilities
- Improve changes command output for local working tree state
- Refresh embedded CLI docs and JSON output contract
0.6.0
- Add universal –merge flag for component/project/server set commands
- Fix changelog entry spacing to preserve blank line before next version
- Refactor core into a headless/public API; treat the CLI as one interface
- Move business logic into the
homeboycore library and reduce CLI responsibilities - Standardize command/output layers and keep TTY concerns in the CLI
- Introduce/expand the extension system and extension settings
- Add generic auth support plus a generic API client/command
- Remove/adjust doctor and error commands during stabilization
0.5.0
- Refactor deploy to use a generic core implementation
- Replace component isNetwork flag with extractCommand for post-upload extraction
- Unify extension runtime config around runCommand/setupCommand/readyCheck/env and remove plugin-specific fields
- Update docs and examples for new generic deployment and extension behavior
0.4.1
- Rename plugin terminology to extension across CLI/docs
- Remove active project concept; require explicit –project where needed
- Update extension manifest filename to
<extension_id>.json
0.4.0
- Unify plugins and extensions under a single extension manifest and config surface
- Remove plugin command and plugin manifest subsystem; migrate CLI/db/deploy/version/build to extension-based lookups
- Rename config fields: plugins→extensions, plugin_settings→extension_settings, extensions→scoped_modules (superseded by extensions field in current releases)
0.3.0
- Add plugin support (nodejs/wordpress)
- Add plugin command and plugin manifest integration
- Improve deploy/build/version command behavior and outputs
0.2.19
- Fix inverted version validation condition to prevent gaps instead of blocking valid bumps
0.2.18
- Fix shell argument escaping for wp and pm2 commands with special characters
- Centralize shell escaping in shell.rs extension with quote_arg, quote_args, quote_path functions
- Fix unescaped file paths in logs and file commands
- Remove redundant escaping functions from template.rs, ssh/client.rs, and deploy.rs
0.2.17
- Add project set –component-ids to replace component attachments
- Add project components add/remove/clear subcommands
- Add tests for project component attachment workflows
0.2.15
- Derive git tag name
- Internal refactor
0.2.14
- Fix unused imports warnings
0.2.13
- Project rewrite
- Internal cleanup
0.2.12
- Refactor command implementations to reduce boilerplate
- Add new CLI flags support
- Fix changelog formatting
0.2.10
- Clean up version show JSON output
0.2.9
- Fix clippy warnings (argument bundling, test extension ordering)
0.2.8
- docs: homeboy docs outputs raw markdown by default
- changelog: homeboy changelog outputs raw markdown (removed show subcommand)
0.2.7
- Default JSON output envelope; allow interactive passthrough
- Require stdin+stdout TTY for interactive passthrough commands
- Standardize
--jsoninput spec handling for subcommands that support it (project create --json,changelog --json) - Fix changelog finalization formatting
0.2.5
- added overlooked config command back in
- docs updated
- extension standardized data contract
0.2.4
- Restore ‘homeboy config’ command wiring
- Update command docs to include config
0.2.3
- Fix changelog finalize placing ## Unreleased at top instead of between versions
- Fix changelog item insertion removing extra blank lines between items
0.2.2
- Add scan_json_dir<T>() helper to json extension for directory scanning
- Refactor config list functions to use centralized json helpers
- Refactor extension loading to use read_json_file_typed()
- Internal refactor
0.2.1
- Default app config values are serialized (no more Option-based defaults for DB settings)
- DB commands now read default CLI path/host/port from AppConfig instead of resolve helpers
0.2.0
Improvements
- Config schema: Introduce
homeboy configcommand group +ConfigKeysschema listing to standardize how config keys are described/exposed. - Config records: Standardize config identity via
slugify_id()+SlugIdentifiable::slug_id()and enforce id/name consistency inConfigManager::save_server()andConfigManager::save_component(). - App config: Extend
AppConfigwithinstalledModules: HashMap<String, InstalledModuleConfig>; each extension storessettings: HashMap<String, Value>and optionalsourceUrl(stored in the extension manifest). - Extension scoping: Add
ExtensionScope::{effective_settings, validate_project_compatibility, resolve_component_scope}to merge settings across app/project/component and validateExtensionManifest.requires(for example:components). - Extension execution: Tighten
homeboy extension runto require an installed/configured entry and resolve project/component context when CLI templates reference project variables. - Command context: Refactor SSH/base-path resolution to shared context helpers (used by
db/deploy) for more consistent configuration errors. - Docs: Normalize docs placeholders (
<project_id>,<server_id>,<component_id>) across embedded CLI documentation.
0.1.13
Improvements
- Changelog:
homeboy changelog addauto-detects changelog path whenchangelogTargetsis not configured. - Changelog: Default next section label is
Unreleased(aliases include[Unreleased]). - Version:
homeboy version bumpfinalizes the "next" section into the new version section whenever--changelog-addis used.
0.1.12
Improvements
- Changelog: Promote
homeboy changelogfrom a shortcut to a subcommand group withshowandadd. - Changelog: Add
homeboy changelog add <component_id> <message>to append items to the “next” section (defaults toUnreleased). - Changelog: Auto-detect changelog path (
CHANGELOG.mdordocs/changelog.md) whenchangelogTargetsis not configured. - Config: Support
changelogTargets+changelogNextSectionLabel/changelogNextSectionAliasesat component/project/app levels. - Version: Write JSON version bumps via the
versionkey (pretty-printed) when using the default JSON version pattern. - Deploy: Load components via
ConfigManagerinstead of ad-hoc JSON parsing.
0.1.11
Improvements
- Docs: Expanded
docs/index.mdto include configuration/state directory layout and a clearer documentation index. - Docs/Positioning: Refined README messaging to emphasize Homeboy’s LLM-first focus.
0.1.10
Improvements
- Extensions: Added git-based extension workflows:
homeboy extension install,homeboy extension update, andhomeboy extension uninstall. - Extensions: Added
.install.jsonmetadata (stored inside each extension directory) to enable reliable updates from the original source. - Docs/Positioning: Updated README and docs index to reflect LLM-first focus and Homeboy data directory layout.
0.1.9
Improvements
- Project management: Added
homeboy project listandhomeboy project pinsubcommands to manage pinned files/logs per project. - Config correctness: Project configs are a strict
ProjectRecord(idderived viaslugify_id(name)) with validation to prevent mismatched IDs and to clearactive_project_idwhen a project is deleted. - Docs: Updated embedded docs to reflect new/removed commands.
0.1.8
Improvements
- Versioning:
versionTargetsare now first-class for component version management (supports multiple files and multiple matches per file, with strict validation). - Deploy: Reads the component version from
versionTargets[0]for local/remote comparisons.
0.1.7
Improvements
- Component configuration: Support
versionTargets(multiple version targets) and optionalbuildCommandin component config. - Version bumping:
homeboy version bumpvalidates that all matches in each target are the same version before replacing. - Deploy JSON output: Deploy results include
artifactPath,remotePath,buildCommand,buildExitCode, and an upload exit code for clearer automation. - Docs refresh: Updated command docs + JSON output contract; removed outdated command/contract doc.
0.1.6
New Features
Embedded docs: Embed
homeboy/docs/**/*.mdinto the CLI binary at build time, sohomeboy docsworks in Homebrew/releases.Docs source of truth: Keep CLI documentation under
homeboy/docs/and embed it into the CLI binary.Docs topic listing:
available_topicsis now generated dynamically from embedded keys (newline-separated).
0.1.5
Breaking Changes
- Docs Command Output:
homeboy docsnow prints embedded markdown to stdout by default (instead of paging).
New Features
- Core Path Utilities: Added
homeboy_core::base_pathhelpers for base path validation and remote path joining (join_remote_path,join_remote_child,remote_dirname). - Core Shell Utilities: Added
homeboy_core::shell::cd_and()to build safe "cd && " strings. - Core Token Utilities: Added
homeboy_core::tokenhelpers for case-insensitive identifiers and doc topic normalization.
Improvements
- Unified JSON Output: CLI commands now return typed structs and are serialized in
crates/homeboy/src/main.rs, standardizing success/error output and exit codes. - Docs & Skill Updates: Updated documentation and the Homeboy skill.
0.1.4
New Features
- Build Command: New
homeboy build <component>for component-scoped builds- Runs a component build in its
local_path
- Runs a component build in its
Improvements
- Runs a component build in its
local_path
0.1.3
New Features
- Runs a component build in its
local_path
0.1.2
New Features
- Version Utilities: Refactored version parsing to shared
homeboycore libraryparse_version,default_pattern_for_file,increment_versionnow in core- Enables future reuse across CLI components
Improvements
parse_version,default_pattern_for_file,increment_versionnow in core- Enables future reuse across CLI components
0.1.1
Breaking Changes
parse_version,default_pattern_for_file,increment_versionnow in core- Enables future reuse across CLI components
Improvements
- Version Command: New
homeboy versioncommand for component-scoped version managementshow– Display current version from component’s version_filebump– Increment version (patch/minor/major) and write back to file- Auto-detects patterns for .toml, .json, .php files
0.1.0
Add code audit system with auto-discovery, convention detection, and drift analysis
show– Display current version from component’s version_filebump– Increment version (patch/minor/major) and write back to file- Auto-detects patterns for .toml, .json, .php files