You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
Is your feature request related to a problem? Please describe.
tl;dr: I need to manually change / deal with / track HEAD@git due to local tooling shortcomings and I'd like jj to help by setting HEAD@git for me to a symbolic branch name (if it exists) as I call jj edit.
My workflow typically maintains a local jj structure that is rooted at main@git. I treat children of this commit as github PRs / published work (using the stacked commits workflow). These children are the basis of an empty merge commit that I call public containing all these sibling changes (that also have branches matched to a github PR). I then typically have a few more commits or trees stacked above public containing some WIP work that is not ready to have a PR.
When I'd like to run an integration test / push to a staging environment with all my collected changes I use the empty public merge commit as it represents a union of what I'll expect to eventually be stacked onto main@git in the future.
Local CI tooling I don't control assumes:
that I am on a branch
requires a clean git working copy
tries to run git operations (including pushing and pulling).
This tooling fails currently because:
While jj sees the working copy as on the public merge commit, git@HEAD is an arbitrary parent of my working copy
Hence git sees a dirty working copy (containing other parent changes), meaning my tool refuses to run.
I can work around this by jj new public to switch to an empty child which then sets HEAD@git to what jj calls public.
I'm on a detached head, and this tooling really wants to be on a real git branch.
I can git checkout public to change git's view of its HEAD (the contents of $(git rev-parse --git-dir)/HEAD) from a sha1 hash to ref: refs/heads/public.
Describe the solution you'd like
I would like jj to set HEAD@git to the branch name of the current revision of the current working copy's change, if it exists, or the detached head sha1 when I run jj edit (rather than jj new).
Describe alternatives you've considered
It could be an option to do the above, or I could use a local alias, or maybe a hook...
The text was updated successfully, but these errors were encountered:
Since jj doesn't track whether the current working commit is edit-ing or checked out (by jj new), it wouldn't be easy to export HEAD@git to different place. (It could be hacked one time by jj edit, but subsequent working-copy snapshot might break the assumption.)
One thing we can fix without changing the underlying data model, I think, is to update the Git index to the merged parent tree (not to the first parent) so the previous merge operation made by jj is staged.
The detached head stuff is discussed several times, and #2338 is the latest one I suppose.
Is your feature request related to a problem? Please describe.
tl;dr: I need to manually change / deal with / track
HEAD@git
due to local tooling shortcomings and I'd likejj
to help by settingHEAD@git
for me to a symbolic branch name (if it exists) as I calljj edit
.I use Jujitsu in a colocated git repository. Jujitsu thus maintains the
HEAD@git
ref as the parent of myjj
working copy at all times via https://github.com/martinvonz/jj/blob/47c010fce4e145e58c259012755b3995e9862fa9/lib/src/git.rs#L923-L925 .My workflow typically maintains a local jj structure that is rooted at
main@git
. I treat children of this commit as github PRs / published work (using the stacked commits workflow). These children are the basis of an empty merge commit that I callpublic
containing all these sibling changes (that also have branches matched to a github PR). I then typically have a few more commits or trees stacked abovepublic
containing some WIP work that is not ready to have a PR.When I'd like to run an integration test / push to a staging environment with all my collected changes I use the empty
public
merge commit as it represents a union of what I'll expect to eventually be stacked ontomain@git
in the future.Local CI tooling I don't control assumes:
This tooling fails currently because:
jj
sees the working copy as on thepublic
merge commit,git@HEAD
is an arbitrary parent of my working copyjj new public
to switch to an empty child which then setsHEAD@git
to what jj callspublic
.git checkout public
to change git's view of itsHEAD
(the contents of$(git rev-parse --git-dir)/HEAD
) from a sha1 hash toref: refs/heads/public
.Describe the solution you'd like
I would like
jj
to setHEAD@git
to the branch name of the current revision of the current working copy's change, if it exists, or the detached head sha1 when I runjj edit
(rather thanjj new
).Describe alternatives you've considered
It could be an option to do the above, or I could use a local alias, or maybe a hook...
The text was updated successfully, but these errors were encountered: