mirror of
https://github.com/nushell/nushell
synced 2025-01-13 21:55:07 +00:00
add like
and not-like
operators as synonyms for the regex operators =~
and !~
(#14072)
# Description This PR adds `like` as a synonym for `=~` and `not-like` as a synonym for `!~`. This is mainly a quality-of-life change to help those people who think in sql. ![image](https://github.com/user-attachments/assets/a0b142cd-30c9-487d-b755-d6da0a0874ec) closes #13261 # User-Facing Changes <!-- List of all changes that impact the user experience here. This helps us keep track of breaking changes. --> # Tests + Formatting <!-- Don't forget to add tests that cover your changes. Make sure you've run and fixed any issues with these commands: - `cargo fmt --all -- --check` to check standard code formatting (`cargo fmt --all` applies these changes) - `cargo clippy --workspace -- -D warnings -D clippy::unwrap_used` to check that you're using the standard code style - `cargo test --workspace` to check that all tests pass (on Windows make sure to [enable developer mode](https://learn.microsoft.com/en-us/windows/apps/get-started/developer-mode-features-and-debugging)) - `cargo run -- -c "use toolkit.nu; toolkit test stdlib"` to run the tests for the standard library > **Note** > from `nushell` you can also use the `toolkit` as follows > ```bash > use toolkit.nu # or use an `env_change` hook to activate it automatically > toolkit check pr > ``` --> # After Submitting <!-- If your PR had any user-facing changes, update [the documentation](https://github.com/nushell/nushell.github.io) after the PR is merged, if necessary. This will help us keep the docs up to date. -->
This commit is contained in:
parent
6230a62e9e
commit
043d1ed9fb
4 changed files with 9 additions and 7 deletions
|
@ -67,7 +67,9 @@ impl Completer for OperatorCompletion {
|
||||||
],
|
],
|
||||||
Expr::String(_) => vec![
|
Expr::String(_) => vec![
|
||||||
("=~", "Contains regex match"),
|
("=~", "Contains regex match"),
|
||||||
|
("like", "Contains regex match"),
|
||||||
("!~", "Does not contain regex match"),
|
("!~", "Does not contain regex match"),
|
||||||
|
("not-like", "Does not contain regex match"),
|
||||||
(
|
(
|
||||||
"++",
|
"++",
|
||||||
"Appends two lists, a list and a value, two strings, or two binary values",
|
"Appends two lists, a list and a value, two strings, or two binary values",
|
||||||
|
|
|
@ -5018,8 +5018,8 @@ pub fn parse_operator(working_set: &mut StateWorkingSet, span: Span) -> Expressi
|
||||||
b"<=" => Operator::Comparison(Comparison::LessThanOrEqual),
|
b"<=" => Operator::Comparison(Comparison::LessThanOrEqual),
|
||||||
b">" => Operator::Comparison(Comparison::GreaterThan),
|
b">" => Operator::Comparison(Comparison::GreaterThan),
|
||||||
b">=" => Operator::Comparison(Comparison::GreaterThanOrEqual),
|
b">=" => Operator::Comparison(Comparison::GreaterThanOrEqual),
|
||||||
b"=~" => Operator::Comparison(Comparison::RegexMatch),
|
b"=~" | b"like" => Operator::Comparison(Comparison::RegexMatch),
|
||||||
b"!~" => Operator::Comparison(Comparison::NotRegexMatch),
|
b"!~" | b"not-like" => Operator::Comparison(Comparison::NotRegexMatch),
|
||||||
b"+" => Operator::Math(Math::Plus),
|
b"+" => Operator::Math(Math::Plus),
|
||||||
b"++" => Operator::Math(Math::Append),
|
b"++" => Operator::Math(Math::Append),
|
||||||
b"-" => Operator::Math(Math::Minus),
|
b"-" => Operator::Math(Math::Minus),
|
||||||
|
|
|
@ -115,8 +115,8 @@ impl Display for Operator {
|
||||||
Operator::Comparison(Comparison::NotEqual) => write!(f, "!="),
|
Operator::Comparison(Comparison::NotEqual) => write!(f, "!="),
|
||||||
Operator::Comparison(Comparison::LessThan) => write!(f, "<"),
|
Operator::Comparison(Comparison::LessThan) => write!(f, "<"),
|
||||||
Operator::Comparison(Comparison::GreaterThan) => write!(f, ">"),
|
Operator::Comparison(Comparison::GreaterThan) => write!(f, ">"),
|
||||||
Operator::Comparison(Comparison::RegexMatch) => write!(f, "=~"),
|
Operator::Comparison(Comparison::RegexMatch) => write!(f, "=~ or like"),
|
||||||
Operator::Comparison(Comparison::NotRegexMatch) => write!(f, "!~"),
|
Operator::Comparison(Comparison::NotRegexMatch) => write!(f, "!~ or not-like"),
|
||||||
Operator::Comparison(Comparison::LessThanOrEqual) => write!(f, "<="),
|
Operator::Comparison(Comparison::LessThanOrEqual) => write!(f, "<="),
|
||||||
Operator::Comparison(Comparison::GreaterThanOrEqual) => write!(f, ">="),
|
Operator::Comparison(Comparison::GreaterThanOrEqual) => write!(f, ">="),
|
||||||
Operator::Comparison(Comparison::StartsWith) => write!(f, "starts-with"),
|
Operator::Comparison(Comparison::StartsWith) => write!(f, "starts-with"),
|
||||||
|
|
|
@ -47,8 +47,8 @@ def get-all-operators [] { return [
|
||||||
[Comparison, <=, LessThanOrEqual, "Checks if a value is less than or equal to another.", 80]
|
[Comparison, <=, LessThanOrEqual, "Checks if a value is less than or equal to another.", 80]
|
||||||
[Comparison, >, GreaterThan, "Checks if a value is greater than another.", 80]
|
[Comparison, >, GreaterThan, "Checks if a value is greater than another.", 80]
|
||||||
[Comparison, >=, GreaterThanOrEqual, "Checks if a value is greater than or equal to another.", 80]
|
[Comparison, >=, GreaterThanOrEqual, "Checks if a value is greater than or equal to another.", 80]
|
||||||
[Comparison, =~, RegexMatch, "Checks if a value matches a regular expression.", 80]
|
[Comparison, '=~ or like', RegexMatch, "Checks if a value matches a regular expression.", 80]
|
||||||
[Comparison, !~, NotRegexMatch, "Checks if a value does not match a regular expression.", 80]
|
[Comparison, '!~ or not-like', NotRegexMatch, "Checks if a value does not match a regular expression.", 80]
|
||||||
[Comparison, in, In, "Checks if a value is in a list or string.", 80]
|
[Comparison, in, In, "Checks if a value is in a list or string.", 80]
|
||||||
[Comparison, not-in, NotIn, "Checks if a value is not in a list or string.", 80]
|
[Comparison, not-in, NotIn, "Checks if a value is not in a list or string.", 80]
|
||||||
[Comparison, starts-with, StartsWith, "Checks if a string starts with another.", 80]
|
[Comparison, starts-with, StartsWith, "Checks if a string starts with another.", 80]
|
||||||
|
|
Loading…
Reference in a new issue