Move str and inc to core plugins

This commit is contained in:
Jonathan Turner 2019-12-10 13:59:13 +13:00
parent 88f899d341
commit e2a95c3e1d
9 changed files with 54 additions and 129 deletions

30
Cargo.lock generated
View file

@ -1903,10 +1903,8 @@ dependencies = [
"nu_plugin_average", "nu_plugin_average",
"nu_plugin_binaryview", "nu_plugin_binaryview",
"nu_plugin_fetch", "nu_plugin_fetch",
"nu_plugin_inc",
"nu_plugin_match", "nu_plugin_match",
"nu_plugin_post", "nu_plugin_post",
"nu_plugin_str",
"nu_plugin_sum", "nu_plugin_sum",
"nu_plugin_tree", "nu_plugin_tree",
"num-bigint", "num-bigint",
@ -2111,19 +2109,6 @@ dependencies = [
"url", "url",
] ]
[[package]]
name = "nu_plugin_inc"
version = "0.1.0"
dependencies = [
"indexmap",
"nu-build",
"nu-errors",
"nu-protocol",
"nu-source",
"nu-value-ext",
"semver",
]
[[package]] [[package]]
name = "nu_plugin_match" name = "nu_plugin_match"
version = "0.1.0" version = "0.1.0"
@ -2152,21 +2137,6 @@ dependencies = [
"url", "url",
] ]
[[package]]
name = "nu_plugin_str"
version = "0.1.0"
dependencies = [
"futures-preview",
"indexmap",
"nu-build",
"nu-errors",
"nu-protocol",
"nu-source",
"nu-value-ext",
"num-bigint",
"regex",
]
[[package]] [[package]]
name = "nu_plugin_sum" name = "nu_plugin_sum"
version = "0.1.0" version = "0.1.0"

View file

