sheepit 🐑
A simple rust tool for releasing projects 🚀.
Installation
Configuration
You can configure Sheepit by placing a sheepit.toml or .sheepit.toml file in your repository. This file has the
following options:
[]
= 'branch/{version}' # The naming pattern for the branch if one is created.
= 'Sheeping {version}' # Commit message if we will create a commit
= 'main' # Default branch in the repo.
= true # When true sheepit will create a release branch before commiting and tagging.
= true # When true sheepit will apply transforms and commit changes.
= true # When true sheepit will create a tag from your latest commit.
= true # When true sheepit will push changes to origin (unless you dry-run)
= '{version}' # The naming pattern to use when creating a tag
# Each of the below subprojects will point to another git repo. Sheepit will clone this project, then
# use it's sheepit config to apply the update. The version info will reflect the main project, meaning the
# previous version and next version will be derived from the main project's update.
[[]]
= 'git@github.com:some-user/test-sub-sheep.git' # Git remote url for subproject
# Each of the below transforms will find and replace a single string in the specified file. If you need to
# replace multiple strings, add multiple transforms.
[[]]
= 'relative/path.file' # The relative path to the file.
= 'version: {version}' # An optional, explicit string to find. If omitted, replace will be used for find & replace.
= 'version: sheep_{version}' # The replace string.
Version Token
The version token is {version}. This can be used in a number of configuration properties and may represent the repo's
current version (as determined by the highest semver tag), or the next version. Generally the following rules apply:
- When
{version}is used in naming patterns or commit message it will be the next version. - When
{version}is used within a transform'sfindstring it will be the previous version. - When
{version}is used within a transform'sreplacestring it will be the next version.- If
replaceis used for bothfindandreplace,{version}will expand to the previous version while finding, then the next versions file replacing.
- If
Defaults
You don't need to specify all of the configuration properties listed at the top of the section. Sheepit tries to pick reasonable defaults. Defaults can be found here: config.rs.
Bumping Versions
Sheepit supports semantic version bumps. You can bump the major, minor and patch version. During a version bump, sheepit will do the following:
- Find the latest version by looking at your repo's tag list.
- Figure out the next version depending on the bump type.
- Optionally create a release branch for you.
- Optionally create a commit after performing any necessary transforms (coming soon!).
- Optionally create a tag.
- Optionally push to a remote.
Commands
# Assuming your version is 1.1.1