Customize your Git workflow.
Gittey is a tool to help you and your team customize your Git workflow to best match your day to day needs. Gittey comes with a number of tools out of the box, including branch, and commit prefix annotations and simplified branch management tools. Everything is configurable from the command line, and saved in a JSON configuration file. This means you can change your configuration in a text editor if you prefer!
Finally, you can easily extend the Gittey command set with custom aliases. Aliases can be raw CLI commands, or you can actually script your own workflow addition and fold it in with everything else with a simple alias.
Make sure you have Node.js installed, and run the following command:
npm install -g gittey
After Gittey is installed, run the following command in a project to add a Gittey configuration:
gittey init
This will walk you though configuring branch annotations for Gittey and save a configuration file to your project. Be sure to commit the configuration so your team can use it too.
{
"branchPrefix": {
"separator": "-",
"validator": "",
"prefixes": {
"Bug": "Bug Fix",
"Fea": "New Feature",
"Ver": "New Version"
}
},
"commitPrefix": {
"separator": " ",
"validator": ".{1,45}",
"prefixes": {
"F": "Feature (<= 8 LoC)",
"B": "Bug fix (<= 8 LoC)",
"R": "Test-supported Procedural Refactoring",
"t": "Test only",
"d": "Developer documentation (non-user facing)",
"a": "Automated formatting / code generation",
"r": "Provable (manual) refactoring",
"c": "Comments (add/delete)",
"e": "Environment (non-code) changes (for development)",
"F!!": "Feature (> 8 LoC)",
"B!!": "Bug fix (> 8 LoC)",
"R!!": "Non-provable refactoring",
"***": "Does not compile -- intermediate step"
}
},
"aliases": [
{
"name": "update-branch",
"command": "gittey update-current-branch",
"description": "Pull changes from remote main and merge into current branch"
},
{
"name": "push-main",
"command": "git push origin main --tags",
"description": "Push to main and include all commit tags"
},
{
"name": "push",
"command": "gittey commit; git push",
"description": "Commit all outstanding changes and push to remote"
},
{
"name": "pull",
"command": "gittey commit; git pull",
"description": "Commit all outstanding changes and pull from remote"
},
{
"name": "publish-patch",
"command": "gittey commit; npm version patch; npm publish; gittey push-main",
"description": "Commit outstanding changes, bump patch version, publish, and push"
},
{
"name": "publish-minor",
"command": "gittey commit; npm version minor; npm publish; gittey push-main",
"description": "Commit outstanding changes, bump minor version, publish, and push"
},
{
"name": "publish-major",
"command": "gittey commit; npm version major; npm publish; gittey push-main",
"description": "Commit outstanding changes, bump major version, publish, and push"
}
],
"collaborators": []
}
- Commit messages do not require quotes for single line messages
- If you put quotes around your commit message, you can enter a multiline commit message, just like working in regular old Git
- Adding a
push
alias in the config file, you can add an auto-commit action which will save you from accidentally pushing without committing your latest files. It works like this:
"aliases": [
{
"name": "push",
"command": "gittey commit; git push"
}
]
// now you can run `gittey push` and it just works
- Adding a
pull
alias you can add a commit, then pull action:
"aliases": [
{
"name": "pull",
"command": "gittey commit; git pull"
}
]
// now you can run `gittey pull` and it just works
- Git pass-through transparency
- Git commands (and arguments) that are not handled by gittey will pass transparently through to git reducing the need to switch to git for more advanced git work; for example, history rewriting.
- Branch annotations
- Branch prefixing
- Branch annotation key visualization
- Branch name validation
- Local branch tooling
- Easy single-branch delete
- Easy delete for multiple local branches (prune)
- Fetch latest master/main branch and update current branch
- Merge into current branch
- Merge current branch into another
- Merge current branch and another branch into a temp branch
- Commit prefix annotations
- Check if changes have not been added, offer to add them
- Provide canned Arlo-style annotations
- Commit message annotation key visualization
- Custom commit annotation prefixing
- Commit collaborators
- Select all commit collaborators from list defined in
gittey-config.json
- Select all commit collaborators from list defined in
- Custom git aliases
- Runnable aliases with
gittey aliasName
- Add new aliases via command line
- Remove aliases via command line
- Runnable aliases with
- Configuration
- Check if there is a newer version on run
- Configure branch prefix annotations
- Configure commit prefix annotations
- Reset Gittey configuration
- Project init
- user global configuration now supported
- Remote management
- Add and remove remote references
- Quickly list all remotes
- Help/Man information
Current options at the command line for Gittey:
add-alias
- Add a new user-configured command aliasadd-collaborator
- Add collaborator to list of team collaboratorsargs
- Arguments to supply to alias commandbranch-prefixes
- Display branch prefixes and descriptionscheckout
- Check out a branch from listgittey checkout --remote
will provide remote branches available for checkoutgittey checkout <branchname>
will check out specified branch without prompting
clone
- Clone remote repositorycommit
- Create a new branch using defined configuration- Commit arguments pass through to git, e.g.
gittey commit --no-verify
- Commit arguments pass through to git, e.g.
commit-prefixes
- Display commit prefixes and descriptionsconfigure-branch-annotations
- Create branch annotation prefixesconfigure-commit-annotations
- Create commit annotation prefixesdelete-alias
- Delete a user-configured command aliasdelete-branch
- Delete a branchhelp
,-h
- Display help infoinit
- Initialize Gittey configuration in your projectinit-repo
- Initialize git repository with custom main branch namelist-remotes
- List remotes for local git repomerge-from-branch
- Merge another branch into current branchmerge-to-branch
- Merge current branch into another branchmerge-to-temp
- Merge current branch and another branch into a temp branchnew-branch
- Create a new branch using defined configurationprune-branches
- Menued branch cleanupremove-collaborators
- Remove collaborators from list of team collaboratorsremove-remote
- Remove remote reference from local git reporename-branch
- Rename current branchreset-configuration
- Reset configuration to default settingsrevert-commits
- Revert recent commitsset-remote-uri
- Set or update remote URIset-verbose-mode
- Set project-level Gittey verbose modeupdate
- Update to latest versionupdate-current-branch
- Update current branch with remote trunk changesverbose
- (Flag) Make all git commands visible when runversion
,-v
- Display current version