mirror of
https://github.com/nushell/nushell
synced 2024-12-31 23:39:00 +00:00
commit
d532f3f304
1 changed files with 40 additions and 32 deletions
|
@ -68,6 +68,39 @@ fn eval_call(context: &EvaluationContext, call: &Call, input: Value) -> Result<V
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fn eval_external(
|
||||||
|
context: &EvaluationContext,
|
||||||
|
name: &Span,
|
||||||
|
args: &[Span],
|
||||||
|
input: Value,
|
||||||
|
) -> Result<Value, ShellError> {
|
||||||
|
let engine_state = context.engine_state.borrow();
|
||||||
|
|
||||||
|
let decl_id = engine_state
|
||||||
|
.find_decl("run_external".as_bytes())
|
||||||
|
.ok_or_else(|| ShellError::ExternalNotSupported(*name))?;
|
||||||
|
|
||||||
|
let command = engine_state.get_decl(decl_id);
|
||||||
|
|
||||||
|
let mut call = Call::new();
|
||||||
|
call.positional = [*name]
|
||||||
|
.iter()
|
||||||
|
.chain(args.iter())
|
||||||
|
.map(|span| {
|
||||||
|
let contents = engine_state.get_span_contents(span);
|
||||||
|
let val = String::from_utf8_lossy(contents);
|
||||||
|
Expression {
|
||||||
|
expr: Expr::String(val.into()),
|
||||||
|
span: *span,
|
||||||
|
ty: Type::String,
|
||||||
|
custom_completion: None,
|
||||||
|
}
|
||||||
|
})
|
||||||
|
.collect();
|
||||||
|
|
||||||
|
command.run(context, &call, input)
|
||||||
|
}
|
||||||
|
|
||||||
pub fn eval_expression(
|
pub fn eval_expression(
|
||||||
context: &EvaluationContext,
|
context: &EvaluationContext,
|
||||||
expr: &Expression,
|
expr: &Expression,
|
||||||
|
@ -125,38 +158,7 @@ pub fn eval_expression(
|
||||||
}
|
}
|
||||||
Expr::RowCondition(_, expr) => eval_expression(context, expr),
|
Expr::RowCondition(_, expr) => eval_expression(context, expr),
|
||||||
Expr::Call(call) => eval_call(context, call, Value::nothing()),
|
Expr::Call(call) => eval_call(context, call, Value::nothing()),
|
||||||
Expr::ExternalCall(name, args) => {
|
Expr::ExternalCall(name, args) => eval_external(context, name, args, Value::nothing()),
|
||||||
let engine_state = context.engine_state.borrow();
|
|
||||||
|
|
||||||
let decl_id = engine_state
|
|
||||||
.find_decl("run_external".as_bytes())
|
|
||||||
.ok_or_else(|| ShellError::ExternalNotSupported(*name))?;
|
|
||||||
|
|
||||||
let command = engine_state.get_decl(decl_id);
|
|
||||||
let new_context = context.enter_scope();
|
|
||||||
|
|
||||||
let mut call = Call::new();
|
|
||||||
call.positional = [*name]
|
|
||||||
.iter()
|
|
||||||
.chain(args.iter())
|
|
||||||
.map(|span| {
|
|
||||||
let contents = engine_state.get_span_contents(span);
|
|
||||||
let val = String::from_utf8_lossy(contents);
|
|
||||||
Expression {
|
|
||||||
expr: Expr::String(val.into()),
|
|
||||||
span: *span,
|
|
||||||
ty: Type::String,
|
|
||||||
custom_completion: None,
|
|
||||||
}
|
|
||||||
})
|
|
||||||
.collect();
|
|
||||||
|
|
||||||
let value = Value::Nothing {
|
|
||||||
span: Span::new(0, 1),
|
|
||||||
};
|
|
||||||
|
|
||||||
command.run(&new_context, &call, value)
|
|
||||||
}
|
|
||||||
Expr::Operator(_) => Ok(Value::Nothing { span: expr.span }),
|
Expr::Operator(_) => Ok(Value::Nothing { span: expr.span }),
|
||||||
Expr::BinaryOp(lhs, op, rhs) => {
|
Expr::BinaryOp(lhs, op, rhs) => {
|
||||||
let op_span = op.span;
|
let op_span = op.span;
|
||||||
|
@ -247,6 +249,12 @@ pub fn eval_block(
|
||||||
} => {
|
} => {
|
||||||
input = eval_call(context, call, input)?;
|
input = eval_call(context, call, input)?;
|
||||||
}
|
}
|
||||||
|
Expression {
|
||||||
|
expr: Expr::ExternalCall(name, args),
|
||||||
|
..
|
||||||
|
} => {
|
||||||
|
input = eval_external(context, name, args, input)?;
|
||||||
|
}
|
||||||
|
|
||||||
elem => {
|
elem => {
|
||||||
input = eval_expression(context, elem)?;
|
input = eval_expression(context, elem)?;
|
||||||
|
|
Loading…
Reference in a new issue