1
0
mirror of https://github.com/jesseduffield/lazygit.git synced 2025-07-01 00:54:58 +02:00
Commit Graph

2701 Commits

Author SHA1 Message Date
75db4faf69 show actual error when trying to check out a branch that doesn't exist 2019-07-14 14:31:48 +10:00
abddea060e revert menu panel error panel usage 2019-06-08 20:29:25 +10:00
0f0fda1660 allow stashing staged changes
reinstate old stash functionality with the 's' keybinding
2019-06-06 20:50:19 +10:00
bd2170a99c request explicit return from subprocess
Previously we were recording output from subprocesses using a multiwriter
and hooking that up to the cmd's stdout to write to both os.Stdout and
a buffer. We would then display the output after the program finished.

This worked well for commands like 'ls' but not for commands like 'vi'
which expect you to be in a tty, and when you've got the cmd's stdout
pointing at a multiwriter, the subprogram thinks we're not in a tty
and then things like terminal corruption can happen. This was the case
with neovim, and even in vim a warning was given with a pause before
starting the program.

Now we're chucking out the multiwriter and instead making it that you
need to press enter after the program has finished to return to lazygit.
This allows you to view the output of the program (e.g. if it's ls) and
then decide that you want to return. It's one level of unnecessary
redirection for editors like vim, but even they could potentially have
output to stderr/stdout that you want to look at before returning.

 Please enter the commit message for your changes. Lines starting
2019-05-26 21:19:54 +10:00
c039e5bed0 support going to start/end of line and deleting lines in simple editor 2019-05-26 12:42:17 +10:00
527c025a0c use shift+j/k to scroll main, ctrl+j/k to move commits 2019-05-25 16:48:17 +10:00
4a4dc676fc simplify code for logging output of subprocess 2019-05-18 11:30:10 +10:00
e38d9d5f22 Add alternatives for scroll actions to context map 2019-05-12 16:20:42 +10:00
97f060d38d Add field Alternative to gui.Binding
Document and use alternative keybinding for generating cheatsheet. Add
alt keybinding fn+up/down for scroll up/down actions.

Also run `go run scripts/generate_cheatsheet.go`.
2019-05-12 16:20:42 +10:00
8754d766e2 Made not enough space pannel looks better on 1 height 2019-05-07 08:47:41 +02:00
2388c3ee9a Fixed some sugestions from jesseduffield 2019-05-06 20:04:54 +02:00
61890cb9de Merge branch 'master' into smaller-ui 2019-05-06 15:24:36 +02:00
5a0d0bb299 support resetting to a commit in either soft, hard, or mixed mode 2019-05-06 22:44:38 +10:00
2746b1bd38 Prevent crash when opening in small window
We were crashing when opening lazygit in a small window because the limit view
was the only view that got created, and there were two functions that referenced
either the 'current' view or the files view, neither of which existed.

Now those functions just return nil if the view does not exist
2019-05-06 22:39:35 +10:00
19a6368377 Changed the way how the view height are set 2019-05-05 15:57:35 +02:00
492614ebc7 Made the ui even smaller 2019-04-26 08:24:14 +02:00
6ba05c94ea Added another resizing step 2019-04-25 21:37:19 +02:00
07fec6d00e Made the go bot happy 2019-04-20 16:51:50 +02:00
a69b985086 Better UI on small screens 2019-04-20 15:56:23 +02:00
0d3a193ab5 Add 'w' keybinding in files panel to commit as a WIP
If your git.skipHookPrefix is set to, say, WIP, in your config, then
hitting 'w' in the files panel will bring up the commit message panel
with 'WIP' pre-filled, so you just need to hit enter to confirm
(or add some more to the message) in order to commit your changes
with the --no-verify flag, meaning the pre-commit hook will be skipped
2019-04-13 14:38:17 +10:00
ab9fa291a8 Add skipHookPrefix to config
allows a user to specify a commit message prefix that will tell lazygit to skip
the pre-commit hook. This defaults to WIP. Setting it to the empty string will
disable the feature.

So if my message goes 'WIP: do the thing' then the pre-commit hook will not run
2019-04-13 14:38:17 +10:00
0f1abcb10c remove subprocess channel stuff 2019-04-07 17:15:01 +10:00
55538a3695 support custom commands 2019-04-07 17:15:01 +10:00
60e33f5d8c Allow for creating fixup! commits 2019-04-07 13:13:40 +10:00
f34be1896a fixed some #397 2019-04-06 13:02:20 +11:00
c350cdba43 add feature of display diff between specific commits #397 2019-04-06 13:02:20 +11:00
1a933eaa73 pass length of options to createMenu 2019-03-23 13:26:17 +11:00
bd46e9c5b0 delete menu keybinding before setting new one 2019-03-23 13:26:17 +11:00
09b7ae21bc always attempt to discard changes from current file 2019-03-23 13:26:17 +11:00
acfc961909 move soft reset keybinding into reset options 2019-03-23 13:26:17 +11:00
f502f75e1f add more options for resetting files in the working tree 2019-03-23 13:26:17 +11:00
ff97ef7b94 support discarding unstaged changes 2019-03-23 13:26:17 +11:00
a2c780b085 retain commit message if precommit hook fails 2019-03-23 13:07:36 +11:00
d84dfc23e7 Rely on model rather than view to focus a point
Currently when we want to focus a point on a view (i.e. highlight a
line and ensure it's within the bounds of a view's box, we use the
LinesHeight method on the view to work out how many lines in total
there are.

This is bad because for example if we come back from editing a file,
the view will have no contents so LinesHeight == 0, but we might
be trying to select line 10 because there are actual ten things we
expect to be rendered already. This causes a crash when e.g. 10 is
greater than the height of the view.

So we need to pass in to our FocusPoint method the actual number of
items we want to render, rather than having the method rely on the
LinesHeight, so that the method knows to scroll a bit before setting
the cursor's y position.

Unfortunately this makes for some awkward code with our current setup.
We don't have a good interface type on these state objects so we now
need to explicitly obtain the len() of whatever array we're rendering.

In the case of the menu panel this is even more awkward because the items
list is just an interface{} and it's not easy to get the list of that, so
now when we instantiate a menu we need to pass in the count of items
as well.

The better solution would be to define an interface with a getItems
and getLength method and have all these item arrays become structs
implementing the interface, but I am too lazy to do this right now :)
2019-03-23 11:54:25 +11:00
e68dbeb7eb organise keybindings better 2019-03-22 20:20:06 +11:00
d5f617ec92 show some more errors in the gui rather than panicking 2019-03-16 12:51:48 +11:00
6d104bfa91 show file remove error in gui rather than panic 2019-03-16 12:51:48 +11:00
e583cc2519 allow autostashing changes when checking out a branch 2019-03-16 12:51:48 +11:00
b6447ebdbb allow adding a file viewed from the commit files panel 2019-03-16 10:20:27 +11:00
c98eddc185 appease golangci 2019-03-16 10:20:27 +11:00
3b2353b5ae remove redundant call to refreshCommitFilesView
We already call this function inside the refreshCommitsView function.
We call it there because it's logical that A) one occurs whenever the other does and
B) the commit files only get refreshed after we've updated the commits themselves
2019-03-16 10:20:27 +11:00
4f7f6a073c allow user to discard old file changes for a given commit 2019-03-16 10:20:27 +11:00
0e008cc15f allow user to checkout old files 2019-03-16 10:20:27 +11:00
1ad9c6faac minor cleanup 2019-03-16 10:20:27 +11:00
06fe726ee7 Add feature of display committed file list #383 2019-03-16 10:20:27 +11:00
ac5088eee6 allow both enter and space to execute menu item 2019-03-03 23:18:28 +11:00
e36899d5c5 prevent crashes when scrolling up 2019-03-03 23:08:07 +11:00
a5d27764cd support user configuring mouse events to be enabled 2019-03-03 16:15:20 +11:00
43758cbb5f i18n for rebase loading states 2019-03-03 16:11:20 +11:00
0079015102 distinguish between inline and non-inline merge conflicts 2019-03-03 15:58:01 +11:00