Add a module command

This commit is contained in:
Jakub Žádník 2021-09-26 01:59:18 +03:00
parent a176f12c9e
commit e9f1575924
3 changed files with 32 additions and 7 deletions

View File

@ -7,7 +7,7 @@ use nu_protocol::{
use crate::{ use crate::{
where_::Where, Alias, Benchmark, BuildString, Def, Do, Each, External, For, Git, GitCheckout, where_::Where, Alias, Benchmark, BuildString, Def, Do, Each, External, For, Git, GitCheckout,
If, Length, Let, LetEnv, Lines, ListGitBranches, Ls, Table, If, Length, Let, LetEnv, Lines, ListGitBranches, Ls, Module, Table,
}; };
pub fn create_default_context() -> Rc<RefCell<EngineState>> { pub fn create_default_context() -> Rc<RefCell<EngineState>> {
@ -46,6 +46,8 @@ pub fn create_default_context() -> Rc<RefCell<EngineState>> {
working_set.add_decl(Box::new(Ls)); working_set.add_decl(Box::new(Ls));
working_set.add_decl(Box::new(Module));
working_set.add_decl(Box::new(Table)); working_set.add_decl(Box::new(Table));
working_set.add_decl(Box::new(External)); working_set.add_decl(Box::new(External));

View File

@ -16,6 +16,7 @@ mod lines;
mod list_git_branches; mod list_git_branches;
mod ls; mod ls;
mod run_external; mod run_external;
mod module;
mod table; mod table;
mod where_; mod where_;
@ -37,4 +38,5 @@ pub use lines::Lines;
pub use list_git_branches::ListGitBranches; pub use list_git_branches::ListGitBranches;
pub use ls::Ls; pub use ls::Ls;
pub use run_external::External; pub use run_external::External;
pub use module::Module;
pub use table::Table; pub use table::Table;

View File

@ -2747,13 +2747,34 @@ pub fn parse_module(
working_set.exit_scope(); working_set.exit_scope();
// WIP error: let block_id = working_set.add_block(block);
let block_expr = Expression {
expr: Expr::Block(block_id),
span: block_span,
ty: Type::Block,
custom_completion: None,
};
let module_decl_id = working_set
.find_decl(b"module")
.expect("internal error: missing module command");
let call = Box::new(Call {
head: spans[0],
decl_id: module_decl_id,
positional: vec![name_expr, block_expr],
named: vec![],
});
( (
garbage_statement(spans), Statement::Pipeline(Pipeline::from_vec(vec![Expression {
Some(ParseError::UnknownState( expr: Expr::Call(call),
"This is OK module".into(), span: span(spans),
span(spans), ty: Type::Unknown,
)), custom_completion: None,
}])),
error,
) )
} else { } else {
( (