From 87765c27da3103787922d695d38e19e2d6f1af31 Mon Sep 17 00:00:00 2001 From: Pavel Ivanov Date: Fri, 2 Jun 2023 20:47:50 +0200 Subject: [PATCH 1/5] fix: benchmarks build fixed --- Cargo.lock | 2 +- Cargo.toml | 2 +- benches/parse-and-format.rs | 2 ++ src/settings.rs | 2 +- 4 files changed, 5 insertions(+), 3 deletions(-) diff --git a/Cargo.lock b/Cargo.lock index 546d8830..8ce4961b 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -785,7 +785,7 @@ dependencies = [ [[package]] name = "hl" -version = "0.15.1" +version = "0.15.2-alpha.1" dependencies = [ "anyhow", "atoi", diff --git a/Cargo.toml b/Cargo.toml index b39e7b5b..29eb47b5 100644 --- a/Cargo.toml +++ b/Cargo.toml @@ -4,7 +4,7 @@ categories = ["command-line-utilities"] description = "Utility for viewing json-formatted log files." keywords = ["cli", "human", "log"] name = "hl" -version = "0.15.1" +version = "0.15.2-alpha.1" edition = "2021" # See more keys and their definitions at https://doc.rust-lang.org/cargo/reference/manifest.html diff --git a/benches/parse-and-format.rs b/benches/parse-and-format.rs index 2b2bf951..c803d30c 100644 --- a/benches/parse-and-format.rs +++ b/benches/parse-and-format.rs @@ -10,6 +10,7 @@ use criterion::{criterion_group, criterion_main, Criterion}; use hl::{ timezone::Tz, DateTimeFormatter, Filter, IncludeExcludeKeyFilter, LinuxDateFormat, Parser, ParserSettings, RecordFormatter, SegmentProcesor, Settings, Theme, + settings, }; // --- @@ -29,6 +30,7 @@ fn benchmark(c: &mut Criterion) { ), false, Arc::new(IncludeExcludeKeyFilter::default()), + settings::Formatting::default(), ); let filter = Filter::default(); let mut processor = SegmentProcesor::new(&parser, &mut formatter, &filter); diff --git a/src/settings.rs b/src/settings.rs index f1c8091a..678fb613 100644 --- a/src/settings.rs +++ b/src/settings.rs @@ -117,7 +117,7 @@ pub struct Field { // --- -#[derive(Debug, Deserialize, Clone)] +#[derive(Clone, Debug, Default, Deserialize)] pub struct Formatting { pub punctuation: Punctuation, } From bb6264bdf9a5ab448e6b20d550928374cf477751 Mon Sep 17 00:00:00 2001 From: Pavel Ivanov Date: Sat, 10 Jun 2023 20:39:50 +0200 Subject: [PATCH 2/5] new: added go module file to go benchmarks --- benches/go/go.mod | 3 +++ 1 file changed, 3 insertions(+) create mode 100644 benches/go/go.mod diff --git a/benches/go/go.mod b/benches/go/go.mod new file mode 100644 index 00000000..64d58b2a --- /dev/null +++ b/benches/go/go.mod @@ -0,0 +1,3 @@ +module github.com/pamburus/hl/benches/go + +go 1.20 From d37ab373ce3c4107aaae42b36c3b07963aa2c58b Mon Sep 17 00:00:00 2001 From: Pavel Ivanov Date: Sat, 10 Jun 2023 20:12:20 +0200 Subject: [PATCH 3/5] fix: fixed typo in segment processor --- benches/parse-and-format.rs | 4 ++-- src/app.rs | 6 +++--- src/lib.rs | 2 +- 3 files changed, 6 insertions(+), 6 deletions(-) diff --git a/benches/parse-and-format.rs b/benches/parse-and-format.rs index c803d30c..b6178092 100644 --- a/benches/parse-and-format.rs +++ b/benches/parse-and-format.rs @@ -9,7 +9,7 @@ use criterion::{criterion_group, criterion_main, Criterion}; // local imports use hl::{ timezone::Tz, DateTimeFormatter, Filter, IncludeExcludeKeyFilter, LinuxDateFormat, Parser, - ParserSettings, RecordFormatter, SegmentProcesor, Settings, Theme, + ParserSettings, RecordFormatter, SegmentProcessor, Settings, Theme, settings, }; @@ -33,7 +33,7 @@ fn benchmark(c: &mut Criterion) { settings::Formatting::default(), ); let filter = Filter::default(); - let mut processor = SegmentProcesor::new(&parser, &mut formatter, &filter); + let mut processor = SegmentProcessor::new(&parser, &mut formatter, &filter); let mut buf = Vec::new(); b.iter(|| { processor.run(record, &mut buf); diff --git a/src/app.rs b/src/app.rs index b95ceaf5..72e9ada7 100644 --- a/src/app.rs +++ b/src/app.rs @@ -94,7 +94,7 @@ impl App { self.options.formatting.clone(), ) .with_field_unescaping(!self.options.raw_fields); - let mut processor = SegmentProcesor::new(&parser, &mut formatter, &self.options.filter); + let mut processor = SegmentProcessor::new(&parser, &mut formatter, &self.options.filter); for segment in rxi.iter() { match segment { Segment::Complete(segment) => { @@ -144,13 +144,13 @@ impl App { // --- -pub struct SegmentProcesor<'a> { +pub struct SegmentProcessor<'a> { parser: &'a Parser, formatter: &'a mut RecordFormatter, filter: &'a Filter, } -impl<'a> SegmentProcesor<'a> { +impl<'a> SegmentProcessor<'a> { pub fn new(parser: &'a Parser, formatter: &'a mut RecordFormatter, filter: &'a Filter) -> Self { Self { parser, diff --git a/src/lib.rs b/src/lib.rs index 34d15ec0..7a7f2237 100644 --- a/src/lib.rs +++ b/src/lib.rs @@ -27,7 +27,7 @@ mod scanning; pub mod signal; // public uses -pub use app::{App, FieldOptions, Options, SegmentProcesor}; +pub use app::{App, FieldOptions, Options, SegmentProcessor}; pub use datefmt::{DateTimeFormatter, LinuxDateFormat}; pub use filtering::DefaultNormalizing; pub use formatting::RecordFormatter; From 91faac1fa6d8ed6e36a35fd069c003169568ac54 Mon Sep 17 00:00:00 2001 From: Pavel Ivanov Date: Sat, 10 Jun 2023 10:03:35 +0200 Subject: [PATCH 4/5] fix: fixed typo in conceal --- src/eseq.rs | 2 +- src/theme.rs | 2 +- src/themecfg.rs | 2 +- 3 files changed, 3 insertions(+), 3 deletions(-) diff --git a/src/eseq.rs b/src/eseq.rs index f1abf79e..18735a51 100644 --- a/src/eseq.rs +++ b/src/eseq.rs @@ -14,7 +14,7 @@ pub enum Mode { SlowBlink, RapidBlink, Reverse, - Conseal, + Conceal, CrossedOut, } diff --git a/src/theme.rs b/src/theme.rs index a1112534..19b37fbf 100644 --- a/src/theme.rs +++ b/src/theme.rs @@ -162,7 +162,7 @@ impl From<&themecfg::Style> for Style { codes.push( match mode { themecfg::Mode::Bold => Mode::Bold, - themecfg::Mode::Conseal => Mode::Conseal, + themecfg::Mode::Conceal => Mode::Conceal, themecfg::Mode::CrossedOut => Mode::CrossedOut, themecfg::Mode::Faint => Mode::Faint, themecfg::Mode::Italic => Mode::Italic, diff --git a/src/themecfg.rs b/src/themecfg.rs index 4191dcdf..933c9d12 100644 --- a/src/themecfg.rs +++ b/src/themecfg.rs @@ -222,7 +222,7 @@ pub enum Mode { SlowBlink, RapidBlink, Reverse, - Conseal, + Conceal, CrossedOut, } From 8c770b9ed7dc8ce7462792c35082e022c2156ec2 Mon Sep 17 00:00:00 2001 From: Pavel Ivanov Date: Tue, 6 Jun 2023 15:26:31 +0200 Subject: [PATCH 5/5] new: now colon delimiter can be used in `--filter` command line option --- Cargo.lock | 2 +- Cargo.toml | 2 +- src/model.rs | 32 +++++++++++++++++++------------- 3 files changed, 21 insertions(+), 15 deletions(-) diff --git a/Cargo.lock b/Cargo.lock index 8ce4961b..342b5b99 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -785,7 +785,7 @@ dependencies = [ [[package]] name = "hl" -version = "0.15.2-alpha.1" +version = "0.15.2" dependencies = [ "anyhow", "atoi", diff --git a/Cargo.toml b/Cargo.toml index 29eb47b5..6829b889 100644 --- a/Cargo.toml +++ b/Cargo.toml @@ -4,7 +4,7 @@ categories = ["command-line-utilities"] description = "Utility for viewing json-formatted log files." keywords = ["cli", "human", "log"] name = "hl" -version = "0.15.2-alpha.1" +version = "0.15.2" edition = "2021" # See more keys and their definitions at https://doc.rust-lang.org/cargo/reference/manifest.html diff --git a/src/model.rs b/src/model.rs index f9159478..d2962d3f 100644 --- a/src/model.rs +++ b/src/model.rs @@ -482,20 +482,26 @@ pub struct FieldFilter { impl FieldFilter { fn parse(text: &str) -> Result { - let mut parts = text.split('='); - match (parts.next(), parts.next()) { - (Some(key), Some(value)) => { - let (key, match_policy, op) = Self::parse_mp_op(key, value)?; - let flat_key = key.as_bytes().iter().position(|&x| x == b'.').is_none(); - Ok(Self { - key: key.into(), - match_policy, - op, - flat_key, - }) - } - _ => Err(Error::WrongFieldFilter(text.into())), + let parse = |key, value| { + let (key, match_policy, op) = Self::parse_mp_op(key, value)?; + let flat_key = key.as_bytes().iter().position(|&x| x == b'.').is_none(); + Ok(Self { + key: key.into(), + match_policy, + op, + flat_key, + }) + }; + + if let Some(index) = text.find('=') { + return parse(&text[0..index], &text[index+1..]); } + + if let Some(index) = text.find(':') { + return parse(&text[0..index], &text[index+1..]); + } + + Err(Error::WrongFieldFilter(text.into())) } fn parse_mp_op<'k>(