From 5a240f36b9251fd6513316333acb969a4d347b9d Mon Sep 17 00:00:00 2001 From: Nicolas AMBRY <34007152+AmbryN@users.noreply.github.com> Date: Thu, 14 Sep 2023 16:04:43 +0200 Subject: [PATCH] Case insensitive `--map-syntax` (#2650) Co-authored-by: Nicolas AMBRY --- CHANGELOG.md | 1 + src/syntax_mapping.rs | 2 +- tests/examples/map-syntax_case.Config | 1 + tests/integration_tests.rs | 24 ++++++++++++++++++++++++ 4 files changed, 27 insertions(+), 1 deletion(-) create mode 100644 tests/examples/map-syntax_case.Config diff --git a/CHANGELOG.md b/CHANGELOG.md index f00211a7..d921f9bb 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -8,6 +8,7 @@ ## Bugfixes - Fix `more` not being found on Windows when provided via `BAT_PAGER`, see #2570, #2580, and #2651 (@mataha) +- Switched default behavior of `--map-syntax` to be case insensitive #2520 ## Other diff --git a/src/syntax_mapping.rs b/src/syntax_mapping.rs index 93b1dc81..d4331bb8 100644 --- a/src/syntax_mapping.rs +++ b/src/syntax_mapping.rs @@ -211,7 +211,7 @@ impl<'a> SyntaxMapping<'a> { pub fn insert(&mut self, from: &str, to: MappingTarget<'a>) -> Result<()> { let glob = GlobBuilder::new(from) - .case_insensitive(false) + .case_insensitive(true) .literal_separator(true) .build()?; self.mappings.push((glob.compile_matcher(), to)); diff --git a/tests/examples/map-syntax_case.Config b/tests/examples/map-syntax_case.Config new file mode 100644 index 00000000..ebd70c12 --- /dev/null +++ b/tests/examples/map-syntax_case.Config @@ -0,0 +1 @@ +{"test": "value"} diff --git a/tests/integration_tests.rs b/tests/integration_tests.rs index aa5ca845..63a4537e 100644 --- a/tests/integration_tests.rs +++ b/tests/integration_tests.rs @@ -2385,3 +2385,27 @@ fn lessopen_validity() { "\u{1b}[33m[bat warning]\u{1b}[0m: LESSOPEN ignored: must contain exactly one %s\n", ); } + +// Regression test for issue #2520 and PR #2650 +// Syntax highlighting should be the same regardless of +// --map-syntax' case or file extension's case +#[test] +fn highlighting_independant_from_map_syntax_case() { + let expected = bat() + .arg("-f") + .arg("--map-syntax=*.config:JSON") + .arg("map-syntax_case.Config") + .assert() + .get_output() + .stdout + .clone(); + + bat() + .arg("-f") + .arg("--map-syntax=*.Config:JSON") + .arg("map-syntax_case.Config") + .assert() + .success() + .stdout(expected) + .stderr(""); +}