Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Show sync status in branches list #3021

Merged
merged 9 commits into from
Oct 10, 2023

Conversation

stefanhaller
Copy link
Collaborator

@stefanhaller stefanhaller commented Sep 22, 2023

  • PR Description

When pulling/pushing/fast-forwarding a branch, show this state in the branches list for that branch for as long as the operation takes, to make it easier to see when it's done (without having to stare at the status bar in the lower left).

This will hopefully help with making these operations feel more predictable, now that we no longer show a loader panel for them.

@stefanhaller stefanhaller force-pushed the show-sync-status-in-branches-panel branch from ae1383d to 3461c26 Compare September 22, 2023 16:59
@stefanhaller stefanhaller marked this pull request as ready for review September 22, 2023 17:00
@stefanhaller stefanhaller added the enhancement New feature or request label Sep 22, 2023
@jesseduffield
Copy link
Owner

Looking good, couple thoughts:

  • it's cool to be able to queue up multiple fast-forwards and see the labels against each branch (thankfully the sync-mutex ensures nothing goes wrong) showing the progress
  • it's cool seeing the label against the branch that the action affects. So I can select the second branch in the list, press 'p' for pull, and see the 'pulling' status is attached to the first branch in the list. That's really good feedback to the user who may have hoped that pulling could affect the selected branch rather than the current branch (compared to say fast-forwarding)
  • If I start a pull, the 'pulling' status appears against the branch but if I then press shift+R to refresh from within the files view that status disappears even though I can see that in the bottom left we're still pulling.
  • the lack of a loaders spinner is jarring. Is there a technical reason why we can't add one?
  • This is a pattern which would be useful in other places e.g. pushing a tag or deleting a remote tag, or any action that we expect to take some time. As such, I'd like to have a more generic way of handling this e.g. having our list context trait hold a field that's a mapping from list item id to status.
  • We'll also want to decide on a rule for when we should and shouldn't show an inline status as part of some action. A rule like 'only do it when we're talking to a remote server' may be fine, but we may want to expand to 'only do it when the action could take a while on large repos' which would include things like rebase operations.

@stefanhaller
Copy link
Collaborator Author

it's cool to be able to queue up multiple fast-forwards and see the labels against each branch (thankfully the sync-mutex ensures nothing goes wrong) showing the progress

Yes, that's cool; also for pushing a stack of branches. It's possible to check out the first branch, push it, and while it's being pushed check out the next branch and push it too.

Actually I'd be interested in trying whether the sync mutex is really needed. I wouldn't be surprised if git is good enough at handling concurrent operations correctly. The only thing I didn't dare trying yet is to check out a different branch while pulling a branch, but the sync mutex wouldn't help with that.

If I start a pull, the 'pulling' status appears against the branch but if I then press shift+R to refresh from within the files view that status disappears even though I can see that in the bottom left we're still pulling.

I'll have to debug this; it works correctly for pushing, so I don't understand why it doesn't for pulling.

the lack of a loaders spinner is jarring. Is there a technical reason why we can't add one?

I couldn't find an easy way to redraw just a single line. Do you think it's ok to redraw the entire view (PostRefreshUpdate) every 50ms?

@stefanhaller
Copy link
Collaborator Author

Actually I'd be interested in trying whether the sync mutex is really needed.

