-
-
Notifications
You must be signed in to change notification settings - Fork 580
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 Go to line feature for the blame view #2262
base: master
Are you sure you want to change the base?
Conversation
@andrea-berling Thanks for the PR! I started testing on my machine, and I think this is looking good overall! One thing I noticed, though, is that, in a larger file with syntax highlighting enabled (I chose |
src/queue.rs
Outdated
@@ -68,6 +68,8 @@ pub enum StackablePopupOpen { | |||
InspectCommit(InspectCommitOpen), | |||
/// | |||
CompareCommits(InspectCommitOpen), | |||
/// | |||
GotoLine, |
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 its a bit of a missed opportunity to not pass it some context: enum Context {Blame, FileView}
and PossibleRange(min,max)
to be able to reuse this in various places
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.
In my last commit I added the Context
enum and used it to preserve the BlameProcess
status across line jumps, and I added the two variants you mentioned in line comments. That's because cargo wouldn't let me compile if I didn't use those variants, which I didn't. Do you have a specific example in mind where those pieces of information could be used? If so, I could use them to implement those use cases as to make them more interesting, otherwise I can leave the comments around as placeholder for future functionality 🙂
@cruessler Added the functionality you requested, it makes a lot of sense for large files. Seems to work for me, can you check it out again? |
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 left a few comments, mostly minor.
I found that there is an issue when you open a blame, then open the goto line popup before syntax highlighting finishes, then close the popup. The syntax highlighting that has completed in the background goes back to an in-progress state and doesn’t change anymore.
@extrawurst There’s a few added #[derive(Debug)]
in this PR. Is that something we’d like to avoid? (I know that I’ve added similar derive
s in the past as well.)
src/queue.rs
Outdated
@@ -56,6 +56,13 @@ pub enum Action { | |||
UndoCommit, | |||
} | |||
|
|||
#[derive(Debug, Clone)] | |||
pub enum Context { |
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.
What do you think about making this a bit more specific by renaming to GotoLineContext
(or whatever fits best)?
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 held off giving it a more specific name until I understood more clearly what @extrawurst meant in #2262 (comment). But yeah, ideally, once I have a better idea of where else this Context enum would be used, I will give it a specific name
@cruessler That is really weird, I was also worried that just cloning the blame as is could run into that issue, but I tested it multiple times and it seems to work fine on my machine. I could also just store the blame if it has completed |
@andrea-berling What happens when you open the goto line popup while syntax highlighting is still running, but close it only once it has finished? |
@cruessler progress goes back to 90% and remains there. I will look into it, perhaps I'm pushing the blame status too early |
Remove context and references to it Addres extrawurst#2262 (comment) Address extrawurst#2262 (comment)
Found a way to offer the same functionality without the need for a context data structure. Not a fan of the fact I had to make the |
@andrea-berling I do understand the concern. Is there any chance we can work around this issue by passing Apart from that, I tested the branch using |
@cruessler yes, I tried the first solution you proposed before pushing my latest version, what I found was that when re-using The second one you propose is more interesting: if instead of reusing |
@cruessler I made the change using your enum idea, it seems to work and I like it better 🙂 |
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.
@extrawurst Just tested on Mac and Linux (Ubuntu, KDE). Looks good to me!
src/popups/goto_line.rs
Outdated
if c.is_ascii_digit() { | ||
// I'd assume it's unusual for people to blame | ||
// files with milions of lines | ||
if self.line.len() < 6 { |
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.
for me this is very cryptic? why hardcode to 6 digits? why is it called line
wouldn't digits
be more fitting and descriptive? instead of this we can just try to parse the result and only allow enter
if the current input is valid and even show it red in case it is not.
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.
The popup is called goto_line
, thus the first name I came up with for the input was: line
😄 but I'm not married to it, digits
works just as well for me, I trust your judgement for fitting-ness and descriptiveness 🙂 and yeah, I went for a very basic implementation at first based on the simplifying assumption that most people don't work with text files with hundreds of thousands of lines, but I like your idea of validating the input based on the max range and highlighting it red if not valid. I was even thinking of allowing to put a minus sign in front of the whole this to allow navigation to the last line, the second to last line, and in general, the n
-th to last line. I will work something up in the next few days 🙂
src/popups/blame_file.rs
Outdated
self.hide_stacked(true); | ||
self.visible = true; | ||
self.queue.push(InternalEvent::OpenPopup( | ||
StackablePopupOpen::GotoLine, |
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.
here we can provide the context: Blame, MaxLine
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.
re context: providing Context, MaxLine
so we can even provide that as validation in the GotoLine popup and make the validation more powerful instead of just 5 valid digits that parse to a usize
.
Context allows us to use this also for the File View in the FileTree
Sorry it took me so long to push my latest changes, a bunch of life happened in between 😅 @extrawurst @cruessler what do you guys think? |
Add new stackable popup to get a line number to go to from the user Add a new internal event to change the selection in the most recent blame view as a result of using the go to line popup Add new keybinding for the go to line functionality (Shift-L) Add boolean to BlameFilePopup to check whether the view is currently shadowed by the go to line popup and, if so, let the key events bubble up to the go to line popup Add new command definition for the go to line functionality in BlameFilePopup Add clamping of the selected row in set_open_selection
Remove unnecessary goto_line_popup_is_open boolean
Add Context enum to keep the blame status across line jumps Add a context field to the GotoLinePopup Add blame field to BlameFilePopup Use the blame field in BlameFilePopup.open if not None
Remove context and references to it Addres extrawurst#2262 (comment) Address extrawurst#2262 (comment)
Modiy uses of BlameFileOpen accordingly Make the blame field of BlameFilePopup private again
Add a context struct for the go to line popup to keep the max line number allowed Add support for negative values for the go to line popup input (go to the -n-th to last line) Make the go to line input box red when invalid values are provided Add an error message to the Go to line popup when invalid values are used Allow arbitrarily large values in the Go to line input box
@andrea-berling could you update to recent master, would love to get this over the finish line |
@extrawurst done, I've merged your |
@extrawurst Fixed the conflicts from today's commits 😅 now we should be good 🙂 |
@extrawurst @andrea-berling I want to do some testing on my machines later in the day, provided it has not already been merged by then. :-) |
Can’t merge for now. It breaks the command bar when the popup is open and I think we should have a default text in the input |
I just tested the changes, and I really like them! There’s one issue that might also not be an issue at all. I can open the popup before the file’s content have been loaded. If I do, the popup doesn’t accept any input because it still has state for a non-loaded file. I get the error message: |
@cruessler Thanks for catching this! The typo was the easiest to fix, but the issue you raised was also reasonably breezy: basically now the go to line popup won't open until it will be possible to determine the actual max line for the file (i.e. until the blame result is something). On most files, I'm not fast enough to try and open the blame popup before this is already the case, so there is no wait at all. On the larger ones (e.g.
@extrawurst hey 👋 so, when you say "It breaks the command bar", you mean that the popup makes it disappear, like in the following screenshot? As per the default text in the input, I'm not so sure: I can't really imagine a bulletproof guess for a good line number for any file (Start of the file? End of the file? Middle of the file? etc.), and I would imagine that most people would end up deleting the default text anyway and put the line number they want to go to (although I guess one could implement something like HTML's input placeholders so the user doesn't need to delete the default text). Did you perhaps already have an idea for what to put as a default, or did you want to brainstorm it/discuss it? |
Hey guys 👋 any news on this? 🙂 @extrawurst @cruessler |
It's still probably a bit rough around the edges, but before I made it too pretty, I though I would get some early feedback on it.
This Pull Request fixes/closes #2219.
It changes the following:
blame view as a result of using the go to line popup
I followed the checklist:
make check
without errors