I would like to create a new GIT stash from a commit on a branch. Is this even possible?
But why? If you have a commit, it means you already have those changes applied to your files. Some, files might have been changed since the commit, but then, if you try to get a stash of that commit changes, then the stash would be the diff of your current files and the state of these files at the commit. What I am trying to say is that I can't think of a case when you would need that.
But anyway, you can get the changes of the commit, create a diff, apply it and then stash whatever was the difference.
git diff YOUR-COMMIT^ YOUR-COMMIT > stash.diff
git apply stash.diff
git commit .
git stash
You don't have to create a temporary stash.diff
file. You can simply pipe git diff
s output to git apply
.
In SourceTree:
Why? In my case I had a cancelled pull request and I needed to use that code as a starting point for another ticket in another branch.
OK so what I did was git cherry-pick --no-commit <your commit hash>
Then git stash push --message "wip or whatever"
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With