I played with this for a while, and I'm now convinced that not only can we get rid of the sync mutex, we actually should because it makes some things work better:

  • pushing a stack of branches by checking out the first branch, pushing it, checking out the next one, pushing it too, and so on works better without the mutex. I did some testing on this, and simulated very slow pushes by putting a sleep 15 into a pre-push hook. This allows you to easily start more than two pushes in parallel. With the mutex, all these are queued up, and since all of these push the current branch at the time they start, they all end up pushing the last branch that was checked out; meaning that the ones in the middle of the stack aren't pushed. Without the mutex, each push pushes the right branch, and it's no problem for them all to run in parallel. Pretty cool. For fetching I'm even more convinced that git is good at locking things as needed, since it can always happen that some other GUI tool has a periodic background fetch running.
  • we had complaints about switching repos or switching to submodules being slow right after startup of lazygit. That was because we do an initial fetch after startup (which can take a long time if you didn't have this repo open for a while), and the sync mutex prevents switching repos. And for no good reason, as far as I can see; I can't think of a reason why we shouldn't let an ongoing push, pull, or fetch run to completion in parallel to opening another repo.
  • it could help with Lazygit crashes when pushing or pulling #2999, where a background fetch seems to hang forever, so issuing a new push or pull blocks forever. Granted, we should probably still figure out the root cause, but not having a sync mutex doesn't make this an issue any more.

I pushed a commit to remove the sync mutex.

If I start a pull, the 'pulling' status appears against the branch but if I then press shift+R to refresh from within the files view that status disappears even though I can see that in the bottom left we're still pulling.

I'll have to debug this; it works correctly for pushing, so I don't understand why it doesn't for pulling.

OK, that was a stupid bug. I reset the branchOperation entry too early by doing it outside of the WithWaitingStatus; this is fixed in 83a216f.

e.g. having our list context trait hold a field that's a mapping from list item id to status.

This sounds good except that sometimes I think it could be useful to look at this state for purposes other than drawing the list. For example, I think it would be a good idea to prevent the user from checking out a different branch while the current branch is being pulled; for this to be possible, we must keep the state somewhere more global than the list context.

@stefanhaller
Copy link
Collaborator Author

Oh, one more thing: when doing a manual refresh while the current branch is being pushed or pulled, you can see that the status panel updates too, because it uses FormatStatus to draw the checkmark or pushable/pullable state. I'm not sure if we want this, but actually I think it's kind of nice to see it there, too. If we do, we need to find a way to redraw the status panel at the beginning of the operation, and that needs moving some code around because it is drawn in RefreshHelper.refreshStatus which can't be called from the outside.

@jesseduffield
Copy link
Owner

I couldn't find an easy way to redraw just a single line. Do you think it's ok to redraw the entire view (PostRefreshUpdate) every 50ms?

I think it's worth trying to see how well it's handled. We show loader spinners in lazydocker against individual lines and it works fine. Two issues that come to mind:

  • I don't think we update just the viewport; we update the whole view, so if a user has a couple hundred branches, it'll be slower to refresh.
  • If there are expensive, non-idempotent callbacks happening in PostRefreshUpdate (e.g. rendering the current item to the main view) then we should introduce a separate method specifically for re-rendering the view. I don't acually recall if they are currently idempotent.

I played with this for a while, and I'm now convinced that not only can we get rid of the sync mutex, we actually should because it makes some things work better

Hmm. You make some very good points. What I don't like is that if there is a conflict the second command will just error e.g. background git fetch starts, then user does a git pull, but git fetch has the lock, so git pull errors.

According to this stack overflow response it seems that that's what will happen. I haven't been able to reproduce that specifically but I can get errors when hitting 'p' multiple times where it says I can't rebase onto multiple branches.

The mutex was originally added for #866. I can't reproduce a panic if I press 'p' repeatedly right as lazygit starts so maybe this is fine.

Happy to remove the mutex and see if anybody has issues with it. But if people do have issues with it I think it's more important to prevent those concurrency issues than to support concurrent commands, meaning I'd want to immediately reintroduce the mutex and then look into more sophisticated concurrency support.

This sounds good except that sometimes I think it could be useful to look at this state for purposes other than drawing the list.

I see: we want the status to be against the model, not the view (or context). That makes sense. I'm happy for it to live in the gui struct then but:

  • I want a struct for holding these statuses (e.g. with a Branches field and a Tags field) so that it's centralised rather than tagging on more fields to the gui struct
  • Currently it is just storing a presentational status string against the model item. If we ever want to read that we should switch to using an enum which then gets mapped to the status string. Given that we don't currently have the use case for reading the string I'm happy to leave it as a string until we do.

Oh, one more thing: when doing a manual refresh while the current branch is being pushed or pulled, you can see that the status panel updates too

I'm not a fan of that: updating three different places on the screen to show that we're pulling is overkill imo. I'd just pull the logic out of FormatStatus and have it specific to the branches view.

@stefanhaller
Copy link
Collaborator Author

What I don't like is that if there is a conflict the second command will just error e.g. background git fetch starts, then user does a git pull, but git fetch has the lock, so git pull errors.

It's true that some scenarios can cause errors like this, but I think a mutex is not the right tool to solve them. The only reason they can happen is that two concurrent operations try to update the same ref; this can only happen if you try to pull the same branch twice, or maybe push the same branch twice (because it needs to update the remote ref). We should simply prevent users from doing that, as there's no reason to do it. And we can use the new DisabledReason to prevent this. (This will not solve the case where the user pushes a branch from another git client, then quickly switches to lazygit and tries to push it from there, too. But I don't think we need to solve this, and the mutex wouldn't have helped with this either.)

The scenario you mentioned is not one of these (user does a pull while a background fetch is running): the background fetch only updates remote refs, the pull only updates a local ref. No conflict here.

I want a struct for holding these statuses (e.g. with a Branches field and a Tags field) so that it's centralised rather than tagging on more fields to the gui struct

I wonder if we could keep using a single map if we switch to storing the full refs as keys, as they are guaranteed to be distinct for branches as tags. Seems easier to me, what do you think?

we should switch to using an enum which then gets mapped to the status string.

I thought about that too, and it sounds easy enough, so I can do it as part of this PR.

@jesseduffield
Copy link
Owner

The scenario you mentioned is not one of these (user does a pull while a background fetch is running): the background fetch only updates remote refs, the pull only updates a local ref. No conflict here.

But a pull internally does a fetch + merge/rebase so I do think there's still a chance of conflict. At any rate I'm still happy to see how we go without the mutex.

I wonder if we could keep using a single map if we switch to storing the full refs as keys, as they are guaranteed to be distinct for branches as tags. Seems easier to me, what do you think?

I had in mind having support for a status against any model item but come to think of it it's really tags/branches that involve talking to the remote so I'm happy to go with that for now

@stefanhaller
Copy link
Collaborator Author

But a pull internally does a fetch + merge/rebase so I do think there's still a chance of conflict.

I don't think two fetches in parallel are a problem for git. (Maybe it takes some reading of the git source code to confirm that.) If it was, then it would be a problem to have several git clients running which all do periodic background fetches.

@jesseduffield
Copy link
Owner

It's quite possible that those conflicting fetches just silently fail and then try again later though, which is different to having a user-initiated pull fail. Or do you mean that we should expect more pulls to fail due to having background fetches from other applications running concurrently? That's a good point.

@stefanhaller
Copy link
Collaborator Author

No, I don't expect a pull to fail when there's a concurrent fetch running. Only two pulls can conflict (because they will try to update the same local ref, or rebase the local branch onto different things), but two fetches won't, and a pull and a fetch won't either. It still needs to be confirmed, but I would be very surprised if that doesn't hold.

@jesseduffield
Copy link
Owner

Makes sense

@stefanhaller stefanhaller force-pushed the show-sync-status-in-branches-panel branch from 12bad5f to 944b399 Compare September 25, 2023 20:09
@stefanhaller
Copy link
Collaborator Author

New version:

  • uses a more generic "ref operation" concept (can be used for branches and tags)
  • uses an enum, and translates to strings at the presentation level
  • draws spinning loader animations
  • uses inline status displays for pushing tags and deleting remote tags

Also, I now disable a few commands in certain situations (e.g. pushing or pulling a branch while the same branch is already being pushed or pulled), so that we can be a bit more confident about removing the sync mutex. We can maybe think about adding more of these. (However, I don't want to disable checkout another branch while the current branch is being pushed; this works reliably, and is useful.)

There's one cosmetic problem with disabling these commands: I use the DisabledReason mechanism for this, which is a problem when you bring up the keybindings dialog, because it doesn't update when the state changes (i.e. when a branch is done pushing). Not sure how problematic we find this.

@stefanhaller
Copy link
Collaborator Author

Another cosmetic problem: when force-pushing a branch, the inline status replaces the ↑4↓9 while pushing, but when done, the ↑4↓9 briefly appears again and is then replaced with the green checkmark a moment later. I find this very ugly. The reason for this is the PostRefreshUpdate call for the branches context in refreshWorktrees; commenting this out fixes the glitch.

I'm not sure what to do about this, to be honest.

@stefanhaller
Copy link
Collaborator Author

I pushed a commit (830c48f) to fix the visual glitch with the ↑4↓9 vs. . I hope that's an appropriate solution; as I don't use worktrees myself, I couldn't really test it much.

Copy link
Owner

@jesseduffield jesseduffield left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Looking good.

I had a go refactoring this to support any arbitrary item (not just refs) and I like the result. What do you think? b726fd4

For the record I see this coming in handy when we improve the recent repos view to be a fully fledged list view that allows fetch/push/pull operations.

pkg/gui/controllers/helpers/repos_helper.go Show resolved Hide resolved
stop chan struct{}
}

func (gui *Gui) startRenderingInlineStatus(contextKey types.ContextKey) {
Copy link
Owner

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

thoughts on moving this stuff to a helper?

Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Ha, I thought I could get away with just putting it into a source file that has "helper" in its name. 😄

Copy link
Owner

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Alas, I still wanna shrink down the gui struct so that it's not so much of a 'God Struct', and the helpers in the helpers package are one way to do that, so I reckon we extract a helper out for this

Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

OK, I can give it a try. Just to be clear, I'd move everything that's now in StateAccessor to the helper, including the state, right?

Copy link
Owner

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I was thinking moreso that you'd leave the state available in StateAccessor but move the functions specific to item operations to the helper

Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Here's what I came up with: 206a4e0. Do let me know if you want something to be done differently, I'm not tired of the review yet. 😄

Also, normally I'd make an effort to squash this down somehow into earlier commits (also your itemOperations refactor) to avoid this back-and-forth in the history, but it's too much work this time, so I'd rather leave it as is.

self.c.State().SetRefOperation(tag.FullRefName(), types.RefOperationPushing, context.TAGS_CONTEXT_KEY)
defer func() {
self.c.State().ClearRefOperation(tag.FullRefName(), context.TAGS_CONTEXT_KEY)
// Render again to remove the inline status:
Copy link
Owner

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

shouldn't this be done from within stopRenderingInlineStatus?

Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

No, this would come too early and cause the ugly flicker again (not for this command, but for the other ones). Most other commands need to refresh first and only redraw again at the end.

Copy link
Owner

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

TL;DR makes sense, happy to leave as-is

I see: what differentiates this from other situations is that in other cases we'll do a refresh at the end of the callback passed to WithItemOperation because we expect the model to change as a result of the action. With tags, we don't keep track of which remotes a tag has been pushed to, so there's no need to refresh. But in this case we can't piggyback on the fact that a refresh causes a re-render because we're not refreshing. That's why we need to do an explicit render.

This actually shines a light on the fact that we could be storing remote tags but we just aren't. Once we support that, we'll add a refresh here and then we won't need the call to HandleRender.

I was wondering whether we should re-render anyway within WithItemOperation but it's an extra render we don't need to do so I'm happy to leave this as is.

@@ -131,6 +131,9 @@ func (self *TagsController) remoteDelete(tag *models.Tag) error {
Prompt: confirmPrompt,
HandleConfirm: func() error {
return self.c.WithWaitingStatus(self.c.Tr.DeletingStatus, func(t gocui.Task) error {
self.c.State().SetRefOperation(tag.FullRefName(), types.RefOperationDeleting, context.TAGS_CONTEXT_KEY)
Copy link
Owner

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

We always defer a clear right after setting the ref and we always pass the same arguments to it. We can DRY this up: I'm thinking we have a function like WithWaitingStatus which takes a function as an argument and does the set/clear around calling that function.

Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Good idea, see a0510f5.

pkg/gui/gui.go Outdated
@@ -110,6 +110,10 @@ type Gui struct {
// lazygit was opened in, or if we'll retain the one we're currently in.
RetainOriginalDir bool

refOperations map[string]types.RefOperation
Copy link
Owner

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Would be good to add a comment here explaining when it's appropriate to set a ref operation. At the moment the rule is to use a ref operation when we need to talk to the remote

Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@stefanhaller stefanhaller force-pushed the show-sync-status-in-branches-panel branch from 830c48f to 5b64b2b Compare October 2, 2023 06:48
@stefanhaller
Copy link
Collaborator Author

I like the generalization from ref to item and cherry-picked it as is.

Copy link
Owner

@jesseduffield jesseduffield left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Just two more things :)

if err != nil {
_ = self.c.Error(err)
}
return self.c.State().WithItemOperation(branch, types.ItemOperationFastForwarding, context.LOCAL_BRANCHES_CONTEXT_KEY, func() error {
Copy link
Owner

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Can we add WithItemOperation to pkg/gui/gui_common.go? Feels like it should be just as accessible as WithWaitingStatus

Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

You mean like this? ca6fefd

I'm still a bit unsure sometimes with all the interfaces that we have. WithWaitingStatus is part of IPopupHandler (not really sure why to be honest), for WithItemOperation I couldn't think of anything better than IGuiCommon.

Copy link
Owner

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

yep!

self.c.State().SetRefOperation(tag.FullRefName(), types.RefOperationPushing, context.TAGS_CONTEXT_KEY)
defer func() {
self.c.State().ClearRefOperation(tag.FullRefName(), context.TAGS_CONTEXT_KEY)
// Render again to remove the inline status:
Copy link
Owner

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

TL;DR makes sense, happy to leave as-is

I see: what differentiates this from other situations is that in other cases we'll do a refresh at the end of the callback passed to WithItemOperation because we expect the model to change as a result of the action. With tags, we don't keep track of which remotes a tag has been pushed to, so there's no need to refresh. But in this case we can't piggyback on the fact that a refresh causes a re-render because we're not refreshing. That's why we need to do an explicit render.

This actually shines a light on the fact that we could be storing remote tags but we just aren't. Once we support that, we'll add a refresh here and then we won't need the call to HandleRender.

I was wondering whether we should re-render anyway within WithItemOperation but it's an extra render we don't need to do so I'm happy to leave this as is.

stop chan struct{}
}

func (gui *Gui) startRenderingInlineStatus(contextKey types.ContextKey) {
Copy link
Owner

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Alas, I still wanna shrink down the gui struct so that it's not so much of a 'God Struct', and the helpers in the helpers package are one way to do that, so I reckon we extract a helper out for this

@stefanhaller stefanhaller force-pushed the show-sync-status-in-branches-panel branch 2 times, most recently from ca6fefd to a6eb1e1 Compare October 5, 2023 12:29
@stefanhaller
Copy link
Collaborator Author

I added one more fixup (a6eb1e1) to rename a few more things from "refOperation" to "itemOperation".

Copy link
Owner

@jesseduffield jesseduffield left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

LGTM, great work this is a really good addition

@jesseduffield
Copy link
Owner

Actually something to consider: what are your thoughts on not showing the bottom-left loader when showing a loader in a view? Showing both at the same time is a little noisy and we don't gain anything extra from showing the loader in the bottom left

@stefanhaller
Copy link
Collaborator Author

Actually something to consider: what are your thoughts on not showing the bottom-left loader when showing a loader in a view? Showing both at the same time is a little noisy and we don't gain anything extra from showing the loader in the bottom left

Yeah good point, I'll try that and see how it feels. It definitely makes sense for the operations that you initiate from the item itself (e.g. fast-forward), because you probably have your eyes there when you do it anyway. I'm less sure for commands like push and pull which I often invoke from the files view or commits view, and in those cases I might look at the status bar more than at the branches list. But it's worth trying.

However, this made me realize another problem: the problem with push_with_credential_prompt.go hanging forever when running it slowly is back (argh), because we need to pause the new inline loader in the same way as we paused the status bar loader. Give me a bit of time to fix that...

We can just return our error to WithWaitingStatus, it will take care of
reporting it.
…essor

Not used by anything yet; committing this separately in the interest of having
smaller independent commits.
Very similar to WithWaitingStatus, except that the status is shown in a view
next to the affected item, rather than in the status bar.

Not used by anything yet; again, committing separately to get smaller commits.
When pulling/pushing/fast-forwarding a branch, show this state in the branches
list for that branch for as long as the operation takes, to make it easier to
see when it's done (without having to stare at the status bar in the lower
left).

This will hopefully help with making these operations feel more predictable, now
that we no longer show a loader panel for them.
I'm pretty convinced we don't need it. Git itself does a good job of making sure
that concurrent operations don't corrupt anything.
refreshWorktrees re-renders the branches view, because the branches view shows
worktrees against branches. This means that when both BRANCHES and WORKTREES are
requested to be refreshed, the branches view would be rendered twice in short
succession. This causes an ugly visual glitch when force-pushing a branch,
because when pushing is done, we would see the ↑4↓9 status come back from under
the Pushing status for a brief moment, to be replaced with a green checkmark a
moment later.

Fix this by including the worktree refresh in the branches refresh when both are
requested. This means that the two are no longer running in parallel for an
async refresh, but hopefully that's not so bad.
@stefanhaller stefanhaller force-pushed the show-sync-status-in-branches-panel branch from a6eb1e1 to 235f5bb Compare October 8, 2023 16:46
@stefanhaller
Copy link
Collaborator Author

I reworked the branch heavily. I now have a clearer separation between the state, which only stores the item operations and knows nothing about where they are shown, and the helper which orchestrates the redrawing. I renamed it to WithInlineStatus, it is more or less a drop-in replacement for WithWaitingStatus now, it behaves basically the same.

I am a little bit embarrassed that it took me so long to arrive at this design (with your help), but I'm quite happy with the result. I also restructured the commit history a bit to try to better reflect what's happening.

It does need a thorough re-review though; I changed so many things that I may easily have made stupid mistakes.

type InlineStatusHelper struct {
c *HelperCommon

contextsWithInlineStatus map[types.ContextKey]*inlineStatusInfo
Copy link
Owner

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

So far helpers have been stateless: letting the Gui or GuiRepoState struct hold any required state. I'm torn about whether we should retain that pattern here or just store the state on the helper. Having it on the helper is good for encapsulation but makes it harder to see at a glance the state of the app.

I'm happy to have it on the helper and see how that goes

Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Hm, I'm torn too. We had this discussion elsewhere (can't find it right now) to maybe convert all helpers to freestanding functions, in order to make interdependencies between helpers more convenient. This would be the only reason for me to keep the state out of here. Unless we accept that some helpers stay objects.

But I really like the encapsulation here; the alternative would be to expose the contextsWithInlineStatus map publicly in GuiCommon, but it really isn't anybody else's business to mess with that state.

Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@jesseduffield I was holding off of merging this one to see if there's any more input on this question. I'd like to merge now though, because it conflicts with #3058.

Copy link
Owner

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Go ahead: happy to see how this approach goes

Copy link
Owner

@jesseduffield jesseduffield left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

LGTM, great work!

@peppy
Copy link
Sponsor

peppy commented Oct 9, 2023

I've been tracking/running off this branch for a couple of weeks now and it's been great for me 👍 .

@stefanhaller stefanhaller merged commit 013cfc7 into master Oct 10, 2023
12 checks passed
@stefanhaller stefanhaller deleted the show-sync-status-in-branches-panel branch October 10, 2023 06:32
@peppy
Copy link
Sponsor

peppy commented Oct 13, 2023

One unfortunate edge case is when there's no space to show this. Currently in this situation there's zero UI feedback on operations:

CleanShot.2023-10-13.at.04.50.41.mp4

In case it isn't obvious, I'm pushing multiple times in this video 😅.

I think this could be resolved by temporarily showing the "Pushing" progress text on top of the branch name (with a few characters of left padding).

@stefanhaller
Copy link
Collaborator Author

stefanhaller commented Oct 13, 2023

Good point. The pushing status is not the only thing affected by this; I also want to see the ↑4↓9 or the "upstream gone". The solution for all of these is to shorten the branch name enough (maybe by appending ...) to make the status string fit after it, whatever it is. I'll see how hard it is to do that. (We'll have to pass the available width into getDisplayStrings somehow.)

@stefanhaller
Copy link
Collaborator Author

This is a little trickier than I thought, because we need to rerender the view whenever the layout changes. For the case of changing the screen mode this is easy to do by putting an AfterLayout around the code in rerenderViewsWithScreenModeDependentContent; but for resizing the terminal window I don't have a good idea how to achieve it, and I'm not sure there are any other reasons why view sizes could change.

@jesseduffield Any advice here? I'm thinking we could keep track of whether any view widths have changed in layout, and rerender them if so. Once we have that, we could get rid of rerenderViewsWithScreenModeDependentContent altogether.

@stefanhaller
Copy link
Collaborator Author

@jesseduffield I tried the approach of rerendering views when their width has changed, and it looks very promising so far. Hope to have a PR tomorrow. Just saying so that you don't waste time thinking about solutions. 😄

@stefanhaller
Copy link
Collaborator Author

@peppy See #3075, if you feel like testing it.

renovate bot added a commit to scottames/dots that referenced this pull request Mar 26, 2024
[![Mend
Renovate](https://app.renovatebot.com/images/banner.svg)](https://renovatebot.com)

This PR contains the following updates:

| Package | Update | Change |
|---|---|---|
| [aquaproj/aqua-registry](https://github.com/aquaproj/aqua-registry)
| minor | `v4.154.0` -> `v4.155.1` |
| [cli/cli](https://github.com/cli/cli) | minor | `v2.45.0` ->
`v2.46.0` |
| [derailed/k9s](https://github.com/derailed/k9s) | patch | `v0.32.3`
-> `v0.32.4` |
| [eza-community/eza](https://github.com/eza-community/eza) | patch |
`v0.18.7` -> `v0.18.8` |
| [golangci/golangci-lint](https://github.com/golangci/golangci-lint)
| minor | `v1.56.2` -> `v1.57.1` |
|
[gruntwork-io/terragrunt](https://github.com/gruntwork-io/terragrunt)
| patch | `v0.55.16` -> `v0.55.20` |
| [jesseduffield/lazygit](https://github.com/jesseduffield/lazygit) |
minor | `v0.40.2` -> `v0.41.0` |
| [junegunn/fzf](https://github.com/junegunn/fzf) | patch | `0.48.0`
-> `0.48.1` |
| [lsd-rs/lsd](https://github.com/lsd-rs/lsd) | minor | `v1.0.0` ->
`v1.1.2` |
| [mikefarah/yq](https://github.com/mikefarah/yq) | minor | `v4.42.1`
-> `v4.43.1` |
| [simulot/immich-go](https://github.com/simulot/immich-go) | minor |
`0.12.0` -> `0.13.0` |
| [snyk/cli](https://github.com/snyk/cli) | minor | `v1.1284.0` ->
`v1.1286.0` |
| [starship/starship](https://github.com/starship/starship) | minor |
`v1.17.1` -> `v1.18.1` |
| [twpayne/chezmoi](https://github.com/twpayne/chezmoi) | patch |
`v2.47.1` -> `v2.47.2` |
| [weaveworks/eksctl](https://github.com/weaveworks/eksctl) | minor |
`v0.174.0` -> `v0.175.0` |

---

> [!WARNING]
> Some dependencies could not be looked up. Check the Dependency
Dashboard for more information.

---

### Release Notes

<details>
<summary>aquaproj/aqua-registry (aquaproj/aqua-registry)</summary>

###
[`v4.155.1`](https://github.com/aquaproj/aqua-registry/releases/tag/v4.155.1)

[Compare
Source](https://github.com/aquaproj/aqua-registry/compare/v4.155.0...v4.155.1)


[Issues](https://github.com/aquaproj/aqua-registry/issues?q=is%3Aissue+milestone%3Av4.155.0)
| [Pull
Requests](https://github.com/aquaproj/aqua-registry/pulls?q=is%3Apr+milestone%3Av4.155.0)
| https://github.com/aquaproj/aqua-registry/compare/v4.155.0...v4.155.1

##### Others


[#&#8203;21239](https://github.com/aquaproj/aqua-registry/issues/21239)
Rename the package crates.io/shellharden to anordal/shellharden
[@&#8203;hituzi-no-sippo](https://github.com/hituzi-no-sippo)

shellharden started releasing pre-built binaries, so we changed the
package type from `cargo` to `github_release` from shellharden v4.3.1.


[https://github.com/anordal/shellharden/pull/57](https://github.com/anordal/shellharden/pull/57)
https://github.com/anordal/shellharden/releases/tag/v4.3.1

> \[!WARNING]
> Please rename the package `crates.io/shellharden` to
`anordal/shellharden`
>
> ```yaml
> packages:
> - name: anordal/[email protected]
> ```
>
> Note that Renovate will update crates.io/shellharden to
crates.io/[email protected], but it wouldn't work.
> You have to change the version to `v4.3.1`.

###
[`v4.155.0`](https://github.com/aquaproj/aqua-registry/releases/tag/v4.155.0)

[Compare
Source](https://github.com/aquaproj/aqua-registry/compare/v4.154.0...v4.155.0)


[Issues](https://github.com/aquaproj/aqua-registry/issues?q=is%3Aissue+milestone%3Av4.154.0)
| [Pull
Requests](https://github.com/aquaproj/aqua-registry/pulls?q=is%3Apr+milestone%3Av4.154.0)
| https://github.com/aquaproj/aqua-registry/compare/v4.154.0...v4.155.0

#### 🎉 New Packages


[#&#8203;21127](https://github.com/aquaproj/aqua-registry/issues/21127)
[ynqa/jnv](https://github.com/ynqa/jnv): interactive JSON filter using
jq [@&#8203;ponkio-o](https://github.com/ponkio-o)

[#&#8203;21079](https://github.com/aquaproj/aqua-registry/issues/21079)
[zaghaghi/openapi-tui](https://github.com/zaghaghi/openapi-tui):
Terminal UI to list, browse and run APIs defined with openapi spec
[@&#8203;wancup](https://github.com/wancup)

#### Fixes


[#&#8203;21122](https://github.com/aquaproj/aqua-registry/issues/21122)
Update some packages to support Cosign v2

⚠️ To install the following packages, aqua v2.25.1 or later is required.

-   aquaproj/aqua-registry-updater
-   aquaproj/registry-tool
-   argoproj/argo-workflows
-   chainguard-dev/apko
-   chainguard-dev/melange
-   charmbracelet/gum
-   goreleaser/nfpm
-   kubernetes-sigs/zeitgeist
-   lintnet/lintnet
-   suzuki-shunsuke/ci-info
-   suzuki-shunsuke/circleci-config-merge
-   suzuki-shunsuke/cmdx
-   suzuki-shunsuke/ghalint
-   suzuki-shunsuke/ghcp
-   suzuki-shunsuke/github-comment
-   suzuki-shunsuke/mkghtag
-   suzuki-shunsuke/nllint
-   suzuki-shunsuke/pinact
-   suzuki-shunsuke/renovate-issue-action
-   suzuki-shunsuke/tfcmt
-   suzuki-shunsuke/tfprovidercheck
-   terraform-linters/tflint
-   tfmigrator/cli
-   updatecli/updatecli
-   yuyaban/gitlab-comment


[#&#8203;21062](https://github.com/aquaproj/aqua-registry/issues/21062)
[#&#8203;21063](https://github.com/aquaproj/aqua-registry/issues/21063)
[#&#8203;21064](https://github.com/aquaproj/aqua-registry/issues/21064)
[#&#8203;21065](https://github.com/aquaproj/aqua-registry/issues/21065)
[#&#8203;21066](https://github.com/aquaproj/aqua-registry/issues/21066)
Transfer [k0kubun/xremap/\*](https://github.com/k0kubun/xremap) to
[xremap/xremap/\*](https://github.com/xremap/xremap)

The GitHub Repository of the package "k0kubun/xremap/hypr" was
transferred from [k0kubun/xremap](https://github.com/k0kubun/xremap)
to [xremap/xremap](https://github.com/xremap/xremap)

</details>

<details>
<summary>cli/cli (cli/cli)</summary>

### [`v2.46.0`](https://github.com/cli/cli/releases/tag/v2.46.0):
GitHub CLI 2.46.0

[Compare Source](https://github.com/cli/cli/compare/v2.45.0...v2.46.0)

#### What's Changed

- Draft issue IDs are included in `project item-list` output by
[@&#8203;yasunori0418](https://github.com/yasunori0418) in
[https://github.com/cli/cli/pull/8754](https://github.com/cli/cli/pull/8754)
- New `--dry-run` option for `pr create` by
[@&#8203;v1v](https://github.com/v1v) in
[https://github.com/cli/cli/pull/8376](https://github.com/cli/cli/pull/8376)
- Bump go-keyring to fix race condition by
[@&#8203;williammartin](https://github.com/williammartin) in
[https://github.com/cli/cli/pull/8833](https://github.com/cli/cli/pull/8833)
- PR numbers are prefixed with owner/repo for context by
[@&#8203;nobe4](https://github.com/nobe4) in
[https://github.com/cli/cli/pull/8778](https://github.com/cli/cli/pull/8778)
- Extra word removed in `codespaces` code comments by
[@&#8203;cuinix](https://github.com/cuinix) in
[https://github.com/cli/cli/pull/8795](https://github.com/cli/cli/pull/8795)
- Clarified description of the `-u`, `--user` option for `gh auth token`
by [@&#8203;gregsmi](https://github.com/gregsmi) in
[https://github.com/cli/cli/pull/8797](https://github.com/cli/cli/pull/8797)
- Fixed formatting for the description of `release upload` by
[@&#8203;malor](https://github.com/malor) in
[https://github.com/cli/cli/pull/8834](https://github.com/cli/cli/pull/8834)
- Clarified the usage of `auth status` to list all authenticated
accounts by [@&#8203;jsoref](https://github.com/jsoref) in
[https://github.com/cli/cli/pull/8838](https://github.com/cli/cli/pull/8838)
- Document auth switch behavior for two or more accounts by
[@&#8203;williammartin](https://github.com/williammartin) in
[https://github.com/cli/cli/pull/8839](https://github.com/cli/cli/pull/8839)
- Document run watch and view not supporting fine grained PATs by
[@&#8203;williammartin](https://github.com/williammartin) in
[https://github.com/cli/cli/pull/8843](https://github.com/cli/cli/pull/8843)
- build(deps): bump google.golang.org/protobuf from 1.30.0 to 1.33.0 by
[@&#8203;dependabot](https://github.com/dependabot) in
[https://github.com/cli/cli/pull/8811](https://github.com/cli/cli/pull/8811)
- build(deps): bump github.com/cpuguy83/go-md2man/v2 from 2.0.3 to 2.0.4
by [@&#8203;dependabot](https://github.com/dependabot) in
[https://github.com/cli/cli/pull/8844](https://github.com/cli/cli/pull/8844)

#### New Contributors

- [@&#8203;cuinix](https://github.com/cuinix) made their first
contribution in
[https://github.com/cli/cli/pull/8795](https://github.com/cli/cli/pull/8795)
- [@&#8203;gregsmi](https://github.com/gregsmi) made their first
contribution in
[https://github.com/cli/cli/pull/8797](https://github.com/cli/cli/pull/8797)
- [@&#8203;nobe4](https://github.com/nobe4) made their first
contribution in
[https://github.com/cli/cli/pull/8778](https://github.com/cli/cli/pull/8778)
- [@&#8203;malor](https://github.com/malor) made their first
contribution in
[https://github.com/cli/cli/pull/8834](https://github.com/cli/cli/pull/8834)
- [@&#8203;yasunori0418](https://github.com/yasunori0418) made their
first contribution in
[https://github.com/cli/cli/pull/8754](https://github.com/cli/cli/pull/8754)

**Full Changelog**: https://github.com/cli/cli/compare/v2.45.0...v2.46.0

</details>

<details>
<summary>derailed/k9s (derailed/k9s)</summary>

### [`v0.32.4`](https://github.com/derailed/k9s/releases/tag/v0.32.4)

[Compare
Source](https://github.com/derailed/k9s/compare/v0.32.3...v0.32.4)

<img
src="https://raw.githubusercontent.com/derailed/k9s/master/assets/k9s.png"
align="center" width="800" height="auto"/>

### Release v0.32.4
#### Notes

Thank you to all that contributed with flushing out issues and
enhancements for K9s!
I'll try to mark some of these issues as fixed. But if you don't mind
grab the latest rev
and see if we're happier with some of the fixes!
If you've filed an issue please help me verify and close.

Your support, kindness and awesome suggestions to make K9s better are,
as ever, very much noted and appreciated!
Also big thanks to all that have allocated their own time to help others
on both slack and on this repo!!

As you may know, K9s is not pimped out by corps with deep pockets, thus
if you feel K9s is helping your Kubernetes journey,
please consider joining our [sponsorship
program](https://github.com/sponsors/derailed) and/or make some noise
on social! [@&#8203;kitesurfer](https://twitter.com/kitesurfer)

On Slack? Please join us
[K9slackers](https://join.slack.com/t/k9sers/shared_invite/enQtOTA5MDEyNzI5MTU0LWQ1ZGI3MzliYzZhZWEyNzYxYzA3NjE0YTk1YmFmNzViZjIyNzhkZGI0MmJjYzhlNjdlMGJhYzE2ZGU1NjkyNTM)

#### Maintenance Release!

***

#### ♫ Sounds Behind The Release ♭

Thinking of all you at KubeCon Paris!!
May I suggest a nice glass of `cold Merlote` or other fine grape juices
from my country?

- [Le Gorille - George
Brassens](https://www.youtube.com/watch?v=KVfwvk_yVyA)
- [Les Funerailles D'antan (Love this guy!) - George
Brassens](https://www.youtube.com/watch?v=bwb5k4k2EMc)
- [Poinconneur Des Lilas - Serge
Gainsbourg](https://www.youtube.com/watch?v=eWkWCFzkOvU)
- [Mon Legionaire (Yup! same guy??) - Serge
Gainsbourg](https://www.youtube.com/watch?v=gl8gopryqWI)
- [Les Cornichons - Nino
Ferrer](https://www.youtube.com/watch?v=N7JSW4NhM8I)
- [Paris s'eveille - Jacques
Dutronc](https://www.youtube.com/watch?v=3WcCg6rm3uM)

***

#### Videos Are In The Can!

Please dial [K9s
Channel](https://www.youtube.com/channel/UC897uwPygni4QIjkPCpgjmw) for
up coming content...

-   [K9s v0.31.0 Configs+Sneak peek](https://youtu.be/X3444KfjguE)
-   [K9s v0.30.0 Sneak peek](https://youtu.be/mVBc1XneRJ4)
-   [Vulnerability Scans](https://youtu.be/ULkl0MsaidU)

***

#### Resolved Issues

- [#&#8203;2608](https://github.com/derailed/k9s/issues/2608) Make the
sanitize feature easier to use
- [#&#8203;2605](https://github.com/derailed/k9s/issues/2605) Built-in
shortcuts being overridden by plugins result in excessive logging
- [#&#8203;2604](https://github.com/derailed/k9s/issues/2604) Ability
to mark a plugin as Dangerous/destructive
- [#&#8203;2592](https://github.com/derailed/k9s/issues/2592) "list
access denied" when switching contexts within k9s since 0.32.0

***

#### Contributed PRs

Please be sure to give `Big Thanks!` and `ATTA Girls/Boys!` to all the
fine contributors for making K9s better for all of us!!

- [#&#8203;2621](https://github.com/derailed/k9s/pull/2621) Fix snap
build

***

<img
src="https://raw.githubusercontent.com/derailed/k9s/master/assets/imhotep_logo.png"
width="32" height="auto"/> © 2024 Imhotep Software LLC. All materials
licensed under [Apache v2.0](http://www.apache.org/licenses/LICENSE-2.0)

</details>

<details>
<summary>eza-community/eza (eza-community/eza)</summary>

###
[`v0.18.8`](https://github.com/eza-community/eza/releases/tag/v0.18.8):
eza v0.18.8

[Compare
Source](https://github.com/eza-community/eza/compare/v0.18.7...v0.18.8)

### Changelog

#### \[0.18.8] - 2024-03-21

##### Bug Fixes

-   Avoid deprecation warnings
-   Rustfmt issues

##### Features

-   Add fennel lang icon and associations

##### Miscellaneous Tasks

-   Release eza v0.18.8

### Checksums

#### sha256sum

80565916de55b23c3cabb363ba1cb7f323f99b158e75b6c029a64108de7bdad9
./target/bin-0.18.8/eza_aarch64-unknown-linux-gnu.tar.gz
d3532278f5eae1c1dd57bcc9373f05b49f40ffac880d5c4efb67ac5d93cdf0ea
./target/bin-0.18.8/eza_aarch64-unknown-linux-gnu.zip
2c1722afbb0f90e40047cfffa93f04fb9b89633402236fb75119c9105265271f
./target/bin-0.18.8/eza_arm-unknown-linux-gnueabihf.tar.gz
a832c4694228780f43f467e2f0536bd4a8969a455edbb872eb8b4614ebd157e0
./target/bin-0.18.8/eza_arm-unknown-linux-gnueabihf.zip
39cc743e9293a5e269b2b2baf167f4f868f682143dc8b1f87efd64848bb3bca4
./target/bin-0.18.8/eza.exe_x86_64-pc-windows-gnu.tar.gz
9b331b2eee259a9afbffd39e5018735651f8053c5429714cdc46a02f571463e7
./target/bin-0.18.8/eza.exe_x86_64-pc-windows-gnu.zip
2e12d0b714aa011d23abb72459a2478eb9e369ac564a9a7e39ba6ec7ef775ad4
./target/bin-0.18.8/eza_x86_64-unknown-linux-gnu.tar.gz
e3c9c3535732cecad5eb9d786e1f7a7c66aa28d42a3516046e5b1cf7f3799920
./target/bin-0.18.8/eza_x86_64-unknown-linux-gnu.zip
2fc6c3ead5c8bc596643597737ba596aee2f61772792927e4e9e602525a6ae81
./target/bin-0.18.8/eza_x86_64-unknown-linux-musl.tar.gz
543f69f52165f654c5ab869319663d7f4ebdc95b7fc9c23be003ca551aec5dc3
./target/bin-0.18.8/eza_x86_64-unknown-linux-musl.zip

#### md5sum

f3dece765bb95c732bce9406c1eb825a
./target/bin-0.18.8/eza_aarch64-unknown-linux-gnu.tar.gz
b655997af2b0df307abd3a126e48fc3d
./target/bin-0.18.8/eza_aarch64-unknown-linux-gnu.zip
9cd1ae35fd90e4341cf8ed1b4a3d6cd9
./target/bin-0.18.8/eza_arm-unknown-linux-gnueabihf.tar.gz
e9cd1a917b39827fc159c100faaf28b9
./target/bin-0.18.8/eza_arm-unknown-linux-gnueabihf.zip
9f02446483003c219eecc1dc15273956
./target/bin-0.18.8/eza.exe_x86_64-pc-windows-gnu.tar.gz
db239fa66fde9800770384831e3a86fa
./target/bin-0.18.8/eza.exe_x86_64-pc-windows-gnu.zip
5722d3f4e4f2848d770713341c7c4bfd
./target/bin-0.18.8/eza_x86_64-unknown-linux-gnu.tar.gz
c9f5ece20dc527fd4ecf4f77bbf70b56
./target/bin-0.18.8/eza_x86_64-unknown-linux-gnu.zip
0826369c7f0ab3b17c4275f98ff1ab70
./target/bin-0.18.8/eza_x86_64-unknown-linux-musl.tar.gz
3c3633a6c54d32ee9f04277f4b103edc
./target/bin-0.18.8/eza_x86_64-unknown-linux-musl.zip

#### blake3sum

0c7fc89dd1cf514e62e644e8ff8dab8759d6bd42f364f2768c41df92ec9e9dfc
./target/bin-0.18.8/eza_aarch64-unknown-linux-gnu.tar.gz
540def87f4f455fcd6067648f05498db775c6c03f291088d03f1dc4cc8cf68e7
./target/bin-0.18.8/eza_aarch64-unknown-linux-gnu.zip
1980d8004ad1f9b0291381c4d57db64fc8ebcf1c0961a8ac3c05c3697d7dfaf3
./target/bin-0.18.8/eza_arm-unknown-linux-gnueabihf.tar.gz
9a80d9f0cfc83521d119778b52b55dce4b33f28b02624297c712efd3ade53f19
./target/bin-0.18.8/eza_arm-unknown-linux-gnueabihf.zip
5d97ba1a2eaccc814aec982922f89ee218521b343b5f3ad6900596ad9574bfa3
./target/bin-0.18.8/eza.exe_x86_64-pc-windows-gnu.tar.gz
2d274f097297ff222dc7756903dfb73fdc744051c75b815d2eea2e08ee0f4418
./target/bin-0.18.8/eza.exe_x86_64-pc-windows-gnu.zip
04ca09128611f9719ac0a7c387282049489243bbe74be8de797d845ec380b9ee
./target/bin-0.18.8/eza_x86_64-unknown-linux-gnu.tar.gz
3e58bf50b39c1b20801f5282b612103b07b12089d2a24f3dcec9882ac8482c8c
./target/bin-0.18.8/eza_x86_64-unknown-linux-gnu.zip
1df711c44e08cc08fc26753f5c50f9de244fdbd7e2f8cc3961d82f101d775154
./target/bin-0.18.8/eza_x86_64-unknown-linux-musl.tar.gz
9d71a5afbc797ca63eecf254fc4971c2a1dd188ce28c8cb4a10cf1a273d747d5
./target/bin-0.18.8/eza_x86_64-unknown-linux-musl.zip

</details>

<details>
<summary>golangci/golangci-lint (golangci/golangci-lint)</summary>

###
[`v1.57.1`](https://github.com/golangci/golangci-lint/releases/tag/v1.57.1)

[Compare
Source](https://github.com/golangci/golangci-lint/compare/v1.57.0...v1.57.1)

#### Changelog

-
[`87b6bf1`](https://github.com/golangci/golangci-lint/commit/87b6bf17)
build(deps): bump github.com/golangci/plugin-module-register from 0.1.0
to 0.1.1
([#&#8203;4549](https://github.com/golangci/golangci-lint/issues/4549))
-
[`921d535`](https://github.com/golangci/golangci-lint/commit/921d5357)
build(deps): bump github.com/pelletier/go-toml/v2 from 2.1.1 to 2.2.0
([#&#8203;4548](https://github.com/golangci/golangci-lint/issues/4548))
-
[`cd890db`](https://github.com/golangci/golangci-lint/commit/cd890db2)
fix: filter invalid issues before other processors
([#&#8203;4552](https://github.com/golangci/golangci-lint/issues/4552))

###
[`v1.57.0`](https://github.com/golangci/golangci-lint/compare/v1.56.2...v1.57.0)

[Compare
Source](https://github.com/golangci/golangci-lint/compare/v1.56.2...v1.57.0)

</details>

<details>
<summary>gruntwork-io/terragrunt (gruntwork-io/terragrunt)</summary>

###
[`v0.55.20`](https://github.com/gruntwork-io/terragrunt/compare/v0.55.19...v0.55.20)

[Compare
Source](https://github.com/gruntwork-io/terragrunt/compare/v0.55.19...v0.55.20)

###
[`v0.55.19`](https://github.com/gruntwork-io/terragrunt/releases/tag/v0.55.19)

[Compare
Source](https://github.com/gruntwork-io/terragrunt/compare/v0.55.18...v0.55.19)

#### Updated CLI args, config attributes and blocks

-   `scaffold`

#### Description

-   Fix grammar in feature text
-   Fix URL handling in the `scaffold` command
-   Updated gon version to 0.2.5

#### Related links

-
[https://github.com/gruntwork-io/terragrunt/pull/3010](https://github.com/gruntwork-io/terragrunt/pull/3010)
-
[https://github.com/gruntwork-io/terragrunt/pull/3005](https://github.com/gruntwork-io/terragrunt/pull/3005)

**Full Changelog**:
https://github.com/gruntwork-io/terragrunt/compare/v0.55.18...v0.55.19

###
[`v0.55.18`](https://github.com/gruntwork-io/terragrunt/releases/tag/v0.55.18)

[Compare
Source](https://github.com/gruntwork-io/terragrunt/compare/v0.55.17...v0.55.18)

#### Description

-   Updated github.com/cloudflare/circl from 1.3.3 to 1.3.7
-   Updated github.com/go-jose/go-jose/v3 from 3.0.0 to 3.0.3
-   Updated google.golang.org/protobuf from 1.32.0 to 1.33.0
-   Updated nokogiri to 1.16.3
-   Updates mini_portile2 from 2.4.0 to 2.8.5

#### Related links

-
[https://github.com/gruntwork-io/terragrunt/pull/2995](https://github.com/gruntwork-io/terragrunt/pull/2995)
-
[https://github.com/gruntwork-io/terragrunt/pull/2996](https://github.com/gruntwork-io/terragrunt/pull/2996)
-
[https://github.com/gruntwork-io/terragrunt/pull/2929](https://github.com/gruntwork-io/terragrunt/pull/2929)
-
[https://github.com/gruntwork-io/terragrunt/pull/3000](https://github.com/gruntwork-io/terragrunt/pull/3000)
-
[https://github.com/gruntwork-io/terragrunt/pull/3009](https://github.com/gruntwork-io/terragrunt/pull/3009)

###
[`v0.55.17`](https://github.com/gruntwork-io/terragrunt/releases/tag/v0.55.17)

[Compare
Source](https://github.com/gruntwork-io/terragrunt/compare/v0.55.16...v0.55.17)

#### Updated CLI args, config attributes and blocks

-   `terraform`

#### Description

-   Added support for OpenTofu registry for shorthand TFR modules.

#### Related links

-
[https://github.com/gruntwork-io/terragrunt/pull/2961](https://github.com/gruntwork-io/terragrunt/pull/2961)

</details>

<details>
<summary>jesseduffield/lazygit (jesseduffield/lazygit)</summary>

###
[`v0.41.0`](https://github.com/jesseduffield/lazygit/releases/tag/v0.41.0)

[Compare
Source](https://github.com/jesseduffield/lazygit/compare/v0.40.2...pre-0.41)

Hold on tight because this is a HUGE release! This release includes a
whopping 595 commits from a period of over 7 months, from 40 different
contributors. Thanks to everybody who made this possible, and apologies
for taking so long to actually release it: we'll be more frequent in
future!

Special thanks to Stefan Haller who is behind many of this release's
changes and who has been critical in getting this release across the
line.

I've made a video running through the big changes here:

[<img
src="https://github.com/jesseduffield/lazygit/assets/8456633/f9b47c5e-f8b2-4b41-8f51-bf06b01046e2">](https://youtu.be/\_REmkoIyPW0)

#### What's Changed

Here's some highlighted features:

##### Range select


![range-select](https://github.com/jesseduffield/lazygit/blob/assets/demo/interactive_rebase-compressed.gif?raw=true)

You can now press 'v' to toggle range select in any list view, just like
you already could in the staging view. You can also press shift+up/down
to select a range. You can use range select to:

-   stage/discard a range of files
- select multiple commits to fixup/squash/move outside an interactive
rebase
- select multiple commits to mark as fixup/squash/etc within an
interactive rebase
- select multiple commit files to discard or add to a custom patch
(courtesy of [@&#8203;afhoffman](https://github.com/afhoffman))
-   select multiple commits to cherry-pick

I have been waiting for this feature for a very long time and it's
already made me way more productive. If I need to squash a range of
commits I can now easily do it directly rather than needing to squash
them one-by-one, or needing to manually start an interactive rebase
first. Likewise, it's much easier to select a range of files and stage
them than stage them one-by-one.

This is a **Breaking change**: Unfortunately, the 'v' key clashes with
the existing key for pasting commits (cherry-pick), so we've replaced
that with shift+V and changed the commit copy key to shift+C. If you
want the old keybindings back, you can do that like so:

```yml
keybinding:
  universal:
      toggleRangeSelect: <something other than v>
    commits:
      cherryPickCopy: 'c'
      pasteCommits: 'v'
```

##### Auto-wrap in commit editor

The commit editor now automatically hard-wraps your content by default,
so you no longer need to hit the enter key yourself when you approach
the margin. You can disable/configure this in your config:

```yml
git:
  commit:
    autoWrapCommitMessage: true
    autoWrapWidth: 72
```

Thanks to [@&#8203;stefanhaller](https://github.com/stefanhaller) for
this feature.

##### Easier remote branch checkout

Now when you go to checkout a remote branch, either via the `c`
keybinding in the branches view or by pressing `space` on a remote
branch, you'll be given the choice to checkout as a local branch or as a
detached head (previously it would just check it out as a detached head
which typically isn't what you want). This is a **Breaking change** in
terms of muscle memory.

Thanks to [@&#8203;stefanhaller](https://github.com/stefanhaller) for
this feature.

##### Easier start interactive rebase

Previously, to start an interactive rebase, you would need to navigate
to a base commit and press `e` on it. Now you can simply press `i` and
regardless of which commit is selected, an interactive rebase will begin
that includes all the commits on your branch (or if there are merge
commits: all the commits up to first merge commit).

The above demo for range select showcases this.

##### Easier squashing of `fixup!` commits

In a similar vein to the above section, now when you press `shift+S`,
you're given the choice of squashing all commits above the selected
commit and squashing all commits on the branch, which is what you
typically want. This is a **Breaking change** in terms of muscle memory.

Thanks to [@&#8203;stefanhaller](https://github.com/stefanhaller) for
this feature.

##### View divergence from upstream branch

If you press `u` on a local branch a menu appears which shows options
relating to the branch's upstream. Now, the first option in that menu
allows you to view the divergence from the upstream which shows commits
to pull and commits to push

Thanks to [@&#8203;stefanhaller](https://github.com/stefanhaller) for
this feature.

##### Find appropriate commit for fixup/amend

This one is some serious voodoo: if somebody suggests changes in a PR
review, you'll often apply the changes, then go hunting for the
appropriate commit to fixup/amend. Now, from the files view you can
press `ctrl+f` and if Lazygit can identify an appropriate commit with
certainty, it will select that commit for you. Pretty cool!

We've made the algorithm very strict so that you can always trust the
result, but this means in circumstances where we can't know for sure
which commit is appropriate (such as when your changes only include
added lines), it's left to you to manually find the commit. We're keen
to get lots of feedback on this feature to see where the sweet spot is.

For more info see [the
docs](https://github.com/jesseduffield/lazygit/blob/master/docs/Fixup_Commits.md#finding-the-commit-to-create-a-fixup-for)

Thanks to [@&#8203;stefanhaller](https://github.com/stefanhaller) for
this feature.

##### Delete remote branches/tags

Now when you press `d` on a local branch, remote branch, or tag, you're
given the option to delete that branch/tag in the remote.

Thanks to [@&#8203;AzraelSec](https://github.com/AzraelSec) for this
feature.

##### Add co-author to commit

When you press `a` on a commit an option now appears to add a co-author
(something GitHub can read).

Thanks to [@&#8203;omaussa](https://github.com/omaussa) for this
feature.

##### Filter commits by author

You can now filter commits by author via pressing `ctrl+s` in the
commits view and selecting the option to filter by author.

Thanks to [@&#8203;Part22](https://github.com/Part22) for this
feature.

##### Change branch sort order

You can now change branch sort order by pressing `s` in the branches
view (and remote branches view). By default local branches are sorted by
'recency' meaning how recently they were checked out, but you can now
sort by head commit date and alphabetically.

Thanks to [@&#8203;hosaka](https://github.com/hosaka) for this
feature.

##### Better bare repo support

We have fixed a bunch of bugs relating to bare repos so if you had
issues with them in the past it should work fine now.

Thanks to [@&#8203;jwhitley](https://github.com/jwhitley) for this
feature.

##### Miscelleneous UI changes

- Unstaged files are now shown in white, not red, which is easier on the
eyes
-   Scrollbars are thinner (and, thus, cooler)
- Keybindings menu now has section headers
([@&#8203;stefanhaller](https://github.com/stefanhaller))
- Error toasts now appear for some errors (less intrusive than popups)
([@&#8203;stefanhaller](https://github.com/stefanhaller))
- Search history is now retained
([@&#8203;karimkhaleel](https://github.com/karimkhaleel))
- Git log is shown by default
([@&#8203;stefanhaller](https://github.com/stefanhaller))

##### More Breaking Changes 💥

- When you press 'g' to bring up the git reset menu, the 'mixed' option
is now the first and default, rather than 'soft'. This is because
'mixed' is the most commonly used option.
- Push/pull/fetch loading statuses are now shown against the branch
rather than in a popup. This allows you to e.g. fetch multiple branches
in parallel and see the status for each branch.
- The git log graph in the commits view is now always shown by default
(previously it was only shown when the view was maximised). If you find
this too noisy, you can change it back via `ctrl+L` -> 'Show git graph'
-> 'when maximised'
- Filtering (e.g. when pressing '/') is less fuzzy by default; it only
matches substrings now. Multiple substrings can be matched by separating
them with spaces. If you want to revert to the old behavior, set the
following in your config:

```yml
gui:
  filterMode: 'fuzzy'
```

#### What's Changed

##### All Enhancements 🔥

- Add range selection ability on list contexts by
[@&#8203;jesseduffield](https://github.com/jesseduffield) in
[https://github.com/jesseduffield/lazygit/pull/3207](https://github.com/jesseduffield/lazygit/pull/3207)
- Allow deleting remote tags/branches from local tag/branch views by
[@&#8203;AzraelSec](https://github.com/AzraelSec) in
[https://github.com/jesseduffield/lazygit/pull/2738](https://github.com/jesseduffield/lazygit/pull/2738)
- Add command to show divergence from upstream by
[@&#8203;stefanhaller](https://github.com/stefanhaller) in
[https://github.com/jesseduffield/lazygit/pull/2871](https://github.com/jesseduffield/lazygit/pull/2871)
- Add 'Quick start interactive rebase' action by
[@&#8203;jesseduffield](https://github.com/jesseduffield) in
[https://github.com/jesseduffield/lazygit/pull/3213](https://github.com/jesseduffield/lazygit/pull/3213)
- Add command to open git difftool by
[@&#8203;stefanhaller](https://github.com/stefanhaller) in
[https://github.com/jesseduffield/lazygit/pull/3156](https://github.com/jesseduffield/lazygit/pull/3156)
- Support editing files in existing neovim instance by
[@&#8203;jesseduffield](https://github.com/jesseduffield) in
[https://github.com/jesseduffield/lazygit/pull/2916](https://github.com/jesseduffield/lazygit/pull/2916)
- Show commit mark before showing extra info by
[@&#8203;jesseduffield](https://github.com/jesseduffield) in
[https://github.com/jesseduffield/lazygit/pull/2928](https://github.com/jesseduffield/lazygit/pull/2928)
- Jump to middle of the view when selection leaves the visible area by
[@&#8203;stefanhaller](https://github.com/stefanhaller) in
[https://github.com/jesseduffield/lazygit/pull/2915](https://github.com/jesseduffield/lazygit/pull/2915)
- Add emacs-keybinds for word navigation by
[@&#8203;horriblename](https://github.com/horriblename) in
[https://github.com/jesseduffield/lazygit/pull/2935](https://github.com/jesseduffield/lazygit/pull/2935)
- Add `gui.scrollOffBehavior` config for scrolling list views by
half-pages by [@&#8203;stefanhaller](https://github.com/stefanhaller)
in
[https://github.com/jesseduffield/lazygit/pull/2939](https://github.com/jesseduffield/lazygit/pull/2939)
- Switch to editor from commit message panel by
[@&#8203;stefanhaller](https://github.com/stefanhaller) in
[https://github.com/jesseduffield/lazygit/pull/2881](https://github.com/jesseduffield/lazygit/pull/2881)
- Select same commit again after pressing "e" to edit a commit by
[@&#8203;stefanhaller](https://github.com/stefanhaller) in
[https://github.com/jesseduffield/lazygit/pull/2954](https://github.com/jesseduffield/lazygit/pull/2954)
- Support custom keybindings for confirm discard by
[@&#8203;mskelton](https://github.com/mskelton) in
[https://github.com/jesseduffield/lazygit/pull/2960](https://github.com/jesseduffield/lazygit/pull/2960)
- Allow adding a port to webDomain part of services config by
[@&#8203;raidora](https://github.com/raidora) in
[https://github.com/jesseduffield/lazygit/pull/2908](https://github.com/jesseduffield/lazygit/pull/2908)
- Add icons for files with .mdx and .svelte file extensions by
[@&#8203;hrstmr](https://github.com/hrstmr) in
[https://github.com/jesseduffield/lazygit/pull/2889](https://github.com/jesseduffield/lazygit/pull/2889)
- Section headers in keybindings menu by
[@&#8203;stefanhaller](https://github.com/stefanhaller) in
[https://github.com/jesseduffield/lazygit/pull/2911](https://github.com/jesseduffield/lazygit/pull/2911)
- Check for staged files for "Amend commit" and "Create fixup commit" by
[@&#8203;stefanhaller](https://github.com/stefanhaller) in
[https://github.com/jesseduffield/lazygit/pull/2970](https://github.com/jesseduffield/lazygit/pull/2970)
- Add support for external diff commands (e.g. difftastic) by
[@&#8203;stefanhaller](https://github.com/stefanhaller) in
[https://github.com/jesseduffield/lazygit/pull/2868](https://github.com/jesseduffield/lazygit/pull/2868)
- Save diff context size in state.yml instead of config.yml by
[@&#8203;stefanhaller](https://github.com/stefanhaller) in
[https://github.com/jesseduffield/lazygit/pull/2969](https://github.com/jesseduffield/lazygit/pull/2969)
- Support to reset the current branch to a selected branch upstream by
[@&#8203;AzraelSec](https://github.com/AzraelSec) in
[https://github.com/jesseduffield/lazygit/pull/2940](https://github.com/jesseduffield/lazygit/pull/2940)
- Replace whitespace with '-' when renaming a branch by
[@&#8203;calthejuggler](https://github.com/calthejuggler) in
[https://github.com/jesseduffield/lazygit/pull/2990](https://github.com/jesseduffield/lazygit/pull/2990)
- Add jump-to-panel label config setting by
[@&#8203;MariaSolOs](https://github.com/MariaSolOs) in
[https://github.com/jesseduffield/lazygit/pull/2993](https://github.com/jesseduffield/lazygit/pull/2993)
- Add co-author to commits by
[@&#8203;omaussa](https://github.com/omaussa) in
[https://github.com/jesseduffield/lazygit/pull/2912](https://github.com/jesseduffield/lazygit/pull/2912)
- Change the default of the "gui.borders" config to "rounded" by
[@&#8203;stefanhaller](https://github.com/stefanhaller) in
[https://github.com/jesseduffield/lazygit/pull/2998](https://github.com/jesseduffield/lazygit/pull/2998)
- Add a DisabledReason mechanism for menu items and keybindings by
[@&#8203;stefanhaller](https://github.com/stefanhaller) in
[https://github.com/jesseduffield/lazygit/pull/2992](https://github.com/jesseduffield/lazygit/pull/2992)
- Allow cherry-picking commits during a rebase by
[@&#8203;stefanhaller](https://github.com/stefanhaller) in
[https://github.com/jesseduffield/lazygit/pull/3013](https://github.com/jesseduffield/lazygit/pull/3013)
- Add history for search view by
[@&#8203;karimkhaleel](https://github.com/karimkhaleel) in
[https://github.com/jesseduffield/lazygit/pull/2877](https://github.com/jesseduffield/lazygit/pull/2877)
- Replace loader panels with waiting status (pull/push/fetch) by
[@&#8203;stefanhaller](https://github.com/stefanhaller) in
[https://github.com/jesseduffield/lazygit/pull/2973](https://github.com/jesseduffield/lazygit/pull/2973)
- Add menu to rebase onto selected branch remote upstream by
[@&#8203;AzraelSec](https://github.com/AzraelSec) in
[https://github.com/jesseduffield/lazygit/pull/3020](https://github.com/jesseduffield/lazygit/pull/3020)
- Add ability to force portrait mode by
[@&#8203;ldelossa](https://github.com/ldelossa) in
[https://github.com/jesseduffield/lazygit/pull/3037](https://github.com/jesseduffield/lazygit/pull/3037)
- Add Micro editor preset by [@&#8203;kytta](https://github.com/kytta)
in
[https://github.com/jesseduffield/lazygit/pull/3049](https://github.com/jesseduffield/lazygit/pull/3049)
- Show sync status in branches list by
[@&#8203;stefanhaller](https://github.com/stefanhaller) in
[https://github.com/jesseduffield/lazygit/pull/3021](https://github.com/jesseduffield/lazygit/pull/3021)
- Add 'lvim' editor preset for lunarvim by
[@&#8203;zottelsheep](https://github.com/zottelsheep) in
[https://github.com/jesseduffield/lazygit/pull/3074](https://github.com/jesseduffield/lazygit/pull/3074)
- Truncate branch names to make branch status always visible by
[@&#8203;stefanhaller](https://github.com/stefanhaller) in
[https://github.com/jesseduffield/lazygit/pull/3075](https://github.com/jesseduffield/lazygit/pull/3075)
- Color file icons by
[@&#8203;jesseduffield](https://github.com/jesseduffield) in
[https://github.com/jesseduffield/lazygit/pull/3080](https://github.com/jesseduffield/lazygit/pull/3080)
- Add UserConfig jsonschema generation script by
[@&#8203;karimkhaleel](https://github.com/karimkhaleel) in
[https://github.com/jesseduffield/lazygit/pull/3039](https://github.com/jesseduffield/lazygit/pull/3039)
- Add a copy-to-clipboard menu to the file view (with `diff` copy
options) by [@&#8203;AzraelSec](https://github.com/AzraelSec) in
[https://github.com/jesseduffield/lazygit/pull/3104](https://github.com/jesseduffield/lazygit/pull/3104)
- Fix bottom line alignment by
[@&#8203;stefanhaller](https://github.com/stefanhaller) in
[https://github.com/jesseduffield/lazygit/pull/3076](https://github.com/jesseduffield/lazygit/pull/3076)
- Make move up/down blocking by
[@&#8203;stefanhaller](https://github.com/stefanhaller) in
[https://github.com/jesseduffield/lazygit/pull/2966](https://github.com/jesseduffield/lazygit/pull/2966)
- Add remote branch sorting menu by
[@&#8203;hosaka](https://github.com/hosaka) in
[https://github.com/jesseduffield/lazygit/pull/3171](https://github.com/jesseduffield/lazygit/pull/3171)
- Add age to stash entries by
[@&#8203;AzraelSec](https://github.com/AzraelSec) in
[https://github.com/jesseduffield/lazygit/pull/3174](https://github.com/jesseduffield/lazygit/pull/3174)
- Add local branch sorting menu by
[@&#8203;hosaka](https://github.com/hosaka) in
[https://github.com/jesseduffield/lazygit/pull/3182](https://github.com/jesseduffield/lazygit/pull/3182)
- Show a friendly error message when starting lazygit from a
non-existent cwd by
[@&#8203;simonwhitaker](https://github.com/simonwhitaker) in
[https://github.com/jesseduffield/lazygit/pull/3192](https://github.com/jesseduffield/lazygit/pull/3192)
- Replace copy commit SHA with copy commit subject on the y s keybind in
the commits view by
[@&#8203;karimkhaleel](https://github.com/karimkhaleel) in
[https://github.com/jesseduffield/lazygit/pull/3188](https://github.com/jesseduffield/lazygit/pull/3188)
- Add config setting for splitting window vertically in half screen mode
by [@&#8203;stefanhaller](https://github.com/stefanhaller) in
[https://github.com/jesseduffield/lazygit/pull/3133](https://github.com/jesseduffield/lazygit/pull/3133)
- Add command to find base commit for creating a fixup by
[@&#8203;stefanhaller](https://github.com/stefanhaller) in
[https://github.com/jesseduffield/lazygit/pull/3105](https://github.com/jesseduffield/lazygit/pull/3105)
- Show Toast instead of error panel when invoking a disabled command by
[@&#8203;stefanhaller](https://github.com/stefanhaller) in
[https://github.com/jesseduffield/lazygit/pull/3180](https://github.com/jesseduffield/lazygit/pull/3180)
- Show file names in default colour by
[@&#8203;jesseduffield](https://github.com/jesseduffield) in
[https://github.com/jesseduffield/lazygit/pull/3081](https://github.com/jesseduffield/lazygit/pull/3081)
- Add config setting to suppress showing file icons by
[@&#8203;stefanhaller](https://github.com/stefanhaller) in
[https://github.com/jesseduffield/lazygit/pull/3216](https://github.com/jesseduffield/lazygit/pull/3216)
- Support range select for rebase actions by
[@&#8203;jesseduffield](https://github.com/jesseduffield) in
[https://github.com/jesseduffield/lazygit/pull/3232](https://github.com/jesseduffield/lazygit/pull/3232)
- Make range selections created with the mouse non-sticky by
[@&#8203;stefanhaller](https://github.com/stefanhaller) in
[https://github.com/jesseduffield/lazygit/pull/3234](https://github.com/jesseduffield/lazygit/pull/3234)
- Support range select for staging/discarding files by
[@&#8203;jesseduffield](https://github.com/jesseduffield) in
[https://github.com/jesseduffield/lazygit/pull/3248](https://github.com/jesseduffield/lazygit/pull/3248)
- Inline status for fetching remotes by
[@&#8203;stefanhaller](https://github.com/stefanhaller) in
[https://github.com/jesseduffield/lazygit/pull/3238](https://github.com/jesseduffield/lazygit/pull/3238)
- Add shortcuts for filtering files by status by
[@&#8203;mark2185](https://github.com/mark2185) in
[https://github.com/jesseduffield/lazygit/pull/3137](https://github.com/jesseduffield/lazygit/pull/3137)
- Keep same selection range when quick-starting an interactive rebase by
[@&#8203;stefanhaller](https://github.com/stefanhaller) in
[https://github.com/jesseduffield/lazygit/pull/3247](https://github.com/jesseduffield/lazygit/pull/3247)
- Add loads of tooltips by
[@&#8203;jesseduffield](https://github.com/jesseduffield) in
[https://github.com/jesseduffield/lazygit/pull/3269](https://github.com/jesseduffield/lazygit/pull/3269)
- Show better keybinding suggestions by
[@&#8203;jesseduffield](https://github.com/jesseduffield) in
[https://github.com/jesseduffield/lazygit/pull/3203](https://github.com/jesseduffield/lazygit/pull/3203)
- Support selecting file range in patch builder by
[@&#8203;afhoffman](https://github.com/afhoffman) in
[https://github.com/jesseduffield/lazygit/pull/3259](https://github.com/jesseduffield/lazygit/pull/3259)
- Add command to squash all fixups in the current branch by
[@&#8203;stefanhaller](https://github.com/stefanhaller) in
[https://github.com/jesseduffield/lazygit/pull/3274](https://github.com/jesseduffield/lazygit/pull/3274)
- Use slimmer scrollbars by
[@&#8203;jesseduffield](https://github.com/jesseduffield) in
[https://github.com/jesseduffield/lazygit/pull/3283](https://github.com/jesseduffield/lazygit/pull/3283)
- Clear cherry-picked commits after pasting by
[@&#8203;molejnik88](https://github.com/molejnik88) in
[https://github.com/jesseduffield/lazygit/pull/3240](https://github.com/jesseduffield/lazygit/pull/3240)
- Change default of git.log.showGraph to 'always' by
[@&#8203;stefanhaller](https://github.com/stefanhaller) in
[https://github.com/jesseduffield/lazygit/pull/3314](https://github.com/jesseduffield/lazygit/pull/3314)
- Support range select removing files from a commit by
[@&#8203;afhoffman](https://github.com/afhoffman) in
[https://github.com/jesseduffield/lazygit/pull/3276](https://github.com/jesseduffield/lazygit/pull/3276)
- Migrate git.log.showGraph and git.log.order to app state by
[@&#8203;hosaka](https://github.com/hosaka) in
[https://github.com/jesseduffield/lazygit/pull/3197](https://github.com/jesseduffield/lazygit/pull/3197)
- Change "git reset" default to --mixed by
[@&#8203;stefanhaller](https://github.com/stefanhaller) in
[https://github.com/jesseduffield/lazygit/pull/3264](https://github.com/jesseduffield/lazygit/pull/3264)
- Add author filtering to commit view by
[@&#8203;part22](https://github.com/part22) in
[https://github.com/jesseduffield/lazygit/pull/3302](https://github.com/jesseduffield/lazygit/pull/3302)
- Provide two helix presets, one for "helix" and one for "hx" by
[@&#8203;stefanhaller](https://github.com/stefanhaller) in
[https://github.com/jesseduffield/lazygit/pull/3346](https://github.com/jesseduffield/lazygit/pull/3346)
- Don't show branch head on rebase todos if the rebase.updateRefs config
is on by [@&#8203;stefanhaller](https://github.com/stefanhaller) in
[https://github.com/jesseduffield/lazygit/pull/3340](https://github.com/jesseduffield/lazygit/pull/3340)
- Show all submodules recursively by
[@&#8203;stefanhaller](https://github.com/stefanhaller) in
[https://github.com/jesseduffield/lazygit/pull/3341](https://github.com/jesseduffield/lazygit/pull/3341)
- Support setting a range of commits to "edit" outside of a rebase by
[@&#8203;stefanhaller](https://github.com/stefanhaller) in
[https://github.com/jesseduffield/lazygit/pull/3370](https://github.com/jesseduffield/lazygit/pull/3370)
- Adjust selection after squashing fixups by
[@&#8203;stefanhaller](https://github.com/stefanhaller) in
[https://github.com/jesseduffield/lazygit/pull/3338](https://github.com/jesseduffield/lazygit/pull/3338)
- Auto-wrap commit message while typing by
[@&#8203;stefanhaller](https://github.com/stefanhaller) in
[https://github.com/jesseduffield/lazygit/pull/3173](https://github.com/jesseduffield/lazygit/pull/3173)
- Add Co-Author support to new commits by
[@&#8203;2KAbhishek](https://github.com/2KAbhishek) in
[https://github.com/jesseduffield/lazygit/pull/3097](https://github.com/jesseduffield/lazygit/pull/3097)
- Show "breaking changes" message at startup by
[@&#8203;stefanhaller](https://github.com/stefanhaller) in
[https://github.com/jesseduffield/lazygit/pull/3377](https://github.com/jesseduffield/lazygit/pull/3377)
- Allow moving and deleting update-ref todos by
[@&#8203;stefanhaller](https://github.com/stefanhaller) in
[https://github.com/jesseduffield/lazygit/pull/3391](https://github.com/jesseduffield/lazygit/pull/3391)
- When checking out a remote branch by name, ask the user how by
[@&#8203;stefanhaller](https://github.com/stefanhaller) in
[https://github.com/jesseduffield/lazygit/pull/3388](https://github.com/jesseduffield/lazygit/pull/3388)
- Use substring filtering instead of fuzzy filtering by default by
[@&#8203;stefanhaller](https://github.com/stefanhaller) in
[https://github.com/jesseduffield/lazygit/pull/3376](https://github.com/jesseduffield/lazygit/pull/3376)
- Always prompt to return from subprocess if there was an error by
[@&#8203;stefanhaller](https://github.com/stefanhaller) in
[https://github.com/jesseduffield/lazygit/pull/3410](https://github.com/jesseduffield/lazygit/pull/3410)
- When adding a new remote, select it and fetch it by
[@&#8203;stefanhaller](https://github.com/stefanhaller) in
[https://github.com/jesseduffield/lazygit/pull/3401](https://github.com/jesseduffield/lazygit/pull/3401)
- Support editing multiple files at once using range selection by
[@&#8203;stefanhaller](https://github.com/stefanhaller) in
[https://github.com/jesseduffield/lazygit/pull/3407](https://github.com/jesseduffield/lazygit/pull/3407)
- Make it easy to create "amend!" commits by
[@&#8203;stefanhaller](https://github.com/stefanhaller) in
[https://github.com/jesseduffield/lazygit/pull/3409](https://github.com/jesseduffield/lazygit/pull/3409)
- Add config to truncate commit hashes when copying them to the
clipboard by [@&#8203;stefanhaller](https://github.com/stefanhaller)
in
[https://github.com/jesseduffield/lazygit/pull/3402](https://github.com/jesseduffield/lazygit/pull/3402)

##### Fixes 🔧

- Fix issue where explosion effect was out-of-view by
[@&#8203;jesseduffield](https://github.com/jesseduffield) in
[https://github.com/jesseduffield/lazygit/pull/2909](https://github.com/jesseduffield/lazygit/pull/2909)
- Show dialogue when attempting to open info link fails by
[@&#8203;simonwhitaker](https://github.com/simonwhitaker) in
[https://github.com/jesseduffield/lazygit/pull/2899](https://github.com/jesseduffield/lazygit/pull/2899)
- Fix jumping to the correct line from the staging view by
[@&#8203;stefanhaller](https://github.com/stefanhaller) in
[https://github.com/jesseduffield/lazygit/pull/2919](https://github.com/jesseduffield/lazygit/pull/2919)
- Fix sha colors when rebasing by
[@&#8203;stefanhaller](https://github.com/stefanhaller) in
[https://github.com/jesseduffield/lazygit/pull/2946](https://github.com/jesseduffield/lazygit/pull/2946)
- Fix the commit graph display after selection jumps in commits view by
[@&#8203;stefanhaller](https://github.com/stefanhaller) in
[https://github.com/jesseduffield/lazygit/pull/2943](https://github.com/jesseduffield/lazygit/pull/2943)
- Handle trailing slash in worktree path by
[@&#8203;Krismix1](https://github.com/Krismix1) in
[https://github.com/jesseduffield/lazygit/pull/2947](https://github.com/jesseduffield/lazygit/pull/2947)
- Fix escape not cancelling filter mode, but closing the menu instead by
[@&#8203;stefanhaller](https://github.com/stefanhaller) in
[https://github.com/jesseduffield/lazygit/pull/2977](https://github.com/jesseduffield/lazygit/pull/2977)
- Use `Error` method to handle commits url copy from unknown service by
[@&#8203;AzraelSec](https://github.com/AzraelSec) in
[https://github.com/jesseduffield/lazygit/pull/3007](https://github.com/jesseduffield/lazygit/pull/3007)
- Hide waiting status during credentials prompt by
[@&#8203;stefanhaller](https://github.com/stefanhaller) in
[https://github.com/jesseduffield/lazygit/pull/3016](https://github.com/jesseduffield/lazygit/pull/3016)
- Use upstream branch when opening pull requests by
[@&#8203;mark2185](https://github.com/mark2185) in
[https://github.com/jesseduffield/lazygit/pull/2693](https://github.com/jesseduffield/lazygit/pull/2693)
- Fix issue where active search inappropriately changed selected line by
[@&#8203;jesseduffield](https://github.com/jesseduffield) in
[https://github.com/jesseduffield/lazygit/pull/3022](https://github.com/jesseduffield/lazygit/pull/3022)
- Respect $GIT_WORK_TREE and $GIT_DIR env vars (fix
[#&#8203;3010](https://github.com/jesseduffield/lazygit/issues/3010)).
by [@&#8203;intrntbrn](https://github.com/intrntbrn) in
[https://github.com/jesseduffield/lazygit/pull/3024](https://github.com/jesseduffield/lazygit/pull/3024)
- Fix crash when trying to filter the list of remotes by
[@&#8203;stefanhaller](https://github.com/stefanhaller) in
[https://github.com/jesseduffield/lazygit/pull/3059](https://github.com/jesseduffield/lazygit/pull/3059)
- Re-apply filter when model changes by
[@&#8203;stefanhaller](https://github.com/stefanhaller) in
[https://github.com/jesseduffield/lazygit/pull/3058](https://github.com/jesseduffield/lazygit/pull/3058)
- Use a PTY when calling external diff command by
[@&#8203;AFutureD](https://github.com/AFutureD) in
[https://github.com/jesseduffield/lazygit/pull/3120](https://github.com/jesseduffield/lazygit/pull/3120)
- Re-enable 'Unset upstream' option when upstream branch is missing by
[@&#8203;mark2185](https://github.com/mark2185) in
[https://github.com/jesseduffield/lazygit/pull/3086](https://github.com/jesseduffield/lazygit/pull/3086)
- Fall back to WithWaitingStatus if item is not visible by
[@&#8203;stefanhaller](https://github.com/stefanhaller) in
[https://github.com/jesseduffield/lazygit/pull/3083](https://github.com/jesseduffield/lazygit/pull/3083)
- Fix checking out a tag when there is a branch with the same name by
[@&#8203;stefanhaller](https://github.com/stefanhaller) in
[https://github.com/jesseduffield/lazygit/pull/3179](https://github.com/jesseduffield/lazygit/pull/3179)
- Fix preserving the commit message when description contains blank
lines by [@&#8203;stefanhaller](https://github.com/stefanhaller) in
[https://github.com/jesseduffield/lazygit/pull/3170](https://github.com/jesseduffield/lazygit/pull/3170)
- Allow multiple fetch commands (or fetch and pull) to run concurrently
by [@&#8203;stefanhaller](https://github.com/stefanhaller) in
[https://github.com/jesseduffield/lazygit/pull/3202](https://github.com/jesseduffield/lazygit/pull/3202)
- Support insteadOf URL rewriting when opening URLs in browser by
[@&#8203;stefanhaller](https://github.com/stefanhaller) in
[https://github.com/jesseduffield/lazygit/pull/3177](https://github.com/jesseduffield/lazygit/pull/3177)
- Fix keybindings for characters involving AltGr on Windows by
[@&#8203;stefanhaller](https://github.com/stefanhaller) in
[https://github.com/jesseduffield/lazygit/pull/3194](https://github.com/jesseduffield/lazygit/pull/3194)
- Do not include keybindings from another view in keybindings menu by
[@&#8203;jesseduffield](https://github.com/jesseduffield) in
[https://github.com/jesseduffield/lazygit/pull/3220](https://github.com/jesseduffield/lazygit/pull/3220)
- Fix crash with short branch names by
[@&#8203;stefanhaller](https://github.com/stefanhaller) in
[https://github.com/jesseduffield/lazygit/pull/3219](https://github.com/jesseduffield/lazygit/pull/3219)
- Keep same branch selected when fetching a branch while sorted by date
by [@&#8203;stefanhaller](https://github.com/stefanhaller) in
[https://github.com/jesseduffield/lazygit/pull/3186](https://github.com/jesseduffield/lazygit/pull/3186)
- Use git rev-parse to obtain repository and worktree paths by
[@&#8203;jwhitley](https://github.com/jwhitley) in
[https://github.com/jesseduffield/lazygit/pull/3183](https://github.com/jesseduffield/lazygit/pull/3183)
- Pass absolute file paths to all editor commands by
[@&#8203;stefanhaller](https://github.com/stefanhaller) in
[https://github.com/jesseduffield/lazygit/pull/3255](https://github.com/jesseduffield/lazygit/pull/3255)
- Disallow cherry-picking merge commits by
[@&#8203;stefanhaller](https://github.com/stefanhaller) in
[https://github.com/jesseduffield/lazygit/pull/3316](https://github.com/jesseduffield/lazygit/pull/3316)
- Fix two problems related to update-ref rebase todo items by
[@&#8203;stefanhaller](https://github.com/stefanhaller) in
[https://github.com/jesseduffield/lazygit/pull/3290](https://github.com/jesseduffield/lazygit/pull/3290)
- Fix order of custom commands history by
[@&#8203;stefanhaller](https://github.com/stefanhaller) in
[https://github.com/jesseduffield/lazygit/pull/3286](https://github.com/jesseduffield/lazygit/pull/3286)
- Fix some problems with patches if `git diff` was customized with
config (e.g. `external` or `noprefix`). by
[@&#8203;mricherzhagen](https://github.com/mricherzhagen) in
[https://github.com/jesseduffield/lazygit/pull/3222](https://github.com/jesseduffield/lazygit/pull/3222)
- Use $XDG_STATE_HOME for state.yml by
[@&#8203;horriblename](https://github.com/horriblename) in
[https://github.com/jesseduffield/lazygit/pull/2936](https://github.com/jesseduffield/lazygit/pull/2936)
- Fix display of Chinese characters on Windows by
[@&#8203;stefanhaller](https://github.com/stefanhaller) in
[https://github.com/jesseduffield/lazygit/pull/3352](https://github.com/jesseduffield/lazygit/pull/3352)
- Allow more than one argument in git.merging.args config by
[@&#8203;stefanhaller](https://github.com/stefanhaller) in
[https://github.com/jesseduffield/lazygit/pull/3336](https://github.com/jesseduffield/lazygit/pull/3336)
- Don't strike out reserved keys in menus by
[@&#8203;stefanhaller](https://github.com/stefanhaller) in
[https://github.com/jesseduffield/lazygit/pull/3365](https://github.com/jesseduffield/lazygit/pull/3365)
- Don't ask to force-push if the remote rejected updates by
[@&#8203;stefanhaller](https://github.com/stefanhaller) in
[https://github.com/jesseduffield/lazygit/pull/3387](https://github.com/jesseduffield/lazygit/pull/3387)
- Fix container detection by
[@&#8203;aritmos](https://github.com/aritmos) in
[https://github.com/jesseduffield/lazygit/pull/3412](https://github.com/jesseduffield/lazygit/pull/3412)

##### Maintenance ⚙️

- Add Click() to GuiDriver by
[@&#8203;simonwhitaker](https://github.com/simonwhitaker) in
[https://github.com/jesseduffield/lazygit/pull/2898](https://github.com/jesseduffield/lazygit/pull/2898)
- Add Makefile by [@&#8203;kyu08](https://github.com/kyu08) in
[https://github.com/jesseduffield/lazygit/pull/2937](https://github.com/jesseduffield/lazygit/pull/2937)
- fix GitHub Actions warnings by
[@&#8203;kyu08](https://github.com/kyu08) in
[https://github.com/jesseduffield/lazygit/pull/2950](https://github.com/jesseduffield/lazygit/pull/2950)
- Add instruction in PR template to start PRs with an imperative by
[@&#8203;jesseduffield](https://github.com/jesseduffield) in
[https://github.com/jesseduffield/lazygit/pull/2967](https://github.com/jesseduffield/lazygit/pull/2967)
- Don't show toasts when running integration tests by
[@&#8203;stefanhaller](https://github.com/stefanhaller) in
[https://github.com/jesseduffield/lazygit/pull/2975](https://github.com/jesseduffield/lazygit/pull/2975)
- Various debugging improvements by
[@&#8203;stefanhaller](https://github.com/stefanhaller) in
[https://github.com/jesseduffield/lazygit/pull/3000](https://github.com/jesseduffield/lazygit/pull/3000)
- Rename `test/results` to `test/_results` by
[@&#8203;stefanhaller](https://github.com/stefanhaller) in
[https://github.com/jesseduffield/lazygit/pull/3012](https://github.com/jesseduffield/lazygit/pull/3012)
- Support passing -race flag to integration tests by
[@&#8203;stefanhaller](https://github.com/stefanhaller) in
[https://github.com/jesseduffield/lazygit/pull/3019](https://github.com/jesseduffield/lazygit/pull/3019)
- Improve debugging of integration tests by
[@&#8203;stefanhaller](https://github.com/stefanhaller) in
[https://github.com/jesseduffield/lazygit/pull/3029](https://github.com/jesseduffield/lazygit/pull/3029)
- Use go:generate for cheatsheet by
[@&#8203;stefanhaller](https://github.com/stefanhaller) in
[https://github.com/jesseduffield/lazygit/pull/3035](https://github.com/jesseduffield/lazygit/pull/3035)
- Change Makefile to build non-optimized by
[@&#8203;stefanhaller](https://github.com/stefanhaller) in
[https://github.com/jesseduffield/lazygit/pull/3028](https://github.com/jesseduffield/lazygit/pull/3028)
- Update PR template to use go generate command by
[@&#8203;jesseduffield](https://github.com/jesseduffield) in
[https://github.com/jesseduffield/lazygit/pull/3041](https://github.com/jesseduffield/lazygit/pull/3041)
- Band-aid fix for submodule/reset.go test failure by
[@&#8203;stefanhaller](https://github.com/stefanhaller) in
[https://github.com/jesseduffield/lazygit/pull/3047](https://github.com/jesseduffield/lazygit/pull/3047)
- Remove redundant `len` check by
[@&#8203;Juneezee](https://github.com/Juneezee) in
[https://github.com/jesseduffield/lazygit/pull/3051](https://github.com/jesseduffield/lazygit/pull/3051)
- Add disabled compat for user config
([#&#8203;2833](https://github.com/jesseduffield/lazygit/issues/2833))
by [@&#8203;karimkhaleel](https://github.com/karimkhaleel) in
[https://github.com/jesseduffield/lazygit/pull/3060](https://github.com/jesseduffield/lazygit/pull/3060)
- Fix go.mod file by
[@&#8203;stefanhaller](https://github.com/stefanhaller) in
[https://github.com/jesseduffield/lazygit/pull/3118](https://github.com/jesseduffield/lazygit/pull/3118)
- Capture test code coverage stats by
[@&#8203;jesseduffield](https://github.com/jesseduffield) in
[https://github.com/jesseduffield/lazygit/pull/3135](https://github.com/jesseduffield/lazygit/pull/3135)
- fixed typo in test description by
[@&#8203;schuebel](https://github.com/schuebel) in
[https://github.com/jesseduffield/lazygit/pull/3101](https://github.com/jesseduffield/lazygit/pull/3101)
-   Update cheatsheets by [@&#8203;stefanhaller](https:

</details>

---

### Configuration

📅 **Schedule**: Branch creation - "after 4pm on thursday" in timezone
America/Los_Angeles, Automerge - At any time (no schedule defined).

🚦 **Automerge**: Enabled.

♻ **Rebasing**: Whenever PR is behind base branch, or you tick the
rebase/retry checkbox.

👻 **Immortal**: This PR will be recreated if closed unmerged. Get
[config help](https://github.com/renovatebot/renovate/discussions) if
that's undesired.

---

- [ ] <!-- rebase-check -->If you want to rebase/retry this PR, check
this box

---

This PR has been generated by [Mend
Renovate](https://www.mend.io/free-developer-tools/renovate/). View
repository job log
[here](https://developer.mend.io/github/scottames/dots).

<!--renovate-debug:eyJjcmVhdGVkSW5WZXIiOiIzNy4yNjEuMCIsInVwZGF0ZWRJblZlciI6IjM3LjI2OS4yIiwidGFyZ2V0QnJhbmNoIjoibWFpbiJ9-->

---------

Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
Co-authored-by: scottames-github-bot[bot] <162828115+scottames-github-bot[bot]@users.noreply.github.com>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
enhancement New feature or request
Projects
None yet
Development

Successfully merging this pull request may close these issues.

None yet

3 participants