Interactively and hierarchically perform git merges across branches and run commands in between.
Project description
GIUP - Git Interactive Update and Publish
Allows to interactively perform hierarchical merges and run publishing commands in between.
When commands fail the user is given the chance to intervene by rerunning the current command, just continuing, running a custom shell command or stopping the project, or the current merge path.
Example Workflow
Example workflow from one of my Minecraft modding projects:
.giup:
{
"merge-paths": [
"1.16",
"1.16->1.15->1.14",
"1.16->1.17"
],
"commands": [
{
"title": "Cleanup build directories",
"run": "rm -rf build .gradle",
"nt": "rmdir /S /Q build & rmdir /S /Q .gradle",
"ignore-errors": true
},
{
"title": "Build and publish",
"run": "./gradlew publish",
"nt": "gradlew publish"
},
"git push"
]
}
This consecutively merges:
1.16
to1.15
1.15
to1.14
1.16
to1.17
After each merge GIUP cleans up, builds, publishes and pushes the code.
Getting Started
To install this project run pip install giup
.
To use this for your project create a .giup
file (as described below) in your project root and run giup
.
Project Specification
By default, the project specification will be read from the .giup
file in the working directory. The specification should be defined in JSON and uses the following keys:
merge-paths
Here you can specify certain merge hierarchies. You can either specify a hierarchy as a string delimited by arrows (->
) or as an array with all branches (["1.16","1.15","1.14"]
).
Specifying a single branch will just switch to that branch and run the commands.
commands
In this array commands are specified.
Commands are specified as an object or a string, which is a short form for an object with the run
key.
The run
entry should contain a string that will be run as a shell command. You can define overrides for Windows (nt
) and POSIX (posix
) shells.
The title
entry is a string that optionally gets displayed when the command is run. If not defined, the command itself will be displayed before execution.
The ignore-errors
entry is an optional boolean telling GIUP whether unsuccessful runs of the command should be treated as errors (on by default). This is useful e.g. when trying to delete a file with rmdir
which might not exist.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file giup-1.1.6.tar.gz
.
File metadata
- Download URL: giup-1.1.6.tar.gz
- Upload date:
- Size: 11.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.4.2 CPython/3.11.3 Linux/5.19.0-42-generic
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 0b519ae7922194fd731237944f0e64046e720647fb8789e39a52428ca2fa26f0 |
|
MD5 | dac6f0814ddeba8fa12de86ef91664c9 |
|
BLAKE2b-256 | b3f25be75431e7e30cc0c2d3283da0cf3f43fd1f49c73a76d27391eba613122c |
File details
Details for the file giup-1.1.6-py3-none-any.whl
.
File metadata
- Download URL: giup-1.1.6-py3-none-any.whl
- Upload date:
- Size: 19.6 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.4.2 CPython/3.11.3 Linux/5.19.0-42-generic
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 2f469f6df3c837353818bbed24001964852d82ff87e43e0dd640d2a3953a9e25 |
|
MD5 | c3019c44bdb9d9c52466b0eea2fb9a28 |
|
BLAKE2b-256 | 9e823e910f77452e28ccd28e76bd6155fe9818a9fea6018158f590c9bd06a7ae |