You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 

1.8 KiB

Release Command

Review all changes in the repository and create a release with proper commit message, version tag, and push to remotes.

Argument: $ARGUMENTS

The argument should be one of:

  • patch - Bump the patch version (e.g., v0.35.3 -> v0.35.4)
  • minor - Bump the minor version and reset patch to 0 (e.g., v0.35.3 -> v0.36.0)

If no argument provided, default to patch.

Steps to perform:

  1. Read the current version from pkg/version/version

  2. Calculate the new version based on the argument:

    • Parse the current version (format: vMAJOR.MINOR.PATCH)
    • If patch: increment PATCH by 1
    • If minor: increment MINOR by 1, set PATCH to 0
  3. Update the version file (pkg/version/version) with the new version

  4. Review changes using git status and git diff --stat HEAD

  5. Compose a commit message following this format:

    • First line: 72 chars max, imperative mood summary
    • Blank line
    • Bullet points describing each significant change
    • "Files modified:" section listing affected files
    • Footer with Claude Code attribution
  6. Stage all changes with git add -A

  7. Create the commit with the composed message

  8. Create a git tag with the new version (e.g., v0.36.0)

  9. Push to remotes (origin and gitea) with tags:

    git push origin main --tags
    git push gitea main --tags
    
  10. Deploy to VPS by running:

    ssh 10.0.0.1 'cd ~/src/next.orly.dev/;git stash;git pull origin main;./scripts/update-embedded-web.sh;sudo systemctl restart orly'
    
  11. Report completion with the new version and commit hash

Important:

  • Do NOT push to github remote (only origin and gitea)
  • Always verify the build compiles before committing: CGO_ENABLED=0 go build -o /dev/null ./...
  • If build fails, fix issues before proceeding