Skip to content
New issue

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

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

Already on GitHub? Sign in to your account

Continuation of Continuation of Add search bar at bottom of revlog #506 #672 #1753

Closed
wants to merge 126 commits into from
Closed
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
126 commits
Select commit Hold shift + click to select a range
f70b92a
Add search bar at bottom of revlog
WizardOhio24 Feb 4, 2021
2a5d9a8
Add esc to escape and fix invisible commit details
WizardOhio24 Feb 4, 2021
5cc8e7d
Remove unused lines
WizardOhio24 Feb 4, 2021
be0c76f
Fix revlog
WizardOhio24 Feb 4, 2021
bd5123a
Fix vim keys test
WizardOhio24 Feb 4, 2021
3414a05
Allow searching to happen live rather than press enter
WizardOhio24 Feb 4, 2021
07f4ec1
Filter commits in selected_entry
WizardOhio24 Feb 4, 2021
e8a6db5
Fix naming
WizardOhio24 Feb 4, 2021
95e3a70
Remove unused command
WizardOhio24 Feb 4, 2021
709b501
Allow escaping with esc again
WizardOhio24 Feb 4, 2021
b06a716
Auto set focus on filter commit to true
WizardOhio24 Feb 4, 2021
bfbcc9a
If filtering log get all commits
WizardOhio24 Feb 4, 2021
0e671b9
Change set total count to update total count in commitlist
WizardOhio24 Feb 4, 2021
1b1c6ee
Change key to bring up find commit box to :
WizardOhio24 Feb 4, 2021
21904ea
Don't show char count in find commit component
WizardOhio24 Feb 4, 2021
84ca7d2
Also filter by author
WizardOhio24 Feb 4, 2021
ab8770c
Add find commit to log commands
WizardOhio24 Feb 4, 2021
41c121e
esc on log tab to cancel search
WizardOhio24 Feb 4, 2021
56ef6be
Change search back to s
WizardOhio24 Feb 4, 2021
e6dd94a
Also update count when not filtering
WizardOhio24 Feb 4, 2021
b5fdceb
Fix h not working in text input
WizardOhio24 Feb 4, 2021
1ba3b23
Change tabs to spaces in keys.rs
WizardOhio24 Feb 4, 2021
504e0a9
Filter commits in commit log rather than commitlist
WizardOhio24 Feb 4, 2021
6930d73
Add extend item list to fetch commit
WizardOhio24 Feb 4, 2021
a505c05
Revert to 1ba3b23: Change tabs to spaces in keys.rs
WizardOhio24 Feb 4, 2021
db48ec5
Implement async filterer for commits
WizardOhio24 Feb 9, 2021
7c9fc66
Remove filter code from commitlist
WizardOhio24 Feb 9, 2021
9d3985d
Shutdown filter thread before starting another filter
WizardOhio24 Feb 9, 2021
47df534
Working async commit filter
WizardOhio24 Feb 9, 2021
b2d2f82
Fix async filter thread terminating upon finishing search
WizardOhio24 Feb 9, 2021
70ca71a
Set commit length when retrieving filtered commits
WizardOhio24 Feb 9, 2021
cd938f6
Finish filter if 0 recieved rather than <=1
WizardOhio24 Feb 9, 2021
fdf2fad
Make search case insensitive
WizardOhio24 Feb 9, 2021
d3abde6
Fix clippy warning
WizardOhio24 Feb 9, 2021
ebbe26e
Add a filter function using : in search to filter by sha, author or m…
WizardOhio24 Feb 9, 2021
16da8a0
Remove expect
WizardOhio24 Feb 9, 2021
0114cbf
Change async filter sleep durations
WizardOhio24 Feb 9, 2021
b4cf798
Trim whitespace
WizardOhio24 Feb 9, 2021
0be4840
Allow union filtering with ||
WizardOhio24 Feb 10, 2021
05c734c
Use rayon core for thread and add work pending
WizardOhio24 Feb 10, 2021
bf0d6ea
Fix sleep timings so filter runs quicker
WizardOhio24 Feb 10, 2021
933d4c5
Store state locally for quicker return if no work pending
WizardOhio24 Feb 10, 2021
9578e8d
Use refcell to fix is_pending
WizardOhio24 Feb 10, 2021
e9eeb53
Allow &&(intersection) and ||(union) filtering
WizardOhio24 Feb 11, 2021
f442c33
Use mutexes to prevent several threads filtering at once
WizardOhio24 Feb 11, 2021
ae01732
Clear filtered commits when starting a new search in thread
WizardOhio24 Feb 11, 2021
c5b469b
Use parking log mutex
WizardOhio24 Feb 11, 2021
8fc599d
Fix import order
WizardOhio24 Feb 11, 2021
524ddcc
Fix spinner up before filter
WizardOhio24 Feb 11, 2021
06d6ade
Remove filter_thread_running
WizardOhio24 Feb 11, 2021
7ed2cda
Remove unneeded comments
WizardOhio24 Feb 11, 2021
c444aaa
Make filter function more succinct
WizardOhio24 Feb 11, 2021
5bd747b
Remove clippy allow too many lines
WizardOhio24 Feb 11, 2021
8db4523
Fix brackets in filter function
WizardOhio24 Feb 11, 2021
a1cd020
Remove reset values from start_filter in main thread
WizardOhio24 Feb 11, 2021
126431a
Remove clear function from async filter
WizardOhio24 Feb 11, 2021
7a416de
Move try_recv to before getting slice of commits
WizardOhio24 Feb 11, 2021
d70e149
Add complement search
WizardOhio24 Feb 11, 2021
a2faf29
Support case sensitive filtering
WizardOhio24 Feb 12, 2021
571c401
Add comment to filter function explaining what input is expected
WizardOhio24 Feb 12, 2021
d5d24fb
Fix clippy warnings and not revlog filter by
WizardOhio24 Feb 12, 2021
712fb82
Fix filter if no leading :
WizardOhio24 Feb 12, 2021
529cc74
Support filtering by tags
WizardOhio24 Feb 13, 2021
f4f5b6e
Support brackets in search
WizardOhio24 Feb 13, 2021
9c51df3
Allow nested brackets
WizardOhio24 Feb 13, 2021
f6863d0
Fix clippy
WizardOhio24 Feb 13, 2021
a361c70
Fix clippy
WizardOhio24 Feb 13, 2021
a0b9af5
Support nested brackets and fix not tag search to show commits with n…
WizardOhio24 Feb 13, 2021
1647357
Remove unneeded comments
WizardOhio24 Feb 13, 2021
507d6f8
Small varible name change
WizardOhio24 Feb 13, 2021
32eb3e2
Reset LIMIT_COUNT in revlog to 3000
WizardOhio24 Feb 13, 2021
501a194
Remove unneeded logging
WizardOhio24 Feb 13, 2021
fe6d817
Remove amount argument from fetch_helper
WizardOhio24 Feb 18, 2021
447d095
Move comment above derive
WizardOhio24 Feb 18, 2021
e68938d
Create function get_tags
WizardOhio24 Feb 18, 2021
71582a7
Remove added ;
WizardOhio24 Feb 18, 2021
f933bf2
Add comment to get_ending_bracket
WizardOhio24 Feb 18, 2021
d1c3b54
Add comment to remove_out_brackets
WizardOhio24 Feb 18, 2021
1f133c7
Only re-filter if string is different
WizardOhio24 Feb 18, 2021
6124b9b
Add filter_string to new revlog
WizardOhio24 Feb 18, 2021
4b07b3a
Change back to set_total_count in commitlist
WizardOhio24 Feb 18, 2021
d70cc4f
Fix clippy warnings and change while to for in get_ending_bracket
WizardOhio24 Feb 18, 2021
2d3cf33
Fix search by trimming string
WizardOhio24 Feb 18, 2021
7b610b3
Add brackets round tag filter in async_filter
WizardOhio24 Feb 18, 2021
6ab22fa
Add search filter commits to readme
WizardOhio24 Feb 19, 2021
2a99ed5
Remove is_and && from filter
WizardOhio24 Feb 19, 2021
c777ef3
Remove ALT down to focus on search
WizardOhio24 Feb 19, 2021
3fe9a33
Remove comment about getting tags from start_filter
WizardOhio24 Feb 19, 2021
dd158e0
Remove continue filter comment
WizardOhio24 Feb 19, 2021
843ff3b
Merge branch 'master' into find-sha
WizardOhio24 Feb 25, 2021
b0ee951
Fix merge problems
WizardOhio24 Feb 25, 2021
82ce6fc
Add tests for `Revlog::get_what_to_filter_by`
willir Apr 25, 2021
f12fde4
Refactor, fix a few bugs(with space handling), and add documentation to
willir Apr 25, 2021
225a1a0
Merge remote-tracking branch 'extrawurst/master' into find-sha
willir Apr 25, 2021
6e31762
Use std::sync::Mutex instead of the one from parking_lot
willir Apr 25, 2021
efa44c2
Return original formating in KeyConfig::get_hint in src/keys.rs
willir Apr 25, 2021
47cdc09
Remove used AsyncCommitFilterer::filter_strings field
willir May 2, 2021
66e6209
Merge remote-tracking branch 'extrawurst/master' into find-sha
willir May 2, 2021
0afcc9e
Reformat with rustfmt
willir May 2, 2021
b0a7224
Merge branch 'master' into find-sha
willir May 8, 2021
38eeeeb
Fix clippy errors
willir May 8, 2021
99f0e0a
Merge remote-tracking branch 'extrawurst/master' into find-sha
willir May 18, 2021
62b2f6a
Merge branch 'master' into find-sha
Rodrigodd Jun 10, 2023
9694905
Merge branch 'master' into find-sha
Rodrigodd Jun 10, 2023
c986221
fix help command triggering while searching
Rodrigodd Jun 10, 2023
ff8743f
cargo fmt
Rodrigodd Jun 10, 2023
734b50a
fix warnings and errors
Rodrigodd Jun 10, 2023
ac1b250
use let guards to avoid identation
Rodrigodd Jun 11, 2023
f62bc50
avoid unecessary calls to drop
Rodrigodd Jun 11, 2023
938a1b7
Make quit key respect consumed events
Rodrigodd Jun 11, 2023
4838109
Replace unused type in channel by unit type
Rodrigodd Jun 17, 2023
bcb174f
Dont continue in filter loop in case of error
Rodrigodd Jun 17, 2023
b45c9e2
Avoid using two Mutex's for filter thread
Rodrigodd Jun 17, 2023
95609f1
Use AtomicBool instead of channel for stop signal
Rodrigodd Jun 21, 2023
bf3281b
Use filter_finished for is_pending logic
Rodrigodd Jun 30, 2023
db623d5
Fix update logic
Rodrigodd Jul 1, 2023
1a8e907
Merge branch 'master' into find-sha
Rodrigodd Jul 1, 2023
277869e
Remove key_list_file
Rodrigodd Jul 7, 2023
80eaa73
Refactor AsyncCommitFilter::filter and add unit tests
Rodrigodd Jul 7, 2023
e0e3785
Drop support for `&&(`
Rodrigodd Jul 9, 2023
acb268f
Revert rename of `set_count_total`
Rodrigodd Jul 9, 2023
57dbad2
Add unit-test for filtering tags
Rodrigodd Jul 9, 2023
0595cb6
Add unit-tests for contains_tag
Rodrigodd Jul 9, 2023
c43b39d
Make AsyncTags share its result
Rodrigodd Jul 9, 2023
7b49d20
Updated CHANGELOG.md
Rodrigodd Jul 9, 2023
6516e85
Fix vim_style_key_config.ron]
Rodrigodd Jul 9, 2023
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
1 change: 1 addition & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -18,6 +18,7 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0
### Added
* support 'n'/'p' key to move to the next/prev hunk in diff component [[@hamflx](https://github.com/hamflx)] ([#1523](https://github.com/extrawurst/gitui/issues/1523))
* simplify theme overrides [[@cruessler](https://github.com/cruessler)] ([#1367](https://github.com/extrawurst/gitui/issues/1367))
* allow searching for commits in the revlog tab by sha, author, message or tag [[@WizardOhio24](https://github.com/WizardOhio24), [@willir](https://github.com/willir), [@Rodrigodd](https://github.com/Rodrigodd)] [#1753](https://github.com/extrawurst/gitui/issues/1753)

### Fixes
* fix commit dialog char count for multibyte characters ([#1726](https://github.com/extrawurst/gitui/issues/1726))
Expand Down
2 changes: 1 addition & 1 deletion README.md
Original file line number Diff line number Diff line change
Expand Up @@ -48,7 +48,7 @@
- Stashing (save, pop, apply, drop, and inspect)
- Push/Fetch to/from remote
- Branch List (create, rename, delete, checkout, remotes)
- Browse commit log, diff committed changes
- Browse commit log, diff committed changes, search/filter commits
- Scalable terminal UI layout
- Async git API for fluid control
- Submodule support
Expand Down
1 change: 1 addition & 0 deletions asyncgit/src/revlog.rs
Original file line number Diff line number Diff line change
Expand Up @@ -26,6 +26,7 @@ pub enum FetchStatus {
}

///
#[derive(Clone)]
pub struct AsyncLog {
current: Arc<Mutex<Vec<CommitId>>>,
current_head: Arc<Mutex<Option<CommitId>>>,
Expand Down
13 changes: 12 additions & 1 deletion asyncgit/src/sync/commits_info.rs
Original file line number Diff line number Diff line change
Expand Up @@ -22,6 +22,17 @@ impl CommitId {
Self(id)
}

/// Parse a hex-formatted object id into an Oid structure.
///
/// # Errors
///
/// Returns an error if the string is empty, is longer than 40 hex
/// characters, or contains any non-hex characters.
pub fn from_hex_str(id: &str) -> Result<Self> {
let oid = Oid::from_str(id)?;
Ok(Self::new(oid))
}

///
pub(crate) const fn get_oid(self) -> Oid {
self.0
Expand Down Expand Up @@ -52,7 +63,7 @@ impl From<Oid> for CommitId {
}

///
#[derive(Debug)]
#[derive(Debug, Clone, PartialEq, Eq)]
pub struct CommitInfo {
///
pub message: String,
Expand Down
24 changes: 16 additions & 8 deletions asyncgit/src/tags.rs
Original file line number Diff line number Diff line change
Expand Up @@ -20,8 +20,9 @@ pub struct TagsResult {
}

///
#[derive(Clone)]
pub struct AsyncTags {
last: Option<(Instant, TagsResult)>,
last: Arc<Mutex<Option<(Instant, TagsResult)>>>,
sender: Sender<AsyncGitNotification>,
job: AsyncSingleJob<AsyncTagsJob>,
repo: RepoPath,
Expand All @@ -35,15 +36,19 @@ impl AsyncTags {
) -> Self {
Self {
repo,
last: None,
last: Arc::new(Mutex::new(None)),
sender: sender.clone(),
job: AsyncSingleJob::new(sender.clone()),
}
}

/// last fetched result
pub fn last(&self) -> Result<Option<Tags>> {
Ok(self.last.as_ref().map(|result| result.1.tags.clone()))
Ok(self
.last
.lock()?
.as_ref()
.map(|result| result.1.tags.clone()))
}

///
Expand All @@ -52,10 +57,12 @@ impl AsyncTags {
}

///
fn is_outdated(&self, dur: Duration) -> bool {
self.last
fn is_outdated(&self, dur: Duration) -> Result<bool> {
Ok(self
.last
.lock()?
.as_ref()
.map_or(true, |(last_time, _)| last_time.elapsed() > dur)
.map_or(true, |(last_time, _)| last_time.elapsed() > dur))
}

///
Expand All @@ -70,7 +77,7 @@ impl AsyncTags {
return Ok(());
}

let outdated = self.is_outdated(dur);
let outdated = self.is_outdated(dur)?;

if !force && !outdated {
return Ok(());
Expand All @@ -81,14 +88,15 @@ impl AsyncTags {
if outdated {
self.job.spawn(AsyncTagsJob::new(
self.last
.lock()?
.as_ref()
.map_or(0, |(_, result)| result.hash),
repo,
));

if let Some(job) = self.job.take_last() {
if let Some(Ok(result)) = job.result() {
self.last = Some(result);
*self.last.lock()? = Some(result);
}
}
} else {
Expand Down
23 changes: 8 additions & 15 deletions src/app.rs
Original file line number Diff line number Diff line change
Expand Up @@ -392,7 +392,7 @@ impl App {
log::trace!("event: {:?}", ev);

if let InputEvent::Input(ev) = ev {
if self.check_hard_exit(&ev) || self.check_quit(&ev) {
if self.check_hard_exit(&ev) {
return Ok(());
}

Expand Down Expand Up @@ -445,6 +445,9 @@ impl App {
) {
self.options_popup.show()?;
NeedsUpdate::ALL
} else if key_match(k, self.key_config.keys.quit) {
self.do_quit = QuitState::Close;
NeedsUpdate::empty()
} else {
NeedsUpdate::empty()
};
Expand Down Expand Up @@ -603,8 +606,8 @@ impl App {
tags_popup,
reset_popup,
options_popup,
help,
revlog,
help,
status_tab,
files_tab,
stashing_tab,
Expand Down Expand Up @@ -642,19 +645,6 @@ impl App {
]
);

fn check_quit(&mut self, ev: &Event) -> bool {
if self.any_popup_visible() {
return false;
}
if let Event::Key(e) = ev {
if key_match(e, self.key_config.keys.quit) {
self.do_quit = QuitState::Close;
return true;
}
}
false
}

fn check_hard_exit(&mut self, ev: &Event) -> bool {
if let Event::Key(e) = ev {
if key_match(e, self.key_config.keys.exit) {
Expand Down Expand Up @@ -887,6 +877,9 @@ impl App {
self.push_tags_popup.push_tags()?;
flags.insert(NeedsUpdate::ALL);
}
InternalEvent::FilterLog(string_to_filter_by) => {
self.revlog.filter(&string_to_filter_by)?;
}
InternalEvent::StatusLastFileMoved => {
self.status_tab.last_file_moved()?;
}
Expand Down
117 changes: 117 additions & 0 deletions src/components/find_commit.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,117 @@
use super::{
textinput::TextInputComponent, CommandBlocking, CommandInfo,
Component, DrawableComponent, EventState,
};
use crate::{
keys::{key_match, SharedKeyConfig},
queue::{InternalEvent, Queue},
strings,
ui::style::SharedTheme,
};
use anyhow::Result;
use crossterm::event::Event;
use ratatui::{backend::Backend, layout::Rect, Frame};

pub struct FindCommitComponent {
input: TextInputComponent,
queue: Queue,
is_focused: bool,
visible: bool,
key_config: SharedKeyConfig,
}

impl DrawableComponent for FindCommitComponent {
fn draw<B: Backend>(
&self,
f: &mut Frame<B>,
rect: Rect,
) -> Result<()> {
self.input.draw(f, rect)?;
Ok(())
}
}

impl Component for FindCommitComponent {
fn commands(
&self,
_out: &mut Vec<CommandInfo>,
_force_all: bool,
) -> CommandBlocking {
CommandBlocking::PassingOn
}

fn event(&mut self, ev: &Event) -> Result<EventState> {
if self.is_visible() && self.focused() {
if let Event::Key(e) = ev {
if key_match(e, self.key_config.keys.exit_popup) {
// Prevent text input closing
self.focus(false);
self.visible = false;
return Ok(EventState::Consumed);
}
}
if self.input.event(ev)?.is_consumed() {
self.queue.push(InternalEvent::FilterLog(
self.input.get_text().to_string(),
));
return Ok(EventState::Consumed);
}
}
Ok(EventState::NotConsumed)
}

fn is_visible(&self) -> bool {
self.visible
}

fn hide(&mut self) {
self.visible = false;
}
fn show(&mut self) -> Result<()> {
self.visible = true;
Ok(())
}

fn focus(&mut self, focus: bool) {
self.is_focused = focus;
}

fn focused(&self) -> bool {
self.is_focused
}

fn toggle_visible(&mut self) -> Result<()> {
self.visible = !self.visible;
Ok(())
}
}

impl FindCommitComponent {
///
pub fn new(
queue: Queue,
theme: SharedTheme,
key_config: SharedKeyConfig,
) -> Self {
let mut input_component = TextInputComponent::new(
theme,
key_config.clone(),
&strings::find_commit_title(&key_config),
&strings::find_commit_msg(&key_config),
false,
);
input_component.show().expect("Will not error");
input_component.embed();
Self {
queue,
input: input_component,
key_config,
visible: false,
is_focused: false,
}
}

pub fn clear_input(&mut self) {
self.input.clear();
}
}
3 changes: 3 additions & 0 deletions src/components/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,7 @@ mod diff;
mod externaleditor;
mod fetch;
mod file_revlog;
mod find_commit;
mod fuzzy_find_popup;
mod help;
mod inspect_commit;
Expand Down Expand Up @@ -48,6 +49,7 @@ pub use diff::DiffComponent;
pub use externaleditor::ExternalEditorComponent;
pub use fetch::FetchComponent;
pub use file_revlog::{FileRevOpen, FileRevlogComponent};
pub use find_commit::FindCommitComponent;
pub use fuzzy_find_popup::FuzzyFindPopup;
pub use help::HelpComponent;
pub use inspect_commit::{InspectCommitComponent, InspectCommitOpen};
Expand All @@ -67,6 +69,7 @@ pub use syntax_text::SyntaxTextComponent;
pub use tag_commit::TagCommitComponent;
pub use taglist::TagListComponent;
pub use textinput::{InputType, TextInputComponent};
pub use utils::async_commit_filter;
pub use utils::filetree::FileTreeItemKind;

use crate::ui::style::Theme;
Expand Down
Loading