mirror of
https://github.com/nushell/nushell.git
synced 2025-01-26 08:08:38 +01:00
Refactor external command (#6083)
Co-authored-by: Frank <v-frankz@microsoft.com>
This commit is contained in:
parent
0bcfa12e0d
commit
0646f1118c
@ -142,7 +142,7 @@ fn help(
|
|||||||
|
|
||||||
cols.push("is_custom".into());
|
cols.push("is_custom".into());
|
||||||
vals.push(Value::Bool {
|
vals.push(Value::Bool {
|
||||||
val: decl.get_block_id().is_some(),
|
val: decl.is_custom_command(),
|
||||||
span: head,
|
span: head,
|
||||||
});
|
});
|
||||||
|
|
||||||
@ -243,7 +243,7 @@ fn help(
|
|||||||
|
|
||||||
cols.push("is_custom".into());
|
cols.push("is_custom".into());
|
||||||
vals.push(Value::Bool {
|
vals.push(Value::Bool {
|
||||||
val: decl.get_block_id().is_some(),
|
val: decl.is_custom_command(),
|
||||||
span: head,
|
span: head,
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -95,7 +95,7 @@ fn get_entry_in_aliases(engine_state: &EngineState, name: &str, span: Span) -> O
|
|||||||
|
|
||||||
fn get_entry_in_commands(engine_state: &EngineState, name: &str, span: Span) -> Option<Value> {
|
fn get_entry_in_commands(engine_state: &EngineState, name: &str, span: Span) -> Option<Value> {
|
||||||
if let Some(decl_id) = engine_state.find_decl(name.as_bytes(), &[]) {
|
if let Some(decl_id) = engine_state.find_decl(name.as_bytes(), &[]) {
|
||||||
let (msg, is_builtin) = if engine_state.get_decl(decl_id).get_block_id().is_some() {
|
let (msg, is_builtin) = if engine_state.get_decl(decl_id).is_custom_command() {
|
||||||
("Nushell custom command", false)
|
("Nushell custom command", false)
|
||||||
} else {
|
} else {
|
||||||
("Nushell built-in command", true)
|
("Nushell built-in command", true)
|
||||||
|
@ -1121,7 +1121,7 @@ pub fn create_scope(
|
|||||||
cols.push("is_builtin".to_string());
|
cols.push("is_builtin".to_string());
|
||||||
// we can only be a is_builtin or is_custom, not both
|
// we can only be a is_builtin or is_custom, not both
|
||||||
vals.push(Value::Bool {
|
vals.push(Value::Bool {
|
||||||
val: decl.get_block_id().is_none(),
|
val: !decl.is_custom_command(),
|
||||||
span,
|
span,
|
||||||
});
|
});
|
||||||
|
|
||||||
@ -1139,7 +1139,7 @@ pub fn create_scope(
|
|||||||
|
|
||||||
cols.push("is_custom".to_string());
|
cols.push("is_custom".to_string());
|
||||||
vals.push(Value::Bool {
|
vals.push(Value::Bool {
|
||||||
val: decl.get_block_id().is_some(),
|
val: decl.is_custom_command(),
|
||||||
span,
|
span,
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -30,6 +30,10 @@ impl Command for KnownExternal {
|
|||||||
true
|
true
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fn is_builtin(&self) -> bool {
|
||||||
|
false
|
||||||
|
}
|
||||||
|
|
||||||
fn run(
|
fn run(
|
||||||
&self,
|
&self,
|
||||||
engine_state: &EngineState,
|
engine_state: &EngineState,
|
||||||
|
@ -1079,26 +1079,32 @@ pub fn parse_call(
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
trace!("parsing: internal call");
|
let decl = working_set.get_decl(decl_id);
|
||||||
|
if decl.is_builtin() {
|
||||||
|
trace!("parsing: internal call");
|
||||||
|
|
||||||
// parse internal command
|
// parse internal command
|
||||||
let parsed_call = parse_internal_call(
|
let parsed_call = parse_internal_call(
|
||||||
working_set,
|
working_set,
|
||||||
span(&spans[cmd_start..pos]),
|
span(&spans[cmd_start..pos]),
|
||||||
&spans[pos..],
|
&spans[pos..],
|
||||||
decl_id,
|
decl_id,
|
||||||
expand_aliases_denylist,
|
expand_aliases_denylist,
|
||||||
);
|
);
|
||||||
|
|
||||||
(
|
(
|
||||||
Expression {
|
Expression {
|
||||||
expr: Expr::Call(parsed_call.call),
|
expr: Expr::Call(parsed_call.call),
|
||||||
span: span(spans),
|
span: span(spans),
|
||||||
ty: parsed_call.output,
|
ty: parsed_call.output,
|
||||||
custom_completion: None,
|
custom_completion: None,
|
||||||
},
|
},
|
||||||
parsed_call.error,
|
parsed_call.error,
|
||||||
)
|
)
|
||||||
|
} else {
|
||||||
|
trace!("parsing: `extern` custom command as external call");
|
||||||
|
parse_external_call(working_set, spans, expand_aliases_denylist)
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
// We might be parsing left-unbounded range ("..10")
|
// We might be parsing left-unbounded range ("..10")
|
||||||
let bytes = working_set.get_span_contents(spans[0]);
|
let bytes = working_set.get_span_contents(spans[0]);
|
||||||
|
@ -37,6 +37,16 @@ pub trait Command: Send + Sync + CommandClone {
|
|||||||
false
|
false
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// This is an enhanced method to determine if a command is custom command or not
|
||||||
|
// since extern "foo" [] and def "foo" [] behaves differently
|
||||||
|
fn is_custom_command(&self) -> bool {
|
||||||
|
if self.get_block_id().is_some() {
|
||||||
|
true
|
||||||
|
} else {
|
||||||
|
self.is_known_external()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// Is a sub command
|
// Is a sub command
|
||||||
fn is_sub(&self) -> bool {
|
fn is_sub(&self) -> bool {
|
||||||
self.name().contains(' ')
|
self.name().contains(' ')
|
||||||
|
@ -12,7 +12,23 @@ fn known_external_runs() -> TestResult {
|
|||||||
fn known_external_unknown_flag() -> TestResult {
|
fn known_external_unknown_flag() -> TestResult {
|
||||||
fail_test(
|
fail_test(
|
||||||
r#"extern "cargo version" []; cargo version --no-such-flag"#,
|
r#"extern "cargo version" []; cargo version --no-such-flag"#,
|
||||||
"command doesn't have flag",
|
"Found argument '--no-such-flag' which wasn't expected, or isn't valid in this context",
|
||||||
|
)
|
||||||
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn known_external_not_defined_flag() -> TestResult {
|
||||||
|
run_test_contains(
|
||||||
|
r#"extern "cargo version" []; cargo version --help"#,
|
||||||
|
"Show version information",
|
||||||
|
)
|
||||||
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn known_external_is_custom() -> TestResult {
|
||||||
|
run_test_contains(
|
||||||
|
r#"extern "cargo version" []; help commands | where is_custom == true | get name"#,
|
||||||
|
"cargo version",
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user