From e149a0a6e9747b238032321f5e1554d0d8ded118 Mon Sep 17 00:00:00 2001 From: Tom Cammann Date: Tue, 11 Apr 2023 09:39:23 +0100 Subject: Add `--reverse` to `atuin search` (#862) Add `-r/--reverse` flag to `atuin search` to allow searching by oldest results first. Example to find the oldest `cargo` command: ``` atuin search --limit 1 --reverse cargo ``` --- atuin-client/src/database.rs | 11 ++++++++--- 1 file changed, 8 insertions(+), 3 deletions(-) (limited to 'atuin-client/src/database.rs') diff --git a/atuin-client/src/database.rs b/atuin-client/src/database.rs index 6d364dbe..c4a9ddc3 100644 --- a/atuin-client/src/database.rs +++ b/atuin-client/src/database.rs @@ -35,6 +35,7 @@ pub struct OptFilters { pub after: Option, pub limit: Option, pub offset: Option, + pub reverse: bool, } pub fn current_context() -> Context { @@ -354,9 +355,7 @@ impl Database for Sqlite { ) -> Result> { let mut sql = SqlBuilder::select_from("history"); - sql.group_by("command") - .having("max(timestamp)") - .order_desc("timestamp"); + sql.group_by("command").having("max(timestamp)"); if let Some(limit) = filter_options.limit { sql.limit(limit); @@ -366,6 +365,12 @@ impl Database for Sqlite { sql.offset(offset); } + if filter_options.reverse { + sql.order_asc("timestamp"); + } else { + sql.order_desc("timestamp"); + } + match filter { FilterMode::Global => &mut sql, FilterMode::Host => sql.and_where_eq("hostname", quote(&context.hostname)), -- cgit v1.3.1