mirror of
https://github.com/nushell/nushell
synced 2025-01-14 22:24:54 +00:00
Refactor: simplify lex_item impl (#10744)
In the final match of `lex_item`, we'll return `Err(ParseError)` in rare case, normally we'll return None. So I think making error part mutable can reduce some code, and it's better if we want to add more lex items.
This commit is contained in:
parent
ed8dee04b6
commit
9e7f84afb0
1 changed files with 32 additions and 42 deletions
|
@ -254,57 +254,47 @@ pub fn lex_item(
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
match &input[(span.start - span_offset)..(span.end - span_offset)] {
|
let mut err = None;
|
||||||
b"out>" | b"o>" => (
|
let output = match &input[(span.start - span_offset)..(span.end - span_offset)] {
|
||||||
Token {
|
b"out>" | b"o>" => Token {
|
||||||
contents: TokenContents::OutGreaterThan,
|
contents: TokenContents::OutGreaterThan,
|
||||||
span,
|
span,
|
||||||
},
|
},
|
||||||
None,
|
b"err>" | b"e>" => Token {
|
||||||
),
|
|
||||||
b"err>" | b"e>" => (
|
|
||||||
Token {
|
|
||||||
contents: TokenContents::ErrGreaterThan,
|
contents: TokenContents::ErrGreaterThan,
|
||||||
span,
|
span,
|
||||||
},
|
},
|
||||||
None,
|
b"out+err>" | b"err+out>" | b"o+e>" | b"e+o>" => Token {
|
||||||
),
|
|
||||||
b"out+err>" | b"err+out>" | b"o+e>" | b"e+o>" => (
|
|
||||||
Token {
|
|
||||||
contents: TokenContents::OutErrGreaterThan,
|
contents: TokenContents::OutErrGreaterThan,
|
||||||
span,
|
span,
|
||||||
},
|
},
|
||||||
None,
|
b"&&" => {
|
||||||
),
|
err = Some(ParseError::ShellAndAnd(span));
|
||||||
b"&&" => (
|
|
||||||
Token {
|
Token {
|
||||||
contents: TokenContents::Item,
|
contents: TokenContents::Item,
|
||||||
span,
|
span,
|
||||||
},
|
|
||||||
Some(ParseError::ShellAndAnd(span)),
|
|
||||||
),
|
|
||||||
b"2>" => (
|
|
||||||
Token {
|
|
||||||
contents: TokenContents::Item,
|
|
||||||
span,
|
|
||||||
},
|
|
||||||
Some(ParseError::ShellErrRedirect(span)),
|
|
||||||
),
|
|
||||||
b"2>&1" => (
|
|
||||||
Token {
|
|
||||||
contents: TokenContents::Item,
|
|
||||||
span,
|
|
||||||
},
|
|
||||||
Some(ParseError::ShellOutErrRedirect(span)),
|
|
||||||
),
|
|
||||||
_ => (
|
|
||||||
Token {
|
|
||||||
contents: TokenContents::Item,
|
|
||||||
span,
|
|
||||||
},
|
|
||||||
None,
|
|
||||||
),
|
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
b"2>" => {
|
||||||
|
err = Some(ParseError::ShellErrRedirect(span));
|
||||||
|
Token {
|
||||||
|
contents: TokenContents::Item,
|
||||||
|
span,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
b"2>&1" => {
|
||||||
|
err = Some(ParseError::ShellOutErrRedirect(span));
|
||||||
|
Token {
|
||||||
|
contents: TokenContents::Item,
|
||||||
|
span,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
_ => Token {
|
||||||
|
contents: TokenContents::Item,
|
||||||
|
span,
|
||||||
|
},
|
||||||
|
};
|
||||||
|
(output, err)
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn lex_signature(
|
pub fn lex_signature(
|
||||||
|
|
Loading…
Reference in a new issue