2019-08-29 22:52:32 +00:00
|
|
|
use crate::commands::command::Command;
|
Extract core stuff into own crates
This commit extracts five new crates:
- nu-source, which contains the core source-code handling logic in Nu,
including Text, Span, and also the pretty.rs-based debug logic
- nu-parser, which is the parser and expander logic
- nu-protocol, which is the bulk of the types and basic conveniences
used by plugins
- nu-errors, which contains ShellError, ParseError and error handling
conveniences
- nu-textview, which is the textview plugin extracted into a crate
One of the major consequences of this refactor is that it's no longer
possible to `impl X for Spanned<Y>` outside of the `nu-source` crate, so
a lot of types became more concrete (Value became a concrete type
instead of Spanned<Value>, for example).
This also turned a number of inherent methods in the main nu crate into
plain functions (impl Value {} became a bunch of functions in the
`value` namespace in `crate::data::value`).
2019-11-26 02:30:48 +00:00
|
|
|
use crate::data::{TaggedDictBuilder, TaggedListBuilder};
|
2019-08-29 22:52:32 +00:00
|
|
|
use crate::prelude::*;
|
Extract core stuff into own crates
This commit extracts five new crates:
- nu-source, which contains the core source-code handling logic in Nu,
including Text, Span, and also the pretty.rs-based debug logic
- nu-parser, which is the parser and expander logic
- nu-protocol, which is the bulk of the types and basic conveniences
used by plugins
- nu-errors, which contains ShellError, ParseError and error handling
conveniences
- nu-textview, which is the textview plugin extracted into a crate
One of the major consequences of this refactor is that it's no longer
possible to `impl X for Spanned<Y>` outside of the `nu-source` crate, so
a lot of types became more concrete (Value became a concrete type
instead of Spanned<Value>, for example).
This also turned a number of inherent methods in the main nu crate into
plain functions (impl Value {} became a bunch of functions in the
`value` namespace in `crate::data::value`).
2019-11-26 02:30:48 +00:00
|
|
|
use nu_protocol::{NamedType, PositionalType, Signature, Value};
|
2019-08-29 22:52:32 +00:00
|
|
|
use std::ops::Deref;
|
|
|
|
|
2019-11-21 14:33:14 +00:00
|
|
|
pub(crate) fn command_dict(command: Arc<Command>, tag: impl Into<Tag>) -> Value {
|
2019-08-29 22:52:32 +00:00
|
|
|
let tag = tag.into();
|
|
|
|
|
2019-10-13 04:12:43 +00:00
|
|
|
let mut cmd_dict = TaggedDictBuilder::new(&tag);
|
2019-08-29 22:52:32 +00:00
|
|
|
|
Extract core stuff into own crates
This commit extracts five new crates:
- nu-source, which contains the core source-code handling logic in Nu,
including Text, Span, and also the pretty.rs-based debug logic
- nu-parser, which is the parser and expander logic
- nu-protocol, which is the bulk of the types and basic conveniences
used by plugins
- nu-errors, which contains ShellError, ParseError and error handling
conveniences
- nu-textview, which is the textview plugin extracted into a crate
One of the major consequences of this refactor is that it's no longer
possible to `impl X for Spanned<Y>` outside of the `nu-source` crate, so
a lot of types became more concrete (Value became a concrete type
instead of Spanned<Value>, for example).
This also turned a number of inherent methods in the main nu crate into
plain functions (impl Value {} became a bunch of functions in the
`value` namespace in `crate::data::value`).
2019-11-26 02:30:48 +00:00
|
|
|
cmd_dict.insert_untagged("name", value::string(command.name()));
|
2019-08-29 22:52:32 +00:00
|
|
|
|
2019-11-21 14:33:14 +00:00
|
|
|
cmd_dict.insert_untagged(
|
2019-08-29 22:52:32 +00:00
|
|
|
"type",
|
Extract core stuff into own crates
This commit extracts five new crates:
- nu-source, which contains the core source-code handling logic in Nu,
including Text, Span, and also the pretty.rs-based debug logic
- nu-parser, which is the parser and expander logic
- nu-protocol, which is the bulk of the types and basic conveniences
used by plugins
- nu-errors, which contains ShellError, ParseError and error handling
conveniences
- nu-textview, which is the textview plugin extracted into a crate
One of the major consequences of this refactor is that it's no longer
possible to `impl X for Spanned<Y>` outside of the `nu-source` crate, so
a lot of types became more concrete (Value became a concrete type
instead of Spanned<Value>, for example).
This also turned a number of inherent methods in the main nu crate into
plain functions (impl Value {} became a bunch of functions in the
`value` namespace in `crate::data::value`).
2019-11-26 02:30:48 +00:00
|
|
|
value::string(match command.deref() {
|
2019-08-29 22:52:32 +00:00
|
|
|
Command::WholeStream(_) => "Command",
|
|
|
|
Command::PerItem(_) => "Filter",
|
|
|
|
}),
|
|
|
|
);
|
|
|
|
|
2019-11-21 14:33:14 +00:00
|
|
|
cmd_dict.insert_value("signature", signature_dict(command.signature(), tag));
|
Extract core stuff into own crates
This commit extracts five new crates:
- nu-source, which contains the core source-code handling logic in Nu,
including Text, Span, and also the pretty.rs-based debug logic
- nu-parser, which is the parser and expander logic
- nu-protocol, which is the bulk of the types and basic conveniences
used by plugins
- nu-errors, which contains ShellError, ParseError and error handling
conveniences
- nu-textview, which is the textview plugin extracted into a crate
One of the major consequences of this refactor is that it's no longer
possible to `impl X for Spanned<Y>` outside of the `nu-source` crate, so
a lot of types became more concrete (Value became a concrete type
instead of Spanned<Value>, for example).
This also turned a number of inherent methods in the main nu crate into
plain functions (impl Value {} became a bunch of functions in the
`value` namespace in `crate::data::value`).
2019-11-26 02:30:48 +00:00
|
|
|
cmd_dict.insert_untagged("usage", value::string(command.usage()));
|
2019-08-29 22:52:32 +00:00
|
|
|
|
2019-11-21 14:33:14 +00:00
|
|
|
cmd_dict.into_value()
|
2019-08-29 22:52:32 +00:00
|
|
|
}
|
|
|
|
|
2019-11-21 14:33:14 +00:00
|
|
|
fn for_spec(name: &str, ty: &str, required: bool, tag: impl Into<Tag>) -> Value {
|
2019-08-29 22:52:32 +00:00
|
|
|
let tag = tag.into();
|
|
|
|
|
|
|
|
let mut spec = TaggedDictBuilder::new(tag);
|
|
|
|
|
Extract core stuff into own crates
This commit extracts five new crates:
- nu-source, which contains the core source-code handling logic in Nu,
including Text, Span, and also the pretty.rs-based debug logic
- nu-parser, which is the parser and expander logic
- nu-protocol, which is the bulk of the types and basic conveniences
used by plugins
- nu-errors, which contains ShellError, ParseError and error handling
conveniences
- nu-textview, which is the textview plugin extracted into a crate
One of the major consequences of this refactor is that it's no longer
possible to `impl X for Spanned<Y>` outside of the `nu-source` crate, so
a lot of types became more concrete (Value became a concrete type
instead of Spanned<Value>, for example).
This also turned a number of inherent methods in the main nu crate into
plain functions (impl Value {} became a bunch of functions in the
`value` namespace in `crate::data::value`).
2019-11-26 02:30:48 +00:00
|
|
|
spec.insert_untagged("name", value::string(name));
|
|
|
|
spec.insert_untagged("type", value::string(ty));
|
2019-11-21 14:33:14 +00:00
|
|
|
spec.insert_untagged(
|
2019-09-05 16:23:42 +00:00
|
|
|
"required",
|
Extract core stuff into own crates
This commit extracts five new crates:
- nu-source, which contains the core source-code handling logic in Nu,
including Text, Span, and also the pretty.rs-based debug logic
- nu-parser, which is the parser and expander logic
- nu-protocol, which is the bulk of the types and basic conveniences
used by plugins
- nu-errors, which contains ShellError, ParseError and error handling
conveniences
- nu-textview, which is the textview plugin extracted into a crate
One of the major consequences of this refactor is that it's no longer
possible to `impl X for Spanned<Y>` outside of the `nu-source` crate, so
a lot of types became more concrete (Value became a concrete type
instead of Spanned<Value>, for example).
This also turned a number of inherent methods in the main nu crate into
plain functions (impl Value {} became a bunch of functions in the
`value` namespace in `crate::data::value`).
2019-11-26 02:30:48 +00:00
|
|
|
value::string(if required { "yes" } else { "no" }),
|
2019-09-05 16:23:42 +00:00
|
|
|
);
|
2019-08-29 22:52:32 +00:00
|
|
|
|
2019-11-21 14:33:14 +00:00
|
|
|
spec.into_value()
|
2019-08-29 22:52:32 +00:00
|
|
|
}
|
|
|
|
|
2019-11-21 14:33:14 +00:00
|
|
|
fn signature_dict(signature: Signature, tag: impl Into<Tag>) -> Value {
|
2019-08-29 22:52:32 +00:00
|
|
|
let tag = tag.into();
|
2019-10-13 04:12:43 +00:00
|
|
|
let mut sig = TaggedListBuilder::new(&tag);
|
2019-08-29 22:52:32 +00:00
|
|
|
|
|
|
|
for arg in signature.positional.iter() {
|
2019-10-28 05:15:35 +00:00
|
|
|
let is_required = match arg.0 {
|
2019-09-05 16:23:42 +00:00
|
|
|
PositionalType::Mandatory(_, _) => true,
|
|
|
|
PositionalType::Optional(_, _) => false,
|
2019-08-29 22:52:32 +00:00
|
|
|
};
|
|
|
|
|
2019-11-21 14:33:14 +00:00
|
|
|
sig.push_value(for_spec(arg.0.name(), "argument", is_required, &tag));
|
2019-08-29 22:52:32 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
if let Some(_) = signature.rest_positional {
|
|
|
|
let is_required = false;
|
2019-11-21 14:33:14 +00:00
|
|
|
sig.push_value(for_spec("rest", "argument", is_required, &tag));
|
2019-08-29 22:52:32 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
for (name, ty) in signature.named.iter() {
|
2019-10-28 05:15:35 +00:00
|
|
|
match ty.0 {
|
2019-11-21 14:33:14 +00:00
|
|
|
NamedType::Mandatory(_) => sig.push_value(for_spec(name, "flag", true, &tag)),
|
|
|
|
NamedType::Optional(_) => sig.push_value(for_spec(name, "flag", false, &tag)),
|
|
|
|
NamedType::Switch => sig.push_value(for_spec(name, "switch", false, &tag)),
|
2019-08-29 22:52:32 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-11-21 14:33:14 +00:00
|
|
|
sig.into_value()
|
2019-08-29 22:52:32 +00:00
|
|
|
}
|