-
-
Notifications
You must be signed in to change notification settings - Fork 1.9k
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
Add range selection ability on list contexts #3207
Conversation
Coverage summary from CodacySee diff coverage on Codacy
Coverage variation details
Coverage variation is the difference between the coverage for the head and common ancestor commits of the pull request branch: Diff coverage details
Diff coverage is the percentage of lines that are covered by tests out of the coverable lines that the pull request added or modified: See your quality gate settings Change summary preferencesYou may notice some variations in coverage metrics with the latest Coverage engine update. For more details, visit the documentation |
2c16d46
to
0dd2d33
Compare
@stefanhaller you mentioned you have an upcoming branch that touches a lot of controller keybinding definitions, relating to GetDisabledReason. I need to add a bunch of checks for there only being a single item selected. Do you have any preference for how I do that? One idea that comes to mind which should minimise conflicts for now is to add a SingleItemOnly field to the keybinding struct: handle that in |
8c3feae
to
53e6fca
Compare
Don't worry about conflicts at this point. That branch is sufficiently out of date already that I will probably have to redo it anyway, and that's no problem for me. Also, most of the work I wanted to do on that branch is adding disabled reasons for things like "is there a selected commit" checks, and it sounds like you are going to have to do that work anyway for the range selection feature. Let me know if that's not your understanding, or if you'd like us to devide up the work somehow.
This doesn't feel right to me, as this field would only be meaningful for list views. I'd rather suggest to extend your new |
Sounds good to me |
@stefanhaller See the latest WIP commit I've copied over your DisabledReason struct definition (though not the part about checking the bool field) and I've created a ListControllerTrait struct to define helper functions like |
Very nice. I read the rest of the branch, great improvements there. Looking forward to having this on master. When testing it though, it crashed on me when pressing 'e' or 'i' in the local commits panel (consistently, it seems). No time to investigate, sorry... |
73710b7
to
117c25d
Compare
Coverage summary from CodacySee diff coverage on Codacy
Coverage variation details
Coverage variation is the difference between the coverage for the head and common ancestor commits of the pull request branch: Diff coverage details
Diff coverage is the percentage of lines that are covered by tests out of the coverable lines that the pull request added or modified: See your quality gate settings Change summary preferencesYou may notice some variations in coverage metrics with the latest Coverage engine update. For more details, visit the documentation |
8a8072a
to
38d7523
Compare
@stefanhaller this is ready for review now. I've fixed the issue with the e/i keybindings |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Really great. Unfortunately I don't have time for an in-depth look at every hunk, but I'm sure we can fix little things later if we find any after merging. The general direction is awesome.
A few random thoughts below.
If we're thinking about cutting a release soon, I think we should try to support a few more commands before we do; right now it looks a bit embarrassing to be able to select ranges everywhere but not be able to do anything with them (almost).
@@ -50,6 +50,13 @@ func Max(x, y int) int { | |||
return y | |||
} | |||
|
|||
func MinMax(x int, y int) (int, int) { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Not a very intuitive name, I had to look at the implementation to figure out what it does. How about SortRange
?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Done
// asserts on the selected line of the view. If you are selecting a range, | ||
// you should use the SelectedLines method instead. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Don't we want this to fail the test if it's called while there's a selection range?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Good point
@@ -165,7 +165,6 @@ func (self *BranchesController) viewUpstreamOptions(selectedBranch *models.Branc | |||
ShowBranchHeads: false, | |||
}) | |||
}, | |||
Key: 'v', |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I don't have a problem with removing this, I always use u enter
to invoke it. I wonder though: shouldn't it be possible to override the global key locally? This is a menu, there's no reason to do a range selection there.
Also, I really think we want to disable selecting ranges for menus. Most people probably won't even try, but if you do, it looks confusing, and there's really no reason.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I think that 'v' will be for range-select in pretty much all contexts, meaning that if we use it for something else in some situations, it will be confusing, so I think we should avoid using it in any local context for something else.
As for disabling range select in menus, I agree.
997e587
to
731bd8c
Compare
I agree, I've got some of that implemented already but didn't want to bloat out this PR more than it already is. Something else I just noticed: on master, if you're selecting hunks in the patch building view, then when you escape and go to another file, hunk-selection mode is still enabled. In this PR, you press escape to go back to line select mode, then escape again to escape the view, meaning if you wanted to stage multiple files hunk-by-hunk, you'll need to press 'a' each time you go to the next file. Funnily on master the staging view does not persist selection mode across files. I'm not sure whether we should be persisting it though: my current plan is to have escape always take you from hunk/range mode back to line mode, and see if anybody cares. Thoughts? |
Also, integration tests are failing but github reports them as succeeding: https://github.com/jesseduffield/lazygit/actions/runs/7526670716/job/20485285388?pr=3207 No idea what caused that: ci.yml hasn't changed in a while. |
731bd8c
to
faab1ab
Compare
I like the change to make hunk mode less sticky. I usually only turn it on temporarily, and it has bothered me sometimes that it was still on next time. Also, once people discover how easy it is to select a range using shift-arrow, I expect them to use that instead of hunk mode more often. I know I do. |
@@ -187,6 +187,7 @@ func (self *BranchesController) viewUpstreamOptions(selectedBranch *models.Branc | |||
ShowBranchHeads: false, | |||
}) | |||
}, | |||
Key: 'v', |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Huh? Did this come back accidentally?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Yes it did haha. I re-introduced it to ensure that if we wanted, we could set 'v' as a key in a menu item. I'll remove it again given that we don't want to do that.
b55c526
to
fc2120c
Compare
Here's a thought about integration tests involving selection ranges. Consider this test fragment:
This succeeds, which I find unexpected. In fact, any combination of putting the I wonder if we can make it so that once you put an Alternatively, we could make it so that |
Yep, I was thinking the same thing. We should definitely make it that if you say you want one to be selected, it's implied that all others must be non-selected. As for whether we should always require the selection to be specified: I think we'd need to see if on net that makes things more noisy or not. We certainly wouldn't want to enforce it for views which aren't focused, but for views which are focused, it's possible that it makes tests more readable and clear on average. This PR is large enough for now and I've got some follow-up PRs on the way so I'm going to merge this now the test code change can come in a separate PR |
No idea why these were hidden in the first place
This adds range select ability in two ways: 1) Sticky: like what we already have with the staging view i.e. press v then use arrow keys 2) Non-sticky: where you just use shift+up/down to expand the range The state machine works like this: (no range, press 'v') -> sticky range (no range, press arrow) -> no range (no range, press shift+arrow) -> nonsticky range (sticky range, press 'v') -> no range (sticky range, press arrow) -> sticky range (sticky range, press shift+arrow) -> nonsticky range (nonsticky range, press 'v') -> no range (nonsticky range, press arrow) -> no range (nonsticky range, press shift+arrow) -> nonsticky range
We're not fully standardising here: different contexts can store their range state however they like. What we are standardising on is that now the view is always responsible for highlighting the selected lines, meaning the context/controller needs to tell the view where the range start is. Two convenient benefits from this change: 1) we no longer need bespoke code in integration tests for asserting on selected lines because we can just ask the view 2) line selection in staging/patch-building/merge-conflicts views now look the same as in list views i.e. the highlight applies to the whole line (including trailing space) I also noticed a bug with merge conflicts not rendering the selection on focus though I suspect it wasn't a bug with any real consequences when the view wasn't displaying the selection. I'm going to scrap the selectedRangeBgColor config and just let it use the single line background color. Hopefully nobody cares, but there's really no need for an extra config.
This is the highest priority of the escape actions because it's the thing you're most likely to want to do upon hitting escape if you have a range selected. Applying this to the staging/patch-building views is tricky: if we want this logic for when a range of lines is selected, we'll also need to apply it when a hunk is selected too. I still think it's worth it though: I've often accidentally escaped from the staging view when trying to cancel a range selection.
We can no longer use this because 'v' is globally reserved for range select. Conveniently it was the first item in the menu anyway for both of these.
The only time we should call SetSelectedLineIdx is when we are happy for a select range to be retained which means things like moving the selected line index to top top/bottom or up/down a page as the user navigates. But in every other case we should now call SetSelection because that will set the selected index and cancel the range which is almost always what we want.
fc2120c
to
7dca983
Compare
Coverage summary from CodacySee diff coverage on Codacy
Coverage variation details
Coverage variation is the difference between the coverage for the head and common ancestor commits of the pull request branch: Diff coverage details
Diff coverage is the percentage of lines that are covered by tests out of the coverable lines that the pull request added or modified: See your quality gate settings Change summary preferencesYou may notice some variations in coverage metrics with the latest Coverage engine update. For more details, visit the documentation Footnotes
|
This requires us to change the 'v' keybinding for paste to something else, now that 'v' is used globally for toggling range select. So I'm using 'shift+v' and I'm likewise changing 'c' to 'shift+c' for copying, so that they're consistent. We will need to clearly communicate this change in keybindings.
We want to show an error when the user tries to invoke an action that expects only a single item to be selected. We're using the GetDisabledReason field to enforce this (as well as DisabledReason on menu items). I've created a ListControllerTrait to store some shared convenience functions for this.
We don't need it there so no need to enable it. I'm leaving the disabled reason checks there, even though they're now redundant, because they're only one-liners and they communicate intent.
Often if a test fails and there's an unaknowledged toast message, that message will explain why the test failed. Given that we don't display toast messages in integration tests when they run (for reasons I can't recall right now), we need to log it as part of the error message.
7dca983
to
ab3004b
Compare
[![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://togithub.com/aquaproj/aqua-registry) | minor | `v4.154.0` -> `v4.155.1` | | [cli/cli](https://togithub.com/cli/cli) | minor | `v2.45.0` -> `v2.46.0` | | [derailed/k9s](https://togithub.com/derailed/k9s) | patch | `v0.32.3` -> `v0.32.4` | | [eza-community/eza](https://togithub.com/eza-community/eza) | patch | `v0.18.7` -> `v0.18.8` | | [golangci/golangci-lint](https://togithub.com/golangci/golangci-lint) | minor | `v1.56.2` -> `v1.57.1` | | [gruntwork-io/terragrunt](https://togithub.com/gruntwork-io/terragrunt) | patch | `v0.55.16` -> `v0.55.20` | | [jesseduffield/lazygit](https://togithub.com/jesseduffield/lazygit) | minor | `v0.40.2` -> `v0.41.0` | | [junegunn/fzf](https://togithub.com/junegunn/fzf) | patch | `0.48.0` -> `0.48.1` | | [lsd-rs/lsd](https://togithub.com/lsd-rs/lsd) | minor | `v1.0.0` -> `v1.1.2` | | [mikefarah/yq](https://togithub.com/mikefarah/yq) | minor | `v4.42.1` -> `v4.43.1` | | [simulot/immich-go](https://togithub.com/simulot/immich-go) | minor | `0.12.0` -> `0.13.0` | | [snyk/cli](https://togithub.com/snyk/cli) | minor | `v1.1284.0` -> `v1.1286.0` | | [starship/starship](https://togithub.com/starship/starship) | minor | `v1.17.1` -> `v1.18.1` | | [twpayne/chezmoi](https://togithub.com/twpayne/chezmoi) | patch | `v2.47.1` -> `v2.47.2` | | [weaveworks/eksctl](https://togithub.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://togithub.com/aquaproj/aqua-registry/releases/tag/v4.155.1) [Compare Source](https://togithub.com/aquaproj/aqua-registry/compare/v4.155.0...v4.155.1) [Issues](https://togithub.com/aquaproj/aqua-registry/issues?q=is%3Aissue+milestone%3Av4.155.0) | [Pull Requests](https://togithub.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 [#​21239](https://togithub.com/aquaproj/aqua-registry/issues/21239) Rename the package crates.io/shellharden to anordal/shellharden [@​hituzi-no-sippo](https://togithub.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://togithub.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/shellharden@v4.3.1 > ``` > > Note that Renovate will update crates.io/shellharden to crates.io/shellharden@4.3.1, but it wouldn't work. > You have to change the version to `v4.3.1`. ### [`v4.155.0`](https://togithub.com/aquaproj/aqua-registry/releases/tag/v4.155.0) [Compare Source](https://togithub.com/aquaproj/aqua-registry/compare/v4.154.0...v4.155.0) [Issues](https://togithub.com/aquaproj/aqua-registry/issues?q=is%3Aissue+milestone%3Av4.154.0) | [Pull Requests](https://togithub.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 [#​21127](https://togithub.com/aquaproj/aqua-registry/issues/21127) [ynqa/jnv](https://togithub.com/ynqa/jnv): interactive JSON filter using jq [@​ponkio-o](https://togithub.com/ponkio-o) [#​21079](https://togithub.com/aquaproj/aqua-registry/issues/21079) [zaghaghi/openapi-tui](https://togithub.com/zaghaghi/openapi-tui): Terminal UI to list, browse and run APIs defined with openapi spec [@​wancup](https://togithub.com/wancup) #### Fixes [#​21122](https://togithub.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 [#​21062](https://togithub.com/aquaproj/aqua-registry/issues/21062) [#​21063](https://togithub.com/aquaproj/aqua-registry/issues/21063) [#​21064](https://togithub.com/aquaproj/aqua-registry/issues/21064) [#​21065](https://togithub.com/aquaproj/aqua-registry/issues/21065) [#​21066](https://togithub.com/aquaproj/aqua-registry/issues/21066) Transfer [k0kubun/xremap/\*](https://togithub.com/k0kubun/xremap) to [xremap/xremap/\*](https://togithub.com/xremap/xremap) The GitHub Repository of the package "k0kubun/xremap/hypr" was transferred from [k0kubun/xremap](https://togithub.com/k0kubun/xremap) to [xremap/xremap](https://togithub.com/xremap/xremap) </details> <details> <summary>cli/cli (cli/cli)</summary> ### [`v2.46.0`](https://togithub.com/cli/cli/releases/tag/v2.46.0): GitHub CLI 2.46.0 [Compare Source](https://togithub.com/cli/cli/compare/v2.45.0...v2.46.0) #### What's Changed - Draft issue IDs are included in `project item-list` output by [@​yasunori0418](https://togithub.com/yasunori0418) in [https://github.com/cli/cli/pull/8754](https://togithub.com/cli/cli/pull/8754) - New `--dry-run` option for `pr create` by [@​v1v](https://togithub.com/v1v) in [https://github.com/cli/cli/pull/8376](https://togithub.com/cli/cli/pull/8376) - Bump go-keyring to fix race condition by [@​williammartin](https://togithub.com/williammartin) in [https://github.com/cli/cli/pull/8833](https://togithub.com/cli/cli/pull/8833) - PR numbers are prefixed with owner/repo for context by [@​nobe4](https://togithub.com/nobe4) in [https://github.com/cli/cli/pull/8778](https://togithub.com/cli/cli/pull/8778) - Extra word removed in `codespaces` code comments by [@​cuinix](https://togithub.com/cuinix) in [https://github.com/cli/cli/pull/8795](https://togithub.com/cli/cli/pull/8795) - Clarified description of the `-u`, `--user` option for `gh auth token` by [@​gregsmi](https://togithub.com/gregsmi) in [https://github.com/cli/cli/pull/8797](https://togithub.com/cli/cli/pull/8797) - Fixed formatting for the description of `release upload` by [@​malor](https://togithub.com/malor) in [https://github.com/cli/cli/pull/8834](https://togithub.com/cli/cli/pull/8834) - Clarified the usage of `auth status` to list all authenticated accounts by [@​jsoref](https://togithub.com/jsoref) in [https://github.com/cli/cli/pull/8838](https://togithub.com/cli/cli/pull/8838) - Document auth switch behavior for two or more accounts by [@​williammartin](https://togithub.com/williammartin) in [https://github.com/cli/cli/pull/8839](https://togithub.com/cli/cli/pull/8839) - Document run watch and view not supporting fine grained PATs by [@​williammartin](https://togithub.com/williammartin) in [https://github.com/cli/cli/pull/8843](https://togithub.com/cli/cli/pull/8843) - build(deps): bump google.golang.org/protobuf from 1.30.0 to 1.33.0 by [@​dependabot](https://togithub.com/dependabot) in [https://github.com/cli/cli/pull/8811](https://togithub.com/cli/cli/pull/8811) - build(deps): bump github.com/cpuguy83/go-md2man/v2 from 2.0.3 to 2.0.4 by [@​dependabot](https://togithub.com/dependabot) in [https://github.com/cli/cli/pull/8844](https://togithub.com/cli/cli/pull/8844) #### New Contributors - [@​cuinix](https://togithub.com/cuinix) made their first contribution in [https://github.com/cli/cli/pull/8795](https://togithub.com/cli/cli/pull/8795) - [@​gregsmi](https://togithub.com/gregsmi) made their first contribution in [https://github.com/cli/cli/pull/8797](https://togithub.com/cli/cli/pull/8797) - [@​nobe4](https://togithub.com/nobe4) made their first contribution in [https://github.com/cli/cli/pull/8778](https://togithub.com/cli/cli/pull/8778) - [@​malor](https://togithub.com/malor) made their first contribution in [https://github.com/cli/cli/pull/8834](https://togithub.com/cli/cli/pull/8834) - [@​yasunori0418](https://togithub.com/yasunori0418) made their first contribution in [https://github.com/cli/cli/pull/8754](https://togithub.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://togithub.com/derailed/k9s/releases/tag/v0.32.4) [Compare Source](https://togithub.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://togithub.com/sponsors/derailed) and/or make some noise on social! [@​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 - [#​2608](https://togithub.com/derailed/k9s/issues/2608) Make the sanitize feature easier to use - [#​2605](https://togithub.com/derailed/k9s/issues/2605) Built-in shortcuts being overridden by plugins result in excessive logging - [#​2604](https://togithub.com/derailed/k9s/issues/2604) Ability to mark a plugin as Dangerous/destructive - [#​2592](https://togithub.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!! - [#​2621](https://togithub.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://togithub.com/eza-community/eza/releases/tag/v0.18.8): eza v0.18.8 [Compare Source](https://togithub.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://togithub.com/golangci/golangci-lint/releases/tag/v1.57.1) [Compare Source](https://togithub.com/golangci/golangci-lint/compare/v1.57.0...v1.57.1) #### Changelog - [`87b6bf1`](https://togithub.com/golangci/golangci-lint/commit/87b6bf17) build(deps): bump github.com/golangci/plugin-module-register from 0.1.0 to 0.1.1 ([#​4549](https://togithub.com/golangci/golangci-lint/issues/4549)) - [`921d535`](https://togithub.com/golangci/golangci-lint/commit/921d5357) build(deps): bump github.com/pelletier/go-toml/v2 from 2.1.1 to 2.2.0 ([#​4548](https://togithub.com/golangci/golangci-lint/issues/4548)) - [`cd890db`](https://togithub.com/golangci/golangci-lint/commit/cd890db2) fix: filter invalid issues before other processors ([#​4552](https://togithub.com/golangci/golangci-lint/issues/4552)) ### [`v1.57.0`](https://togithub.com/golangci/golangci-lint/compare/v1.56.2...v1.57.0) [Compare Source](https://togithub.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://togithub.com/gruntwork-io/terragrunt/compare/v0.55.19...v0.55.20) [Compare Source](https://togithub.com/gruntwork-io/terragrunt/compare/v0.55.19...v0.55.20) ### [`v0.55.19`](https://togithub.com/gruntwork-io/terragrunt/releases/tag/v0.55.19) [Compare Source](https://togithub.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://togithub.com/gruntwork-io/terragrunt/pull/3010) - [https://github.com/gruntwork-io/terragrunt/pull/3005](https://togithub.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://togithub.com/gruntwork-io/terragrunt/releases/tag/v0.55.18) [Compare Source](https://togithub.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://togithub.com/gruntwork-io/terragrunt/pull/2995) - [https://github.com/gruntwork-io/terragrunt/pull/2996](https://togithub.com/gruntwork-io/terragrunt/pull/2996) - [https://github.com/gruntwork-io/terragrunt/pull/2929](https://togithub.com/gruntwork-io/terragrunt/pull/2929) - [https://github.com/gruntwork-io/terragrunt/pull/3000](https://togithub.com/gruntwork-io/terragrunt/pull/3000) - [https://github.com/gruntwork-io/terragrunt/pull/3009](https://togithub.com/gruntwork-io/terragrunt/pull/3009) ### [`v0.55.17`](https://togithub.com/gruntwork-io/terragrunt/releases/tag/v0.55.17) [Compare Source](https://togithub.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://togithub.com/gruntwork-io/terragrunt/pull/2961) </details> <details> <summary>jesseduffield/lazygit (jesseduffield/lazygit)</summary> ### [`v0.41.0`](https://togithub.com/jesseduffield/lazygit/releases/tag/v0.41.0) [Compare Source](https://togithub.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://togithub.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 [@​afhoffman](https://togithub.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 [@​stefanhaller](https://togithub.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 [@​stefanhaller](https://togithub.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 [@​stefanhaller](https://togithub.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 [@​stefanhaller](https://togithub.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://togithub.com/jesseduffield/lazygit/blob/master/docs/Fixup_Commits.md#finding-the-commit-to-create-a-fixup-for) Thanks to [@​stefanhaller](https://togithub.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 [@​AzraelSec](https://togithub.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 [@​omaussa](https://togithub.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 [@​Part22](https://togithub.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 [@​hosaka](https://togithub.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 [@​jwhitley](https://togithub.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 ([@​stefanhaller](https://togithub.com/stefanhaller)) - Error toasts now appear for some errors (less intrusive than popups) ([@​stefanhaller](https://togithub.com/stefanhaller)) - Search history is now retained ([@​karimkhaleel](https://togithub.com/karimkhaleel)) - Git log is shown by default ([@​stefanhaller](https://togithub.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 [@​jesseduffield](https://togithub.com/jesseduffield) in [https://github.com/jesseduffield/lazygit/pull/3207](https://togithub.com/jesseduffield/lazygit/pull/3207) - Allow deleting remote tags/branches from local tag/branch views by [@​AzraelSec](https://togithub.com/AzraelSec) in [https://github.com/jesseduffield/lazygit/pull/2738](https://togithub.com/jesseduffield/lazygit/pull/2738) - Add command to show divergence from upstream by [@​stefanhaller](https://togithub.com/stefanhaller) in [https://github.com/jesseduffield/lazygit/pull/2871](https://togithub.com/jesseduffield/lazygit/pull/2871) - Add 'Quick start interactive rebase' action by [@​jesseduffield](https://togithub.com/jesseduffield) in [https://github.com/jesseduffield/lazygit/pull/3213](https://togithub.com/jesseduffield/lazygit/pull/3213) - Add command to open git difftool by [@​stefanhaller](https://togithub.com/stefanhaller) in [https://github.com/jesseduffield/lazygit/pull/3156](https://togithub.com/jesseduffield/lazygit/pull/3156) - Support editing files in existing neovim instance by [@​jesseduffield](https://togithub.com/jesseduffield) in [https://github.com/jesseduffield/lazygit/pull/2916](https://togithub.com/jesseduffield/lazygit/pull/2916) - Show commit mark before showing extra info by [@​jesseduffield](https://togithub.com/jesseduffield) in [https://github.com/jesseduffield/lazygit/pull/2928](https://togithub.com/jesseduffield/lazygit/pull/2928) - Jump to middle of the view when selection leaves the visible area by [@​stefanhaller](https://togithub.com/stefanhaller) in [https://github.com/jesseduffield/lazygit/pull/2915](https://togithub.com/jesseduffield/lazygit/pull/2915) - Add emacs-keybinds for word navigation by [@​horriblename](https://togithub.com/horriblename) in [https://github.com/jesseduffield/lazygit/pull/2935](https://togithub.com/jesseduffield/lazygit/pull/2935) - Add `gui.scrollOffBehavior` config for scrolling list views by half-pages by [@​stefanhaller](https://togithub.com/stefanhaller) in [https://github.com/jesseduffield/lazygit/pull/2939](https://togithub.com/jesseduffield/lazygit/pull/2939) - Switch to editor from commit message panel by [@​stefanhaller](https://togithub.com/stefanhaller) in [https://github.com/jesseduffield/lazygit/pull/2881](https://togithub.com/jesseduffield/lazygit/pull/2881) - Select same commit again after pressing "e" to edit a commit by [@​stefanhaller](https://togithub.com/stefanhaller) in [https://github.com/jesseduffield/lazygit/pull/2954](https://togithub.com/jesseduffield/lazygit/pull/2954) - Support custom keybindings for confirm discard by [@​mskelton](https://togithub.com/mskelton) in [https://github.com/jesseduffield/lazygit/pull/2960](https://togithub.com/jesseduffield/lazygit/pull/2960) - Allow adding a port to webDomain part of services config by [@​raidora](https://togithub.com/raidora) in [https://github.com/jesseduffield/lazygit/pull/2908](https://togithub.com/jesseduffield/lazygit/pull/2908) - Add icons for files with .mdx and .svelte file extensions by [@​hrstmr](https://togithub.com/hrstmr) in [https://github.com/jesseduffield/lazygit/pull/2889](https://togithub.com/jesseduffield/lazygit/pull/2889) - Section headers in keybindings menu by [@​stefanhaller](https://togithub.com/stefanhaller) in [https://github.com/jesseduffield/lazygit/pull/2911](https://togithub.com/jesseduffield/lazygit/pull/2911) - Check for staged files for "Amend commit" and "Create fixup commit" by [@​stefanhaller](https://togithub.com/stefanhaller) in [https://github.com/jesseduffield/lazygit/pull/2970](https://togithub.com/jesseduffield/lazygit/pull/2970) - Add support for external diff commands (e.g. difftastic) by [@​stefanhaller](https://togithub.com/stefanhaller) in [https://github.com/jesseduffield/lazygit/pull/2868](https://togithub.com/jesseduffield/lazygit/pull/2868) - Save diff context size in state.yml instead of config.yml by [@​stefanhaller](https://togithub.com/stefanhaller) in [https://github.com/jesseduffield/lazygit/pull/2969](https://togithub.com/jesseduffield/lazygit/pull/2969) - Support to reset the current branch to a selected branch upstream by [@​AzraelSec](https://togithub.com/AzraelSec) in [https://github.com/jesseduffield/lazygit/pull/2940](https://togithub.com/jesseduffield/lazygit/pull/2940) - Replace whitespace with '-' when renaming a branch by [@​calthejuggler](https://togithub.com/calthejuggler) in [https://github.com/jesseduffield/lazygit/pull/2990](https://togithub.com/jesseduffield/lazygit/pull/2990) - Add jump-to-panel label config setting by [@​MariaSolOs](https://togithub.com/MariaSolOs) in [https://github.com/jesseduffield/lazygit/pull/2993](https://togithub.com/jesseduffield/lazygit/pull/2993) - Add co-author to commits by [@​omaussa](https://togithub.com/omaussa) in [https://github.com/jesseduffield/lazygit/pull/2912](https://togithub.com/jesseduffield/lazygit/pull/2912) - Change the default of the "gui.borders" config to "rounded" by [@​stefanhaller](https://togithub.com/stefanhaller) in [https://github.com/jesseduffield/lazygit/pull/2998](https://togithub.com/jesseduffield/lazygit/pull/2998) - Add a DisabledReason mechanism for menu items and keybindings by [@​stefanhaller](https://togithub.com/stefanhaller) in [https://github.com/jesseduffield/lazygit/pull/2992](https://togithub.com/jesseduffield/lazygit/pull/2992) - Allow cherry-picking commits during a rebase by [@​stefanhaller](https://togithub.com/stefanhaller) in [https://github.com/jesseduffield/lazygit/pull/3013](https://togithub.com/jesseduffield/lazygit/pull/3013) - Add history for search view by [@​karimkhaleel](https://togithub.com/karimkhaleel) in [https://github.com/jesseduffield/lazygit/pull/2877](https://togithub.com/jesseduffield/lazygit/pull/2877) - Replace loader panels with waiting status (pull/push/fetch) by [@​stefanhaller](https://togithub.com/stefanhaller) in [https://github.com/jesseduffield/lazygit/pull/2973](https://togithub.com/jesseduffield/lazygit/pull/2973) - Add menu to rebase onto selected branch remote upstream by [@​AzraelSec](https://togithub.com/AzraelSec) in [https://github.com/jesseduffield/lazygit/pull/3020](https://togithub.com/jesseduffield/lazygit/pull/3020) - Add ability to force portrait mode by [@​ldelossa](https://togithub.com/ldelossa) in [https://github.com/jesseduffield/lazygit/pull/3037](https://togithub.com/jesseduffield/lazygit/pull/3037) - Add Micro editor preset by [@​kytta](https://togithub.com/kytta) in [https://github.com/jesseduffield/lazygit/pull/3049](https://togithub.com/jesseduffield/lazygit/pull/3049) - Show sync status in branches list by [@​stefanhaller](https://togithub.com/stefanhaller) in [https://github.com/jesseduffield/lazygit/pull/3021](https://togithub.com/jesseduffield/lazygit/pull/3021) - Add 'lvim' editor preset for lunarvim by [@​zottelsheep](https://togithub.com/zottelsheep) in [https://github.com/jesseduffield/lazygit/pull/3074](https://togithub.com/jesseduffield/lazygit/pull/3074) - Truncate branch names to make branch status always visible by [@​stefanhaller](https://togithub.com/stefanhaller) in [https://github.com/jesseduffield/lazygit/pull/3075](https://togithub.com/jesseduffield/lazygit/pull/3075) - Color file icons by [@​jesseduffield](https://togithub.com/jesseduffield) in [https://github.com/jesseduffield/lazygit/pull/3080](https://togithub.com/jesseduffield/lazygit/pull/3080) - Add UserConfig jsonschema generation script by [@​karimkhaleel](https://togithub.com/karimkhaleel) in [https://github.com/jesseduffield/lazygit/pull/3039](https://togithub.com/jesseduffield/lazygit/pull/3039) - Add a copy-to-clipboard menu to the file view (with `diff` copy options) by [@​AzraelSec](https://togithub.com/AzraelSec) in [https://github.com/jesseduffield/lazygit/pull/3104](https://togithub.com/jesseduffield/lazygit/pull/3104) - Fix bottom line alignment by [@​stefanhaller](https://togithub.com/stefanhaller) in [https://github.com/jesseduffield/lazygit/pull/3076](https://togithub.com/jesseduffield/lazygit/pull/3076) - Make move up/down blocking by [@​stefanhaller](https://togithub.com/stefanhaller) in [https://github.com/jesseduffield/lazygit/pull/2966](https://togithub.com/jesseduffield/lazygit/pull/2966) - Add remote branch sorting menu by [@​hosaka](https://togithub.com/hosaka) in [https://github.com/jesseduffield/lazygit/pull/3171](https://togithub.com/jesseduffield/lazygit/pull/3171) - Add age to stash entries by [@​AzraelSec](https://togithub.com/AzraelSec) in [https://github.com/jesseduffield/lazygit/pull/3174](https://togithub.com/jesseduffield/lazygit/pull/3174) - Add local branch sorting menu by [@​hosaka](https://togithub.com/hosaka) in [https://github.com/jesseduffield/lazygit/pull/3182](https://togithub.com/jesseduffield/lazygit/pull/3182) - Show a friendly error message when starting lazygit from a non-existent cwd by [@​simonwhitaker](https://togithub.com/simonwhitaker) in [https://github.com/jesseduffield/lazygit/pull/3192](https://togithub.com/jesseduffield/lazygit/pull/3192) - Replace copy commit SHA with copy commit subject on the y s keybind in the commits view by [@​karimkhaleel](https://togithub.com/karimkhaleel) in [https://github.com/jesseduffield/lazygit/pull/3188](https://togithub.com/jesseduffield/lazygit/pull/3188) - Add config setting for splitting window vertically in half screen mode by [@​stefanhaller](https://togithub.com/stefanhaller) in [https://github.com/jesseduffield/lazygit/pull/3133](https://togithub.com/jesseduffield/lazygit/pull/3133) - Add command to find base commit for creating a fixup by [@​stefanhaller](https://togithub.com/stefanhaller) in [https://github.com/jesseduffield/lazygit/pull/3105](https://togithub.com/jesseduffield/lazygit/pull/3105) - Show Toast instead of error panel when invoking a disabled command by [@​stefanhaller](https://togithub.com/stefanhaller) in [https://github.com/jesseduffield/lazygit/pull/3180](https://togithub.com/jesseduffield/lazygit/pull/3180) - Show file names in default colour by [@​jesseduffield](https://togithub.com/jesseduffield) in [https://github.com/jesseduffield/lazygit/pull/3081](https://togithub.com/jesseduffield/lazygit/pull/3081) - Add config setting to suppress showing file icons by [@​stefanhaller](https://togithub.com/stefanhaller) in [https://github.com/jesseduffield/lazygit/pull/3216](https://togithub.com/jesseduffield/lazygit/pull/3216) - Support range select for rebase actions by [@​jesseduffield](https://togithub.com/jesseduffield) in [https://github.com/jesseduffield/lazygit/pull/3232](https://togithub.com/jesseduffield/lazygit/pull/3232) - Make range selections created with the mouse non-sticky by [@​stefanhaller](https://togithub.com/stefanhaller) in [https://github.com/jesseduffield/lazygit/pull/3234](https://togithub.com/jesseduffield/lazygit/pull/3234) - Support range select for staging/discarding files by [@​jesseduffield](https://togithub.com/jesseduffield) in [https://github.com/jesseduffield/lazygit/pull/3248](https://togithub.com/jesseduffield/lazygit/pull/3248) - Inline status for fetching remotes by [@​stefanhaller](https://togithub.com/stefanhaller) in [https://github.com/jesseduffield/lazygit/pull/3238](https://togithub.com/jesseduffield/lazygit/pull/3238) - Add shortcuts for filtering files by status by [@​mark2185](https://togithub.com/mark2185) in [https://github.com/jesseduffield/lazygit/pull/3137](https://togithub.com/jesseduffield/lazygit/pull/3137) - Keep same selection range when quick-starting an interactive rebase by [@​stefanhaller](https://togithub.com/stefanhaller) in [https://github.com/jesseduffield/lazygit/pull/3247](https://togithub.com/jesseduffield/lazygit/pull/3247) - Add loads of tooltips by [@​jesseduffield](https://togithub.com/jesseduffield) in [https://github.com/jesseduffield/lazygit/pull/3269](https://togithub.com/jesseduffield/lazygit/pull/3269) - Show better keybinding suggestions by [@​jesseduffield](https://togithub.com/jesseduffield) in [https://github.com/jesseduffield/lazygit/pull/3203](https://togithub.com/jesseduffield/lazygit/pull/3203) - Support selecting file range in patch builder by [@​afhoffman](https://togithub.com/afhoffman) in [https://github.com/jesseduffield/lazygit/pull/3259](https://togithub.com/jesseduffield/lazygit/pull/3259) - Add command to squash all fixups in the current branch by [@​stefanhaller](https://togithub.com/stefanhaller) in [https://github.com/jesseduffield/lazygit/pull/3274](https://togithub.com/jesseduffield/lazygit/pull/3274) - Use slimmer scrollbars by [@​jesseduffield](https://togithub.com/jesseduffield) in [https://github.com/jesseduffield/lazygit/pull/3283](https://togithub.com/jesseduffield/lazygit/pull/3283) - Clear cherry-picked commits after pasting by [@​molejnik88](https://togithub.com/molejnik88) in [https://github.com/jesseduffield/lazygit/pull/3240](https://togithub.com/jesseduffield/lazygit/pull/3240) - Change default of git.log.showGraph to 'always' by [@​stefanhaller](https://togithub.com/stefanhaller) in [https://github.com/jesseduffield/lazygit/pull/3314](https://togithub.com/jesseduffield/lazygit/pull/3314) - Support range select removing files from a commit by [@​afhoffman](https://togithub.com/afhoffman) in [https://github.com/jesseduffield/lazygit/pull/3276](https://togithub.com/jesseduffield/lazygit/pull/3276) - Migrate git.log.showGraph and git.log.order to app state by [@​hosaka](https://togithub.com/hosaka) in [https://github.com/jesseduffield/lazygit/pull/3197](https://togithub.com/jesseduffield/lazygit/pull/3197) - Change "git reset" default to --mixed by [@​stefanhaller](https://togithub.com/stefanhaller) in [https://github.com/jesseduffield/lazygit/pull/3264](https://togithub.com/jesseduffield/lazygit/pull/3264) - Add author filtering to commit view by [@​part22](https://togithub.com/part22) in [https://github.com/jesseduffield/lazygit/pull/3302](https://togithub.com/jesseduffield/lazygit/pull/3302) - Provide two helix presets, one for "helix" and one for "hx" by [@​stefanhaller](https://togithub.com/stefanhaller) in [https://github.com/jesseduffield/lazygit/pull/3346](https://togithub.com/jesseduffield/lazygit/pull/3346) - Don't show branch head on rebase todos if the rebase.updateRefs config is on by [@​stefanhaller](https://togithub.com/stefanhaller) in [https://github.com/jesseduffield/lazygit/pull/3340](https://togithub.com/jesseduffield/lazygit/pull/3340) - Show all submodules recursively by [@​stefanhaller](https://togithub.com/stefanhaller) in [https://github.com/jesseduffield/lazygit/pull/3341](https://togithub.com/jesseduffield/lazygit/pull/3341) - Support setting a range of commits to "edit" outside of a rebase by [@​stefanhaller](https://togithub.com/stefanhaller) in [https://github.com/jesseduffield/lazygit/pull/3370](https://togithub.com/jesseduffield/lazygit/pull/3370) - Adjust selection after squashing fixups by [@​stefanhaller](https://togithub.com/stefanhaller) in [https://github.com/jesseduffield/lazygit/pull/3338](https://togithub.com/jesseduffield/lazygit/pull/3338) - Auto-wrap commit message while typing by [@​stefanhaller](https://togithub.com/stefanhaller) in [https://github.com/jesseduffield/lazygit/pull/3173](https://togithub.com/jesseduffield/lazygit/pull/3173) - Add Co-Author support to new commits by [@​2KAbhishek](https://togithub.com/2KAbhishek) in [https://github.com/jesseduffield/lazygit/pull/3097](https://togithub.com/jesseduffield/lazygit/pull/3097) - Show "breaking changes" message at startup by [@​stefanhaller](https://togithub.com/stefanhaller) in [https://github.com/jesseduffield/lazygit/pull/3377](https://togithub.com/jesseduffield/lazygit/pull/3377) - Allow moving and deleting update-ref todos by [@​stefanhaller](https://togithub.com/stefanhaller) in [https://github.com/jesseduffield/lazygit/pull/3391](https://togithub.com/jesseduffield/lazygit/pull/3391) - When checking out a remote branch by name, ask the user how by [@​stefanhaller](https://togithub.com/stefanhaller) in [https://github.com/jesseduffield/lazygit/pull/3388](https://togithub.com/jesseduffield/lazygit/pull/3388) - Use substring filtering instead of fuzzy filtering by default by [@​stefanhaller](https://togithub.com/stefanhaller) in [https://github.com/jesseduffield/lazygit/pull/3376](https://togithub.com/jesseduffield/lazygit/pull/3376) - Always prompt to return from subprocess if there was an error by [@​stefanhaller](https://togithub.com/stefanhaller) in [https://github.com/jesseduffield/lazygit/pull/3410](https://togithub.com/jesseduffield/lazygit/pull/3410) - When adding a new remote, select it and fetch it by [@​stefanhaller](https://togithub.com/stefanhaller) in [https://github.com/jesseduffield/lazygit/pull/3401](https://togithub.com/jesseduffield/lazygit/pull/3401) - Support editing multiple files at once using range selection by [@​stefanhaller](https://togithub.com/stefanhaller) in [https://github.com/jesseduffield/lazygit/pull/3407](https://togithub.com/jesseduffield/lazygit/pull/3407) - Make it easy to create "amend!" commits by [@​stefanhaller](https://togithub.com/stefanhaller) in [https://github.com/jesseduffield/lazygit/pull/3409](https://togithub.com/jesseduffield/lazygit/pull/3409) - Add config to truncate commit hashes when copying them to the clipboard by [@​stefanhaller](https://togithub.com/stefanhaller) in [https://github.com/jesseduffield/lazygit/pull/3402](https://togithub.com/jesseduffield/lazygit/pull/3402) ##### Fixes 🔧 - Fix issue where explosion effect was out-of-view by [@​jesseduffield](https://togithub.com/jesseduffield) in [https://github.com/jesseduffield/lazygit/pull/2909](https://togithub.com/jesseduffield/lazygit/pull/2909) - Show dialogue when attempting to open info link fails by [@​simonwhitaker](https://togithub.com/simonwhitaker) in [https://github.com/jesseduffield/lazygit/pull/2899](https://togithub.com/jesseduffield/lazygit/pull/2899) - Fix jumping to the correct line from the staging view by [@​stefanhaller](https://togithub.com/stefanhaller) in [https://github.com/jesseduffield/lazygit/pull/2919](https://togithub.com/jesseduffield/lazygit/pull/2919) - Fix sha colors when rebasing by [@​stefanhaller](https://togithub.com/stefanhaller) in [https://github.com/jesseduffield/lazygit/pull/2946](https://togithub.com/jesseduffield/lazygit/pull/2946) - Fix the commit graph display after selection jumps in commits view by [@​stefanhaller](https://togithub.com/stefanhaller) in [https://github.com/jesseduffield/lazygit/pull/2943](https://togithub.com/jesseduffield/lazygit/pull/2943) - Handle trailing slash in worktree path by [@​Krismix1](https://togithub.com/Krismix1) in [https://github.com/jesseduffield/lazygit/pull/2947](https://togithub.com/jesseduffield/lazygit/pull/2947) - Fix escape not cancelling filter mode, but closing the menu instead by [@​stefanhaller](https://togithub.com/stefanhaller) in [https://github.com/jesseduffield/lazygit/pull/2977](https://togithub.com/jesseduffield/lazygit/pull/2977) - Use `Error` method to handle commits url copy from unknown service by [@​AzraelSec](https://togithub.com/AzraelSec) in [https://github.com/jesseduffield/lazygit/pull/3007](https://togithub.com/jesseduffield/lazygit/pull/3007) - Hide waiting status during credentials prompt by [@​stefanhaller](https://togithub.com/stefanhaller) in [https://github.com/jesseduffield/lazygit/pull/3016](https://togithub.com/jesseduffield/lazygit/pull/3016) - Use upstream branch when opening pull requests by [@​mark2185](https://togithub.com/mark2185) in [https://github.com/jesseduffield/lazygit/pull/2693](https://togithub.com/jesseduffield/lazygit/pull/2693) - Fix issue where active search inappropriately changed selected line by [@​jesseduffield](https://togithub.com/jesseduffield) in [https://github.com/jesseduffield/lazygit/pull/3022](https://togithub.com/jesseduffield/lazygit/pull/3022) - Respect $GIT_WORK_TREE and $GIT_DIR env vars (fix [#​3010](https://togithub.com/jesseduffield/lazygit/issues/3010)). by [@​intrntbrn](https://togithub.com/intrntbrn) in [https://github.com/jesseduffield/lazygit/pull/3024](https://togithub.com/jesseduffield/lazygit/pull/3024) - Fix crash when trying to filter the list of remotes by [@​stefanhaller](https://togithub.com/stefanhaller) in [https://github.com/jesseduffield/lazygit/pull/3059](https://togithub.com/jesseduffield/lazygit/pull/3059) - Re-apply filter when model changes by [@​stefanhaller](https://togithub.com/stefanhaller) in [https://github.com/jesseduffield/lazygit/pull/3058](https://togithub.com/jesseduffield/lazygit/pull/3058) - Use a PTY when calling external diff command by [@​AFutureD](https://togithub.com/AFutureD) in [https://github.com/jesseduffield/lazygit/pull/3120](https://togithub.com/jesseduffield/lazygit/pull/3120) - Re-enable 'Unset upstream' option when upstream branch is missing by [@​mark2185](https://togithub.com/mark2185) in [https://github.com/jesseduffield/lazygit/pull/3086](https://togithub.com/jesseduffield/lazygit/pull/3086) - Fall back to WithWaitingStatus if item is not visible by [@​stefanhaller](https://togithub.com/stefanhaller) in [https://github.com/jesseduffield/lazygit/pull/3083](https://togithub.com/jesseduffield/lazygit/pull/3083) - Fix checking out a tag when there is a branch with the same name by [@​stefanhaller](https://togithub.com/stefanhaller) in [https://github.com/jesseduffield/lazygit/pull/3179](https://togithub.com/jesseduffield/lazygit/pull/3179) - Fix preserving the commit message when description contains blank lines by [@​stefanhaller](https://togithub.com/stefanhaller) in [https://github.com/jesseduffield/lazygit/pull/3170](https://togithub.com/jesseduffield/lazygit/pull/3170) - Allow multiple fetch commands (or fetch and pull) to run concurrently by [@​stefanhaller](https://togithub.com/stefanhaller) in [https://github.com/jesseduffield/lazygit/pull/3202](https://togithub.com/jesseduffield/lazygit/pull/3202) - Support insteadOf URL rewriting when opening URLs in browser by [@​stefanhaller](https://togithub.com/stefanhaller) in [https://github.com/jesseduffield/lazygit/pull/3177](https://togithub.com/jesseduffield/lazygit/pull/3177) - Fix keybindings for characters involving AltGr on Windows by [@​stefanhaller](https://togithub.com/stefanhaller) in [https://github.com/jesseduffield/lazygit/pull/3194](https://togithub.com/jesseduffield/lazygit/pull/3194) - Do not include keybindings from another view in keybindings menu by [@​jesseduffield](https://togithub.com/jesseduffield) in [https://github.com/jesseduffield/lazygit/pull/3220](https://togithub.com/jesseduffield/lazygit/pull/3220) - Fix crash with short branch names by [@​stefanhaller](https://togithub.com/stefanhaller) in [https://github.com/jesseduffield/lazygit/pull/3219](https://togithub.com/jesseduffield/lazygit/pull/3219) - Keep same branch selected when fetching a branch while sorted by date by [@​stefanhaller](https://togithub.com/stefanhaller) in [https://github.com/jesseduffield/lazygit/pull/3186](https://togithub.com/jesseduffield/lazygit/pull/3186) - Use git rev-parse to obtain repository and worktree paths by [@​jwhitley](https://togithub.com/jwhitley) in [https://github.com/jesseduffield/lazygit/pull/3183](https://togithub.com/jesseduffield/lazygit/pull/3183) - Pass absolute file paths to all editor commands by [@​stefanhaller](https://togithub.com/stefanhaller) in [https://github.com/jesseduffield/lazygit/pull/3255](https://togithub.com/jesseduffield/lazygit/pull/3255) - Disallow cherry-picking merge commits by [@​stefanhaller](https://togithub.com/stefanhaller) in [https://github.com/jesseduffield/lazygit/pull/3316](https://togithub.com/jesseduffield/lazygit/pull/3316) - Fix two problems related to update-ref rebase todo items by [@​stefanhaller](https://togithub.com/stefanhaller) in [https://github.com/jesseduffield/lazygit/pull/3290](https://togithub.com/jesseduffield/lazygit/pull/3290) - Fix order of custom commands history by [@​stefanhaller](https://togithub.com/stefanhaller) in [https://github.com/jesseduffield/lazygit/pull/3286](https://togithub.com/jesseduffield/lazygit/pull/3286) - Fix some problems with patches if `git diff` was customized with config (e.g. `external` or `noprefix`). by [@​mricherzhagen](https://togithub.com/mricherzhagen) in [https://github.com/jesseduffield/lazygit/pull/3222](https://togithub.com/jesseduffield/lazygit/pull/3222) - Use $XDG_STATE_HOME for state.yml by [@​horriblename](https://togithub.com/horriblename) in [https://github.com/jesseduffield/lazygit/pull/2936](https://togithub.com/jesseduffield/lazygit/pull/2936) - Fix display of Chinese characters on Windows by [@​stefanhaller](https://togithub.com/stefanhaller) in [https://github.com/jesseduffield/lazygit/pull/3352](https://togithub.com/jesseduffield/lazygit/pull/3352) - Allow more than one argument in git.merging.args config by [@​stefanhaller](https://togithub.com/stefanhaller) in [https://github.com/jesseduffield/lazygit/pull/3336](https://togithub.com/jesseduffield/lazygit/pull/3336) - Don't strike out reserved keys in menus by [@​stefanhaller](https://togithub.com/stefanhaller) in [https://github.com/jesseduffield/lazygit/pull/3365](https://togithub.com/jesseduffield/lazygit/pull/3365) - Don't ask to force-push if the remote rejected updates by [@​stefanhaller](https://togithub.com/stefanhaller) in [https://github.com/jesseduffield/lazygit/pull/3387](https://togithub.com/jesseduffield/lazygit/pull/3387) - Fix container detection by [@​aritmos](https://togithub.com/aritmos) in [https://github.com/jesseduffield/lazygit/pull/3412](https://togithub.com/jesseduffield/lazygit/pull/3412) ##### Maintenance ⚙️ - Add Click() to GuiDriver by [@​simonwhitaker](https://togithub.com/simonwhitaker) in [https://github.com/jesseduffield/lazygit/pull/2898](https://togithub.com/jesseduffield/lazygit/pull/2898) - Add Makefile by [@​kyu08](https://togithub.com/kyu08) in [https://github.com/jesseduffield/lazygit/pull/2937](https://togithub.com/jesseduffield/lazygit/pull/2937) - fix GitHub Actions warnings by [@​kyu08](https://togithub.com/kyu08) in [https://github.com/jesseduffield/lazygit/pull/2950](https://togithub.com/jesseduffield/lazygit/pull/2950) - Add instruction in PR template to start PRs with an imperative by [@​jesseduffield](https://togithub.com/jesseduffield) in [https://github.com/jesseduffield/lazygit/pull/2967](https://togithub.com/jesseduffield/lazygit/pull/2967) - Don't show toasts when running integration tests by [@​stefanhaller](https://togithub.com/stefanhaller) in [https://github.com/jesseduffield/lazygit/pull/2975](https://togithub.com/jesseduffield/lazygit/pull/2975) - Various debugging improvements by [@​stefanhaller](https://togithub.com/stefanhaller) in [https://github.com/jesseduffield/lazygit/pull/3000](https://togithub.com/jesseduffield/lazygit/pull/3000) - Rename `test/results` to `test/_results` by [@​stefanhaller](https://togithub.com/stefanhaller) in [https://github.com/jesseduffield/lazygit/pull/3012](https://togithub.com/jesseduffield/lazygit/pull/3012) - Support passing -race flag to integration tests by [@​stefanhaller](https://togithub.com/stefanhaller) in [https://github.com/jesseduffield/lazygit/pull/3019](https://togithub.com/jesseduffield/lazygit/pull/3019) - Improve debugging of integration tests by [@​stefanhaller](https://togithub.com/stefanhaller) in [https://github.com/jesseduffield/lazygit/pull/3029](https://togithub.com/jesseduffield/lazygit/pull/3029) - Use go:generate for cheatsheet by [@​stefanhaller](https://togithub.com/stefanhaller) in [https://github.com/jesseduffield/lazygit/pull/3035](https://togithub.com/jesseduffield/lazygit/pull/3035) - Change Makefile to build non-optimized by [@​stefanhaller](https://togithub.com/stefanhaller) in [https://github.com/jesseduffield/lazygit/pull/3028](https://togithub.com/jesseduffield/lazygit/pull/3028) - Update PR template to use go generate command by [@​jesseduffield](https://togithub.com/jesseduffield) in [https://github.com/jesseduffield/lazygit/pull/3041](https://togithub.com/jesseduffield/lazygit/pull/3041) - Band-aid fix for submodule/reset.go test failure by [@​stefanhaller](https://togithub.com/stefanhaller) in [https://github.com/jesseduffield/lazygit/pull/3047](https://togithub.com/jesseduffield/lazygit/pull/3047) - Remove redundant `len` check by [@​Juneezee](https://togithub.com/Juneezee) in [https://github.com/jesseduffield/lazygit/pull/3051](https://togithub.com/jesseduffield/lazygit/pull/3051) - Add disabled compat for user config ([#​2833](https://togithub.com/jesseduffield/lazygit/issues/2833)) by [@​karimkhaleel](https://togithub.com/karimkhaleel) in [https://github.com/jesseduffield/lazygit/pull/3060](https://togithub.com/jesseduffield/lazygit/pull/3060) - Fix go.mod file by [@​stefanhaller](https://togithub.com/stefanhaller) in [https://github.com/jesseduffield/lazygit/pull/3118](https://togithub.com/jesseduffield/lazygit/pull/3118) - Capture test code coverage stats by [@​jesseduffield](https://togithub.com/jesseduffield) in [https://github.com/jesseduffield/lazygit/pull/3135](https://togithub.com/jesseduffield/lazygit/pull/3135) - fixed typo in test description by [@​schuebel](https://togithub.com/schuebel) in [https://github.com/jesseduffield/lazygit/pull/3101](https://togithub.com/jesseduffield/lazygit/pull/3101) - Update cheatsheets by [@​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://togithub.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>
Issue: #3196
This PR adds the ability to select a range of items in list contexts. It does this in two ways:
The PR adds the ability to range select in all list contexts, but it's up to individual actions to opt-in to supporting a range. This PR only supports it for copying a range of commits for cherry-picking. We can add more support iteratively so that we're not merging a single giant PR. For all actions requiring selection of a single-item, an error will be shown if a range is selected.
Other use cases we want to support in the near future:
Updated keybindings
Because the 'v' binding is now globally dedicated to toggling range select, I've changed the cherry-pick copy/paste keys from 'c' and 'v' to 'shift+C' and 'shift+V' respectively. I've also nullified the 'v' keybinding on the 'view divergence from upstream' option in the upstream options menu (conveniently it was the first option in the menu so you can press enter on it).
Standardised range select display
As a bonus, this PR standardises how we display a range select. We already had range select support in the patch explorer view and merge conflicts view, but they were directly rendering the highlighted selection (i.e. blue background colour) in the content written to the view, rather than tell the view which lines were selected and have the view highlight them itself. A convenient benefit here is that now the entire line is highlighted, including trailing space, rather than just the content of the line. Another convenient benefit is that our integration tests can now easily ask the view which lines are selected, rather than depending on the specific context, because the view keeps track of it.
I've removed the selectedRangeBgColor config option because selectedLineBgColor should be fine. I don't see the need for two options, but tell me if you think otherwise.
Also, another thing we're standardising on: hitting escape will cancel the range select, which in the staging/patch-building views means if you're selecting a range, you'll need to hit escape twice to exit out of the view. For consistency, we're also applying this logic if you have a hunk selected. I personally would much prefer this and have several times accidentally exited out of the view when trying to cancel a range select by pressing escape. In lazygit in general, 'escape' means 'exit out of the innermost mode' and I would consider range select to be a kind of mode.
Sticky vs non-sticky range interaction
Here's the state machine that explains how the sticky and non-sticky range select modes interact. Although users will typically pick one or the other, it's important to be clear on what the logic is if you swap between them:
Also if you press escape in either range mode, it cancels the range select.
Some implementation details
go generate ./...
)docs/Config.md
) have been updated if necessary