- fix: assure branch creation respects fetch-specs of remotes (#522)
- ci: ubuntu-24.04 is now used to build release binaries
- chore: gix is updated to 0.70
- feat: new "name" subcommand
- feat: support calling stg rebase without arguments
- docs: explain stgit.autosign a bit better
- feat: organize subcommands by group in help
- fix(squash): preserve consensus author
- chore: update gix to 0.68
- feat(push): revert overzealous modified status
- updated dependencies
- fix(push): report modified patches in output (#464)
- feat(push): colorize push status string
- chore: update gix to 0.66
- feat: use jiff instead of time
- feat: use winnow instead of nom
- updated other dependencies
- fix(import): --reject should create empty commit (#471)
- docs(changelog): repair heading
- updated dependencies
- feat(rebase): do not rebase to same base
- feat(rebase): show ref names of rebase target
- chore: update gix to 0.64.0
- fix(refresh): handle edited message and patch name (#470)
- fix: harden "stg rebase -i" against patches with multi-line subjects
- fix: prefer --authdate over patch time with author
- updated dependencies
- docs(pop): clarify --spill behavior (#445)
- fix(branch): disallow branch before subcommand (#447)
- refactor: get gix-command via gix with command feature
- Update gix to version 0.62
- fix(bash): fix completion for "committish"
- docs: Update copyright year
- chore: update gix to 0.61.1
- ci: update to wix 4.0.5
- fix: stdout from hooks (#418)
- chore: add category and keywords to Cargo.toml
- build: exclude some paths from crate
- docs(readme): enumerate more package repositories
- chore: update dependencies
- fix: pass stdio for interactive editing (#415)
- fix: update gix-tempfile and gix-lock to 13.1.0 (#413)
- chore: update dependencies
- feat(branch): allow delete of current branch
- fix(branch): delete branch config with branch
- fix: use gix-command for interactive edit (#407)
- fix: improved interactive editor diagnostics
- chore: update gix to 0.58.0 (#407)
- docs: fix dates in changelog
- refactor(branch): use gix to rename config section
- refactor: use gix to remove stgit branch config
- refactor: use gix-command for hooks
- refactor: use non-deprecated indexmap methods
- ci: update cargo-generate-rpm to 0.14.0
- ci: update to upload-artifact@v4
- ci: restore use of IO::Pty in MacOS build
- feat(pop): allow unescaped negative patch offsets
- feat(show): allow unescaped negative patch offsets
- chore: update dependencies
- fix(zsh): short -r opt for
stg series
- chore: update gix to 0.56.0
- chore: update transient dependencies
- feat(delete): --all -A -U -H options
- feat(sink): -T/--above option
- feat(branch): short opts for clone and delete
- fix(zsh): -S option for float, import, and sync
- build: avoid non-portable install options
- test: improved test script portability
- update dependencies
- fix!(uncommit): check for HEAD/top mismatch (#360)
- docs: docstring spelling and formatting fixes
- feat(uncommit): print uncommited patches
- pin serde to avoid using precompiled binary
- update dependencies
- fix(zsh): typo in completion help for stg commit --all
- fix: use canonical Message-ID spelling
- fix(stgit.el): recognize new empty patch marker
- fix(import): Keep first line break in body
- update dependencies
- import-compressed is always enabled, no longer a feature
- unofficial deb and rpm packages
- msi package for Windows
- fix(import): would panic without import-url feature
- fix(import): patch numbers not stripped from name
- use bzip2-rs instead of bzip2 crate
- update dependencies
- feat: Upgrade from ancient stack state formats (#235)
- fix(branch): create based on remote branch (#317)
- fix(import): lost subject lines resembling header (#321)
- fix(import): subject line may be discarded
- chore: update dependencies
- fix: error using on Windows (#273)
- fix: path handling for Windows compatibility
- fix: commit-msg hook run from work root
- fix: avoid "stg.exe" in usage on Windows
- fix: use gitattributes to force LF endings on Windows
- fix: wrap hooks with sh on Windows
- chore: update to gix 0.44.0
- chore: update other dependencies
- fix: rebase with '@' in ref names (#306)
- fix: improved error messages for unrecognized commands
- chore: update to clap 4.2.0
- chore: update to gix 0.43.0
- chore: pin clap minor version
- fix(branch): allow reuse of partially deleted branch names (#290)
- fix(branch): branch list alignment
- fix: running hooks from worktree subdir (#295)
- fix: running from linked worktree (#297)
- fix(float): correct -S in usage string
- fix: correctly show bold command/subcommand in overidden usage
- feat!: remove short -s option for --submodules
- fix!: patch name cannot be {base} or @
- feat: patch locator syntax
- feat: locate branches using @{-N} syntax
- feat(series): Add --reverse option
- feat(series): options for patch offsets and indices
- feat(series): --no-xxx options to override display options
- feat(series): optional value for --short
- feat!: short -s option for --signoff (#245)
- feat(init): add -b/--branch option
- fix!: use -S as short opt for --series
- feat!: constrain refresh -p to visible patches
- feat(series)!: empty patch prefix changed to *
- feat!: spell errors in lowercase
- refactor: use gitoxide instead of git2
- refactor: use time crate instead of chrono
- feat!: update to clap 4.1
- chore: update to latest dependencies
- fix: Error if author or committer is not configured
- fix: Use correct base directory for core.hooksPaths
- fix(rename): colliding patch names
- fix(rebase): repair rebasing to a tag (#265)
- fix(branch): switch branch with detached head
- docs: Repair docstrings being confused as html
- docs: normalized spelling for --branch value
- feat: Configurable push conflict policy (#60)
- feat: Add --committer-date-is-author-date option (#47)
- feat(import): Add --3way option (#36)
- feat(import): Add --directory option (#36)
- feat!: Relaxed stack initialization (#238)
- feat!: Only sign stack based on stgit.gpgsign (#238)
- fix!: Allow "---" separator in messages (#243)
- feat: More descriptive push conflict message (#60)
- feat: Avoid post-edit commits when no change
- chore: Update dependencies to latest versions
- fix: Improved error message for uninitialized stack
- fix: Improve error for re-initialization attempt
- fix(prev): Different error message for empty stack
- fix: Accept full ref name for branches
- fix(zsh): Complete --edit and --diff for stg new
- docs: Document configuration variables
- refactor: Use is-terminal instead of atty
- chore: Update Cargo.lock with latest dependencies.
- fix: Don't generate new patch name until after edit (#239)
- fix: Run shell aliases from top-level of work tree
- fix: Use GIT_PREFIX in built-in aliases
- chore: Update Cargo.lock with latest dependencies.
- fix: improved git version parsing on MacOS
- fix: StGit-specific branch config handling
- docs: fixed many typos
- chore: Update Cargo.lock with latest dependencies.
- docs(init): Add long help for
stg init
.
- feat: Enable basic support for
extensions.worktreeconfig
to unblock sparse checkout with partial clone (#195).
- docs: More inter-command links
- docs: Normalize quoting
- chore: Update to clap 4.0.22
- docs(readme): Clarify static versus dynamic linking (#230)
- build: Improve Documentation build performance (#229)
stg clone
is removed. Usegit clone
andstg init
instead.stg mail
is replaced withstg email format
andstg email send
.stg refresh --spill
is replaced with dedicatedstg spill
command.stg edit
no longer accepts-O/--diff-opts
. Custom diff options is in conflict with editable diffs since many (most?) diff options cause the diff to no long be applicable.stg files
no longer accepts-O/--diff-opts
. This option was of marginal value since it only had a possible side effect when--stat
was being used.
stg id
now accepts the-b/--branch
option.stg completion
command provides runtime support for shell completions.stg completion bash
generates bash shell completion script.stg completion fish
generates fish shell completion script.stg completion zsh
outputs zsh shell completion script.stg completion list
shows StGit commands and aliases and is used at completion-time by shell completion scripts.stg completion man
generates man pages in asciidoc format.stg email format
wrapsgit format-patch
and provides a mechanism to generate patch emails and optional cover letter in mbox format.stg email send
wrapsgit send-email
and allows sending patch emails, either from files generated bystg email format
or by specifying patches directly.stg new --refresh
allows a new patch to be refreshed with changes in one step. The-i/--index
,-F/--force
,-s/--submodules
, and--no-submodules
options fromstg refresh
are also available tostg new
when using-r/--refresh
.stg series
gains the-i/--commit-id
option to display patches' commit ids.stg show
diff output can now be limited to certain paths by specifying path limits on the command line.stg spill
replacesstg refresh --spill
.stg version
gains-s/--short
flag to show shortened version info.- Added documentation for patch range syntax to stg(1) man page.
- Added
install-all
target to top-level Makefile that installs the executable, man pages, html pages, and shell completions.
- StGit is now implemented entirely in Rust instead of Python.
- StGit is generally much faster; many commands are up to 4x faster.
There was an emphasis on making informational commands such as
stg id
,stg series
, andstg top
as fast as possible to make their use in interactive contexts (shell prompts, IDE extensions) more comfortable. - StGit error messages have been updated; many have different, and hopefully better, wording. Error messages are also use color (when color is enabled). Scripts relying on exact error messages from StGit will need to be updated.
- StGit output to stdout is generally more terse. Commands that change
the stack such as
push
,pop
, andcommit
, use sigils to denote the changes made to the stack. E.g.stg commit p0..p3
will output$ p0..p3
where the "$" sigil means that a patch, or patch range, has been committed. These are all the currently used stack change sigils:+
patch was pushed-
patch was popped>
patch became the current topmost patch&
patch was updated$
patch was committed#
patch was deleted@
patch was rolled-back!
patch was hidden
- StGit aliases are now more like Git aliases. Normal aliases refer to
StGit subcommands, but aliases prefixed with '!' are shell aliases
that may run arbitrary commands. An example normal alias would be
git config stgit.alias.list 'series --description --empty'
. An example shell alias would begit config stgit.alias.st '!git status --short'
. - Commands such as
stg goto
,stg push
, andstg pop
now require full/correct patch names on the command line and no longer accept unambiguous patch name prefixes. When an inexact patch name is provided on the command line, the error message will now suggest similar valid patch names. - Additional template search paths were added. In addition to looking
for template files in .git/, also look in
$XDG_CONFIG_HOME/stgit/templates/
and$HOME/.stgit/templates
. This search strategy is consistent with how git looks for the global config file. - The new
--signoff
patch edit option supersedes the deprecated--sign
and--sign-by
options.--signoff
without its optional value does the same thing as--sign
, while--signoff=<value>
does the same thing as--sign-by=<value>
. - The
--ack
and--review
patch edit options now optionally take a value. The--ack-by
and--review-by
options are deprecated. stg branch
output is now generally less verbose.stg branch --describe
replacesstg branch --description
. The--description
subcommand remains supported as a hidden alias to--describe
, but the description string must now be provided as its own argument; i.e.--description="description string"
is no longer supported.stg branch --list
now produces colorized output. The--color
option orNO_COLOR
environment variable may be used to affect this behavior.stg branch --rename
now supports renaming regular git branches in addition to StGit-enabled branches.stg clean
now uses-A
and-U
short options for--applied
and--unapplied
instead of-a
and-u
. This is done for consistency withstg series
andstg show
.stg import
now only recognizes compressed patches by their file extension (.bz2
or.gz
) and no longer proactively attempts to decompress using all known decompressors.stg import
support for compressed input files is selectable at compile time using theimport-compressed
feature.stg import
support for importing from a URL is selectable at compile time using theimport-url
feature. N.B. there is a measurable runtime performance impact of building withimport-url
due to the unconditional, pre-main initialization ofcurl
which affects allstg
commands.stg log
now colorizes output by default. The--color
option orNO_COLOR
environment variable may be used to affect this behavior.stgit.new.verbose
changed tostgit.edit.verbose
and now also affects edit behavior foredit
,refresh
, andsquash
along withnew
.stg new
now accepts-e/--edit
and-d/--diff
instead of-v/--verbose
stg pick
now allows a mix of commits and patches to be picked whereas previously only a single commit xor multiple patches could be picked.stg pick
now performs a single stack transaction for all the picked patches/commits instead of one transaction per pick.stg push
now attempts to perform three-way merges, which may improve conflict resolution in some cases. This feature is enabled by default when git >= 2.32.0 is detected.stg rebase --interactive
the "squash" and "fixup" instructions may no longer be applied to the first patch in the instruction list. The stated semantics of both "squash" and "fixup" is that they squash the labeled patch with the preceding patch, which is not possible/valid when there is no preceding patch.stg refresh
no longer has a--spill
flag. Usestg spill
instead.stg series
has updated colorized output.stg series
now requires patch range arguments to be both in-order and contiguous. Constraining patch ranges in this manner ensures that the output fromstg series
is always a valid/correct view of a subset of the series.stg show
diff output respects the--color
option.stg squash
now allows the full suite of patch edit options, including-d/--diff
. Previously only a few message-related options were available.stg version
now displays copyright and license statements.
stg branch --create
inherits the current branch's remote branch configuration, if available. The Python implementation had an apparent bug that prevented inheriting the remote branch configuration when creating from the current branch.- Avoid case insensitive patch name collisions. On operating systems with case-insensitive paths, patch names that only differ by case lead to patch reference collisions. StGit now ensures that patch names are distinct under case insensitive comparisons.
stg pull
andstg rebase
record updated stack state instead of deferring until the next stack-modifying command to do so.
- chore: Update Cargo.lock
- fix(zsh): Repair broken completion of --git-opt
- fix(zsh): Add missing
stg email send --branch
- fix(email): Send using --branch option
- fix: Avoid duplicate signoff with stgit.autosign
- fix: Do not use 3way for merged checks
- The
--diff-opts
option is renamed to--diff-opt
.--diff-opts
remains available as an alias. - The
--diff-opt
option no longer allows multiple git options per occurrence. This allows git diff options with spaces in their values. - The
--git-opts
option forstg email format
andstg email send
is renamed--git-opt
. - The
--git-opt
option no longer allows multiple git options per occurrence. This allows git options with spaces in their values. - Zsh completion for
--diff-opt
and--git-opt
leverage the full-featured git completion capability.
- Repair check for modifications to stack by external tools.
stg pull
andstg rebase
record updated stack state instead of deferring until the next stack-modifying command to do so.- Improve patch application with
git apply --3way
when pushing` (#225) - Zsh completion for
--diff-opt
accommodates multiple occurrences
- Added
--annotate
flag tostg email send
. - Added
-p
/--patch
option tostg show
as alternative way to select patch ranges (#216). - Added
-n
/--name
option tostg new
as alternative way to specify new patch name (#216).
- Update
git2
to 0.15.0, which may further help compatibility with sparse checkouts and multiple worktrees (#195). - Update to
clap
4.0, which changes the help formatting and coloring. - Update other dependencies to latest versions in Cargo.lock.
- No longer depend on
lazy_static
crate. - Use
std::thread::scope
instead of custom mechanism. This brings the total number of uses ofunsafe
in StGit to zero. - Minimum rustc requirement is set to 1.63.0.
- The '$' sigil used for committed patches is now yellow instead of white.
- Patch names beginning with a hyphen '-' may be disambiguated from command line options by escaping the leading '-' with a backslash.
stg email format
andstg email send
now use-G
/--git-opts
to pass additional options togit format-patch
andgit send-email
.- Patch name arguments to
stg email format
andstg email-send
can now be placed after a--
separator (#216). - Update top-level usage help for
stg
.
- Various errors that may occur when executing a stack transaction are now handled more robustly such that the changes from the transaction are rolled-back so that the stack, repository, and worktree are all in a consistent state (#205).
- The
stg uncommit -h
usage indentation is repaired. - The
stg float
usage now shows the two distinct usage modes. stg squash --name
allows patch names with leading '-'.stg diff --range
allows patch names and ranges with leading '-'.- Fix some pre-indented paragraphs in help/about strings.
- Zsh completion for
stg edit
incorrectly included -O/--diff-opts. - Zsh completion for
stg files
incorrectly included -O/--diff-opts.
- Add install targets for
contrib/
directory.
- Use
git
executable instead oflibgit2
for all status and index operations to improve compatibility with sparse index checkouts (#195). - Show commit hash in
stg version
output when not built from tag. - Use
cargo --locked
consistently in Makefiles. - Use "patch" extension in temp file name when editing a patch with a diff.
- Updated transient dependencies in Cargo.lock.
- Repair
stg branch --describe
panic when run without arguments - Repair zsh completions for
git branch
- Repair
stgit.el
to use compatiblestg show
commands (#202). - Repair
stg uncommit --to
to work with annotated tags (#203). - Repair
make install
to not install cargo tracking files.
- Improved error when push conflicts with untracked files (#193)
- Removed a few transitive dependencies by turning-off features in bstr and chrono.
- Update Cargo.lock with latest dependencies
- Update to clap 3.2 and only use non-deprecated interfaces
- Repair
stg spill
when spilling newly added files and using path limits.
- Removed Python implementation of StGit.
- Man page generation in asciidoc format with
stg completion man
. This was needed for feature parity with the Python implementation. - Added documentation for patch range syntax to stg(1) man page.
- Added
install-all
target to top-level Makefile that installs the executable, man pages, html pages, and shell completions.
- Additional template search paths were added. In addition to looking
for template files in .git/, also look in
$XDG_CONFIG_HOME/stgit/templates/
and$HOME/.stgit/templates
. This search strategy is consistent with how git looks for the global config file. - Makefile targets are updated such that they are all applicable to the Rust implementation.
- Argument value names are now all lowercase in help and man pages.
- Updated Cargo.lock with latest versions of dependencies.
- Release checklist is updated for Rust implementation.
- Minor typo fixes in help strings
- Improved documentation for top-level
stg
options. - Improve error message in edge case of attempting to push a hidden patch by name when there are no unapplied patches.
stg email format
wrapsgit format-patch
and provides a mechanism to generate patch emails and optional cover letter in mbox format.stg email send
wrapsgit send-email
and allows sending patch emails, either from files generated bystg email format
or by specifying patches directly.
- Bash completions for shell aliases now fallback to filename completions (#191).
- Help options listings now ensure --color and --help are shown last.
- Various zsh completion improvements:
- Add descriptions for --color values
- Complete -O/--diff-opts values (using
git diff-tree --git-completion-helper
) - Comprehend
stg -C <dir>
options - Improved/corrected alias expansion
- Improved error messages when completion is attempted outside git repo and/or StGit-initialized branch
- Patch name completions now look and feel like output from
stg series
- Complete patch range syntax ('patch0..patchN') for all relevant commands
- Completion for
stg squash
no longer allows duplicate patch name arguments - Removed completions for removed
stg mail
command - Completion for
stg sink
no longer offers hidden patches - Completion for
stg rename
comprehends second, new patch name argument - Completion for
stg diff --range
now works
- Compatibility with git versions prior to 2.35.0 is repaired by
avoiding using
git apply --allow-empty
(#192). - Fish completions for -O/--diff-opts are repaired
stg series
gains the-i/--commit-id
option to display patches' commit ids.stg series
colorized output is modified. The main change is that patch descriptions are no longer yellow.stg version
now displays copyright and license statements.stg version
gains-s/--short
flag to show shortened version info.- The
stgit.diff-opts
configuration variable is now respected as it was in the Python implementation. stg completion
command provides runtime support for shell completions.stg completion bash
generates bash shell completion script.stg completion fish
generates fish shell completion script.stg completion zsh
outputs zsh shell completion script.stg completion list
shows StGit commands and aliases and is used at completion-time by shell completion scripts.
- The
-O/--diff-opts
flag now allows both multiple space separated opts in one value as well as multiple occurrences of-O/--diff-opts
on the same command line. This behavior is compatible with the Python implementation. stg series
help output splits options into a few sections.- Dependencies are updated to more recent versions in Cargo.lock.
stg edit --set-tree
no longer causes the interactive editor to be implicitly invoked.- Repair build for non-Linux unix targets (including MacOS) and Windows targets.
- Avoid case insensitive patch name collisions. On operating systems with case-insensitive paths, patch names that only differ by case lead to patch reference collisions. StGit now ensures that patch names are distinct under case insensitive comparisons.
- Add missing
-t
short option for--set-tree
forstg edit
. - Add missing
-k
short option for--keep
.
stg edit
no longer accepts-O/--diff-opts
. Custom diff options is in conflict with editable diffs since many (most?) diff options cause the diff to no long be applicable.stg files
no longer accepts-O/--diff-opts
. This option was of marginal value since it only had a possible side effect when--stat
was being used.stg clone
is removed (at least for the time being). Usegit clone
andstg init
instead.stg mail
is removed, but will be re-added or replaced prior to the 2.0.0 release.
stg new --refresh
allows a new patch to be refreshed with changes in one step. The-i/--index
,-F/--force
,-s/--submodules
, and--no-submodules
options fromstg refresh
are also available tostg new
.stg id
now accepts the-b/--branch
option.stg spill
replacesstg refresh --spill
.
- StGit aliases are now more like Git aliases. Normal aliases refer to
StGit subcommands, but aliases prefixed with '!' are shell aliases
that may run arbitrary commands. An example normal alias would be
git config stgit.alias.list 'series --description --empty'
. An example shell alias would begit config stgit.alias.st '!git status --short'
. - The
--ack
and--review
options now optionally take a value. The--ack-by
and--review-by
options are deprecated. - Commands such as
stg goto
,stg push
, andstg pop
now require full/correct patch names on the command line and no longer accept unambiguous patch name prefixes. When an inexact patch name is provided on the command line, the error message will now indicate similar valid patch names. stg branch
output is now generally less verbose.stg branch --describe
replacesstg branch --description
. The--description
subcommand remains supported as a hidden alias to--describe
, but the description string must now be provided as its own argument; i.e.--description="description string"
is no longer supported.stg branch --list
now produces colorized output. The--color
option orNO_COLOR
environment variable may be used to affect this behavior.stg branch --rename
now supports renaming regular git branches in addition to StGit-enabled branches.stg clean
now uses-A
and-U
short options for--applied
and--unapplied
instead of-a
and-u
. This is done for consistency withstg series
andstg show
.stg import
now only recognizes compressed patches by their file extension (.bz2
or.gz
) and no longer attempts to decompress using all known decompressors.stg import
support for compressed input files is selectable at compile time using theimport-compressed
feature.stg import
support for importing from a URL is selectable at compile time using theimport-url
feature.stg log
now colorizes output by default. The--color
option orNO_COLOR
environment variable may be used to affect this behavior.stgit.new.verbose
changed tostgit.edit.verbose
and now affects edit behavior foredit
,refresh
, andsquash
along withnew
.stg new
now accepts-e/--edit
and-d/--diff
instead of-v/--verbose
stg pick
now allows a mix of commits and patches to be picked whereas previously only a single commit xor multiple patches could be picked.stg pick
now performs a single stack transaction for all the picked patches/commits instead of one transaction per pick.stg rebase --interactive
the "squash" and "fixup" instructions may no longer be applied to the first patch in the instruction list. The stated semantics of both "squash" and "fixup" is that they squash the labeled patch with the preceding patch, which is not possible/valid when there is no preceding patch.stg refresh
no longer has the--spill
flag. Usestg spill
instead.- Updated colorized output for
stg series
. stg series
now requires patch range arguments to be both in-order and contiguous. Constraining patch ranges in this manner ensures that the output fromstg series
is always a valid/correct view of a subset of the series.stg show
diff can now be limited to certain paths by specifying path limits on the command line.stg show
diff output respects the--color
option.- The new
--signoff
patch edit option supersedes the deprecated--sign
and--sign-by
options.--signoff
without its optional value does the same thing as--sign
, while--signoff=<value>
does the same thing as--sign-by=<value>
. stg squash
now allows the full suite of patch edit options, including-d/--diff
. Previously only a few message-related options were available.
stg branch --create
inherits the current branch's remote branch configuration, if available. The Python implementation had an apparent bug that prevented inheriting the remote branch configuration when creating from the current branch.
- Add Makefile targets for installing shell completions
stg rebase --interactive
learns 'hide' instruction
- Picked patch names are preserved when possible (#175)
- Replace
--unapplied
option with--noapply
forstg pick
(#174) stg pick --noapply
no longer reverses patch order (#174)- Use
stg version
usessys.executable
to get Python version.
- Repair
stg repair
with amended first patch (#163) - Repair corner cases where invalid patchnames could be generated by
stg new
,stg uncommit
, etc. (#176) stg mail
could crash due to a misspelled reference (#178)- Zsh completion for
stg refresh -p
now completes against all patches (not just applied patches). - Zsh gains missing completion for
stg push --noapply
- Minor repair to help for
stg float --noapply
andstg push --noapply
- Restore
stg sink --nopush
capability.
- Python 3.5, which became EOL 2020-09-13, support is deprecated and will be removed in a future StGit release
- Python 3.6, which will be EOL 2021-12-23, support is deprecated and will be removed in a future StGit release
- The new
stg import --message-id
option causes the Message-ID from imported emails to be included as the Message-Id trailer in the patch description (#42) - The new 'stgit.import.message-id' config option also enables the Message-Id trailer (#42)
stg import
no longer creates "Message-Id" trailer by default when importing patches from email (#42)- StGit works with Python 3.10
stg version
prints a more abbreviated Python versionstg commit
will no longer commit empty patches by default; the--allow-empty
option may be used to override this behavior (#158)- The
stgit.main.main()
function now takes an argv parameter and returns an int return code in most cases instead of calling sys.exit(), thus making main() a bit easier to use as an API.
- Repair stack upgrade with
stg branch --list
(#155) - Repair crash in
stg squash
with out of order patches and no name specified (#157) - Zsh completions learn
stg float --noapply
option - Zsh completion for
stg sink
now allows multiple patches
- Repair crash regression when using
stgit.autosign
- Python 3.5, which became EOL 2020-09-13, support is deprecated and will be removed in a future StGit release
- Python 3.6, which will be EOL 2021-12-23, support is deprecated and will be removed in a future StGit release
stg rebase
learns--interactive
; easily re-order, edit, squash, fixup, or delete patches via your editorstg rebase
learns--autostash
; stash changes before the rebase and apply them after. Also configurable with thestgit.autostash
configuration optionstg edit
can now rename patches (#119)stg edit
gains helpful instructions (#138)stg new
learns--verbose
, which includes a diff in the editor window (similar togit commit --verbose
). This behavior is also configurable with thestgit.new.verbose
configuration optionstg push
andstg float
learn--noapply
option; allows patches to be reordered without updating worktree and deferring merge conflict resolution (#144)stg edit
,stg refresh
, andstg new
learn the--sign-by
,--ack-by
, and--review-by
options which allow those respective trailers' values to be specified by the user on the command line (#92)
- Stack metadata version 5; stack metadata is moved from
refs/heads/<branch>.stgit
torefs/stacks/<branch>
and the stack metadata file now uses a JSON format instead of the prior custom format; the stack metadata will be upgraded to v5 on first use of this version of StGit; like all stack metadata upgrades, this is a one-way auto-upgrade for existing stacks (#65) - Use setuptools instead of distutils for packaging
- No git or python version checks in setup.py
- Use different dynamic versioning system
- Install
stg
executable as console_script entry point - More sophisticated search for bash.exe on Windows when running hooks
- The editor window text for
stg squash
has been modified to mirror git's behavior -- the squash edit message now includes all commits (#71) - Binary diffs are no longer shown when with
stg edit -d
- Multiple trailers can now be added at once; this is now allowed, for
example:
stg edit --sign --review --ack
- Update zsh completion for
stg rebase
to show local and remote heads (#102) - Zsh completions for commands with patch arguments now comprehend the
effect of
-b/--branch
and-B/--ref-branch
- Zsh completions now guard patch names--one less TAB press to complete patch names in certain contexts
stg import
now extracts theMessage-ID
email header into the patch message (#42)
- Repair crash when attempting to export empty patch (#112)
- Exact command name matches are unambiguous (#110)
- Exiting with an empty
stg edit
editor will now abort the edit; previously it would delete your commit message. (#138) - Repair completions when stg.series.description is enabled in config
- Workaround child process reaping race on Windows (#78)
- Repair crash with
stg float --series
when bad patch name in series - Repair zsh completion for
stg float
to accept multiple patch names - Repair zsh completion for changed files, affecting
stg refresh
andstg diff
- Add link to coverage.io project to CONTRIBUTING.md
- Set smart
exclude_lines
default for 'coverage' - Expanded test suite for
stg edit
- Add pkgtest.py script to help test StGit packaging
- Cleanup .gitignore files
- StGit GPG-signs patches when
commit.gpgsign
is set (#12) - Support
core.hooksPath
in git config - Add
-C
option forstg import
andstg fold
(#18)
- Allow importing mail and series from urls (#94)
stg refresh --edit
may also use--diff
and--diff-opts
(#98)stg goto
allows sha1 of a patch instead of patch name (#93)
- Repair hang in
stg pull -m
,stg goto -m
, andstg push -m
- Repair
stg mail
to show diffstat of whole series (#104) - Repair MANIFEST.in to include AUTHORS.md and README.md files
- Drop support for Python < 3.5
- Remove previously deprecated
stg publish
command - Removed contrib scripts:
stg-swallow
,stg-fold-files-from
,stg-dispatch
,stg-whatchanged
, andstg-show-old
- The pre-commit hook is now run for
stg refresh
- New
--spill
option forstg refresh
- Add stgit.series.description config option (#88)
- Official support for Python versions up to 3.9
- Stack metadata format 4. All metadata now kept in Git objects; no more stack state files in .git/patches. A one-way auto-upgrade to format version 4 will occur when StGit commands are run on an existing StGit branch.
- Use
python3
in shebangs instead ofpython
contrib/stgbashprompt.sh
is no longer executable- Internal docstrings now use reStructuredText instead of Epytext
- Importing large patches is much, much faster (#66)
- Other performance improvements when dealing with large patches
- Repair diffstat when outside work tree root (#62)
- Use encoded (string) environment variables on Windows (#79)
- Fix
stg pull
when no upstream is configured (#83) - Fix
refresh
crash with path limiting and files added to index (#85) - Repair
new
with patchdescr.template crash (#87) - Repair
log
from worktree subdir with patches specified - Repair
import
allowing/generating duplicate patch names (#64) - Repair
mail --auto
to strip comments after addrs (#91)
- Drop support for Python 3.3; Python 2 (2.6 and 2.7) remain deprecated, but supported for one last release
- Tutorial is removed; it now exists as part of the website
- Python 2.x support is deprecated and will be removed in a future release
- Support html5 output of docs from asciidoc
- Add
--expose
option forstg pick
to allow picked commit message to be customized
- Limit mail diffstat to 72 columns
- Added pyproject.toml file for black configuration
- Minimum Git version is 2.2.0
- Quote stg and subcommand in man page synopsis
- Replaced RELEASENOTES with this CHANGELOG.md
- Replaces Documentation/SubmittingPatches with CONTRIBUTING.md
- Repair MANIFEST.in and generated source dist
- Repair importing mail with ": " (colon space) in subject
- Fix mail cover letter shortlog
- Fix mail cover letter diffstat
stg series
now only outputs colors whenisatty()
- Repair mail SSL check (#57)
- Repair
stg mail
with both-a
and-e
options (#58) - Remove empty short-opt for
--no-submodules
ofstg refresh
- Repair build.py for Python 2 with explicit
flush()
stgit.refreshsubmodules
added to sample gitconfig
- Update docs build system from upstream Git docs
- Use coverage contexts to map commands to covered lines
- Improve mail tests
- Use GitHub Actions instead of TravisCI
- Format StGit source using black formatter
- Remove debian packaging; downstream Debian uses its own anyway
- Python 2.x support is deprecated and will be removed in the next StGit release
stg publish
is deprecated and will be removed in the next StGit release
stg import
has new --keep-cr option, likegit mailsplit
stg new
now includes patch name in log messagestg branch --rename
can now rename the current branchstg branch --create
now works even if the workspace is dirty, consistent withgit checkout
stg branch --description
now works on both regular and stgit branchesstg edit --diff
now implies--edit
stg refresh
andstg edit
now reset the committer information, consistent withstg push
- git notes are now preserved when patches are modified
- Tutorial improvements
- Many additional tests and test improvements
- All stgit commands now use "new" git library infrastructure
stg branch --create
inherits remote correctly from parent committish- Patch names are checked earlier to avoid inconsistent stack states
- Improved commit data parsing and handling of non-UTF8 encodings
- Repair git error messages when checking stgit version from outside a git repo
- Faster handling of large patches (#44)
- Build reproducibility repairs (Thanks reproducible-builds.org team!)
- Python can now be run with optimizations (
python -O
) stg log
now prints trailing newline- Improved command line option parsing for
stg log
stg patches -d
can now output colored diffs.stg publish --overwrite
allows branch to be overwritten instead of creating new commits.stg log --clear
deletes the stack's log history. Use with caution.- Fish shell completions for stg.
- Zsh completions for stg.
stg mail --domain
option overrides the host's domain in the message ID.
- Branch protection metadata now captured in config instead of .git/patches/protect file. This updates stgit's metadata format from v2 to v3.
stg diff
no longer shows binary diffs by default. Use-O--binary
or add--binary
to stgit.diff-opts in config.- Diagnostic output is now routed to stderr instead of stdout. Diagnostic output is also now sent to stderr unconditionally, i.e. no more isatty() test (#35).
- Converted to "new" lib infrastructure:
show
,patches
,diff
,pick
,pull
,rebase
, andfold
.
stg show
detects conflicting --applied and --unapplied options.stg show --stat
now shows commit headers.stg patches --diff
now shows proper diff instead ofb'...'
repr of diff.stg diff --range
detects some invalid values (e.g.-r ..
).- Date parsing is now more portable, only use platform specific
date
as last parsing option. Affects, e.g.,stg refresh --authdate
. - Repaired search path for templates to avoid looking in Python site-packages directory.
- Ensure stdout and stderr are flushed. Rarely affected
stg diff
. stg repair
will now fail if extra command line arguments are provided.- Bash completions are now generated in a reproducible manner.
stg edit --diff
on an empty patch no longer crashes.stg pick
no longer fails when picked commit has empty message (#39).stg rebase
no longer crashes when there are conflicts (#34).stg pick
no longer crashes if --name is not provided when picking a regular commit object.- Improved test coverage for: branch, diff, pick, sync,
- New tests for: files, patches, fold, series
- Portable use of iconv, sort, and sed in tests.
- Linting using flake8 and isort.
- All Python code now conforms to PEP-8.
- Updated test infrastructure from git 2.20.
- Parallel tests with coverage (
make -j4 coverage
) now works. - Documentation build is not included in code coverage.
- Repaired log end messages when using
STGIT_SUBPROCESS_LOG=debug
. - Renamed "dunder" instance attributes to improve debugging.
- Fail faster when patch name has slash ('/') (#24).
- Python 3 support. StGit supports Python 2.6, 2.7, 3.3, 3.4, 3.5, 3.6, and 3.7. PyPy interpreters are also supported.
- Submodules are now ignored when checking if working tree is clean. Submodules are also not included by default when refreshing a patch.
- Config booleans are now parsed similarly to git-config.
contrib/stgit.el
is now licenced with GPLv2.- Add continuous integration (travis-ci) and code coverage (coveralls) support.
- Many new test cases were added.
- Repair handling of emails with utf-8 bodies containing latin-1 characters. Also correctly decode email headers containing quoted encoded words.
- StGit's version is now correct/available in the release archive.
commit-msg
hook support for easier integration with Gerrit, allowing a Change-Id line to be inserted in the commit messagestg mail
improvements for 'Suggested-by:' tag and auto generation of Cc for the cover letter based on all tags in the seriesstg mail
bash completion for the --to, --cc and --bcc options based on the content of the [mail "alias"] section of Git configurationstg edit --review
option to add a 'Reviewed-by:' tagstg pop --spill
functionality to allow popping a patch from the stack while keeping its modification in the tree
- Project page details updated (gna.org has been shut down)
- Various fixes and test coverage improvements
- Test suite improvements.
- Print tracebacks to stderr.
- Run test suite in parallel.
- Fix dirty index errors when resolving conflicts.
- Fix --authdate date parsing.
stg delete --top
option for deleting the top patch.stg branch --merge
option for merging the work tree changes into the other branch.- Support for sending patches both as attachment and inline.
stg mail
no longer filters explicitly added--cc
sender address.stg refresh
warns when index is dirty.
- Fix for parsing the commit header correctly.
- Several
stgit.el
(Emacs mode) improvements. - Fix
stg status --reset
error messages. - HTML documentation fix.
- Email template fixes.
- UI adjustments to better match the Git commands.
stg status
is an alias forgit status
.stg reset --hard
behaves similarly to the corresponding git command and option.
stg branch --cleanup
option to remove the StGit metadata for a given branch.stg mail
can usegit send-email
directly.- Vim syntax highlighting for StGit commit messages.
- Several improvements to the Emacs mode (stgit.el).
- Many bug-fixes.
- The commands "stg add", "stg rm", "stg cp", and "stg resolved" were removed, since there are corresponding Git equivalents.
- New core infrastructure for repository operations, including:
- Infinite undo/redo operations and corresponding commands.
- Automatic rollback of changes following a failed operation (using transactions)---this ensures that StGit commands either succeed or do nothing. Previously, every commands had its own ad hoc implementation of this.
- Some commands were added, including
stg squash
, for combining two or more patches into one.stg publish
, for maintaining merge-friendly branches (which are not rebased).stg prev/next
for printing the name of the previous or next patch in the series.
- The
stg import
andstg fold
commands support the-p N
option for stripping leading slashes from diff paths. - The
stg import
andstg fold
commands support the--reject
option for leaving rejected hunks in corresponding*.rej
files. - New patch identification syntax:
<branch>:<patch>
(see documentation for the "stg id" command). - Autosigning of imported patches when
sign.autosign
configuration option is set. - A powerful Emacs mode for StGit was added to the "contrib" directory. It displays the patch stack in an Emacs buffer, and can handle all common StGit tasks.
- Man pages and an improved tutorial.
- Improved bash tab-completion, automatically generated from the stg command definitions.