@ -19,10 +19,8 @@ members = [
"crates/nu_plugin_average", "crates/nu_plugin_average",
"crates/nu_plugin_binaryview", "crates/nu_plugin_binaryview",
"crates/nu_plugin_fetch", "crates/nu_plugin_fetch",
"crates/nu_plugin_inc",
"crates/nu_plugin_match", "crates/nu_plugin_match",
"crates/nu_plugin_post", "crates/nu_plugin_post",
"crates/nu_plugin_str",
"crates/nu_plugin_sum", "crates/nu_plugin_sum",
"crates/nu_plugin_tree", "crates/nu_plugin_tree",
"crates/nu-protocol", "crates/nu-protocol",
@ -42,10 +40,8 @@ nu-value-ext = { version = "0.1.0", path = "./crates/nu-value-ext" }
nu_plugin_average = {version = "0.1.0", path = "./crates/nu_plugin_average", optional=true} nu_plugin_average = {version = "0.1.0", path = "./crates/nu_plugin_average", optional=true}
nu_plugin_binaryview = {version = "0.1.0", path = "./crates/nu_plugin_binaryview", optional=true} nu_plugin_binaryview = {version = "0.1.0", path = "./crates/nu_plugin_binaryview", optional=true}
nu_plugin_fetch = {version = "0.1.0", path = "./crates/nu_plugin_fetch", optional=true} nu_plugin_fetch = {version = "0.1.0", path = "./crates/nu_plugin_fetch", optional=true}
nu_plugin_inc = {version = "0.1.0", path = "./crates/nu_plugin_inc", optional=true}
nu_plugin_match = {version = "0.1.0", path = "./crates/nu_plugin_match", optional=true} nu_plugin_match = {version = "0.1.0", path = "./crates/nu_plugin_match", optional=true}
nu_plugin_post = {version = "0.1.0", path = "./crates/nu_plugin_post", optional=true} nu_plugin_post = {version = "0.1.0", path = "./crates/nu_plugin_post", optional=true}
nu_plugin_str = {version = "0.1.0", path = "./crates/nu_plugin_str", optional=true}
nu_plugin_sum = {version = "0.1.0", path = "./crates/nu_plugin_sum", optional=true} nu_plugin_sum = {version = "0.1.0", path = "./crates/nu_plugin_sum", optional=true}
nu_plugin_tree = {version = "0.1.0", path = "./crates/nu_plugin_tree", optional=true} nu_plugin_tree = {version = "0.1.0", path = "./crates/nu_plugin_tree", optional=true}
@ -96,7 +92,6 @@ subprocess = "0.1.18"
pretty-hex = "0.1.1" pretty-hex = "0.1.1"
hex = "0.4" hex = "0.4"
tempfile = "3.1.0" tempfile = "3.1.0"
semver = "0.9.0"
which = "3.1" which = "3.1"
textwrap = {version = "0.11.0", features = ["term_size"]} textwrap = {version = "0.11.0", features = ["term_size"]}
shellexpand = "1.0.0" shellexpand = "1.0.0"
@ -124,20 +119,21 @@ onig_sys = {version = "=69.1.0", optional = true }
crossterm = {version = "0.10.2", optional = true} crossterm = {version = "0.10.2", optional = true}
futures-timer = {version = "1.0.2", optional = true} futures-timer = {version = "1.0.2", optional = true}
url = {version = "2.1.0", optional = true} url = {version = "2.1.0", optional = true}
semver = {version = "0.9.0", optional = true}
[features] [features]
default = ["sys", "ps", "textview", "match", "inc", "average", "str", "sum"] default = ["sys", "ps", "textview", "match", "inc", "average", "str", "sum"]
sys = ["heim", "battery"] sys = ["heim", "battery"]
ps = ["heim"] ps = ["heim"]
textview = ["crossterm", "syntect", "onig_sys"] textview = ["crossterm", "syntect", "onig_sys"]
inc = ["semver"]
str = []
starship-prompt = ["starship"] starship-prompt = ["starship"]
binaryview = ["nu_plugin_binaryview"] binaryview = ["nu_plugin_binaryview"]
match = ["nu_plugin_match"] match = ["nu_plugin_match"]
tree = ["nu_plugin_tree"] tree = ["nu_plugin_tree"]
inc = ["nu_plugin_inc"]
average = ["nu_plugin_average"] average = ["nu_plugin_average"]
str = ["nu_plugin_str"]
sum = ["nu_plugin_sum"] sum = ["nu_plugin_sum"]
#trace = ["nu-parser/trace"] #trace = ["nu-parser/trace"]
@ -163,11 +159,21 @@ name = "nu_plugin_textview"
path = "src/core_plugins/textview.rs" path = "src/core_plugins/textview.rs"
required-features = ["textview"] required-features = ["textview"]
[[bin]]
name = "nu_plugin_inc"
path = "src/core_plugins/inc.rs"
required-features = ["inc"]
[[bin]] [[bin]]
name = "nu_plugin_ps" name = "nu_plugin_ps"
path = "src/core_plugins/ps.rs" path = "src/core_plugins/ps.rs"
required-features = ["ps"] required-features = ["ps"]
[[bin]]
name = "nu_plugin_str"
path = "src/core_plugins/str.rs"
required-features = ["str"]
[[bin]] [[bin]]
name = "nu_plugin_sys" name = "nu_plugin_sys"
path = "src/core_plugins/sys.rs" path = "src/core_plugins/sys.rs"

View file

@ -1,18 +0,0 @@
[package]
name = "nu_plugin_inc"
version = "0.1.0"
authors = ["Yehuda Katz <wycats@gmail.com>", "Jonathan Turner <jonathan.d.turner@gmail.com>", "Andrés N. Robalino <andres@androbtech.com>"]
edition = "2018"
# See more keys and their definitions at https://doc.rust-lang.org/cargo/reference/manifest.html
[dependencies]
nu-protocol = { path = "../nu-protocol" }
nu-source = { path = "../nu-source" }
nu-errors = { path = "../nu-errors" }
nu-value-ext = { path = "../nu-value-ext" }
indexmap = "1.3.0"
semver = "0.9.0"
[build-dependencies]
nu-build = { version = "0.1.0", path = "../nu-build" }

View file

@ -1,3 +0,0 @@
fn main() -> Result<(), Box<dyn std::error::Error>> {
nu_build::build()
}

View file

@ -1,21 +0,0 @@
[package]
name = "nu_plugin_str"
version = "0.1.0"
authors = ["Yehuda Katz <wycats@gmail.com>", "Jonathan Turner <jonathan.d.turner@gmail.com>", "Andrés N. Robalino <andres@androbtech.com>"]
edition = "2018"
# See more keys and their definitions at https://doc.rust-lang.org/cargo/reference/manifest.html
[dependencies]
nu-protocol = { path = "../nu-protocol" }
nu-source = { path = "../nu-source" }
nu-errors = { path = "../nu-errors" }
nu-value-ext = { path = "../nu-value-ext" }
futures-preview = { version = "=0.3.0-alpha.19", features = ["compat", "io-compat"] }
regex = "1"
indexmap = "1.3.0"
num-bigint = "0.2.3"
[build-dependencies]
nu-build = { version = "0.1.0", path = "../nu-build" }

View file

@ -1,3 +0,0 @@
fn main() -> Result<(), Box<dyn std::error::Error>> {
nu_build::build()
}

View file

@ -92,8 +92,7 @@ fn converts_from_csv_text_to_structured_table() {
open los_tres_caballeros.txt open los_tres_caballeros.txt
| from-csv | from-csv
| get rusty_luck | get rusty_luck
| str --to-int | count
| sum
| echo $it | echo $it
"# "#
)); ));
@ -121,8 +120,7 @@ fn converts_from_csv_text_with_separator_to_structured_table() {
open los_tres_caballeros.txt open los_tres_caballeros.txt
| from-csv --separator ';' | from-csv --separator ';'
| get rusty_luck | get rusty_luck
| str --to-int | count
| sum
| echo $it | echo $it
"# "#
)); ));
@ -150,8 +148,7 @@ fn converts_from_csv_text_with_tab_separator_to_structured_table() {
open los_tres_caballeros.txt open los_tres_caballeros.txt
| from-csv --separator '\t' | from-csv --separator '\t'
| get rusty_luck | get rusty_luck
| str --to-int | count
| sum
| echo $it | echo $it
"# "#
)); ));
@ -178,8 +175,7 @@ fn converts_from_csv_text_skipping_headers_to_structured_table() {
open los_tres_amigos.txt open los_tres_amigos.txt
| from-csv --headerless | from-csv --headerless
| get Column3 | get Column3
| str --to-int | count
| sum
| echo $it | echo $it
"# "#
)); ));
@ -223,7 +219,7 @@ fn converts_from_json_text_to_structured_table() {
let actual = nu!( let actual = nu!(
cwd: dirs.test(), cwd: dirs.test(),
"open katz.txt | from-json | get katz | get rusty_luck | sum | echo $it" "open katz.txt | from-json | get katz | get rusty_luck | count | echo $it"
); );
assert_eq!(actual, "4"); assert_eq!(actual, "4");
@ -385,8 +381,7 @@ fn converts_from_tsv_text_to_structured_table() {
open los_tres_amigos.txt open los_tres_amigos.txt
| from-tsv | from-tsv
| get rusty_luck | get rusty_luck
| str --to-int | count
| sum
| echo $it | echo $it
"# "#
)); ));
@ -413,8 +408,7 @@ fn converts_from_tsv_text_skipping_headers_to_structured_table() {
open los_tres_amigos.txt open los_tres_amigos.txt
| from-tsv --headerless | from-tsv --headerless
| get Column3 | get Column3
| str --to-int | count
| sum
| echo $it | echo $it
"# "#
)); ));
@ -658,45 +652,45 @@ fn can_split_by_column() {
assert_eq!(actual, "name"); assert_eq!(actual, "name");
} }
#[test] // #[test]
fn can_sum() { // fn can_sum() {
let actual = nu!( // let actual = nu!(
cwd: "tests/fixtures/formats", h::pipeline( // cwd: "tests/fixtures/formats", h::pipeline(
r#" // r#"
open sgml_description.json // open sgml_description.json
| get glossary.GlossDiv.GlossList.GlossEntry.Sections // | get glossary.GlossDiv.GlossList.GlossEntry.Sections
| sum // | sum
| echo $it // | echo $it
"# // "#
)); // ));
assert_eq!(actual, "203") // assert_eq!(actual, "203")
} // }
#[test] // #[test]
fn can_average_numbers() { // fn can_average_numbers() {
let actual = nu!( // let actual = nu!(
cwd: "tests/fixtures/formats", h::pipeline( // cwd: "tests/fixtures/formats", h::pipeline(
r#" // r#"
open sgml_description.json // open sgml_description.json
| get glossary.GlossDiv.GlossList.GlossEntry.Sections // | get glossary.GlossDiv.GlossList.GlossEntry.Sections
| average // | average
| echo $it // | echo $it
"# // "#
)); // ));
assert_eq!(actual, "101.5000000000000") // assert_eq!(actual, "101.5000000000000")
} // }
#[test] // #[test]
fn can_average_bytes() { // fn can_average_bytes() {
let actual = nu!( // let actual = nu!(
cwd: "tests/fixtures/formats", // cwd: "tests/fixtures/formats",
"ls | sort-by name | skip 1 | first 2 | get size | average | echo $it" // "ls | sort-by name | skip 1 | first 2 | get size | average | echo $it"
); // );
assert_eq!(actual, "1600.000000000000"); // assert_eq!(actual, "1600.000000000000");
} // }
#[test] #[test]
fn can_filter_by_unit_size_comparison() { fn can_filter_by_unit_size_comparison() {