diff --git a/.azure/azure-pipelines.yml b/.azure/azure-pipelines.yml new file mode 100644 index 0000000000..55c7114b34 --- /dev/null +++ b/.azure/azure-pipelines.yml @@ -0,0 +1,35 @@ +variables: + lkg-rust-nightly: "2019-06-16" + +trigger: + - master + +strategy: + matrix: + linux-nightly: + image: ubuntu-16.04 + toolchain: nightly-$(lkg-rust-nightly) + macos-nightly: + image: macos-10.13 + toolchain: nightly-$(lkg-rust-nightly) + windows-nightly: + image: vs2017-win2016 + toolchain: nightly-$(lkg-rust-nightly) + +pool: + vmImage: $(image) + +steps: + - bash: | + set -e + curl https://sh.rustup.rs -sSf | sh -s -- -y --no-modify-path --default-toolchain none + export PATH=$HOME/.cargo/bin:$PATH + rustup install --no-self-update $(toolchain) + rustup default $(toolchain) + rustc -Vv + echo "##vso[task.prependpath]$HOME/.cargo/bin" + displayName: Install Rust + - bash: cargo build + displayName: Build source + - bash: cargo test + displayName: Run tests diff --git a/Cargo.lock b/Cargo.lock index a4de3e0f90..77339f6fd7 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -7,9 +7,9 @@ source = "registry+https://github.com/rust-lang/crates.io-index" dependencies = [ "proc-macro2 0.4.30 (registry+https://github.com/rust-lang/crates.io-index)", "quote 0.6.12 (registry+https://github.com/rust-lang/crates.io-index)", - "regex 1.1.6 (registry+https://github.com/rust-lang/crates.io-index)", - "regex-syntax 0.6.6 (registry+https://github.com/rust-lang/crates.io-index)", - "syn 0.15.34 (registry+https://github.com/rust-lang/crates.io-index)", + "regex 1.1.7 (registry+https://github.com/rust-lang/crates.io-index)", + "regex-syntax 0.6.7 (registry+https://github.com/rust-lang/crates.io-index)", + "syn 0.15.36 (registry+https://github.com/rust-lang/crates.io-index)", ] [[package]] @@ -85,25 +85,25 @@ version = "0.2.11" source = "registry+https://github.com/rust-lang/crates.io-index" dependencies = [ "libc 0.2.58 (registry+https://github.com/rust-lang/crates.io-index)", - "termion 1.5.2 (registry+https://github.com/rust-lang/crates.io-index)", + "termion 1.5.3 (registry+https://github.com/rust-lang/crates.io-index)", "winapi 0.3.7 (registry+https://github.com/rust-lang/crates.io-index)", ] [[package]] name = "autocfg" -version = "0.1.2" +version = "0.1.4" source = "registry+https://github.com/rust-lang/crates.io-index" [[package]] name = "backtrace" -version = "0.3.20" +version = "0.3.30" source = "registry+https://github.com/rust-lang/crates.io-index" dependencies = [ - "autocfg 0.1.2 (registry+https://github.com/rust-lang/crates.io-index)", + "autocfg 0.1.4 (registry+https://github.com/rust-lang/crates.io-index)", "backtrace-sys 0.1.28 (registry+https://github.com/rust-lang/crates.io-index)", "cfg-if 0.1.9 (registry+https://github.com/rust-lang/crates.io-index)", "libc 0.2.58 (registry+https://github.com/rust-lang/crates.io-index)", - "rustc-demangle 0.1.14 (registry+https://github.com/rust-lang/crates.io-index)", + "rustc-demangle 0.1.15 (registry+https://github.com/rust-lang/crates.io-index)", ] [[package]] @@ -120,7 +120,7 @@ name = "base64" version = "0.10.1" source = "registry+https://github.com/rust-lang/crates.io-index" dependencies = [ - "byteorder 1.3.1 (registry+https://github.com/rust-lang/crates.io-index)", + "byteorder 1.3.2 (registry+https://github.com/rust-lang/crates.io-index)", ] [[package]] @@ -128,14 +128,14 @@ name = "bincode" version = "1.1.4" source = "registry+https://github.com/rust-lang/crates.io-index" dependencies = [ - "autocfg 0.1.2 (registry+https://github.com/rust-lang/crates.io-index)", - "byteorder 1.3.1 (registry+https://github.com/rust-lang/crates.io-index)", - "serde 1.0.91 (registry+https://github.com/rust-lang/crates.io-index)", + "autocfg 0.1.4 (registry+https://github.com/rust-lang/crates.io-index)", + "byteorder 1.3.2 (registry+https://github.com/rust-lang/crates.io-index)", + "serde 1.0.92 (registry+https://github.com/rust-lang/crates.io-index)", ] [[package]] name = "bitflags" -version = "1.0.4" +version = "1.1.0" source = "registry+https://github.com/rust-lang/crates.io-index" [[package]] @@ -163,7 +163,7 @@ version = "2.1.0" source = "registry+https://github.com/rust-lang/crates.io-index" dependencies = [ "lazy_static 1.3.0 (registry+https://github.com/rust-lang/crates.io-index)", - "regex 1.1.6 (registry+https://github.com/rust-lang/crates.io-index)", + "regex 1.1.7 (registry+https://github.com/rust-lang/crates.io-index)", ] [[package]] @@ -173,7 +173,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index" [[package]] name = "byteorder" -version = "1.3.1" +version = "1.3.2" source = "registry+https://github.com/rust-lang/crates.io-index" [[package]] @@ -181,7 +181,7 @@ name = "bytes" version = "0.4.12" source = "registry+https://github.com/rust-lang/crates.io-index" dependencies = [ - "byteorder 1.3.1 (registry+https://github.com/rust-lang/crates.io-index)", + "byteorder 1.3.2 (registry+https://github.com/rust-lang/crates.io-index)", "either 1.5.2 (registry+https://github.com/rust-lang/crates.io-index)", "iovec 0.1.2 (registry+https://github.com/rust-lang/crates.io-index)", ] @@ -201,9 +201,9 @@ name = "chrono" version = "0.4.6" source = "registry+https://github.com/rust-lang/crates.io-index" dependencies = [ - "num-integer 0.1.40 (registry+https://github.com/rust-lang/crates.io-index)", - "num-traits 0.2.7 (registry+https://github.com/rust-lang/crates.io-index)", - "serde 1.0.91 (registry+https://github.com/rust-lang/crates.io-index)", + "num-integer 0.1.41 (registry+https://github.com/rust-lang/crates.io-index)", + "num-traits 0.2.8 (registry+https://github.com/rust-lang/crates.io-index)", + "serde 1.0.92 (registry+https://github.com/rust-lang/crates.io-index)", "time 0.1.42 (registry+https://github.com/rust-lang/crates.io-index)", ] @@ -231,7 +231,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index" dependencies = [ "ansi_term 0.11.0 (registry+https://github.com/rust-lang/crates.io-index)", "atty 0.2.11 (registry+https://github.com/rust-lang/crates.io-index)", - "bitflags 1.0.4 (registry+https://github.com/rust-lang/crates.io-index)", + "bitflags 1.1.0 (registry+https://github.com/rust-lang/crates.io-index)", "strsim 0.8.0 (registry+https://github.com/rust-lang/crates.io-index)", "textwrap 0.11.0 (registry+https://github.com/rust-lang/crates.io-index)", "unicode-width 0.1.5 (registry+https://github.com/rust-lang/crates.io-index)", @@ -274,7 +274,7 @@ name = "cloudabi" version = "0.0.3" source = "registry+https://github.com/rust-lang/crates.io-index" dependencies = [ - "bitflags 1.0.4 (registry+https://github.com/rust-lang/crates.io-index)", + "bitflags 1.1.0 (registry+https://github.com/rust-lang/crates.io-index)", ] [[package]] @@ -293,7 +293,7 @@ dependencies = [ "lazy_static 1.3.0 (registry+https://github.com/rust-lang/crates.io-index)", "nom 4.2.3 (registry+https://github.com/rust-lang/crates.io-index)", "rust-ini 0.13.0 (registry+https://github.com/rust-lang/crates.io-index)", - "serde 1.0.91 (registry+https://github.com/rust-lang/crates.io-index)", + "serde 1.0.92 (registry+https://github.com/rust-lang/crates.io-index)", "serde-hjson 0.8.2 (registry+https://github.com/rust-lang/crates.io-index)", "serde_json 1.0.39 (registry+https://github.com/rust-lang/crates.io-index)", "toml 0.4.10 (registry+https://github.com/rust-lang/crates.io-index)", @@ -302,7 +302,7 @@ dependencies = [ [[package]] name = "console" -version = "0.7.5" +version = "0.7.7" source = "registry+https://github.com/rust-lang/crates.io-index" dependencies = [ "atty 0.2.11 (registry+https://github.com/rust-lang/crates.io-index)", @@ -311,7 +311,7 @@ dependencies = [ "lazy_static 1.3.0 (registry+https://github.com/rust-lang/crates.io-index)", "libc 0.2.58 (registry+https://github.com/rust-lang/crates.io-index)", "parking_lot 0.8.0 (registry+https://github.com/rust-lang/crates.io-index)", - "regex 1.1.6 (registry+https://github.com/rust-lang/crates.io-index)", + "regex 1.1.7 (registry+https://github.com/rust-lang/crates.io-index)", "termios 0.3.1 (registry+https://github.com/rust-lang/crates.io-index)", "unicode-width 0.1.5 (registry+https://github.com/rust-lang/crates.io-index)", "winapi 0.3.7 (registry+https://github.com/rust-lang/crates.io-index)", @@ -349,7 +349,7 @@ dependencies = [ "idna 0.1.5 (registry+https://github.com/rust-lang/crates.io-index)", "log 0.4.6 (registry+https://github.com/rust-lang/crates.io-index)", "publicsuffix 1.5.2 (registry+https://github.com/rust-lang/crates.io-index)", - "serde 1.0.91 (registry+https://github.com/rust-lang/crates.io-index)", + "serde 1.0.92 (registry+https://github.com/rust-lang/crates.io-index)", "serde_json 1.0.39 (registry+https://github.com/rust-lang/crates.io-index)", "time 0.1.42 (registry+https://github.com/rust-lang/crates.io-index)", "try_from 0.3.2 (registry+https://github.com/rust-lang/crates.io-index)", @@ -392,16 +392,16 @@ version = "0.3.8" source = "registry+https://github.com/rust-lang/crates.io-index" dependencies = [ "crossbeam-utils 0.6.5 (registry+https://github.com/rust-lang/crates.io-index)", - "smallvec 0.6.9 (registry+https://github.com/rust-lang/crates.io-index)", + "smallvec 0.6.10 (registry+https://github.com/rust-lang/crates.io-index)", ] [[package]] name = "crossbeam-deque" -version = "0.2.0" +version = "0.6.3" source = "registry+https://github.com/rust-lang/crates.io-index" dependencies = [ - "crossbeam-epoch 0.3.1 (registry+https://github.com/rust-lang/crates.io-index)", - "crossbeam-utils 0.2.2 (registry+https://github.com/rust-lang/crates.io-index)", + "crossbeam-epoch 0.7.1 (registry+https://github.com/rust-lang/crates.io-index)", + "crossbeam-utils 0.6.5 (registry+https://github.com/rust-lang/crates.io-index)", ] [[package]] @@ -413,20 +413,6 @@ dependencies = [ "crossbeam-utils 0.6.5 (registry+https://github.com/rust-lang/crates.io-index)", ] -[[package]] -name = "crossbeam-epoch" -version = "0.3.1" -source = "registry+https://github.com/rust-lang/crates.io-index" -dependencies = [ - "arrayvec 0.4.10 (registry+https://github.com/rust-lang/crates.io-index)", - "cfg-if 0.1.9 (registry+https://github.com/rust-lang/crates.io-index)", - "crossbeam-utils 0.2.2 (registry+https://github.com/rust-lang/crates.io-index)", - "lazy_static 1.3.0 (registry+https://github.com/rust-lang/crates.io-index)", - "memoffset 0.2.1 (registry+https://github.com/rust-lang/crates.io-index)", - "nodrop 0.1.13 (registry+https://github.com/rust-lang/crates.io-index)", - "scopeguard 0.3.3 (registry+https://github.com/rust-lang/crates.io-index)", -] - [[package]] name = "crossbeam-epoch" version = "0.7.1" @@ -448,14 +434,6 @@ dependencies = [ "crossbeam-utils 0.6.5 (registry+https://github.com/rust-lang/crates.io-index)", ] -[[package]] -name = "crossbeam-utils" -version = "0.2.2" -source = "registry+https://github.com/rust-lang/crates.io-index" -dependencies = [ - "cfg-if 0.1.9 (registry+https://github.com/rust-lang/crates.io-index)", -] - [[package]] name = "crossbeam-utils" version = "0.5.0" @@ -478,7 +456,7 @@ dependencies = [ "csv-core 0.1.5 (registry+https://github.com/rust-lang/crates.io-index)", "itoa 0.4.4 (registry+https://github.com/rust-lang/crates.io-index)", "ryu 0.2.8 (registry+https://github.com/rust-lang/crates.io-index)", - "serde 1.0.91 (registry+https://github.com/rust-lang/crates.io-index)", + "serde 1.0.92 (registry+https://github.com/rust-lang/crates.io-index)", ] [[package]] @@ -495,7 +473,7 @@ version = "0.1.9" source = "registry+https://github.com/rust-lang/crates.io-index" dependencies = [ "quote 0.6.12 (registry+https://github.com/rust-lang/crates.io-index)", - "syn 0.15.34 (registry+https://github.com/rust-lang/crates.io-index)", + "syn 0.15.36 (registry+https://github.com/rust-lang/crates.io-index)", ] [[package]] @@ -507,20 +485,6 @@ dependencies = [ "winapi 0.3.7 (registry+https://github.com/rust-lang/crates.io-index)", ] -[[package]] -name = "curl-sys" -version = "0.4.18" -source = "registry+https://github.com/rust-lang/crates.io-index" -dependencies = [ - "cc 1.0.37 (registry+https://github.com/rust-lang/crates.io-index)", - "libc 0.2.58 (registry+https://github.com/rust-lang/crates.io-index)", - "libz-sys 1.0.25 (registry+https://github.com/rust-lang/crates.io-index)", - "openssl-sys 0.9.47 (registry+https://github.com/rust-lang/crates.io-index)", - "pkg-config 0.3.14 (registry+https://github.com/rust-lang/crates.io-index)", - "vcpkg 0.2.6 (registry+https://github.com/rust-lang/crates.io-index)", - "winapi 0.3.7 (registry+https://github.com/rust-lang/crates.io-index)", -] - [[package]] name = "cursive" version = "0.12.0" @@ -531,7 +495,7 @@ dependencies = [ "crossbeam-channel 0.3.8 (registry+https://github.com/rust-lang/crates.io-index)", "enum-map 0.5.0 (registry+https://github.com/rust-lang/crates.io-index)", "enumset 0.4.0 (registry+https://github.com/rust-lang/crates.io-index)", - "hashbrown 0.3.0 (registry+https://github.com/rust-lang/crates.io-index)", + "hashbrown 0.3.1 (registry+https://github.com/rust-lang/crates.io-index)", "lazy_static 1.3.0 (registry+https://github.com/rust-lang/crates.io-index)", "libc 0.2.58 (registry+https://github.com/rust-lang/crates.io-index)", "log 0.4.6 (registry+https://github.com/rust-lang/crates.io-index)", @@ -574,7 +538,7 @@ dependencies = [ "ident_case 1.0.1 (registry+https://github.com/rust-lang/crates.io-index)", "proc-macro2 0.4.30 (registry+https://github.com/rust-lang/crates.io-index)", "quote 0.6.12 (registry+https://github.com/rust-lang/crates.io-index)", - "syn 0.15.34 (registry+https://github.com/rust-lang/crates.io-index)", + "syn 0.15.36 (registry+https://github.com/rust-lang/crates.io-index)", ] [[package]] @@ -587,7 +551,7 @@ dependencies = [ "proc-macro2 0.4.30 (registry+https://github.com/rust-lang/crates.io-index)", "quote 0.6.12 (registry+https://github.com/rust-lang/crates.io-index)", "strsim 0.7.0 (registry+https://github.com/rust-lang/crates.io-index)", - "syn 0.15.34 (registry+https://github.com/rust-lang/crates.io-index)", + "syn 0.15.36 (registry+https://github.com/rust-lang/crates.io-index)", ] [[package]] @@ -597,7 +561,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index" dependencies = [ "darling_core 0.8.6 (registry+https://github.com/rust-lang/crates.io-index)", "quote 0.6.12 (registry+https://github.com/rust-lang/crates.io-index)", - "syn 0.15.34 (registry+https://github.com/rust-lang/crates.io-index)", + "syn 0.15.36 (registry+https://github.com/rust-lang/crates.io-index)", ] [[package]] @@ -607,7 +571,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index" dependencies = [ "darling_core 0.9.0 (registry+https://github.com/rust-lang/crates.io-index)", "quote 0.6.12 (registry+https://github.com/rust-lang/crates.io-index)", - "syn 0.15.34 (registry+https://github.com/rust-lang/crates.io-index)", + "syn 0.15.36 (registry+https://github.com/rust-lang/crates.io-index)", ] [[package]] @@ -617,30 +581,30 @@ source = "registry+https://github.com/rust-lang/crates.io-index" dependencies = [ "proc-macro2 0.4.30 (registry+https://github.com/rust-lang/crates.io-index)", "quote 0.6.12 (registry+https://github.com/rust-lang/crates.io-index)", - "syn 0.15.34 (registry+https://github.com/rust-lang/crates.io-index)", + "syn 0.15.36 (registry+https://github.com/rust-lang/crates.io-index)", ] [[package]] name = "derive_builder" -version = "0.7.1" +version = "0.7.2" source = "registry+https://github.com/rust-lang/crates.io-index" dependencies = [ - "darling 0.8.6 (registry+https://github.com/rust-lang/crates.io-index)", - "derive_builder_core 0.4.1 (registry+https://github.com/rust-lang/crates.io-index)", + "darling 0.9.0 (registry+https://github.com/rust-lang/crates.io-index)", + "derive_builder_core 0.5.0 (registry+https://github.com/rust-lang/crates.io-index)", "proc-macro2 0.4.30 (registry+https://github.com/rust-lang/crates.io-index)", "quote 0.6.12 (registry+https://github.com/rust-lang/crates.io-index)", - "syn 0.15.34 (registry+https://github.com/rust-lang/crates.io-index)", + "syn 0.15.36 (registry+https://github.com/rust-lang/crates.io-index)", ] [[package]] name = "derive_builder_core" -version = "0.4.1" +version = "0.5.0" source = "registry+https://github.com/rust-lang/crates.io-index" dependencies = [ - "darling 0.8.6 (registry+https://github.com/rust-lang/crates.io-index)", + "darling 0.9.0 (registry+https://github.com/rust-lang/crates.io-index)", "proc-macro2 0.4.30 (registry+https://github.com/rust-lang/crates.io-index)", "quote 0.6.12 (registry+https://github.com/rust-lang/crates.io-index)", - "syn 0.15.34 (registry+https://github.com/rust-lang/crates.io-index)", + "syn 0.15.36 (registry+https://github.com/rust-lang/crates.io-index)", ] [[package]] @@ -651,9 +615,9 @@ dependencies = [ "lazy_static 1.3.0 (registry+https://github.com/rust-lang/crates.io-index)", "proc-macro2 0.4.30 (registry+https://github.com/rust-lang/crates.io-index)", "quote 0.6.12 (registry+https://github.com/rust-lang/crates.io-index)", - "regex 1.1.6 (registry+https://github.com/rust-lang/crates.io-index)", + "regex 1.1.7 (registry+https://github.com/rust-lang/crates.io-index)", "rustc_version 0.2.3 (registry+https://github.com/rust-lang/crates.io-index)", - "syn 0.15.34 (registry+https://github.com/rust-lang/crates.io-index)", + "syn 0.15.36 (registry+https://github.com/rust-lang/crates.io-index)", ] [[package]] @@ -822,7 +786,7 @@ dependencies = [ "proc-macro2 0.4.30 (registry+https://github.com/rust-lang/crates.io-index)", "quote 0.6.12 (registry+https://github.com/rust-lang/crates.io-index)", "serde_derive_internals 0.24.1 (registry+https://github.com/rust-lang/crates.io-index)", - "syn 0.15.34 (registry+https://github.com/rust-lang/crates.io-index)", + "syn 0.15.36 (registry+https://github.com/rust-lang/crates.io-index)", ] [[package]] @@ -845,7 +809,7 @@ version = "0.4.0" source = "registry+https://github.com/rust-lang/crates.io-index" dependencies = [ "enumset_derive 0.4.0 (registry+https://github.com/rust-lang/crates.io-index)", - "num-traits 0.2.7 (registry+https://github.com/rust-lang/crates.io-index)", + "num-traits 0.2.8 (registry+https://github.com/rust-lang/crates.io-index)", ] [[package]] @@ -856,7 +820,7 @@ dependencies = [ "darling 0.9.0 (registry+https://github.com/rust-lang/crates.io-index)", "proc-macro2 0.4.30 (registry+https://github.com/rust-lang/crates.io-index)", "quote 0.6.12 (registry+https://github.com/rust-lang/crates.io-index)", - "syn 0.15.34 (registry+https://github.com/rust-lang/crates.io-index)", + "syn 0.15.36 (registry+https://github.com/rust-lang/crates.io-index)", ] [[package]] @@ -867,8 +831,8 @@ dependencies = [ "atty 0.2.11 (registry+https://github.com/rust-lang/crates.io-index)", "humantime 1.2.0 (registry+https://github.com/rust-lang/crates.io-index)", "log 0.4.6 (registry+https://github.com/rust-lang/crates.io-index)", - "regex 1.1.6 (registry+https://github.com/rust-lang/crates.io-index)", - "termcolor 1.0.4 (registry+https://github.com/rust-lang/crates.io-index)", + "regex 1.1.7 (registry+https://github.com/rust-lang/crates.io-index)", + "termcolor 1.0.5 (registry+https://github.com/rust-lang/crates.io-index)", ] [[package]] @@ -876,7 +840,7 @@ name = "error-chain" version = "0.12.1" source = "registry+https://github.com/rust-lang/crates.io-index" dependencies = [ - "backtrace 0.3.20 (registry+https://github.com/rust-lang/crates.io-index)", + "backtrace 0.3.30 (registry+https://github.com/rust-lang/crates.io-index)", "version_check 0.1.5 (registry+https://github.com/rust-lang/crates.io-index)", ] @@ -885,7 +849,7 @@ name = "failure" version = "0.1.5" source = "registry+https://github.com/rust-lang/crates.io-index" dependencies = [ - "backtrace 0.3.20 (registry+https://github.com/rust-lang/crates.io-index)", + "backtrace 0.3.30 (registry+https://github.com/rust-lang/crates.io-index)", "failure_derive 0.1.5 (registry+https://github.com/rust-lang/crates.io-index)", ] @@ -896,7 +860,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index" dependencies = [ "proc-macro2 0.4.30 (registry+https://github.com/rust-lang/crates.io-index)", "quote 0.6.12 (registry+https://github.com/rust-lang/crates.io-index)", - "syn 0.15.34 (registry+https://github.com/rust-lang/crates.io-index)", + "syn 0.15.36 (registry+https://github.com/rust-lang/crates.io-index)", "synstructure 0.10.2 (registry+https://github.com/rust-lang/crates.io-index)", ] @@ -907,7 +871,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index" [[package]] name = "flate2" -version = "1.0.7" +version = "1.0.9" source = "registry+https://github.com/rust-lang/crates.io-index" dependencies = [ "crc32fast 1.2.0 (registry+https://github.com/rust-lang/crates.io-index)", @@ -944,7 +908,7 @@ name = "fuchsia-zircon" version = "0.3.3" source = "registry+https://github.com/rust-lang/crates.io-index" dependencies = [ - "bitflags 1.0.4 (registry+https://github.com/rust-lang/crates.io-index)", + "bitflags 1.1.0 (registry+https://github.com/rust-lang/crates.io-index)", "fuchsia-zircon-sys 0.3.3 (registry+https://github.com/rust-lang/crates.io-index)", ] @@ -977,7 +941,7 @@ version = "0.1.8" source = "registry+https://github.com/rust-lang/crates.io-index" dependencies = [ "futures 0.1.27 (registry+https://github.com/rust-lang/crates.io-index)", - "num_cpus 1.10.0 (registry+https://github.com/rust-lang/crates.io-index)", + "num_cpus 1.10.1 (registry+https://github.com/rust-lang/crates.io-index)", ] [[package]] @@ -988,7 +952,7 @@ dependencies = [ "futures-channel-preview 0.3.0-alpha.16 (registry+https://github.com/rust-lang/crates.io-index)", "futures-core-preview 0.3.0-alpha.16 (registry+https://github.com/rust-lang/crates.io-index)", "futures-util-preview 0.3.0-alpha.16 (registry+https://github.com/rust-lang/crates.io-index)", - "num_cpus 1.10.0 (registry+https://github.com/rust-lang/crates.io-index)", + "num_cpus 1.10.1 (registry+https://github.com/rust-lang/crates.io-index)", "pin-utils 0.1.0-alpha.4 (registry+https://github.com/rust-lang/crates.io-index)", ] @@ -1054,17 +1018,17 @@ source = "registry+https://github.com/rust-lang/crates.io-index" dependencies = [ "proc-macro2 0.4.30 (registry+https://github.com/rust-lang/crates.io-index)", "quote 0.6.12 (registry+https://github.com/rust-lang/crates.io-index)", - "syn 0.15.34 (registry+https://github.com/rust-lang/crates.io-index)", + "syn 0.15.36 (registry+https://github.com/rust-lang/crates.io-index)", ] [[package]] name = "git2" -version = "0.8.0" +version = "0.9.1" source = "registry+https://github.com/rust-lang/crates.io-index" dependencies = [ - "bitflags 1.0.4 (registry+https://github.com/rust-lang/crates.io-index)", + "bitflags 1.1.0 (registry+https://github.com/rust-lang/crates.io-index)", "libc 0.2.58 (registry+https://github.com/rust-lang/crates.io-index)", - "libgit2-sys 0.7.11 (registry+https://github.com/rust-lang/crates.io-index)", + "libgit2-sys 0.8.1 (registry+https://github.com/rust-lang/crates.io-index)", "log 0.4.6 (registry+https://github.com/rust-lang/crates.io-index)", "openssl-probe 0.1.2 (registry+https://github.com/rust-lang/crates.io-index)", "openssl-sys 0.9.47 (registry+https://github.com/rust-lang/crates.io-index)", @@ -1073,10 +1037,10 @@ dependencies = [ [[package]] name = "h2" -version = "0.1.23" +version = "0.1.24" source = "registry+https://github.com/rust-lang/crates.io-index" dependencies = [ - "byteorder 1.3.1 (registry+https://github.com/rust-lang/crates.io-index)", + "byteorder 1.3.2 (registry+https://github.com/rust-lang/crates.io-index)", "bytes 0.4.12 (registry+https://github.com/rust-lang/crates.io-index)", "fnv 1.0.6 (registry+https://github.com/rust-lang/crates.io-index)", "futures 0.1.27 (registry+https://github.com/rust-lang/crates.io-index)", @@ -1090,7 +1054,7 @@ dependencies = [ [[package]] name = "hashbrown" -version = "0.3.0" +version = "0.3.1" source = "registry+https://github.com/rust-lang/crates.io-index" [[package]] @@ -1129,13 +1093,13 @@ dependencies = [ [[package]] name = "hyper" -version = "0.12.29" +version = "0.12.30" source = "registry+https://github.com/rust-lang/crates.io-index" dependencies = [ "bytes 0.4.12 (registry+https://github.com/rust-lang/crates.io-index)", "futures 0.1.27 (registry+https://github.com/rust-lang/crates.io-index)", "futures-cpupool 0.1.8 (registry+https://github.com/rust-lang/crates.io-index)", - "h2 0.1.23 (registry+https://github.com/rust-lang/crates.io-index)", + "h2 0.1.24 (registry+https://github.com/rust-lang/crates.io-index)", "http 0.1.17 (registry+https://github.com/rust-lang/crates.io-index)", "http-body 0.1.0 (registry+https://github.com/rust-lang/crates.io-index)", "httparse 1.3.3 (registry+https://github.com/rust-lang/crates.io-index)", @@ -1163,7 +1127,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index" dependencies = [ "bytes 0.4.12 (registry+https://github.com/rust-lang/crates.io-index)", "futures 0.1.27 (registry+https://github.com/rust-lang/crates.io-index)", - "hyper 0.12.29 (registry+https://github.com/rust-lang/crates.io-index)", + "hyper 0.12.30 (registry+https://github.com/rust-lang/crates.io-index)", "native-tls 0.2.3 (registry+https://github.com/rust-lang/crates.io-index)", "tokio-io 0.1.12 (registry+https://github.com/rust-lang/crates.io-index)", ] @@ -1188,7 +1152,7 @@ name = "indexmap" version = "1.0.2" source = "registry+https://github.com/rust-lang/crates.io-index" dependencies = [ - "serde 1.0.91 (registry+https://github.com/rust-lang/crates.io-index)", + "serde 1.0.92 (registry+https://github.com/rust-lang/crates.io-index)", ] [[package]] @@ -1260,7 +1224,7 @@ dependencies = [ "itertools 0.7.11 (registry+https://github.com/rust-lang/crates.io-index)", "log 0.4.6 (registry+https://github.com/rust-lang/crates.io-index)", "render-tree 0.1.1 (registry+https://github.com/rust-lang/crates.io-index)", - "termcolor 1.0.4 (registry+https://github.com/rust-lang/crates.io-index)", + "termcolor 1.0.5 (registry+https://github.com/rust-lang/crates.io-index)", ] [[package]] @@ -1285,11 +1249,10 @@ source = "registry+https://github.com/rust-lang/crates.io-index" [[package]] name = "libgit2-sys" -version = "0.7.11" +version = "0.8.1" source = "registry+https://github.com/rust-lang/crates.io-index" dependencies = [ "cc 1.0.37 (registry+https://github.com/rust-lang/crates.io-index)", - "curl-sys 0.4.18 (registry+https://github.com/rust-lang/crates.io-index)", "libc 0.2.58 (registry+https://github.com/rust-lang/crates.io-index)", "libssh2-sys 0.2.11 (registry+https://github.com/rust-lang/crates.io-index)", "libz-sys 1.0.25 (registry+https://github.com/rust-lang/crates.io-index)", @@ -1383,10 +1346,10 @@ source = "registry+https://github.com/rust-lang/crates.io-index" dependencies = [ "proc-macro2 0.4.30 (registry+https://github.com/rust-lang/crates.io-index)", "quote 0.6.12 (registry+https://github.com/rust-lang/crates.io-index)", - "regex-syntax 0.6.6 (registry+https://github.com/rust-lang/crates.io-index)", + "regex-syntax 0.6.7 (registry+https://github.com/rust-lang/crates.io-index)", "rustc-hash 1.0.1 (registry+https://github.com/rust-lang/crates.io-index)", - "syn 0.15.34 (registry+https://github.com/rust-lang/crates.io-index)", - "utf8-ranges 1.0.2 (registry+https://github.com/rust-lang/crates.io-index)", + "syn 0.15.36 (registry+https://github.com/rust-lang/crates.io-index)", + "utf8-ranges 1.0.3 (registry+https://github.com/rust-lang/crates.io-index)", ] [[package]] @@ -1537,7 +1500,7 @@ name = "nix" version = "0.14.1" source = "registry+https://github.com/rust-lang/crates.io-index" dependencies = [ - "bitflags 1.0.4 (registry+https://github.com/rust-lang/crates.io-index)", + "bitflags 1.1.0 (registry+https://github.com/rust-lang/crates.io-index)", "cc 1.0.37 (registry+https://github.com/rust-lang/crates.io-index)", "cfg-if 0.1.9 (registry+https://github.com/rust-lang/crates.io-index)", "libc 0.2.58 (registry+https://github.com/rust-lang/crates.io-index)", @@ -1603,7 +1566,7 @@ dependencies = [ "futures-sink-preview 0.3.0-alpha.16 (registry+https://github.com/rust-lang/crates.io-index)", "futures_codec 0.2.2 (registry+https://github.com/rust-lang/crates.io-index)", "getset 0.0.7 (registry+https://github.com/rust-lang/crates.io-index)", - "git2 0.8.0 (registry+https://github.com/rust-lang/crates.io-index)", + "git2 0.9.1 (registry+https://github.com/rust-lang/crates.io-index)", "indexmap 1.0.2 (registry+https://github.com/rust-lang/crates.io-index)", "itertools 0.8.0 (registry+https://github.com/rust-lang/crates.io-index)", "lalrpop-util 0.17.0 (registry+https://github.com/rust-lang/crates.io-index)", @@ -1620,20 +1583,22 @@ dependencies = [ "pretty 0.5.2 (registry+https://github.com/rust-lang/crates.io-index)", "pretty_assertions 0.6.1 (registry+https://github.com/rust-lang/crates.io-index)", "pretty_env_logger 0.3.0 (registry+https://github.com/rust-lang/crates.io-index)", - "prettyprint 0.6.0 (registry+https://github.com/rust-lang/crates.io-index)", + "prettyprint 0.7.0 (registry+https://github.com/rust-lang/crates.io-index)", "prettytable-rs 0.8.0 (registry+https://github.com/rust-lang/crates.io-index)", "ptree 0.2.1 (registry+https://github.com/rust-lang/crates.io-index)", - "regex 1.1.6 (registry+https://github.com/rust-lang/crates.io-index)", + "regex 1.1.7 (registry+https://github.com/rust-lang/crates.io-index)", "reqwest 0.9.18 (registry+https://github.com/rust-lang/crates.io-index)", - "roxmltree 0.6.0 (registry+https://github.com/rust-lang/crates.io-index)", - "rustyline 4.1.0 (git+https://github.com/kkawakam/rustyline.git)", - "serde 1.0.91 (registry+https://github.com/rust-lang/crates.io-index)", + "roxmltree 0.6.1 (registry+https://github.com/rust-lang/crates.io-index)", + "rustyline 5.0.0 (git+https://github.com/kkawakam/rustyline.git)", + "serde 1.0.92 (registry+https://github.com/rust-lang/crates.io-index)", "serde-hjson 0.9.0 (registry+https://github.com/rust-lang/crates.io-index)", - "serde_derive 1.0.91 (registry+https://github.com/rust-lang/crates.io-index)", + "serde_derive 1.0.92 (registry+https://github.com/rust-lang/crates.io-index)", + "serde_ini 0.2.0 (registry+https://github.com/rust-lang/crates.io-index)", "serde_json 1.0.39 (registry+https://github.com/rust-lang/crates.io-index)", "serde_yaml 0.8.9 (registry+https://github.com/rust-lang/crates.io-index)", - "subprocess 0.1.19 (git+https://github.com/jonathandturner/rust-subprocess.git?branch=is_already_escaped)", - "sysinfo 0.8.4 (registry+https://github.com/rust-lang/crates.io-index)", + "subprocess 0.1.18 (registry+https://github.com/rust-lang/crates.io-index)", + "sys-info 0.5.7 (registry+https://github.com/rust-lang/crates.io-index)", + "sysinfo 0.8.5 (registry+https://github.com/rust-lang/crates.io-index)", "term 0.5.2 (registry+https://github.com/rust-lang/crates.io-index)", "tokio-fs 0.1.6 (registry+https://github.com/rust-lang/crates.io-index)", "toml 0.5.1 (registry+https://github.com/rust-lang/crates.io-index)", @@ -1646,47 +1611,49 @@ name = "num" version = "0.2.0" source = "registry+https://github.com/rust-lang/crates.io-index" dependencies = [ - "num-complex 0.2.1 (registry+https://github.com/rust-lang/crates.io-index)", - "num-integer 0.1.40 (registry+https://github.com/rust-lang/crates.io-index)", - "num-iter 0.1.38 (registry+https://github.com/rust-lang/crates.io-index)", - "num-rational 0.2.1 (registry+https://github.com/rust-lang/crates.io-index)", - "num-traits 0.2.7 (registry+https://github.com/rust-lang/crates.io-index)", + "num-complex 0.2.3 (registry+https://github.com/rust-lang/crates.io-index)", + "num-integer 0.1.41 (registry+https://github.com/rust-lang/crates.io-index)", + "num-iter 0.1.39 (registry+https://github.com/rust-lang/crates.io-index)", + "num-rational 0.2.2 (registry+https://github.com/rust-lang/crates.io-index)", + "num-traits 0.2.8 (registry+https://github.com/rust-lang/crates.io-index)", ] [[package]] name = "num-complex" -version = "0.2.1" +version = "0.2.3" source = "registry+https://github.com/rust-lang/crates.io-index" dependencies = [ - "num-traits 0.2.7 (registry+https://github.com/rust-lang/crates.io-index)", + "autocfg 0.1.4 (registry+https://github.com/rust-lang/crates.io-index)", + "num-traits 0.2.8 (registry+https://github.com/rust-lang/crates.io-index)", ] [[package]] name = "num-integer" -version = "0.1.40" +version = "0.1.41" source = "registry+https://github.com/rust-lang/crates.io-index" dependencies = [ - "autocfg 0.1.2 (registry+https://github.com/rust-lang/crates.io-index)", - "num-traits 0.2.7 (registry+https://github.com/rust-lang/crates.io-index)", + "autocfg 0.1.4 (registry+https://github.com/rust-lang/crates.io-index)", + "num-traits 0.2.8 (registry+https://github.com/rust-lang/crates.io-index)", ] [[package]] name = "num-iter" -version = "0.1.38" +version = "0.1.39" source = "registry+https://github.com/rust-lang/crates.io-index" dependencies = [ - "autocfg 0.1.2 (registry+https://github.com/rust-lang/crates.io-index)", - "num-integer 0.1.40 (registry+https://github.com/rust-lang/crates.io-index)", - "num-traits 0.2.7 (registry+https://github.com/rust-lang/crates.io-index)", + "autocfg 0.1.4 (registry+https://github.com/rust-lang/crates.io-index)", + "num-integer 0.1.41 (registry+https://github.com/rust-lang/crates.io-index)", + "num-traits 0.2.8 (registry+https://github.com/rust-lang/crates.io-index)", ] [[package]] name = "num-rational" -version = "0.2.1" +version = "0.2.2" source = "registry+https://github.com/rust-lang/crates.io-index" dependencies = [ - "num-integer 0.1.40 (registry+https://github.com/rust-lang/crates.io-index)", - "num-traits 0.2.7 (registry+https://github.com/rust-lang/crates.io-index)", + "autocfg 0.1.4 (registry+https://github.com/rust-lang/crates.io-index)", + "num-integer 0.1.41 (registry+https://github.com/rust-lang/crates.io-index)", + "num-traits 0.2.8 (registry+https://github.com/rust-lang/crates.io-index)", ] [[package]] @@ -1694,20 +1661,20 @@ name = "num-traits" version = "0.1.43" source = "registry+https://github.com/rust-lang/crates.io-index" dependencies = [ - "num-traits 0.2.7 (registry+https://github.com/rust-lang/crates.io-index)", + "num-traits 0.2.8 (registry+https://github.com/rust-lang/crates.io-index)", ] [[package]] name = "num-traits" -version = "0.2.7" +version = "0.2.8" source = "registry+https://github.com/rust-lang/crates.io-index" dependencies = [ - "autocfg 0.1.2 (registry+https://github.com/rust-lang/crates.io-index)", + "autocfg 0.1.4 (registry+https://github.com/rust-lang/crates.io-index)", ] [[package]] name = "num_cpus" -version = "1.10.0" +version = "1.10.1" source = "registry+https://github.com/rust-lang/crates.io-index" dependencies = [ "libc 0.2.58 (registry+https://github.com/rust-lang/crates.io-index)", @@ -1758,7 +1725,7 @@ name = "onig" version = "4.3.2" source = "registry+https://github.com/rust-lang/crates.io-index" dependencies = [ - "bitflags 1.0.4 (registry+https://github.com/rust-lang/crates.io-index)", + "bitflags 1.1.0 (registry+https://github.com/rust-lang/crates.io-index)", "lazy_static 1.3.0 (registry+https://github.com/rust-lang/crates.io-index)", "libc 0.2.58 (registry+https://github.com/rust-lang/crates.io-index)", "onig_sys 69.1.0 (registry+https://github.com/rust-lang/crates.io-index)", @@ -1778,7 +1745,7 @@ name = "openssl" version = "0.10.23" source = "registry+https://github.com/rust-lang/crates.io-index" dependencies = [ - "bitflags 1.0.4 (registry+https://github.com/rust-lang/crates.io-index)", + "bitflags 1.1.0 (registry+https://github.com/rust-lang/crates.io-index)", "cfg-if 0.1.9 (registry+https://github.com/rust-lang/crates.io-index)", "foreign-types 0.3.2 (registry+https://github.com/rust-lang/crates.io-index)", "lazy_static 1.3.0 (registry+https://github.com/rust-lang/crates.io-index)", @@ -1796,7 +1763,7 @@ name = "openssl-sys" version = "0.9.47" source = "registry+https://github.com/rust-lang/crates.io-index" dependencies = [ - "autocfg 0.1.2 (registry+https://github.com/rust-lang/crates.io-index)", + "autocfg 0.1.4 (registry+https://github.com/rust-lang/crates.io-index)", "cc 1.0.37 (registry+https://github.com/rust-lang/crates.io-index)", "libc 0.2.58 (registry+https://github.com/rust-lang/crates.io-index)", "pkg-config 0.3.14 (registry+https://github.com/rust-lang/crates.io-index)", @@ -1808,7 +1775,7 @@ name = "ordered-float" version = "1.0.2" source = "registry+https://github.com/rust-lang/crates.io-index" dependencies = [ - "num-traits 0.2.7 (registry+https://github.com/rust-lang/crates.io-index)", + "num-traits 0.2.8 (registry+https://github.com/rust-lang/crates.io-index)", ] [[package]] @@ -1871,7 +1838,7 @@ dependencies = [ "libc 0.2.58 (registry+https://github.com/rust-lang/crates.io-index)", "rand 0.6.5 (registry+https://github.com/rust-lang/crates.io-index)", "rustc_version 0.2.3 (registry+https://github.com/rust-lang/crates.io-index)", - "smallvec 0.6.9 (registry+https://github.com/rust-lang/crates.io-index)", + "smallvec 0.6.10 (registry+https://github.com/rust-lang/crates.io-index)", "winapi 0.3.7 (registry+https://github.com/rust-lang/crates.io-index)", ] @@ -1886,7 +1853,7 @@ dependencies = [ "rand 0.6.5 (registry+https://github.com/rust-lang/crates.io-index)", "redox_syscall 0.1.54 (registry+https://github.com/rust-lang/crates.io-index)", "rustc_version 0.2.3 (registry+https://github.com/rust-lang/crates.io-index)", - "smallvec 0.6.9 (registry+https://github.com/rust-lang/crates.io-index)", + "smallvec 0.6.10 (registry+https://github.com/rust-lang/crates.io-index)", "winapi 0.3.7 (registry+https://github.com/rust-lang/crates.io-index)", ] @@ -1895,7 +1862,7 @@ name = "parse-zoneinfo" version = "0.2.0" source = "registry+https://github.com/rust-lang/crates.io-index" dependencies = [ - "regex 1.1.6 (registry+https://github.com/rust-lang/crates.io-index)", + "regex 1.1.7 (registry+https://github.com/rust-lang/crates.io-index)", ] [[package]] @@ -1968,14 +1935,14 @@ source = "registry+https://github.com/rust-lang/crates.io-index" [[package]] name = "plist" -version = "0.4.1" +version = "0.4.2" source = "registry+https://github.com/rust-lang/crates.io-index" dependencies = [ "base64 0.10.1 (registry+https://github.com/rust-lang/crates.io-index)", - "byteorder 1.3.1 (registry+https://github.com/rust-lang/crates.io-index)", + "byteorder 1.3.2 (registry+https://github.com/rust-lang/crates.io-index)", "humantime 1.2.0 (registry+https://github.com/rust-lang/crates.io-index)", "line-wrap 0.1.1 (registry+https://github.com/rust-lang/crates.io-index)", - "serde 1.0.91 (registry+https://github.com/rust-lang/crates.io-index)", + "serde 1.0.92 (registry+https://github.com/rust-lang/crates.io-index)", "xml-rs 0.8.0 (registry+https://github.com/rust-lang/crates.io-index)", ] @@ -2010,16 +1977,16 @@ dependencies = [ [[package]] name = "prettyprint" -version = "0.6.0" +version = "0.7.0" source = "registry+https://github.com/rust-lang/crates.io-index" dependencies = [ "ansi_colours 1.0.1 (registry+https://github.com/rust-lang/crates.io-index)", "ansi_term 0.11.0 (registry+https://github.com/rust-lang/crates.io-index)", "atty 0.2.11 (registry+https://github.com/rust-lang/crates.io-index)", "clap 2.33.0 (registry+https://github.com/rust-lang/crates.io-index)", - "console 0.7.5 (registry+https://github.com/rust-lang/crates.io-index)", + "console 0.7.7 (registry+https://github.com/rust-lang/crates.io-index)", "content_inspector 0.2.4 (registry+https://github.com/rust-lang/crates.io-index)", - "derive_builder 0.7.1 (registry+https://github.com/rust-lang/crates.io-index)", + "derive_builder 0.7.2 (registry+https://github.com/rust-lang/crates.io-index)", "directories 1.0.2 (registry+https://github.com/rust-lang/crates.io-index)", "encoding 0.2.33 (registry+https://github.com/rust-lang/crates.io-index)", "error-chain 0.12.1 (registry+https://github.com/rust-lang/crates.io-index)", @@ -2059,9 +2026,9 @@ dependencies = [ "directories 1.0.2 (registry+https://github.com/rust-lang/crates.io-index)", "isatty 0.1.9 (registry+https://github.com/rust-lang/crates.io-index)", "petgraph 0.4.13 (registry+https://github.com/rust-lang/crates.io-index)", - "serde 1.0.91 (registry+https://github.com/rust-lang/crates.io-index)", + "serde 1.0.92 (registry+https://github.com/rust-lang/crates.io-index)", "serde-value 0.5.3 (registry+https://github.com/rust-lang/crates.io-index)", - "serde_derive 1.0.91 (registry+https://github.com/rust-lang/crates.io-index)", + "serde_derive 1.0.92 (registry+https://github.com/rust-lang/crates.io-index)", "tint 1.0.1 (registry+https://github.com/rust-lang/crates.io-index)", ] @@ -2073,7 +2040,7 @@ dependencies = [ "error-chain 0.12.1 (registry+https://github.com/rust-lang/crates.io-index)", "idna 0.1.5 (registry+https://github.com/rust-lang/crates.io-index)", "lazy_static 1.3.0 (registry+https://github.com/rust-lang/crates.io-index)", - "regex 1.1.6 (registry+https://github.com/rust-lang/crates.io-index)", + "regex 1.1.7 (registry+https://github.com/rust-lang/crates.io-index)", "url 1.7.2 (registry+https://github.com/rust-lang/crates.io-index)", ] @@ -2095,7 +2062,7 @@ name = "rand" version = "0.6.5" source = "registry+https://github.com/rust-lang/crates.io-index" dependencies = [ - "autocfg 0.1.2 (registry+https://github.com/rust-lang/crates.io-index)", + "autocfg 0.1.4 (registry+https://github.com/rust-lang/crates.io-index)", "libc 0.2.58 (registry+https://github.com/rust-lang/crates.io-index)", "rand_chacha 0.1.1 (registry+https://github.com/rust-lang/crates.io-index)", "rand_core 0.4.0 (registry+https://github.com/rust-lang/crates.io-index)", @@ -2113,7 +2080,7 @@ name = "rand_chacha" version = "0.1.1" source = "registry+https://github.com/rust-lang/crates.io-index" dependencies = [ - "autocfg 0.1.2 (registry+https://github.com/rust-lang/crates.io-index)", + "autocfg 0.1.4 (registry+https://github.com/rust-lang/crates.io-index)", "rand_core 0.3.1 (registry+https://github.com/rust-lang/crates.io-index)", ] @@ -2174,7 +2141,7 @@ name = "rand_pcg" version = "0.1.2" source = "registry+https://github.com/rust-lang/crates.io-index" dependencies = [ - "autocfg 0.1.2 (registry+https://github.com/rust-lang/crates.io-index)", + "autocfg 0.1.4 (registry+https://github.com/rust-lang/crates.io-index)", "rand_core 0.4.0 (registry+https://github.com/rust-lang/crates.io-index)", ] @@ -2188,23 +2155,24 @@ dependencies = [ [[package]] name = "rayon" -version = "1.0.3" +version = "1.1.0" source = "registry+https://github.com/rust-lang/crates.io-index" dependencies = [ - "crossbeam-deque 0.2.0 (registry+https://github.com/rust-lang/crates.io-index)", + "crossbeam-deque 0.6.3 (registry+https://github.com/rust-lang/crates.io-index)", "either 1.5.2 (registry+https://github.com/rust-lang/crates.io-index)", - "rayon-core 1.4.1 (registry+https://github.com/rust-lang/crates.io-index)", + "rayon-core 1.5.0 (registry+https://github.com/rust-lang/crates.io-index)", ] [[package]] name = "rayon-core" -version = "1.4.1" +version = "1.5.0" source = "registry+https://github.com/rust-lang/crates.io-index" dependencies = [ - "crossbeam-deque 0.2.0 (registry+https://github.com/rust-lang/crates.io-index)", + "crossbeam-deque 0.6.3 (registry+https://github.com/rust-lang/crates.io-index)", + "crossbeam-queue 0.1.2 (registry+https://github.com/rust-lang/crates.io-index)", + "crossbeam-utils 0.6.5 (registry+https://github.com/rust-lang/crates.io-index)", "lazy_static 1.3.0 (registry+https://github.com/rust-lang/crates.io-index)", - "libc 0.2.58 (registry+https://github.com/rust-lang/crates.io-index)", - "num_cpus 1.10.0 (registry+https://github.com/rust-lang/crates.io-index)", + "num_cpus 1.10.1 (registry+https://github.com/rust-lang/crates.io-index)", ] [[package]] @@ -2241,19 +2209,19 @@ dependencies = [ [[package]] name = "regex" -version = "1.1.6" +version = "1.1.7" source = "registry+https://github.com/rust-lang/crates.io-index" dependencies = [ "aho-corasick 0.7.3 (registry+https://github.com/rust-lang/crates.io-index)", "memchr 2.2.0 (registry+https://github.com/rust-lang/crates.io-index)", - "regex-syntax 0.6.6 (registry+https://github.com/rust-lang/crates.io-index)", + "regex-syntax 0.6.7 (registry+https://github.com/rust-lang/crates.io-index)", "thread_local 0.3.6 (registry+https://github.com/rust-lang/crates.io-index)", - "utf8-ranges 1.0.2 (registry+https://github.com/rust-lang/crates.io-index)", + "utf8-ranges 1.0.3 (registry+https://github.com/rust-lang/crates.io-index)", ] [[package]] name = "regex-syntax" -version = "0.6.6" +version = "0.6.7" source = "registry+https://github.com/rust-lang/crates.io-index" dependencies = [ "ucd-util 0.1.3 (registry+https://github.com/rust-lang/crates.io-index)", @@ -2261,7 +2229,7 @@ dependencies = [ [[package]] name = "remove_dir_all" -version = "0.5.1" +version = "0.5.2" source = "registry+https://github.com/rust-lang/crates.io-index" dependencies = [ "winapi 0.3.7 (registry+https://github.com/rust-lang/crates.io-index)", @@ -2274,7 +2242,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index" dependencies = [ "itertools 0.7.11 (registry+https://github.com/rust-lang/crates.io-index)", "log 0.4.6 (registry+https://github.com/rust-lang/crates.io-index)", - "termcolor 1.0.4 (registry+https://github.com/rust-lang/crates.io-index)", + "termcolor 1.0.5 (registry+https://github.com/rust-lang/crates.io-index)", ] [[package]] @@ -2287,16 +2255,16 @@ dependencies = [ "cookie 0.12.0 (registry+https://github.com/rust-lang/crates.io-index)", "cookie_store 0.7.0 (registry+https://github.com/rust-lang/crates.io-index)", "encoding_rs 0.8.17 (registry+https://github.com/rust-lang/crates.io-index)", - "flate2 1.0.7 (registry+https://github.com/rust-lang/crates.io-index)", + "flate2 1.0.9 (registry+https://github.com/rust-lang/crates.io-index)", "futures 0.1.27 (registry+https://github.com/rust-lang/crates.io-index)", "http 0.1.17 (registry+https://github.com/rust-lang/crates.io-index)", - "hyper 0.12.29 (registry+https://github.com/rust-lang/crates.io-index)", + "hyper 0.12.30 (registry+https://github.com/rust-lang/crates.io-index)", "hyper-tls 0.3.2 (registry+https://github.com/rust-lang/crates.io-index)", "log 0.4.6 (registry+https://github.com/rust-lang/crates.io-index)", "mime 0.3.13 (registry+https://github.com/rust-lang/crates.io-index)", "mime_guess 2.0.0-alpha.6 (registry+https://github.com/rust-lang/crates.io-index)", "native-tls 0.2.3 (registry+https://github.com/rust-lang/crates.io-index)", - "serde 1.0.91 (registry+https://github.com/rust-lang/crates.io-index)", + "serde 1.0.92 (registry+https://github.com/rust-lang/crates.io-index)", "serde_json 1.0.39 (registry+https://github.com/rust-lang/crates.io-index)", "serde_urlencoded 0.5.5 (registry+https://github.com/rust-lang/crates.io-index)", "time 0.1.42 (registry+https://github.com/rust-lang/crates.io-index)", @@ -2309,9 +2277,14 @@ dependencies = [ "uuid 0.7.4 (registry+https://github.com/rust-lang/crates.io-index)", ] +[[package]] +name = "result" +version = "1.0.0" +source = "registry+https://github.com/rust-lang/crates.io-index" + [[package]] name = "roxmltree" -version = "0.6.0" +version = "0.6.1" source = "registry+https://github.com/rust-lang/crates.io-index" dependencies = [ "xmlparser 0.9.0 (registry+https://github.com/rust-lang/crates.io-index)", @@ -2324,7 +2297,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index" [[package]] name = "rustc-demangle" -version = "0.1.14" +version = "0.1.15" source = "registry+https://github.com/rust-lang/crates.io-index" [[package]] @@ -2332,7 +2305,7 @@ name = "rustc-hash" version = "1.0.1" source = "registry+https://github.com/rust-lang/crates.io-index" dependencies = [ - "byteorder 1.3.1 (registry+https://github.com/rust-lang/crates.io-index)", + "byteorder 1.3.2 (registry+https://github.com/rust-lang/crates.io-index)", ] [[package]] @@ -2345,8 +2318,8 @@ dependencies = [ [[package]] name = "rustyline" -version = "4.1.0" -source = "git+https://github.com/kkawakam/rustyline.git#cad8b2fc0b253831aaff143bdce5d2abec66a9c9" +version = "5.0.0" +source = "git+https://github.com/kkawakam/rustyline.git#70e45caf47b699e43bec0d2fb722aae2cdad602f" dependencies = [ "dirs 2.0.1 (registry+https://github.com/rust-lang/crates.io-index)", "libc 0.2.58 (registry+https://github.com/rust-lang/crates.io-index)", @@ -2440,10 +2413,10 @@ source = "registry+https://github.com/rust-lang/crates.io-index" [[package]] name = "serde" -version = "1.0.91" +version = "1.0.92" source = "registry+https://github.com/rust-lang/crates.io-index" dependencies = [ - "serde_derive 1.0.91 (registry+https://github.com/rust-lang/crates.io-index)", + "serde_derive 1.0.92 (registry+https://github.com/rust-lang/crates.io-index)", ] [[package]] @@ -2454,7 +2427,7 @@ dependencies = [ "lazy_static 0.2.11 (registry+https://github.com/rust-lang/crates.io-index)", "linked-hash-map 0.3.0 (registry+https://github.com/rust-lang/crates.io-index)", "num-traits 0.1.43 (registry+https://github.com/rust-lang/crates.io-index)", - "regex 1.1.6 (registry+https://github.com/rust-lang/crates.io-index)", + "regex 1.1.7 (registry+https://github.com/rust-lang/crates.io-index)", "serde 0.8.23 (registry+https://github.com/rust-lang/crates.io-index)", ] @@ -2466,7 +2439,7 @@ dependencies = [ "lazy_static 0.2.11 (registry+https://github.com/rust-lang/crates.io-index)", "linked-hash-map 0.3.0 (registry+https://github.com/rust-lang/crates.io-index)", "num-traits 0.1.43 (registry+https://github.com/rust-lang/crates.io-index)", - "regex 1.1.6 (registry+https://github.com/rust-lang/crates.io-index)", + "regex 1.1.7 (registry+https://github.com/rust-lang/crates.io-index)", "serde 0.8.23 (registry+https://github.com/rust-lang/crates.io-index)", ] @@ -2476,17 +2449,17 @@ version = "0.5.3" source = "registry+https://github.com/rust-lang/crates.io-index" dependencies = [ "ordered-float 1.0.2 (registry+https://github.com/rust-lang/crates.io-index)", - "serde 1.0.91 (registry+https://github.com/rust-lang/crates.io-index)", + "serde 1.0.92 (registry+https://github.com/rust-lang/crates.io-index)", ] [[package]] name = "serde_derive" -version = "1.0.91" +version = "1.0.92" source = "registry+https://github.com/rust-lang/crates.io-index" dependencies = [ "proc-macro2 0.4.30 (registry+https://github.com/rust-lang/crates.io-index)", "quote 0.6.12 (registry+https://github.com/rust-lang/crates.io-index)", - "syn 0.15.34 (registry+https://github.com/rust-lang/crates.io-index)", + "syn 0.15.36 (registry+https://github.com/rust-lang/crates.io-index)", ] [[package]] @@ -2495,7 +2468,17 @@ version = "0.24.1" source = "registry+https://github.com/rust-lang/crates.io-index" dependencies = [ "proc-macro2 0.4.30 (registry+https://github.com/rust-lang/crates.io-index)", - "syn 0.15.34 (registry+https://github.com/rust-lang/crates.io-index)", + "syn 0.15.36 (registry+https://github.com/rust-lang/crates.io-index)", +] + +[[package]] +name = "serde_ini" +version = "0.2.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +dependencies = [ + "result 1.0.0 (registry+https://github.com/rust-lang/crates.io-index)", + "serde 1.0.92 (registry+https://github.com/rust-lang/crates.io-index)", + "void 1.0.2 (registry+https://github.com/rust-lang/crates.io-index)", ] [[package]] @@ -2505,7 +2488,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index" dependencies = [ "itoa 0.4.4 (registry+https://github.com/rust-lang/crates.io-index)", "ryu 0.2.8 (registry+https://github.com/rust-lang/crates.io-index)", - "serde 1.0.91 (registry+https://github.com/rust-lang/crates.io-index)", + "serde 1.0.92 (registry+https://github.com/rust-lang/crates.io-index)", ] [[package]] @@ -2523,7 +2506,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index" dependencies = [ "dtoa 0.4.4 (registry+https://github.com/rust-lang/crates.io-index)", "itoa 0.4.4 (registry+https://github.com/rust-lang/crates.io-index)", - "serde 1.0.91 (registry+https://github.com/rust-lang/crates.io-index)", + "serde 1.0.92 (registry+https://github.com/rust-lang/crates.io-index)", "url 1.7.2 (registry+https://github.com/rust-lang/crates.io-index)", ] @@ -2534,7 +2517,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index" dependencies = [ "dtoa 0.4.4 (registry+https://github.com/rust-lang/crates.io-index)", "linked-hash-map 0.5.2 (registry+https://github.com/rust-lang/crates.io-index)", - "serde 1.0.91 (registry+https://github.com/rust-lang/crates.io-index)", + "serde 1.0.92 (registry+https://github.com/rust-lang/crates.io-index)", "yaml-rust 0.4.3 (registry+https://github.com/rust-lang/crates.io-index)", ] @@ -2582,7 +2565,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index" [[package]] name = "smallvec" -version = "0.6.9" +version = "0.6.10" source = "registry+https://github.com/rust-lang/crates.io-index" [[package]] @@ -2610,8 +2593,8 @@ source = "registry+https://github.com/rust-lang/crates.io-index" [[package]] name = "subprocess" -version = "0.1.19" -source = "git+https://github.com/jonathandturner/rust-subprocess.git?branch=is_already_escaped#6d184a680d825da4f365c063db1c4f9db3d64ba6" +version = "0.1.18" +source = "registry+https://github.com/rust-lang/crates.io-index" dependencies = [ "crossbeam-utils 0.5.0 (registry+https://github.com/rust-lang/crates.io-index)", "libc 0.2.58 (registry+https://github.com/rust-lang/crates.io-index)", @@ -2630,7 +2613,7 @@ dependencies = [ [[package]] name = "syn" -version = "0.15.34" +version = "0.15.36" source = "registry+https://github.com/rust-lang/crates.io-index" dependencies = [ "proc-macro2 0.4.30 (registry+https://github.com/rust-lang/crates.io-index)", @@ -2645,7 +2628,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index" dependencies = [ "proc-macro2 0.4.30 (registry+https://github.com/rust-lang/crates.io-index)", "quote 0.6.12 (registry+https://github.com/rust-lang/crates.io-index)", - "syn 0.15.34 (registry+https://github.com/rust-lang/crates.io-index)", + "syn 0.15.36 (registry+https://github.com/rust-lang/crates.io-index)", "unicode-xid 0.1.0 (registry+https://github.com/rust-lang/crates.io-index)", ] @@ -2655,29 +2638,38 @@ version = "3.2.0" source = "registry+https://github.com/rust-lang/crates.io-index" dependencies = [ "bincode 1.1.4 (registry+https://github.com/rust-lang/crates.io-index)", - "bitflags 1.0.4 (registry+https://github.com/rust-lang/crates.io-index)", - "flate2 1.0.7 (registry+https://github.com/rust-lang/crates.io-index)", + "bitflags 1.1.0 (registry+https://github.com/rust-lang/crates.io-index)", + "flate2 1.0.9 (registry+https://github.com/rust-lang/crates.io-index)", "fnv 1.0.6 (registry+https://github.com/rust-lang/crates.io-index)", "lazy_static 1.3.0 (registry+https://github.com/rust-lang/crates.io-index)", "lazycell 1.2.1 (registry+https://github.com/rust-lang/crates.io-index)", "onig 4.3.2 (registry+https://github.com/rust-lang/crates.io-index)", - "plist 0.4.1 (registry+https://github.com/rust-lang/crates.io-index)", - "regex-syntax 0.6.6 (registry+https://github.com/rust-lang/crates.io-index)", - "serde 1.0.91 (registry+https://github.com/rust-lang/crates.io-index)", - "serde_derive 1.0.91 (registry+https://github.com/rust-lang/crates.io-index)", + "plist 0.4.2 (registry+https://github.com/rust-lang/crates.io-index)", + "regex-syntax 0.6.7 (registry+https://github.com/rust-lang/crates.io-index)", + "serde 1.0.92 (registry+https://github.com/rust-lang/crates.io-index)", + "serde_derive 1.0.92 (registry+https://github.com/rust-lang/crates.io-index)", "serde_json 1.0.39 (registry+https://github.com/rust-lang/crates.io-index)", - "walkdir 2.2.7 (registry+https://github.com/rust-lang/crates.io-index)", + "walkdir 2.2.8 (registry+https://github.com/rust-lang/crates.io-index)", "yaml-rust 0.4.3 (registry+https://github.com/rust-lang/crates.io-index)", ] +[[package]] +name = "sys-info" +version = "0.5.7" +source = "registry+https://github.com/rust-lang/crates.io-index" +dependencies = [ + "cc 1.0.37 (registry+https://github.com/rust-lang/crates.io-index)", + "libc 0.2.58 (registry+https://github.com/rust-lang/crates.io-index)", +] + [[package]] name = "sysinfo" -version = "0.8.4" +version = "0.8.5" source = "registry+https://github.com/rust-lang/crates.io-index" dependencies = [ "cfg-if 0.1.9 (registry+https://github.com/rust-lang/crates.io-index)", "libc 0.2.58 (registry+https://github.com/rust-lang/crates.io-index)", - "rayon 1.0.3 (registry+https://github.com/rust-lang/crates.io-index)", + "rayon 1.1.0 (registry+https://github.com/rust-lang/crates.io-index)", "winapi 0.3.7 (registry+https://github.com/rust-lang/crates.io-index)", ] @@ -2690,7 +2682,7 @@ dependencies = [ "libc 0.2.58 (registry+https://github.com/rust-lang/crates.io-index)", "rand 0.6.5 (registry+https://github.com/rust-lang/crates.io-index)", "redox_syscall 0.1.54 (registry+https://github.com/rust-lang/crates.io-index)", - "remove_dir_all 0.5.1 (registry+https://github.com/rust-lang/crates.io-index)", + "remove_dir_all 0.5.2 (registry+https://github.com/rust-lang/crates.io-index)", "winapi 0.3.7 (registry+https://github.com/rust-lang/crates.io-index)", ] @@ -2699,7 +2691,7 @@ name = "term" version = "0.5.2" source = "registry+https://github.com/rust-lang/crates.io-index" dependencies = [ - "byteorder 1.3.1 (registry+https://github.com/rust-lang/crates.io-index)", + "byteorder 1.3.2 (registry+https://github.com/rust-lang/crates.io-index)", "dirs 1.0.5 (registry+https://github.com/rust-lang/crates.io-index)", "winapi 0.3.7 (registry+https://github.com/rust-lang/crates.io-index)", ] @@ -2716,7 +2708,7 @@ dependencies = [ [[package]] name = "termcolor" -version = "1.0.4" +version = "1.0.5" source = "registry+https://github.com/rust-lang/crates.io-index" dependencies = [ "wincolor 1.0.1 (registry+https://github.com/rust-lang/crates.io-index)", @@ -2724,7 +2716,7 @@ dependencies = [ [[package]] name = "termion" -version = "1.5.2" +version = "1.5.3" source = "registry+https://github.com/rust-lang/crates.io-index" dependencies = [ "libc 0.2.58 (registry+https://github.com/rust-lang/crates.io-index)", @@ -2783,7 +2775,7 @@ dependencies = [ "bytes 0.4.12 (registry+https://github.com/rust-lang/crates.io-index)", "futures 0.1.27 (registry+https://github.com/rust-lang/crates.io-index)", "mio 0.6.19 (registry+https://github.com/rust-lang/crates.io-index)", - "num_cpus 1.10.0 (registry+https://github.com/rust-lang/crates.io-index)", + "num_cpus 1.10.1 (registry+https://github.com/rust-lang/crates.io-index)", "tokio-current-thread 0.1.6 (registry+https://github.com/rust-lang/crates.io-index)", "tokio-executor 0.1.7 (registry+https://github.com/rust-lang/crates.io-index)", "tokio-io 0.1.12 (registry+https://github.com/rust-lang/crates.io-index)", @@ -2852,7 +2844,7 @@ dependencies = [ "lazy_static 1.3.0 (registry+https://github.com/rust-lang/crates.io-index)", "log 0.4.6 (registry+https://github.com/rust-lang/crates.io-index)", "mio 0.6.19 (registry+https://github.com/rust-lang/crates.io-index)", - "num_cpus 1.10.0 (registry+https://github.com/rust-lang/crates.io-index)", + "num_cpus 1.10.1 (registry+https://github.com/rust-lang/crates.io-index)", "parking_lot 0.7.1 (registry+https://github.com/rust-lang/crates.io-index)", "slab 0.4.2 (registry+https://github.com/rust-lang/crates.io-index)", "tokio-executor 0.1.7 (registry+https://github.com/rust-lang/crates.io-index)", @@ -2892,7 +2884,7 @@ dependencies = [ "crossbeam-utils 0.6.5 (registry+https://github.com/rust-lang/crates.io-index)", "futures 0.1.27 (registry+https://github.com/rust-lang/crates.io-index)", "log 0.4.6 (registry+https://github.com/rust-lang/crates.io-index)", - "num_cpus 1.10.0 (registry+https://github.com/rust-lang/crates.io-index)", + "num_cpus 1.10.1 (registry+https://github.com/rust-lang/crates.io-index)", "rand 0.6.5 (registry+https://github.com/rust-lang/crates.io-index)", "slab 0.4.2 (registry+https://github.com/rust-lang/crates.io-index)", "tokio-executor 0.1.7 (registry+https://github.com/rust-lang/crates.io-index)", @@ -2922,7 +2914,7 @@ name = "toml" version = "0.4.10" source = "registry+https://github.com/rust-lang/crates.io-index" dependencies = [ - "serde 1.0.91 (registry+https://github.com/rust-lang/crates.io-index)", + "serde 1.0.92 (registry+https://github.com/rust-lang/crates.io-index)", ] [[package]] @@ -2930,7 +2922,7 @@ name = "toml" version = "0.5.1" source = "registry+https://github.com/rust-lang/crates.io-index" dependencies = [ - "serde 1.0.91 (registry+https://github.com/rust-lang/crates.io-index)", + "serde 1.0.92 (registry+https://github.com/rust-lang/crates.io-index)", ] [[package]] @@ -2942,7 +2934,7 @@ dependencies = [ "failure_derive 0.1.5 (registry+https://github.com/rust-lang/crates.io-index)", "is-match 0.1.0 (registry+https://github.com/rust-lang/crates.io-index)", "lazy_static 1.3.0 (registry+https://github.com/rust-lang/crates.io-index)", - "regex 1.1.6 (registry+https://github.com/rust-lang/crates.io-index)", + "regex 1.1.7 (registry+https://github.com/rust-lang/crates.io-index)", "toml 0.5.1 (registry+https://github.com/rust-lang/crates.io-index)", "toml-query_derive 0.9.0 (registry+https://github.com/rust-lang/crates.io-index)", ] @@ -2954,7 +2946,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index" dependencies = [ "darling 0.8.6 (registry+https://github.com/rust-lang/crates.io-index)", "quote 0.6.12 (registry+https://github.com/rust-lang/crates.io-index)", - "syn 0.15.34 (registry+https://github.com/rust-lang/crates.io-index)", + "syn 0.15.36 (registry+https://github.com/rust-lang/crates.io-index)", ] [[package]] @@ -3009,7 +3001,7 @@ name = "unicode-normalization" version = "0.1.8" source = "registry+https://github.com/rust-lang/crates.io-index" dependencies = [ - "smallvec 0.6.9 (registry+https://github.com/rust-lang/crates.io-index)", + "smallvec 0.6.10 (registry+https://github.com/rust-lang/crates.io-index)", ] [[package]] @@ -3039,7 +3031,7 @@ dependencies = [ [[package]] name = "utf8-ranges" -version = "1.0.2" +version = "1.0.3" source = "registry+https://github.com/rust-lang/crates.io-index" [[package]] @@ -3077,7 +3069,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index" [[package]] name = "walkdir" -version = "2.2.7" +version = "2.2.8" source = "registry+https://github.com/rust-lang/crates.io-index" dependencies = [ "same-file 1.0.4 (registry+https://github.com/rust-lang/crates.io-index)", @@ -3215,18 +3207,18 @@ dependencies = [ "checksum array-macro 1.0.3 (registry+https://github.com/rust-lang/crates.io-index)" = "7c4ff37a25fb442a1fecfd399be0dde685558bca30fb998420532889a36852d2" "checksum arrayvec 0.4.10 (registry+https://github.com/rust-lang/crates.io-index)" = "92c7fb76bc8826a8b33b4ee5bb07a247a81e76764ab4d55e8f73e3a4d8808c71" "checksum atty 0.2.11 (registry+https://github.com/rust-lang/crates.io-index)" = "9a7d5b8723950951411ee34d271d99dddcc2035a16ab25310ea2c8cfd4369652" -"checksum autocfg 0.1.2 (registry+https://github.com/rust-lang/crates.io-index)" = "a6d640bee2da49f60a4068a7fae53acde8982514ab7bae8b8cea9e88cbcfd799" -"checksum backtrace 0.3.20 (registry+https://github.com/rust-lang/crates.io-index)" = "45934a579eff9fd0ff637ac376a4bd134f47f8fc603f0b211d696b54d61e35f1" +"checksum autocfg 0.1.4 (registry+https://github.com/rust-lang/crates.io-index)" = "0e49efa51329a5fd37e7c79db4621af617cd4e3e5bc224939808d076077077bf" +"checksum backtrace 0.3.30 (registry+https://github.com/rust-lang/crates.io-index)" = "ada4c783bb7e7443c14e0480f429ae2cc99da95065aeab7ee1b81ada0419404f" "checksum backtrace-sys 0.1.28 (registry+https://github.com/rust-lang/crates.io-index)" = "797c830ac25ccc92a7f8a7b9862bde440715531514594a6154e3d4a54dd769b6" "checksum base64 0.10.1 (registry+https://github.com/rust-lang/crates.io-index)" = "0b25d992356d2eb0ed82172f5248873db5560c4721f564b13cb5193bda5e668e" "checksum bincode 1.1.4 (registry+https://github.com/rust-lang/crates.io-index)" = "9f04a5e50dc80b3d5d35320889053637d15011aed5e66b66b37ae798c65da6f7" -"checksum bitflags 1.0.4 (registry+https://github.com/rust-lang/crates.io-index)" = "228047a76f468627ca71776ecdebd732a3423081fcf5125585bcd7c49886ce12" +"checksum bitflags 1.1.0 (registry+https://github.com/rust-lang/crates.io-index)" = "3d155346769a6855b86399e9bc3814ab343cd3d62c7e985113d46a0ec3c281fd" "checksum blake2-rfc 0.2.18 (registry+https://github.com/rust-lang/crates.io-index)" = "5d6d530bdd2d52966a6d03b7a964add7ae1a288d25214066fd4b600f0f796400" "checksum block 0.1.6 (registry+https://github.com/rust-lang/crates.io-index)" = "0d8c1fef690941d3e7788d328517591fecc684c084084702d6ff1641e993699a" "checksum build_const 0.2.1 (registry+https://github.com/rust-lang/crates.io-index)" = "39092a32794787acd8525ee150305ff051b0aa6cc2abaf193924f5ab05425f39" "checksum byte-unit 2.1.0 (registry+https://github.com/rust-lang/crates.io-index)" = "6754bb4703aa167bed5381f0c6842f1cc31a9ecde3b9443f726dde3ad3afb841" "checksum bytecount 0.3.2 (registry+https://github.com/rust-lang/crates.io-index)" = "f861d9ce359f56dbcb6e0c2a1cb84e52ad732cadb57b806adeb3c7668caccbd8" -"checksum byteorder 1.3.1 (registry+https://github.com/rust-lang/crates.io-index)" = "a019b10a2a7cdeb292db131fc8113e57ea2a908f6e7894b0c3c671893b65dbeb" +"checksum byteorder 1.3.2 (registry+https://github.com/rust-lang/crates.io-index)" = "a7c3dd8985a7111efc5c80b44e23ecdd8c007de8ade3b96595387e812b957cf5" "checksum bytes 0.4.12 (registry+https://github.com/rust-lang/crates.io-index)" = "206fdffcfa2df7cbe15601ef46c813fce0965eb3286db6b56c583b814b51c81c" "checksum cc 1.0.37 (registry+https://github.com/rust-lang/crates.io-index)" = "39f75544d7bbaf57560d2168f28fd649ff9c76153874db88bdbdfd839b1a7e7d" "checksum cfg-if 0.1.9 (registry+https://github.com/rust-lang/crates.io-index)" = "b486ce3ccf7ffd79fdeb678eac06a9e6c09fc88d33836340becb8fffe87c5e33" @@ -3240,7 +3232,7 @@ dependencies = [ "checksum cloudabi 0.0.3 (registry+https://github.com/rust-lang/crates.io-index)" = "ddfc5b9aa5d4507acaf872de71051dfd0e309860e88966e1051e462a077aac4f" "checksum conch-parser 0.1.1 (registry+https://github.com/rust-lang/crates.io-index)" = "baf61cea7edff80a7d8a9a4c219d391664715559e9d4e7129494b45278705a41" "checksum config 0.9.3 (registry+https://github.com/rust-lang/crates.io-index)" = "f9107d78ed62b3fa5a86e7d18e647abed48cfd8f8fab6c72f4cdb982d196f7e6" -"checksum console 0.7.5 (registry+https://github.com/rust-lang/crates.io-index)" = "2bf3720d3f3fc30b721ef1ae54e13af3264af4af39dc476a8de56a6ee1e2184b" +"checksum console 0.7.7 (registry+https://github.com/rust-lang/crates.io-index)" = "8ca57c2c14b8a2bf3105bc9d15574aad80babf6a9c44b1058034cdf8bd169628" "checksum constant_time_eq 0.1.3 (registry+https://github.com/rust-lang/crates.io-index)" = "8ff012e225ce166d4422e0e78419d901719760f62ae2b7969ca6b564d1b54a9e" "checksum content_inspector 0.2.4 (registry+https://github.com/rust-lang/crates.io-index)" = "b7bda66e858c683005a53a9a60c69a4aca7eeaa45d124526e389f7aec8e62f38" "checksum cookie 0.12.0 (registry+https://github.com/rust-lang/crates.io-index)" = "888604f00b3db336d2af898ec3c1d5d0ddf5e6d462220f2ededc33a87ac4bbd5" @@ -3250,19 +3242,16 @@ dependencies = [ "checksum crc 1.8.1 (registry+https://github.com/rust-lang/crates.io-index)" = "d663548de7f5cca343f1e0a48d14dcfb0e9eb4e079ec58883b7251539fa10aeb" "checksum crc32fast 1.2.0 (registry+https://github.com/rust-lang/crates.io-index)" = "ba125de2af0df55319f41944744ad91c71113bf74a4646efff39afe1f6842db1" "checksum crossbeam-channel 0.3.8 (registry+https://github.com/rust-lang/crates.io-index)" = "0f0ed1a4de2235cabda8558ff5840bffb97fcb64c97827f354a451307df5f72b" -"checksum crossbeam-deque 0.2.0 (registry+https://github.com/rust-lang/crates.io-index)" = "f739f8c5363aca78cfb059edf753d8f0d36908c348f3d8d1503f03d8b75d9cf3" +"checksum crossbeam-deque 0.6.3 (registry+https://github.com/rust-lang/crates.io-index)" = "05e44b8cf3e1a625844d1750e1f7820da46044ff6d28f4d43e455ba3e5bb2c13" "checksum crossbeam-deque 0.7.1 (registry+https://github.com/rust-lang/crates.io-index)" = "b18cd2e169ad86297e6bc0ad9aa679aee9daa4f19e8163860faf7c164e4f5a71" -"checksum crossbeam-epoch 0.3.1 (registry+https://github.com/rust-lang/crates.io-index)" = "927121f5407de9956180ff5e936fe3cf4324279280001cd56b669d28ee7e9150" "checksum crossbeam-epoch 0.7.1 (registry+https://github.com/rust-lang/crates.io-index)" = "04c9e3102cc2d69cd681412141b390abd55a362afc1540965dad0ad4d34280b4" "checksum crossbeam-queue 0.1.2 (registry+https://github.com/rust-lang/crates.io-index)" = "7c979cd6cfe72335896575c6b5688da489e420d36a27a0b9eb0c73db574b4a4b" -"checksum crossbeam-utils 0.2.2 (registry+https://github.com/rust-lang/crates.io-index)" = "2760899e32a1d58d5abb31129f8fae5de75220bc2176e77ff7c627ae45c918d9" "checksum crossbeam-utils 0.5.0 (registry+https://github.com/rust-lang/crates.io-index)" = "677d453a17e8bd2b913fa38e8b9cf04bcdbb5be790aa294f2389661d72036015" "checksum crossbeam-utils 0.6.5 (registry+https://github.com/rust-lang/crates.io-index)" = "f8306fcef4a7b563b76b7dd949ca48f52bc1141aa067d2ea09565f3e2652aa5c" "checksum csv 1.0.7 (registry+https://github.com/rust-lang/crates.io-index)" = "9044e25afb0924b5a5fc5511689b0918629e85d68ea591e5e87fbf1e85ea1b3b" "checksum csv-core 0.1.5 (registry+https://github.com/rust-lang/crates.io-index)" = "fa5cdef62f37e6ffe7d1f07a381bc0db32b7a3ff1cac0de56cb0d81e71f53d65" "checksum ctor 0.1.9 (registry+https://github.com/rust-lang/crates.io-index)" = "3b4c17619643c1252b5f690084b82639dd7fac141c57c8e77a00e0148132092c" "checksum ctrlc 3.1.3 (registry+https://github.com/rust-lang/crates.io-index)" = "c7dfd2d8b4c82121dfdff120f818e09fc4380b0b7e17a742081a89b94853e87f" -"checksum curl-sys 0.4.18 (registry+https://github.com/rust-lang/crates.io-index)" = "9d91a0052d5b982887d8e829bee0faffc7218ea3c6ebd3d6c2c8f678a93c9a42" "checksum cursive 0.12.0 (registry+https://github.com/rust-lang/crates.io-index)" = "b7ecc7282b5361471b607c26f44148205607e26d48a2fc65bd16e7619b1ebb78" "checksum darling 0.8.6 (registry+https://github.com/rust-lang/crates.io-index)" = "9158d690bc62a3a57c3e45b85e4d50de2008b39345592c64efd79345c7e24be0" "checksum darling 0.9.0 (registry+https://github.com/rust-lang/crates.io-index)" = "fcfbcb0c5961907597a7d1148e3af036268f2b773886b8bb3eeb1e1281d3d3d6" @@ -3271,8 +3260,8 @@ dependencies = [ "checksum darling_macro 0.8.6 (registry+https://github.com/rust-lang/crates.io-index)" = "244e8987bd4e174385240cde20a3657f607fb0797563c28255c353b5819a07b1" "checksum darling_macro 0.9.0 (registry+https://github.com/rust-lang/crates.io-index)" = "c6d8dac1c6f1d29a41c4712b4400f878cb4fcc4c7628f298dd75038e024998d1" "checksum derive-new 0.5.6 (registry+https://github.com/rust-lang/crates.io-index)" = "6ca414e896ae072546f4d789f452daaecf60ddee4c9df5dc6d5936d769e3d87c" -"checksum derive_builder 0.7.1 (registry+https://github.com/rust-lang/crates.io-index)" = "a0ca533e6abb78f9108585535ce2ae0b14c8b4504e138a9a28eaf8ba2b270c1d" -"checksum derive_builder_core 0.4.1 (registry+https://github.com/rust-lang/crates.io-index)" = "fb484fe06ba1dc5b82f88aff700191dfc127e02b06b35e302c169706168e2528" +"checksum derive_builder 0.7.2 (registry+https://github.com/rust-lang/crates.io-index)" = "3ac53fa6a3cda160df823a9346442525dcaf1e171999a1cf23e67067e4fd64d4" +"checksum derive_builder_core 0.5.0 (registry+https://github.com/rust-lang/crates.io-index)" = "0288a23da9333c246bb18c143426074a6ae96747995c5819d2947b64cd942b37" "checksum derive_more 0.15.0 (registry+https://github.com/rust-lang/crates.io-index)" = "7a141330240c921ec6d074a3e188a7c7ef95668bb95e7d44fa0e5778ec2a7afe" "checksum difference 2.0.0 (registry+https://github.com/rust-lang/crates.io-index)" = "524cbf6897b527295dff137cec09ecf3a05f4fddffd7dfcd1585403449e74198" "checksum directories 1.0.2 (registry+https://github.com/rust-lang/crates.io-index)" = "72d337a64190607d4fcca2cb78982c5dd57f4916e19696b48a575fa746b6cb0f" @@ -3304,7 +3293,7 @@ dependencies = [ "checksum failure 0.1.5 (registry+https://github.com/rust-lang/crates.io-index)" = "795bd83d3abeb9220f257e597aa0080a508b27533824adf336529648f6abf7e2" "checksum failure_derive 0.1.5 (registry+https://github.com/rust-lang/crates.io-index)" = "ea1063915fd7ef4309e222a5a07cf9c319fb9c7836b1f89b85458672dbb127e1" "checksum fixedbitset 0.1.9 (registry+https://github.com/rust-lang/crates.io-index)" = "86d4de0081402f5e88cdac65c8dcdcc73118c1a7a465e2a05f0da05843a8ea33" -"checksum flate2 1.0.7 (registry+https://github.com/rust-lang/crates.io-index)" = "f87e68aa82b2de08a6e037f1385455759df6e445a8df5e005b4297191dbf18aa" +"checksum flate2 1.0.9 (registry+https://github.com/rust-lang/crates.io-index)" = "550934ad4808d5d39365e5d61727309bf18b3b02c6c56b729cb92e7dd84bc3d8" "checksum fnv 1.0.6 (registry+https://github.com/rust-lang/crates.io-index)" = "2fad85553e09a6f881f739c29f0b00b0f01357c743266d478b68951ce23285f3" "checksum foreign-types 0.3.2 (registry+https://github.com/rust-lang/crates.io-index)" = "f6f339eb8adc052cd2ca78910fda869aefa38d22d5cb648e6485e4d3fc06f3b1" "checksum foreign-types-shared 0.1.1 (registry+https://github.com/rust-lang/crates.io-index)" = "00b0228411908ca8685dba7fc2cdd70ec9990a6e753e89b6ac91a84c40fbaf4b" @@ -3322,14 +3311,14 @@ dependencies = [ "checksum futures-util-preview 0.3.0-alpha.16 (registry+https://github.com/rust-lang/crates.io-index)" = "f7a0451b9c5047c2b9ab93425ffd0793165511e93c04b977cd45fbd41c6e34b2" "checksum futures_codec 0.2.2 (registry+https://github.com/rust-lang/crates.io-index)" = "b60f48aa03e365df015d2fbf0b79f17b440350c268a5e20305da17b394adcc1e" "checksum getset 0.0.7 (registry+https://github.com/rust-lang/crates.io-index)" = "19fbde0fad0c1c1f9474694b1f5c9ba22b09f2f74f74e6d2bd19c43f6656e2cb" -"checksum git2 0.8.0 (registry+https://github.com/rust-lang/crates.io-index)" = "c7339329bfa14a00223244311560d11f8f489b453fb90092af97f267a6090ab0" -"checksum h2 0.1.23 (registry+https://github.com/rust-lang/crates.io-index)" = "1e42e3daed5a7e17b12a0c23b5b2fbff23a925a570938ebee4baca1a9a1a2240" -"checksum hashbrown 0.3.0 (registry+https://github.com/rust-lang/crates.io-index)" = "570178d5e4952010d138b0f1d581271ff3a02406d990f887d1e87e3d6e43b0ac" +"checksum git2 0.9.1 (registry+https://github.com/rust-lang/crates.io-index)" = "924b2e7d2986e625dcad89e8a429a7b3adee3c3d71e585f4a66c4f7e78715e31" +"checksum h2 0.1.24 (registry+https://github.com/rust-lang/crates.io-index)" = "69b2a5a3092cbebbc951fe55408402e696ee2ed09019137d1800fc2c411265d2" +"checksum hashbrown 0.3.1 (registry+https://github.com/rust-lang/crates.io-index)" = "29fba9abe4742d586dfd0c06ae4f7e73a1c2d86b856933509b269d82cdf06e18" "checksum http 0.1.17 (registry+https://github.com/rust-lang/crates.io-index)" = "eed324f0f0daf6ec10c474f150505af2c143f251722bf9dbd1261bd1f2ee2c1a" "checksum http-body 0.1.0 (registry+https://github.com/rust-lang/crates.io-index)" = "6741c859c1b2463a423a1dbce98d418e6c3c3fc720fb0d45528657320920292d" "checksum httparse 1.3.3 (registry+https://github.com/rust-lang/crates.io-index)" = "e8734b0cfd3bc3e101ec59100e101c2eecd19282202e87808b3037b442777a83" "checksum humantime 1.2.0 (registry+https://github.com/rust-lang/crates.io-index)" = "3ca7e5f2e110db35f93b837c81797f3714500b81d517bf20c431b16d3ca4f114" -"checksum hyper 0.12.29 (registry+https://github.com/rust-lang/crates.io-index)" = "e2cd6adf83b3347d36e271f030621a8cf95fd1fd0760546b9fc5a24a0f1447c7" +"checksum hyper 0.12.30 (registry+https://github.com/rust-lang/crates.io-index)" = "40e7692b2009a70b1e9b362284add4d8b75880fefddb4acaa5e67194e843f219" "checksum hyper-tls 0.3.2 (registry+https://github.com/rust-lang/crates.io-index)" = "3a800d6aa50af4b5850b2b0f659625ce9504df908e9733b635720483be26174f" "checksum ident_case 1.0.1 (registry+https://github.com/rust-lang/crates.io-index)" = "b9e0384b61958566e926dc50660321d12159025e767c18e043daf26b70104c39" "checksum idna 0.1.5 (registry+https://github.com/rust-lang/crates.io-index)" = "38f09e0f0b1fb55fdee1f17470ad800da77af5186a1a76c026b679358b7e844e" @@ -3347,7 +3336,7 @@ dependencies = [ "checksum lazy_static 1.3.0 (registry+https://github.com/rust-lang/crates.io-index)" = "bc5729f27f159ddd61f4df6228e827e86643d4d3e7c32183cb30a1c08f604a14" "checksum lazycell 1.2.1 (registry+https://github.com/rust-lang/crates.io-index)" = "b294d6fa9ee409a054354afc4352b0b9ef7ca222c69b8812cbea9e7d2bf3783f" "checksum libc 0.2.58 (registry+https://github.com/rust-lang/crates.io-index)" = "6281b86796ba5e4366000be6e9e18bf35580adf9e63fbe2294aadb587613a319" -"checksum libgit2-sys 0.7.11 (registry+https://github.com/rust-lang/crates.io-index)" = "48441cb35dc255da8ae72825689a95368bf510659ae1ad55dc4aa88cb1789bf1" +"checksum libgit2-sys 0.8.1 (registry+https://github.com/rust-lang/crates.io-index)" = "941a41e23f77323b8c9d2ee118aec9ee39dfc176078c18b4757d3bad049d9ff7" "checksum libssh2-sys 0.2.11 (registry+https://github.com/rust-lang/crates.io-index)" = "126a1f4078368b163bfdee65fbab072af08a1b374a5551b21e87ade27b1fbf9d" "checksum libz-sys 1.0.25 (registry+https://github.com/rust-lang/crates.io-index)" = "2eb5e43362e38e2bca2fd5f5134c4d4564a23a5c28e9b95411652021a8675ebe" "checksum line-wrap 0.1.1 (registry+https://github.com/rust-lang/crates.io-index)" = "f30344350a2a51da54c1d53be93fade8a237e545dbcc4bdbe635413f2117cab9" @@ -3379,13 +3368,13 @@ dependencies = [ "checksum nom-trace 0.1.0 (git+https://github.com/pythondude325/nom-trace.git)" = "" "checksum nom_locate 0.3.1 (registry+https://github.com/rust-lang/crates.io-index)" = "6a47c112b3861d81f7fbf73892b9271af933af32bd5dee6889aa3c3fa9caed7e" "checksum num 0.2.0 (registry+https://github.com/rust-lang/crates.io-index)" = "cf4825417e1e1406b3782a8ce92f4d53f26ec055e3622e1881ca8e9f5f9e08db" -"checksum num-complex 0.2.1 (registry+https://github.com/rust-lang/crates.io-index)" = "107b9be86cd2481930688277b675b0114578227f034674726605b8a482d8baf8" -"checksum num-integer 0.1.40 (registry+https://github.com/rust-lang/crates.io-index)" = "8b8af8caa3184078cd419b430ff93684cb13937970fcb7639f728992f33ce674" -"checksum num-iter 0.1.38 (registry+https://github.com/rust-lang/crates.io-index)" = "50b7cf973f09f27829571927831972c92bfd29de7a5a0148380afd12acf6d124" -"checksum num-rational 0.2.1 (registry+https://github.com/rust-lang/crates.io-index)" = "4e96f040177bb3da242b5b1ecf3f54b5d5af3efbbfb18608977a5d2767b22f10" +"checksum num-complex 0.2.3 (registry+https://github.com/rust-lang/crates.io-index)" = "fcb0cf31fb3ff77e6d2a6ebd6800df7fdcd106f2ad89113c9130bcd07f93dffc" +"checksum num-integer 0.1.41 (registry+https://github.com/rust-lang/crates.io-index)" = "b85e541ef8255f6cf42bbfe4ef361305c6c135d10919ecc26126c4e5ae94bc09" +"checksum num-iter 0.1.39 (registry+https://github.com/rust-lang/crates.io-index)" = "76bd5272412d173d6bf9afdf98db8612bbabc9a7a830b7bfc9c188911716132e" +"checksum num-rational 0.2.2 (registry+https://github.com/rust-lang/crates.io-index)" = "f2885278d5fe2adc2f75ced642d52d879bffaceb5a2e0b1d4309ffdfb239b454" "checksum num-traits 0.1.43 (registry+https://github.com/rust-lang/crates.io-index)" = "92e5113e9fd4cc14ded8e499429f396a20f98c772a47cc8622a736e1ec843c31" -"checksum num-traits 0.2.7 (registry+https://github.com/rust-lang/crates.io-index)" = "d9c79c952a4a139f44a0fe205c4ee66ce239c0e6ce72cd935f5f7e2f717549dd" -"checksum num_cpus 1.10.0 (registry+https://github.com/rust-lang/crates.io-index)" = "1a23f0ed30a54abaa0c7e83b1d2d87ada7c3c23078d1d87815af3e3b6385fbba" +"checksum num-traits 0.2.8 (registry+https://github.com/rust-lang/crates.io-index)" = "6ba9a427cfca2be13aa6f6403b0b7e7368fe982bfa16fccc450ce74c46cd9b32" +"checksum num_cpus 1.10.1 (registry+https://github.com/rust-lang/crates.io-index)" = "bcef43580c035376c0705c42792c294b66974abbfd2789b511784023f71f3273" "checksum numtoa 0.1.0 (registry+https://github.com/rust-lang/crates.io-index)" = "b8f8bdf33df195859076e54ab11ee78a1b208382d3a26ec40d142ffc1ecc49ef" "checksum objc 0.2.6 (registry+https://github.com/rust-lang/crates.io-index)" = "31d20fd2b37e07cf5125be68357b588672e8cefe9a96f8c17a9d46053b3e590d" "checksum objc-foundation 0.1.1 (registry+https://github.com/rust-lang/crates.io-index)" = "1add1b659e36c9607c7aab864a76c7a4c2760cd0cd2e120f3fb8b952c7e22bf9" @@ -3415,11 +3404,11 @@ dependencies = [ "checksum phf_shared 0.7.24 (registry+https://github.com/rust-lang/crates.io-index)" = "234f71a15de2288bcb7e3b6515828d22af7ec8598ee6d24c3b526fa0a80b67a0" "checksum pin-utils 0.1.0-alpha.4 (registry+https://github.com/rust-lang/crates.io-index)" = "5894c618ce612a3fa23881b152b608bafb8c56cfc22f434a3ba3120b40f7b587" "checksum pkg-config 0.3.14 (registry+https://github.com/rust-lang/crates.io-index)" = "676e8eb2b1b4c9043511a9b7bea0915320d7e502b0a079fb03f9635a5252b18c" -"checksum plist 0.4.1 (registry+https://github.com/rust-lang/crates.io-index)" = "f4739851c08dd9a62a78beff2edf1a438517268b2c563c42fc6d9d3139e42d2a" +"checksum plist 0.4.2 (registry+https://github.com/rust-lang/crates.io-index)" = "5f2a9f075f6394100e7c105ed1af73fb1859d6fd14e49d4290d578120beb167f" "checksum pretty 0.5.2 (registry+https://github.com/rust-lang/crates.io-index)" = "f60c0d9f6fc88ecdd245d90c1920ff76a430ab34303fc778d33b1d0a4c3bf6d3" "checksum pretty_assertions 0.6.1 (registry+https://github.com/rust-lang/crates.io-index)" = "3f81e1644e1b54f5a68959a29aa86cde704219254669da328ecfdf6a1f09d427" "checksum pretty_env_logger 0.3.0 (registry+https://github.com/rust-lang/crates.io-index)" = "df8b3f4e0475def7d9c2e5de8e5a1306949849761e107b360d03e98eafaffd61" -"checksum prettyprint 0.6.0 (registry+https://github.com/rust-lang/crates.io-index)" = "2705417f8aa07cb6308db42e55623479c1c9667942a4d5e4174c684e5da5590d" +"checksum prettyprint 0.7.0 (registry+https://github.com/rust-lang/crates.io-index)" = "f32f02328f651d5283173c7a9b2ef354b079fa535706547dde16d61ae23ecded" "checksum prettytable-rs 0.8.0 (registry+https://github.com/rust-lang/crates.io-index)" = "0fd04b170004fa2daccf418a7f8253aaf033c27760b5f225889024cf66d7ac2e" "checksum proc-macro2 0.4.30 (registry+https://github.com/rust-lang/crates.io-index)" = "cf3d2011ab5c909338f7887f4fc896d35932e29146c12c8d01da6b22a80ba759" "checksum ptree 0.2.1 (registry+https://github.com/rust-lang/crates.io-index)" = "6b0a3be00b19ee7bd33238c1c523a7ab4df697345f6b36f90827a7860ea938d4" @@ -3436,23 +3425,24 @@ dependencies = [ "checksum rand_os 0.1.3 (registry+https://github.com/rust-lang/crates.io-index)" = "7b75f676a1e053fc562eafbb47838d67c84801e38fc1ba459e8f180deabd5071" "checksum rand_pcg 0.1.2 (registry+https://github.com/rust-lang/crates.io-index)" = "abf9b09b01790cfe0364f52bf32995ea3c39f4d2dd011eac241d2914146d0b44" "checksum rand_xorshift 0.1.1 (registry+https://github.com/rust-lang/crates.io-index)" = "cbf7e9e623549b0e21f6e97cf8ecf247c1a8fd2e8a992ae265314300b2455d5c" -"checksum rayon 1.0.3 (registry+https://github.com/rust-lang/crates.io-index)" = "373814f27745b2686b350dd261bfd24576a6fb0e2c5919b3a2b6005f820b0473" -"checksum rayon-core 1.4.1 (registry+https://github.com/rust-lang/crates.io-index)" = "b055d1e92aba6877574d8fe604a63c8b5df60f60e5982bf7ccbb1338ea527356" +"checksum rayon 1.1.0 (registry+https://github.com/rust-lang/crates.io-index)" = "a4b0186e22767d5b9738a05eab7c6ac90b15db17e5b5f9bd87976dd7d89a10a4" +"checksum rayon-core 1.5.0 (registry+https://github.com/rust-lang/crates.io-index)" = "ebbe0df8435ac0c397d467b6cad6d25543d06e8a019ef3f6af3c384597515bd2" "checksum rdrand 0.4.0 (registry+https://github.com/rust-lang/crates.io-index)" = "678054eb77286b51581ba43620cc911abf02758c91f93f479767aed0f90458b2" "checksum redox_syscall 0.1.54 (registry+https://github.com/rust-lang/crates.io-index)" = "12229c14a0f65c4f1cb046a3b52047cdd9da1f4b30f8a39c5063c8bae515e252" "checksum redox_termios 0.1.1 (registry+https://github.com/rust-lang/crates.io-index)" = "7e891cfe48e9100a70a3b6eb652fef28920c117d366339687bd5576160db0f76" "checksum redox_users 0.3.0 (registry+https://github.com/rust-lang/crates.io-index)" = "3fe5204c3a17e97dde73f285d49be585df59ed84b50a872baf416e73b62c3828" -"checksum regex 1.1.6 (registry+https://github.com/rust-lang/crates.io-index)" = "8f0a0bcab2fd7d1d7c54fa9eae6f43eddeb9ce2e7352f8518a814a4f65d60c58" -"checksum regex-syntax 0.6.6 (registry+https://github.com/rust-lang/crates.io-index)" = "dcfd8681eebe297b81d98498869d4aae052137651ad7b96822f09ceb690d0a96" -"checksum remove_dir_all 0.5.1 (registry+https://github.com/rust-lang/crates.io-index)" = "3488ba1b9a2084d38645c4c08276a1752dcbf2c7130d74f1569681ad5d2799c5" +"checksum regex 1.1.7 (registry+https://github.com/rust-lang/crates.io-index)" = "0b2f0808e7d7e4fb1cb07feb6ff2f4bc827938f24f8c2e6a3beb7370af544bdd" +"checksum regex-syntax 0.6.7 (registry+https://github.com/rust-lang/crates.io-index)" = "9d76410686f9e3a17f06128962e0ecc5755870bb890c34820c7af7f1db2e1d48" +"checksum remove_dir_all 0.5.2 (registry+https://github.com/rust-lang/crates.io-index)" = "4a83fa3702a688b9359eccba92d153ac33fd2e8462f9e0e3fdf155239ea7792e" "checksum render-tree 0.1.1 (registry+https://github.com/rust-lang/crates.io-index)" = "68ed587df09cfb7ce1bc6fe8f77e24db219f222c049326ccbfb948ec67e31664" "checksum reqwest 0.9.18 (registry+https://github.com/rust-lang/crates.io-index)" = "00eb63f212df0e358b427f0f40aa13aaea010b470be642ad422bcbca2feff2e4" -"checksum roxmltree 0.6.0 (registry+https://github.com/rust-lang/crates.io-index)" = "53b0200cbfa8b3f6cfd6076592717d697a1ddc57cb2a8fbfd3d133c06011b579" +"checksum result 1.0.0 (registry+https://github.com/rust-lang/crates.io-index)" = "194d8e591e405d1eecf28819740abed6d719d1a2db87fc0bcdedee9a26d55560" +"checksum roxmltree 0.6.1 (registry+https://github.com/rust-lang/crates.io-index)" = "330d8f80a274bc3cb608908ee345970e7e24b96907f1ad69615a498bec57871c" "checksum rust-ini 0.13.0 (registry+https://github.com/rust-lang/crates.io-index)" = "3e52c148ef37f8c375d49d5a73aa70713125b7f19095948a923f80afdeb22ec2" -"checksum rustc-demangle 0.1.14 (registry+https://github.com/rust-lang/crates.io-index)" = "ccc78bfd5acd7bf3e89cffcf899e5cb1a52d6fafa8dec2739ad70c9577a57288" +"checksum rustc-demangle 0.1.15 (registry+https://github.com/rust-lang/crates.io-index)" = "a7f4dccf6f4891ebcc0c39f9b6eb1a83b9bf5d747cb439ec6fba4f3b977038af" "checksum rustc-hash 1.0.1 (registry+https://github.com/rust-lang/crates.io-index)" = "7540fc8b0c49f096ee9c961cda096467dce8084bec6bdca2fc83895fd9b28cb8" "checksum rustc_version 0.2.3 (registry+https://github.com/rust-lang/crates.io-index)" = "138e3e0acb6c9fb258b19b67cb8abd63c00679d2851805ea151465464fe9030a" -"checksum rustyline 4.1.0 (git+https://github.com/kkawakam/rustyline.git)" = "" +"checksum rustyline 5.0.0 (git+https://github.com/kkawakam/rustyline.git)" = "" "checksum ryu 0.2.8 (registry+https://github.com/rust-lang/crates.io-index)" = "b96a9549dc8d48f2c283938303c4b5a77aa29bfbc5b54b084fb1630408899a8f" "checksum safemem 0.3.0 (registry+https://github.com/rust-lang/crates.io-index)" = "8dca453248a96cb0749e36ccdfe2b0b4e54a61bfef89fb97ec621eb8e0a93dd9" "checksum same-file 1.0.4 (registry+https://github.com/rust-lang/crates.io-index)" = "8f20c4be53a8a1ff4c1f1b2bd14570d2f634628709752f0702ecdd2b3f9a5267" @@ -3465,12 +3455,13 @@ dependencies = [ "checksum semver 0.9.0 (registry+https://github.com/rust-lang/crates.io-index)" = "1d7eb9ef2c18661902cc47e535f9bc51b78acd254da71d375c2f6720d9a40403" "checksum semver-parser 0.7.0 (registry+https://github.com/rust-lang/crates.io-index)" = "388a1df253eca08550bef6c72392cfe7c30914bf41df5269b68cbd6ff8f570a3" "checksum serde 0.8.23 (registry+https://github.com/rust-lang/crates.io-index)" = "9dad3f759919b92c3068c696c15c3d17238234498bbdcc80f2c469606f948ac8" -"checksum serde 1.0.91 (registry+https://github.com/rust-lang/crates.io-index)" = "a72e9b96fa45ce22a4bc23da3858dfccfd60acd28a25bcd328a98fdd6bea43fd" +"checksum serde 1.0.92 (registry+https://github.com/rust-lang/crates.io-index)" = "32746bf0f26eab52f06af0d0aa1984f641341d06d8d673c693871da2d188c9be" "checksum serde-hjson 0.8.2 (registry+https://github.com/rust-lang/crates.io-index)" = "0b833c5ad67d52ced5f5938b2980f32a9c1c5ef047f0b4fb3127e7a423c76153" "checksum serde-hjson 0.9.0 (registry+https://github.com/rust-lang/crates.io-index)" = "4640cf3168e40c00c874ff1ad436c0f18c37edec101d5d897a4396f617abce29" "checksum serde-value 0.5.3 (registry+https://github.com/rust-lang/crates.io-index)" = "7a663f873dedc4eac1a559d4c6bc0d0b2c34dc5ac4702e105014b8281489e44f" -"checksum serde_derive 1.0.91 (registry+https://github.com/rust-lang/crates.io-index)" = "101b495b109a3e3ca8c4cbe44cf62391527cdfb6ba15821c5ce80bcd5ea23f9f" +"checksum serde_derive 1.0.92 (registry+https://github.com/rust-lang/crates.io-index)" = "46a3223d0c9ba936b61c0d2e3e559e3217dbfb8d65d06d26e8b3c25de38bae3e" "checksum serde_derive_internals 0.24.1 (registry+https://github.com/rust-lang/crates.io-index)" = "8a80c6c0b1ebbcea4ec2c7e9e2e9fa197a425d17f1afec8ba79fcd1352b18ffb" +"checksum serde_ini 0.2.0 (registry+https://github.com/rust-lang/crates.io-index)" = "eb236687e2bb073a7521c021949be944641e671b8505a94069ca37b656c81139" "checksum serde_json 1.0.39 (registry+https://github.com/rust-lang/crates.io-index)" = "5a23aa71d4a4d43fdbfaac00eff68ba8a06a51759a89ac3304323e800c4dd40d" "checksum serde_test 0.8.23 (registry+https://github.com/rust-lang/crates.io-index)" = "110b3dbdf8607ec493c22d5d947753282f3bae73c0f56d322af1e8c78e4c23d5" "checksum serde_urlencoded 0.5.5 (registry+https://github.com/rust-lang/crates.io-index)" = "642dd69105886af2efd227f75a520ec9b44a820d65bc133a9131f7d229fd165a" @@ -3481,22 +3472,23 @@ dependencies = [ "checksum signal-hook-registry 1.0.1 (registry+https://github.com/rust-lang/crates.io-index)" = "cded4ffa32146722ec54ab1f16320568465aa922aa9ab4708129599740da85d7" "checksum siphasher 0.2.3 (registry+https://github.com/rust-lang/crates.io-index)" = "0b8de496cf83d4ed58b6be86c3a275b8602f6ffe98d3024a869e124147a9a3ac" "checksum slab 0.4.2 (registry+https://github.com/rust-lang/crates.io-index)" = "c111b5bd5695e56cffe5129854aa230b39c93a305372fdbb2668ca2394eea9f8" -"checksum smallvec 0.6.9 (registry+https://github.com/rust-lang/crates.io-index)" = "c4488ae950c49d403731982257768f48fada354a5203fe81f9bb6f43ca9002be" +"checksum smallvec 0.6.10 (registry+https://github.com/rust-lang/crates.io-index)" = "ab606a9c5e214920bb66c458cd7be8ef094f813f20fe77a54cc7dbfff220d4b7" "checksum stable_deref_trait 1.1.1 (registry+https://github.com/rust-lang/crates.io-index)" = "dba1a27d3efae4351c8051072d619e3ade2820635c3958d826bfea39d59b54c8" "checksum string 0.2.0 (registry+https://github.com/rust-lang/crates.io-index)" = "d0bbfb8937e38e34c3444ff00afb28b0811d9554f15c5ad64d12b0308d1d1995" "checksum strsim 0.7.0 (registry+https://github.com/rust-lang/crates.io-index)" = "bb4f380125926a99e52bc279241539c018323fab05ad6368b56f93d9369ff550" "checksum strsim 0.8.0 (registry+https://github.com/rust-lang/crates.io-index)" = "8ea5119cdb4c55b55d432abb513a0429384878c15dde60cc77b1c99de1a95a6a" -"checksum subprocess 0.1.19 (git+https://github.com/jonathandturner/rust-subprocess.git?branch=is_already_escaped)" = "" +"checksum subprocess 0.1.18 (registry+https://github.com/rust-lang/crates.io-index)" = "28fc0f40f0c0da73339d347aa7d6d2b90341a95683a47722bc4eebed71ff3c00" "checksum syn 0.14.9 (registry+https://github.com/rust-lang/crates.io-index)" = "261ae9ecaa397c42b960649561949d69311f08eeaea86a65696e6e46517cf741" -"checksum syn 0.15.34 (registry+https://github.com/rust-lang/crates.io-index)" = "a1393e4a97a19c01e900df2aec855a29f71cf02c402e2f443b8d2747c25c5dbe" +"checksum syn 0.15.36 (registry+https://github.com/rust-lang/crates.io-index)" = "8b4f551a91e2e3848aeef8751d0d4eec9489b6474c720fd4c55958d8d31a430c" "checksum synstructure 0.10.2 (registry+https://github.com/rust-lang/crates.io-index)" = "02353edf96d6e4dc81aea2d8490a7e9db177bf8acb0e951c24940bf866cb313f" "checksum syntect 3.2.0 (registry+https://github.com/rust-lang/crates.io-index)" = "e80b8831c5a543192ffc3727f01cf0e57579c6ac15558e3048bfb5708892167b" -"checksum sysinfo 0.8.4 (registry+https://github.com/rust-lang/crates.io-index)" = "65f0e28a49b7bf142cee89befd7077b40627d7cc70aa8a8acfe03afc26016c33" +"checksum sys-info 0.5.7 (registry+https://github.com/rust-lang/crates.io-index)" = "76d6cf7b349b6a6daaf7a3797227e2f4108c8dd398e0aca7e29b9fb239948541" +"checksum sysinfo 0.8.5 (registry+https://github.com/rust-lang/crates.io-index)" = "1cf62641ed7e88e20242b948d17b9fcc37e80b5599cf09cde190d6d4bb4bf289" "checksum tempfile 3.0.8 (registry+https://github.com/rust-lang/crates.io-index)" = "7dc4738f2e68ed2855de5ac9cdbe05c9216773ecde4739b2f095002ab03a13ef" "checksum term 0.5.2 (registry+https://github.com/rust-lang/crates.io-index)" = "edd106a334b7657c10b7c540a0106114feadeb4dc314513e97df481d5d966f42" "checksum term_size 0.3.1 (registry+https://github.com/rust-lang/crates.io-index)" = "9e5b9a66db815dcfd2da92db471106457082577c3c278d4138ab3e3b4e189327" -"checksum termcolor 1.0.4 (registry+https://github.com/rust-lang/crates.io-index)" = "4096add70612622289f2fdcdbd5086dc81c1e2675e6ae58d6c4f62a16c6d7f2f" -"checksum termion 1.5.2 (registry+https://github.com/rust-lang/crates.io-index)" = "dde0593aeb8d47accea5392b39350015b5eccb12c0d98044d856983d89548dea" +"checksum termcolor 1.0.5 (registry+https://github.com/rust-lang/crates.io-index)" = "96d6098003bde162e4277c70665bd87c326f5a0c3f3fbfb285787fa482d54e6e" +"checksum termion 1.5.3 (registry+https://github.com/rust-lang/crates.io-index)" = "6a8fb22f7cde82c8220e5aeacb3258ed7ce996142c77cba193f203515e26c330" "checksum termios 0.3.1 (registry+https://github.com/rust-lang/crates.io-index)" = "72b620c5ea021d75a735c943269bb07d30c9b77d6ac6b236bc8b5c496ef05625" "checksum textwrap 0.11.0 (registry+https://github.com/rust-lang/crates.io-index)" = "d326610f408c7a4eb6f51c37c330e496b08506c9457c9d34287ecc38809fb060" "checksum thread_local 0.3.6 (registry+https://github.com/rust-lang/crates.io-index)" = "c6b53e329000edc2b34dbe8545fd20e55a333362d0a321909685a19bd28c3f1b" @@ -3530,14 +3522,14 @@ dependencies = [ "checksum unicode-width 0.1.5 (registry+https://github.com/rust-lang/crates.io-index)" = "882386231c45df4700b275c7ff55b6f3698780a650026380e72dabe76fa46526" "checksum unicode-xid 0.1.0 (registry+https://github.com/rust-lang/crates.io-index)" = "fc72304796d0818e357ead4e000d19c9c174ab23dc11093ac919054d20a6a7fc" "checksum url 1.7.2 (registry+https://github.com/rust-lang/crates.io-index)" = "dd4e7c0d531266369519a4aa4f399d748bd37043b00bde1e4ff1f60a120b355a" -"checksum utf8-ranges 1.0.2 (registry+https://github.com/rust-lang/crates.io-index)" = "796f7e48bef87609f7ade7e06495a87d5cd06c7866e6a5cbfceffc558a243737" +"checksum utf8-ranges 1.0.3 (registry+https://github.com/rust-lang/crates.io-index)" = "9d50aa7650df78abf942826607c62468ce18d9019673d4a2ebe1865dbb96ffde" "checksum utf8parse 0.1.1 (registry+https://github.com/rust-lang/crates.io-index)" = "8772a4ccbb4e89959023bc5b7cb8623a795caa7092d99f3aa9501b9484d4557d" "checksum uuid 0.7.4 (registry+https://github.com/rust-lang/crates.io-index)" = "90dbc611eb48397705a6b0f6e917da23ae517e4d127123d2cf7674206627d32a" "checksum vcpkg 0.2.6 (registry+https://github.com/rust-lang/crates.io-index)" = "def296d3eb3b12371b2c7d0e83bfe1403e4db2d7a0bba324a12b21c4ee13143d" "checksum vec_map 0.8.1 (registry+https://github.com/rust-lang/crates.io-index)" = "05c78687fb1a80548ae3250346c3db86a80a7cdd77bda190189f2d0a0987c81a" "checksum version_check 0.1.5 (registry+https://github.com/rust-lang/crates.io-index)" = "914b1a6776c4c929a602fafd8bc742e06365d4bcbe48c30f9cca5824f70dc9dd" "checksum void 1.0.2 (registry+https://github.com/rust-lang/crates.io-index)" = "6a02e4885ed3bc0f2de90ea6dd45ebcbb66dacffe03547fadbb0eeae2770887d" -"checksum walkdir 2.2.7 (registry+https://github.com/rust-lang/crates.io-index)" = "9d9d7ed3431229a144296213105a390676cc49c9b6a72bd19f3176c98e129fa1" +"checksum walkdir 2.2.8 (registry+https://github.com/rust-lang/crates.io-index)" = "c7904a7e2bb3cdf0cf5e783f44204a85a37a93151738fa349f06680f59a98b45" "checksum want 0.0.6 (registry+https://github.com/rust-lang/crates.io-index)" = "797464475f30ddb8830cc529aaaae648d581f99e2036a928877dfde027ddf6b3" "checksum winapi 0.2.8 (registry+https://github.com/rust-lang/crates.io-index)" = "167dc9d6949a9b857f3451275e911c3f44255842c1f7a76f33c55103a909087a" "checksum winapi 0.3.7 (registry+https://github.com/rust-lang/crates.io-index)" = "f10e386af2b13e47c89e7236a7a14a086791a2b88ebad6df9bf42040195cf770" diff --git a/Cargo.toml b/Cargo.toml index ce9b612010..ba0b3b98f9 100644 --- a/Cargo.toml +++ b/Cargo.toml @@ -11,7 +11,7 @@ edition = "2018" [dependencies] #rustyline = "4.1.0" rustyline = { git ="https://github.com/kkawakam/rustyline.git" } -sysinfo = "0.8.4" +sysinfo = "0.8.5" chrono = { version = "0.4.6", features = ["serde"] } chrono-tz = "0.5.1" derive-new = "0.5.6" @@ -25,7 +25,7 @@ indexmap = { version = "1.0.2", features = ["serde-1"] } chrono-humanize = "0.0.11" byte-unit = "2.1.0" ordered-float = "1.0.2" -prettyprint = "0.6.0" +prettyprint = "0.7.0" cursive = { version = "0.12.0", features = ["pancurses-backend"], default-features = false } futures-preview = { version = "0.3.0-alpha.16", features = ["compat", "io-compat"] } futures-sink-preview = "0.3.0-alpha.16" @@ -37,11 +37,11 @@ log = "0.4.6" pretty_env_logger = "0.3.0" lalrpop-util = "0.17.0" regex = "1.1.6" -serde = "1.0.91" +serde = "1.0.92" serde_json = "1.0.39" serde-hjson = "0.9.0" serde_yaml = "0.8" -serde_derive = "1.0.91" +serde_derive = "1.0.92" getset = "0.0.7" logos = "0.10.0-rc2" logos-derive = "0.10.0-rc2" @@ -53,7 +53,7 @@ clap = "2.33.0" enum_derive = "0.1.7" adhoc_derive = "0.1.2" lazy_static = "1.3.0" -git2 = "0.8.0" +git2 = "0.9.1" dirs = "2.0.1" ctrlc = "3.1.3" ptree = "0.2" @@ -66,14 +66,13 @@ derive_more = "0.15.0" enum-utils = "0.1.0" unicode-xid = "0.1.0" nom-trace = { version = "0.1.0", git = "https://github.com/pythondude325/nom-trace.git" } +serde_ini = "0.2.0" +subprocess = "0.1.18" +sys-info = "0.5.7" [dependencies.pancurses] version = "0.16" features = ["win32a"] -[dependencies.subprocess] -git = "https://github.com/jonathandturner/rust-subprocess.git" -branch = "is_already_escaped" - [dev-dependencies] pretty_assertions = "0.6.1" diff --git a/README.md b/README.md index aa2f3bd1d6..1d4a9c410d 100644 --- a/README.md +++ b/README.md @@ -1,24 +1,174 @@ +[![Build Status](https://dev.azure.com/nushell/nushell/_apis/build/status/nushell.nushell?branchName=master)](https://dev.azure.com/nushell/nushell/_build/latest?definitionId=2&branchName=master) + # Nu Shell -A shell for the GitHub era. Like having a playground for a shell. +Like having a shell in a playground. # Status -This project has little of what will eventually be necessary for Nu to serve as your day-to-day shell. It already works well enough for contributors to dogfood it as their daily driver, but there are too many basic deficiencies for it to be useful for most people. +This project is currently in its early stages, though it already works well enough for contributors to dogfood it as their daily driver. Its design is subject to change as it matures. -At the moment, executing a command that isn't identified as a built-in new command will fall back to running it as a shell command (using cmd on Windows or bash on Linux and MacOS), correctly passing through stdin, stdout and stderr, so things like your daily git workflows and even `vim` will work just fine. +Nu has a list of built-in commands (listed below). If a command is unknown, the command will shell-out and execute it (using cmd on Windows or bash on Linux and MacOS), correctly passing through stdin, stdout and stderr, so things like your daily git workflows and even `vim` will work just fine. -## Commands +# Philosophy + +Nu draws heavy inspiration from projects like PowerShell. Rather than thinking of you filesystem and services as raw streams of text, Nu looks at each input as something with structure. For example, when you list the contents of a directory, what you get back in a list of objects, where each object represents an item in that directory. + +## Pipelines + +Nu takes this a step further and builds heavily on the idea of _pipelines_. Just as the Unix philosophy, Nu allows commands to output from stdout and read from stdin. Additionally, commands can output structured data (you can think of this as a third kind of stream). Commands that work in the pipeline fit into one of three categories + +* Commands that produce a stream (eg, `ls`) +* Commands that filter a stream (eg, `where "file type" == "Directory"`) +* Commands that consumes the output of the pipeline (eg, `autoview`) + +Commands are separated by the pipe symbol (`|`) to denote a pipeline flowing left to right. + +``` +/home/jonathan/Source/nushell(master)> ls | where "file type" == "Directory" | autoview +-----------+-----------+----------+--------+--------------+---------------- + file name | file type | readonly | size | accessed | modified +-----------+-----------+----------+--------+--------------+---------------- + target | Directory | | 4.1 KB | 19 hours ago | 19 hours ago + images | Directory | | 4.1 KB | 2 weeks ago | a week ago + tests | Directory | | 4.1 KB | 2 weeks ago | 18 minutes ago + docs | Directory | | 4.1 KB | a week ago | a week ago + .git | Directory | | 4.1 KB | 2 weeks ago | 25 minutes ago + src | Directory | | 4.1 KB | 2 weeks ago | 25 minutes ago + .cargo | Directory | | 4.1 KB | 2 weeks ago | 2 weeks ago +-----------+-----------+----------+--------+--------------+---------------- +``` + +Because most of the time you'll want to see the output of a pipeline, `autoview` is assumed. We could have also written the above: + +``` +/home/jonathan/Source/nushell(master)> ls | where "file type" == "Directory" +``` + +Being able to use the same commands and compose them differently is an important philosophy in Nu. For example, we could use the built-in `ps` command as well to get a list of the running processes, using the same `where` as above. + +```text +C:\Code\nushell(master)> ps | where cpu > 0 +------------------ +-----+-------+-------+---------- + name | cmd | cpu | pid | status +------------------ +-----+-------+-------+---------- + msedge.exe | - | 0.77 | 26472 | Runnable + nu.exe | - | 7.83 | 15473 | Runnable + SearchIndexer.exe | - | 82.17 | 23476 | Runnable + BlueJeans.exe | - | 4.54 | 10000 | Runnable +-------------------+-----+-------+-------+---------- +``` + +## Opening files + +Nu can load file and URL contents as raw text or as structured data (if it recognizes the format). For example, you can load a .toml file as structured data and explore it: + +``` +/home/jonathan/Source/nushell(master)> open Cargo.toml +-----------------+------------------+----------------- + dependencies | dev-dependencies | package +-----------------+------------------+----------------- + [object Object] | [object Object] | [object Object] +-----------------+------------------+----------------- +``` + +We can pipeline this into a command that gets the contents of one of the columns: + +``` +/home/jonathan/Source/nushell(master)> open Cargo.toml | get package +-------------+----------------------------+---------+---------+------+--------- + authors | description | edition | license | name | version +-------------+----------------------------+---------+---------+------+--------- + [list List] | A shell for the GitHub era | 2018 | MIT | nu | 0.1.2 +-------------+----------------------------+---------+---------+------+--------- +``` + +Finally, we can use commands outside of Nu once we have the data we want: + +``` +/home/jonathan/Source/nushell(master)> open Cargo.toml | get package.version | echo $it +0.1.2 +``` + +Here we use the variable `$it` to refer to the value being piped to the external command. + + +## Navigation + +By default, Nu opens up into your filesystem and the current working directory. One way to think of this is a pair: the current object and the current path in the object. The filesystem is our first object, and the path is the cwd. + +| object | path | +| ------ | ---- | +| Filesystem | /home/jonathan/Source/nushell | + +Using the `cd` command allows you to change the path from the current path to a new path, just as you might expect. Using `ls` allows you to view the contents of the filesystem at the current path (or at the path of your choosing). + +In addition to `cd` and `ls`, we can `enter` an object. Entering an object makes it the current object to navigate (similar to the concept of mounting a filesystem in Unix systems). + +``` +/home/jonathan/Source/nushell(master)> enter Cargo.toml +object/> +``` + +As we enter, we create a stack of objects we're navigating: + +| object | path | +| ------ | ---- | +| Filesystem | /home/jonathan/Source/nushell | +| object (from Cargo.toml) | / | + +Commands `cd` and `ls` now work on the object being navigated. + +``` +object/> ls +-----------------+------------------+----------------- + dependencies | dev-dependencies | package +-----------------+------------------+----------------- + [object Object] | [object Object] | [object Object] +-----------------+------------------+----------------- +``` + +``` +object/> cd package/version +object/package/version> ls +------- + value +------- + 0.1.2 +------- +``` + +The `exit` command will pop the stack and get us back to a previous object we were navigating. + +# Goals + +Nu adheres closely to a set of goals that make up its design philosophy. As features are added, they are checked against these goals. + +* First and foremost, Nu is cross-platform. Commands and techniques should carry between platforms and offer first-class consistent support for Windows, macOS, and Linux. + +* Nu ensures direct compatibility with existing platform-specific executables that make up people's workflows. + +* Nu's workflow and tools should have the usability in day-to-day experience of using a shell in 2019 (and beyond). + +* Nu views data as both structured and unstructured. It is an object shell like PowerShell. + +These goals are all critical, project-defining priorities. Priority #1 is "direct compatibility" because any new shell absolutely needs a way to use existing executables in a direct and natural way. + +# Commands +## Initial commands | command | description | -| ------------- | ------------- | -| cd directory | Change to the given directory | -| ls | View current directory contents | +| ------------- | ------------- | +| cd path | Change to a new path | +| ls (path) | View the contents of the current or given path | | ps | View current processes | -| open filename | Load a file into a cell, convert to table if possible (avoid by appending '--raw') | +| sysinfo | View information about the current system | +| open {filename or url} | Load a file into a cell, convert to table if possible (avoid by appending '--raw') | +| enter {filename or url} | Enter (mount) the given contents as the current object | +| exit | Leave/pop from the current object (exits if in filesystem object) | -## Commands on tables +## Filters on tables (structured data) | command | description | -| ------------- | ------------- | +| ------------- | ------------- | | pick ...columns | Down-select table to only these columns | | reject ...columns | Remove the given columns from the table | | get column-or-column-path | Open given cells as text | @@ -29,10 +179,12 @@ At the moment, executing a command that isn't identified as a built-in new comma | to-array | Collapse rows into a single list | | to-json | Convert table into .json text | | to-toml | Convert table into .toml text | +| to-ini | Convert table into .ini text | -## Commands on text +## Filters on text (unstructured data) | command | description | -| ------------- | ------------- | +| ------------- | ------------- | +| from-ini | Parse text as .ini and create table | | from-json | Parse text as .json and create table | | from-toml | Parse text as .toml and create table | | from-xml | Parse text as .xml and create a table | @@ -40,144 +192,19 @@ At the moment, executing a command that isn't identified as a built-in new comma | split-column sep ...fields | Split row contents across multiple columns via the separator | | split-row sep | Split row contents over multiple rows via the separator | | trim | Trim leading and following whitespace from text data | -| {external-command} $it | Run external command with given arguments, replacing $it with each row text | +| {external-command} $it | Run external command with given arguments, replacing $it with each row text | -# Goals - -Prime Directive: Cross platform workflows, with first-class consistent support for Windows, OSX and Linux. - -Priority #1: direct compatibility with existing platform-specific executables that make up people's workflows - -Priority #2: Create workflow tools that more closely match the day-to-day experience of using a shell in 2019 (and beyond) - -Priority #3: It's an object shell like PowerShell. - -> These goals are all critical, project-defining priorities. Priority #1 is "direct compatibility" because any new shell absolutely needs a way to use existing executables in a direct and natural way. +## Consuming commands +| command | description | +| ------------- | ------------- | +| autoview | View the contents of the pipeline as a table or list | +| clip | Copy the contents of the pipeline to the copy/paste buffer | +| save filename | Save the contents of the pipeline to a file | +| table | View the contents of the pipeline as a table | +| tree | View the contents of the pipeline as a tree | +| vtable | View the contents of the pipeline as a vertical (rotated) table | # License The project is made available under the MIT license. See "LICENSE" for more information. -# A Taste of Nu - -Nu has built-in commands for ls and ps, loading these results into a table you can work with. - -```text -~\Code\nushell> ps | where cpu > 0 ------------------------------------------------- - name cmd cpu pid status ------------------------------------------------- - msedge.exe - 0.77 26472 Runnable ------------------------------------------------- - nu.exe - 7.83 15473 Runnable ------------------------------------------------- - SearchIndexer.exe - 82.17 23476 Runnable ------------------------------------------------- - BlueJeans.exe - 4.54 10000 Runnable ------------------------------------------------- -``` - -Commands are linked together with pipes, allowing you to select the data you want to use. - -```text -~\Code\nushell> ps | where name == chrome.exe | first 5 ----------------------------------------- - name cmd cpu pid status ----------------------------------------- - chrome.exe - 0.00 22092 Runnable ----------------------------------------- - chrome.exe - 0.00 17324 Runnable ----------------------------------------- - chrome.exe - 0.00 16376 Runnable ----------------------------------------- - chrome.exe - 0.00 21876 Runnable ----------------------------------------- - chrome.exe - 0.00 13432 Runnable ----------------------------------------- -``` - -The name of the columns in the table can be used to sort the table. - -```text -~\Code\nushell> ls | sort-by "file type" size ----------------------------------------------------------------------------------------- - file name file type readonly size created accessed modified ----------------------------------------------------------------------------------------- - .cargo Directory Empty a week ago a week ago a week ago ----------------------------------------------------------------------------------------- - .git Directory Empty 2 weeks ago 9 hours ago 9 hours ago ----------------------------------------------------------------------------------------- - images Directory Empty 2 weeks ago 2 weeks ago 2 weeks ago ----------------------------------------------------------------------------------------- - src Directory Empty 2 weeks ago 10 hours ago 10 hours ago ----------------------------------------------------------------------------------------- - target Directory Empty 10 hours ago 10 hours ago 10 hours ago ----------------------------------------------------------------------------------------- - tests Directory Empty 14 hours ago 10 hours ago 10 hours ago ----------------------------------------------------------------------------------------- - tmp Directory Empty 2 days ago 2 days ago 2 days ago ----------------------------------------------------------------------------------------- - rustfmt.toml File 16 B a week ago a week ago a week ago ----------------------------------------------------------------------------------------- - .gitignore File 32 B 2 weeks ago 2 weeks ago 2 weeks ago ----------------------------------------------------------------------------------------- - .editorconfig File 156 B 2 weeks ago 2 weeks ago 2 weeks ago ----------------------------------------------------------------------------------------- -``` - -You can also use the names of the columns to down-select to only the data you want. -```text -~\Code\nushell> ls | pick "file name" "file type" size | sort-by "file type" ------------------------------------- - file name file type size ------------------------------------- - .cargo Directory Empty ------------------------------------- - .git Directory Empty ------------------------------------- - images Directory Empty ------------------------------------- - src Directory Empty ------------------------------------- - target Directory Empty ------------------------------------- - tests Directory Empty ------------------------------------- - rustfmt.toml File 16 B ------------------------------------- - .gitignore File 32 B ------------------------------------- - .editorconfig File 156 B ------------------------------------- -``` - -Some file types can be loaded as tables. - -```text -~\Code\nushell> open Cargo.toml ----------------------------------------------------- - dependencies dev-dependencies package ----------------------------------------------------- - [object Object] [object Object] [object Object] ----------------------------------------------------- - -~\Code\nushell> open Cargo.toml | get package --------------------------------------------------------------------------- - authors description edition license name version --------------------------------------------------------------------------- - [list List] A shell for the GitHub era 2018 MIT nu 0.1.1 --------------------------------------------------------------------------- -``` - -Once you've found the data, you can call out to external applications and use it. - -```text -~\Code\nushell> open Cargo.toml | get package.version | echo $it -0.1.1 -``` - -Nu currently has fish-style completion of previous commands, as well ctrl-r reverse search. - -![autocompletion][fish-style] - -[fish-style]: ./images/nushell-autocomplete3.gif "Fish-style autocomplete" diff --git a/appveyor.yml b/appveyor.yml new file mode 100644 index 0000000000..770f32a2a9 --- /dev/null +++ b/appveyor.yml @@ -0,0 +1,31 @@ +image: Visual Studio 2017 + +environment: + global: + PROJECT_NAME: nushell + RUST_BACKTRACE: 1 + matrix: + - TARGET: x86_64-pc-windows-msvc + CHANNEL: nightly + BITS: 64 + +install: + - set PATH=C:\msys64\mingw%BITS%\bin;C:\msys64\usr\bin;%PATH% + - curl -sSf -o rustup-init.exe https://win.rustup.rs + # Install rust + - rustup-init.exe -y --default-host %TARGET% --default-toolchain %CHANNEL%-%TARGET% + - set PATH=%PATH%;C:\Users\appveyor\.cargo\bin + # Required for Racer autoconfiguration + - call "C:\Program Files (x86)\Microsoft Visual Studio\2017\Community\VC\Auxiliary\Build\vcvars64.bat" + + +build: false + +test_script: + # compile #[cfg(not(test))] code + - cargo build --verbose + - cargo test --all --verbose + +cache: + - target -> Cargo.lock + - C:\Users\appveyor\.cargo\registry -> Cargo.lock diff --git a/src/cli.rs b/src/cli.rs index 24e654da34..1dbba22c02 100644 --- a/src/cli.rs +++ b/src/cli.rs @@ -15,6 +15,7 @@ use crate::evaluate::Scope; use crate::git::current_branch; use crate::object::Value; use crate::parser::ast::{Expression, Leaf, RawExpression}; +use crate::parser::lexer::Spanned; use crate::parser::{Args, Pipeline}; use log::debug; @@ -49,11 +50,13 @@ pub async fn cli() -> Result<(), Box> { context.add_commands(vec![ command("ps", ps::ps), command("ls", ls::ls), + command("sysinfo", sysinfo::sysinfo), command("cd", cd::cd), command("view", view::view), command("skip", skip::skip), command("first", first::first), command("size", size::size), + command("from-ini", from_ini::from_ini), command("from-json", from_json::from_json), command("from-toml", from_toml::from_toml), command("from-xml", from_xml::from_xml), @@ -62,16 +65,19 @@ pub async fn cli() -> Result<(), Box> { command("open", open::open), command("enter", enter::enter), command("exit", exit::exit), + command("lines", lines::lines), command("pick", pick::pick), command("split-column", split_column::split_column), command("split-row", split_row::split_row), command("reject", reject::reject), command("trim", trim::trim), command("to-array", to_array::to_array), + command("to-ini", to_ini::to_ini), command("to-json", to_json::to_json), command("to-toml", to_toml::to_toml), Arc::new(Where), Arc::new(Config), + Arc::new(SkipWhile), command("sort-by", sort_by::sort_by), ]); @@ -79,7 +85,9 @@ pub async fn cli() -> Result<(), Box> { sink("autoview", autoview::autoview), sink("clip", clip::clip), sink("save", save::save), + sink("table", table::table), sink("tree", tree::tree), + sink("vtable", vtable::vtable), ]); } @@ -101,19 +109,16 @@ pub async fn cli() -> Result<(), Box> { cc.store(true, Ordering::SeqCst); }) .expect("Error setting Ctrl-C handler"); - + let mut ctrlcbreak = false; loop { if ctrl_c.load(Ordering::SeqCst) { ctrl_c.store(false, Ordering::SeqCst); - if let ShellError::String(s) = ShellError::string("CTRL-C") { - context.host.lock().unwrap().stdout(&format!("{:?}", s)); - } continue; } let (obj, cwd) = { let env = context.env.lock().unwrap(); - let last = env.last().unwrap(); + let last = env.back().unwrap(); (last.obj().clone(), last.path().display().to_string()) }; let readline = match obj { @@ -133,36 +138,55 @@ pub async fn cli() -> Result<(), Box> { rl.add_history_entry(line.clone()); } - LineResult::Error(mut line, err) => match err { - ShellError::Diagnostic(diag) => { - let host = context.host.lock().unwrap(); - let writer = host.err_termcolor(); - line.push_str(" "); - let files = crate::parser::span::Files::new(line); - - language_reporting::emit( - &mut writer.lock(), - &files, - &diag.diagnostic, - &language_reporting::DefaultConfig, - ) - .unwrap(); + LineResult::CtrlC => { + if ctrlcbreak { + std::process::exit(0); + } else { + context + .host + .lock() + .unwrap() + .stdout("CTRL-C pressed (again to quit)"); + ctrlcbreak = true; + continue; } + } - ShellError::TypeError(desc) => context - .host - .lock() - .unwrap() - .stdout(&format!("TypeError: {}", desc)), + LineResult::Error(mut line, err) => { + rl.add_history_entry(line.clone()); + match err { + ShellError::Diagnostic(diag) => { + let host = context.host.lock().unwrap(); + let writer = host.err_termcolor(); + line.push_str(" "); + let files = crate::parser::span::Files::new(line); - ShellError::MissingProperty { subpath, .. } => context - .host - .lock() - .unwrap() - .stdout(&format!("Missing property {}", subpath)), + language_reporting::emit( + &mut writer.lock(), + &files, + &diag.diagnostic, + &language_reporting::DefaultConfig, + ) + .unwrap(); + } - ShellError::String(_) => context.host.lock().unwrap().stdout(&format!("{}", err)), - }, + ShellError::TypeError(desc) => context + .host + .lock() + .unwrap() + .stdout(&format!("TypeError: {}", desc)), + + ShellError::MissingProperty { subpath, .. } => context + .host + .lock() + .unwrap() + .stdout(&format!("Missing property {}", subpath)), + + ShellError::String(_) => { + context.host.lock().unwrap().stdout(&format!("{}", err)) + } + } + } LineResult::Break => { break; @@ -176,6 +200,7 @@ pub async fn cli() -> Result<(), Box> { .stdout(&format!("A surprising fatal error occurred.\n{:?}", err)); } } + ctrlcbreak = false; } rl.save_history("history.txt").unwrap(); @@ -185,6 +210,7 @@ pub async fn cli() -> Result<(), Box> { enum LineResult { Success(String), Error(String, ShellError), + CtrlC, Break, #[allow(unused)] @@ -200,6 +226,7 @@ impl std::ops::Try for LineResult { LineResult::Success(s) => Ok(Some(s)), LineResult::Error(_, s) => Err(s), LineResult::Break => Ok(None), + LineResult::CtrlC => Ok(None), LineResult::FatalError(err) => Err(err), } } @@ -258,27 +285,28 @@ async fn process_line(readline: Result, ctx: &mut Context (None, _) => break, (Some(ClassifiedCommand::Expr(_)), _) => { - return LineResult::Error(line.clone(), ShellError::unimplemented( - "Expression-only commands", - )) + return LineResult::Error( + line.clone(), + ShellError::unimplemented("Expression-only commands"), + ) } (_, Some(ClassifiedCommand::Expr(_))) => { - return LineResult::Error(line.clone(), ShellError::unimplemented( - "Expression-only commands", - )) + return LineResult::Error( + line.clone(), + ShellError::unimplemented("Expression-only commands"), + ) } - (Some(ClassifiedCommand::Sink(_)), Some(_)) => { - return LineResult::Error(line.clone(), ShellError::string("Commands like table, save, and autoview must come last in the pipeline")) + (Some(ClassifiedCommand::Sink(SinkCommand { name_span, .. })), Some(_)) => { + return LineResult::Error(line.clone(), ShellError::maybe_labeled_error("Commands like table, save, and autoview must come last in the pipeline", "must come last", name_span)); } (Some(ClassifiedCommand::Sink(left)), None) => { let input_vec: Vec = input.objects.collect().await; - left.run( - ctx, - input_vec, - )?; + if let Err(err) = left.run(ctx, input_vec) { + return LineResult::Error(line.clone(), err); + } break; } @@ -290,13 +318,12 @@ async fn process_line(readline: Result, ctx: &mut Context Err(err) => return LineResult::Error(line.clone(), err), }, - ( - Some(ClassifiedCommand::Internal(left)), - Some(_), - ) => match left.run(ctx, input).await { - Ok(val) => ClassifiedInputStream::from_input_stream(val), - Err(err) => return LineResult::Error(line.clone(), err), - }, + (Some(ClassifiedCommand::Internal(left)), Some(_)) => { + match left.run(ctx, input).await { + Ok(val) => ClassifiedInputStream::from_input_stream(val), + Err(err) => return LineResult::Error(line.clone(), err), + } + } (Some(ClassifiedCommand::Internal(left)), None) => { match left.run(ctx, input).await { @@ -313,13 +340,12 @@ async fn process_line(readline: Result, ctx: &mut Context Err(err) => return LineResult::Error(line.clone(), err), }, - ( - Some(ClassifiedCommand::External(left)), - Some(_), - ) => match left.run(ctx, input, StreamNext::Internal).await { - Ok(val) => val, - Err(err) => return LineResult::Error(line.clone(), err), - }, + (Some(ClassifiedCommand::External(left)), Some(_)) => { + match left.run(ctx, input, StreamNext::Internal).await { + Ok(val) => val, + Err(err) => return LineResult::Error(line.clone(), err), + } + } (Some(ClassifiedCommand::External(left)), None) => { match left.run(ctx, input, StreamNext::Last).await { @@ -332,9 +358,7 @@ async fn process_line(readline: Result, ctx: &mut Context LineResult::Success(line.clone()) } - Err(ReadlineError::Interrupted) => { - LineResult::Error("".to_string(), ShellError::string("CTRL-C")) - } + Err(ReadlineError::Interrupted) => LineResult::CtrlC, Err(ReadlineError::Eof) => { println!("CTRL-D"); LineResult::Break @@ -416,13 +440,17 @@ fn classify_command( })) } false => { - let arg_list_strings: Vec = match args { - Some(args) => args.iter().map(|i| i.as_external_arg()).collect(), + let arg_list_strings: Vec> = match args { + Some(args) => args + .iter() + .map(|i| Spanned::from_item(i.as_external_arg(), i.span)) + .collect(), None => vec![], }; Ok(ClassifiedCommand::External(ExternalCommand { name: name.to_string(), + name_span: Some(span.clone()), args: arg_list_strings, })) } diff --git a/src/commands.rs b/src/commands.rs index 5c21cfc20b..2923d449ff 100644 --- a/src/commands.rs +++ b/src/commands.rs @@ -8,11 +8,13 @@ crate mod config; crate mod enter; crate mod exit; crate mod first; +crate mod from_ini; crate mod from_json; crate mod from_toml; crate mod from_xml; crate mod from_yaml; crate mod get; +crate mod lines; crate mod ls; crate mod open; crate mod pick; @@ -21,18 +23,24 @@ crate mod reject; crate mod save; crate mod size; crate mod skip; +crate mod skip_while; crate mod sort_by; crate mod split_column; crate mod split_row; +crate mod sysinfo; +crate mod table; crate mod to_array; +crate mod to_ini; crate mod to_json; crate mod to_toml; crate mod tree; crate mod trim; crate mod view; +crate mod vtable; crate mod where_; crate use command::command; crate use config::Config; crate use where_::Where; +crate use skip_while::SkipWhile; diff --git a/src/commands/cd.rs b/src/commands/cd.rs index d69f71e2bc..380c7d5832 100644 --- a/src/commands/cd.rs +++ b/src/commands/cd.rs @@ -5,7 +5,7 @@ use std::path::PathBuf; pub fn cd(args: CommandArgs) -> Result { let env = args.env.lock().unwrap(); - let latest = env.last().unwrap(); + let latest = env.back().unwrap(); match latest.obj { Value::Filesystem => { @@ -13,17 +13,23 @@ pub fn cd(args: CommandArgs) -> Result { let path = match args.positional.first() { None => match dirs::home_dir() { Some(o) => o, - _ => return Err(ShellError::string("Can not change to home directory")), + _ => { + return Err(ShellError::maybe_labeled_error( + "Can not change to home directory", + "can not go to home", + args.name_span, + )) + } }, Some(v) => { let target = v.as_string()?.clone(); match dunce::canonicalize(cwd.join(&target).as_path()) { Ok(p) => p, Err(_) => { - return Err(ShellError::labeled_error( + return Err(ShellError::maybe_labeled_error( "Can not change to directory", "directory not found", - args.positional[0].span.clone(), + Some(args.positional[0].span.clone()), )); } } @@ -35,10 +41,10 @@ pub fn cd(args: CommandArgs) -> Result { Ok(_) => {} Err(_) => { if args.positional.len() > 0 { - return Err(ShellError::labeled_error( + return Err(ShellError::maybe_labeled_error( "Can not change to directory", "directory not found", - args.positional[0].span.clone(), + Some(args.positional[0].span.clone()), )); } else { return Err(ShellError::string("Can not change to directory")); diff --git a/src/commands/classified.rs b/src/commands/classified.rs index fcd9586f2d..bb476187ee 100644 --- a/src/commands/classified.rs +++ b/src/commands/classified.rs @@ -1,9 +1,10 @@ use crate::commands::command::Sink; use crate::parser::ast::Expression; -use crate::parser::lexer::Span; +use crate::parser::lexer::{Span, Spanned}; use crate::parser::registry::Args; use crate::prelude::*; use bytes::{BufMut, BytesMut}; +use futures::stream::StreamExt; use futures_codec::{Decoder, Encoder, Framed}; use std::io::{Error, ErrorKind}; use std::path::PathBuf; @@ -109,51 +110,56 @@ impl InternalCommand { context: &mut Context, input: ClassifiedInputStream, ) -> Result { - let result = context.run_command( + let mut result = context.run_command( self.command, self.name_span.clone(), self.args, input.objects, )?; - let env = context.env.clone(); - - let stream = result.filter_map(move |v| match v { - ReturnValue::Action(action) => match action { - CommandAction::ChangePath(path) => { - env.lock().unwrap().last_mut().map(|x| { - x.path = path; - x - }); - futures::future::ready(None) + let mut stream = VecDeque::new(); + while let Some(item) = result.next().await { + match item { + ReturnValue::Value(Value::Error(err)) => { + return Err(*err); } - CommandAction::Enter(obj) => { - let new_env = Environment { - obj: obj, - path: PathBuf::from("/"), - }; - env.lock().unwrap().push(new_env); - futures::future::ready(None) - } - CommandAction::Exit => { - let mut v = env.lock().unwrap(); - if v.len() == 1 { - std::process::exit(0); + ReturnValue::Action(action) => match action { + CommandAction::ChangePath(path) => { + context.env.lock().unwrap().back_mut().map(|x| { + x.path = path; + x + }); } - v.pop(); - futures::future::ready(None) + CommandAction::Enter(obj) => { + let new_env = Environment { + obj: obj, + path: PathBuf::from("/"), + }; + context.env.lock().unwrap().push_back(new_env); + } + CommandAction::Exit => match context.env.lock().unwrap().pop_back() { + Some(Environment { + obj: Value::Filesystem, + .. + }) => std::process::exit(0), + None => std::process::exit(-1), + _ => {} + }, + }, + + ReturnValue::Value(v) => { + stream.push_back(v); } - }, - - ReturnValue::Value(v) => futures::future::ready(Some(v)), - }); - + } + } Ok(stream.boxed() as InputStream) } } crate struct ExternalCommand { crate name: String, - crate args: Vec, + #[allow(unused)] + crate name_span: Option, + crate args: Vec>, } crate enum StreamNext { @@ -174,10 +180,11 @@ impl ExternalCommand { let mut arg_string = format!("{}", self.name); for arg in &self.args { arg_string.push_str(" "); - arg_string.push_str(&arg); + arg_string.push_str(&arg.item); } let mut process; + #[cfg(windows)] { process = Exec::shell(&self.name); @@ -185,6 +192,23 @@ impl ExternalCommand { if arg_string.contains("$it") { let mut first = true; for i in &inputs { + if i.as_string().is_err() { + let mut span = None; + for arg in &self.args { + if arg.item.contains("$it") { + span = Some(arg.span); + } + } + if let Some(span) = span { + return Err(ShellError::labeled_error( + "External $it needs string data", + "given object instead of string data", + span, + )); + } else { + return Err(ShellError::string("Error: $it needs string data")); + } + } if !first { process = process.arg("&&"); process = process.arg(&self.name); @@ -198,7 +222,7 @@ impl ExternalCommand { } } else { for arg in &self.args { - process = process.arg(arg); + process = process.arg(arg.item.clone()); } } } @@ -209,6 +233,19 @@ impl ExternalCommand { if arg_string.contains("$it") { let mut first = true; for i in &inputs { + if i.as_string().is_err() { + let mut span = None; + for arg in &self.args { + if arg.item.contains("$it") { + span = Some(arg.span); + } + } + return Err(ShellError::maybe_labeled_error( + "External $it needs string data", + "given object instead of string data", + span, + )); + } if !first { new_arg_string.push_str("&&"); new_arg_string.push_str(&self.name); @@ -227,9 +264,10 @@ impl ExternalCommand { new_arg_string.push_str(&arg); } } + process = Exec::shell(new_arg_string); } - process = process.cwd(context.env.lock().unwrap().first().unwrap().path()); + process = process.cwd(context.env.lock().unwrap().front().unwrap().path()); let mut process = match stream_next { StreamNext::Last => process, diff --git a/src/commands/clip.rs b/src/commands/clip.rs index 42e2af5027..a55e7119b1 100644 --- a/src/commands/clip.rs +++ b/src/commands/clip.rs @@ -13,7 +13,16 @@ pub fn clip(args: SinkCommandArgs) -> Result<(), ShellError> { } else { first = false; } - new_copy_data.push_str(&i.as_string().unwrap()); + match i.as_string() { + Ok(s) => new_copy_data.push_str(&s), + Err(_) => { + return Err(ShellError::maybe_labeled_error( + "Given non-string data", + "expected strings from pipeline", + args.name_span, + )) + } + } } } clip_context.set_contents(new_copy_data).unwrap(); diff --git a/src/commands/command.rs b/src/commands/command.rs index 2d9faff09e..ff2046206e 100644 --- a/src/commands/command.rs +++ b/src/commands/command.rs @@ -8,7 +8,7 @@ use std::path::PathBuf; pub struct CommandArgs { pub host: Arc>, - pub env: Arc>>, + pub env: Arc>>, pub name_span: Option, pub positional: Vec>, pub named: indexmap::IndexMap, diff --git a/src/commands/enter.rs b/src/commands/enter.rs index d1bbef5da2..2ca3c2ccaf 100644 --- a/src/commands/enter.rs +++ b/src/commands/enter.rs @@ -7,14 +7,20 @@ use std::path::{Path, PathBuf}; pub fn enter(args: CommandArgs) -> Result { if args.positional.len() == 0 { - return Err(ShellError::string("open requires a filepath or url")); + return Err(ShellError::maybe_labeled_error( + "open requires a path or url", + "missing path", + args.name_span, + )); } + let span = args.name_span; + let cwd = args .env .lock() .unwrap() - .first() + .front() .unwrap() .path() .to_path_buf(); @@ -85,45 +91,111 @@ pub fn enter(args: CommandArgs) -> Result { let mut stream = VecDeque::new(); - let open_raw = match args.positional.get(1) { + let file_extension = match args.positional.get(1) { Some(Spanned { item: Value::Primitive(Primitive::String(s)), - .. - }) if s == "--raw" => true, - Some(v) => { - return Err(ShellError::labeled_error( - "Unknown flag for open", - "unknown flag", - v.span, - )) + span, + }) => { + if s == "--raw" { + None + } else if s == "--json" { + Some("json".to_string()) + } else if s == "--xml" { + Some("xml".to_string()) + } else if s == "--ini" { + Some("ini".to_string()) + } else if s == "--yaml" { + Some("yaml".to_string()) + } else if s == "--toml" { + Some("toml".to_string()) + } else { + return Err(ShellError::labeled_error( + "Unknown flag for open", + "unknown flag", + span.clone(), + )); + } } - _ => false, + _ => file_extension, }; match file_extension { - Some(x) if x == "toml" && !open_raw => { + Some(x) if x == "toml" => { stream.push_back(ReturnValue::Action(CommandAction::Enter( - crate::commands::from_toml::from_toml_string_to_value(contents), + crate::commands::from_toml::from_toml_string_to_value(contents).map_err( + move |_| { + ShellError::maybe_labeled_error( + "Could not load as TOML", + "could not load as TOML", + span, + ) + }, + )?, ))); } - Some(x) if x == "json" && !open_raw => { + Some(x) if x == "json" => { stream.push_back(ReturnValue::Action(CommandAction::Enter( - crate::commands::from_json::from_json_string_to_value(contents), + crate::commands::from_json::from_json_string_to_value(contents).map_err( + move |_| { + ShellError::maybe_labeled_error( + "Could not load as JSON", + "could not load as JSON", + span, + ) + }, + )?, ))); } - Some(x) if x == "xml" && !open_raw => { + Some(x) if x == "xml" => { stream.push_back(ReturnValue::Action(CommandAction::Enter( - crate::commands::from_xml::from_xml_string_to_value(contents), + crate::commands::from_xml::from_xml_string_to_value(contents).map_err( + move |_| { + ShellError::maybe_labeled_error( + "Could not load as XML", + "could not load as XML", + span, + ) + }, + )?, ))); } - Some(x) if x == "yml" && !open_raw => { + Some(x) if x == "ini" => { stream.push_back(ReturnValue::Action(CommandAction::Enter( - crate::commands::from_yaml::from_yaml_string_to_value(contents), + crate::commands::from_ini::from_ini_string_to_value(contents).map_err( + move |_| { + ShellError::maybe_labeled_error( + "Could not load as INI", + "could not load as INI", + span, + ) + }, + )?, ))); } - Some(x) if x == "yaml" && !open_raw => { + Some(x) if x == "yml" => { stream.push_back(ReturnValue::Action(CommandAction::Enter( - crate::commands::from_yaml::from_yaml_string_to_value(contents), + crate::commands::from_yaml::from_yaml_string_to_value(contents).map_err( + move |_| { + ShellError::maybe_labeled_error( + "Could not load as YAML", + "could not load as YAML", + span, + ) + }, + )?, + ))); + } + Some(x) if x == "yaml" => { + stream.push_back(ReturnValue::Action(CommandAction::Enter( + crate::commands::from_yaml::from_yaml_string_to_value(contents).map_err( + move |_| { + ShellError::maybe_labeled_error( + "Could not load as YAML", + "could not load as YAML", + span, + ) + }, + )?, ))); } _ => { diff --git a/src/commands/exit.rs b/src/commands/exit.rs index 0669adee76..27438f6654 100644 --- a/src/commands/exit.rs +++ b/src/commands/exit.rs @@ -1,11 +1,8 @@ use crate::commands::command::CommandAction; use crate::errors::ShellError; -use crate::object::{Primitive, Value}; -use crate::parser::lexer::Spanned; use crate::prelude::*; -use std::path::{Path, PathBuf}; -pub fn exit(args: CommandArgs) -> Result { +pub fn exit(_args: CommandArgs) -> Result { let mut stream = VecDeque::new(); stream.push_back(ReturnValue::Action(CommandAction::Exit)); Ok(stream.boxed()) diff --git a/src/commands/first.rs b/src/commands/first.rs index afc1ff8f52..89bb4ff9c9 100644 --- a/src/commands/first.rs +++ b/src/commands/first.rs @@ -5,15 +5,11 @@ use crate::prelude::*; pub fn first(args: CommandArgs) -> Result { if args.positional.len() == 0 { - if let Some(span) = args.name_span { - return Err(ShellError::labeled_error( - "First requires an amount", - "needs parameter", - span, - )); - } else { - return Err(ShellError::string("first requires an amount.")); - } + return Err(ShellError::maybe_labeled_error( + "First requires an amount", + "needs parameter", + args.name_span, + )); } let amount = args.positional[0].as_i64(); diff --git a/src/commands/from_ini.rs b/src/commands/from_ini.rs new file mode 100644 index 0000000000..fd14101367 --- /dev/null +++ b/src/commands/from_ini.rs @@ -0,0 +1,54 @@ +use crate::object::{DataDescriptor, Dictionary, Primitive, Value}; +use crate::prelude::*; +use indexmap::IndexMap; +use std::collections::HashMap; + +fn convert_ini_second_to_nu_value(v: &HashMap) -> Value { + let mut second = Dictionary::new(IndexMap::new()); + for (key, value) in v.into_iter() { + second.add( + DataDescriptor::from(key.as_str()), + Value::Primitive(Primitive::String(value.clone())), + ); + } + Value::Object(second) +} +fn convert_ini_top_to_nu_value(v: &HashMap>) -> Value { + let mut top_level = Dictionary::new(IndexMap::new()); + for (key, value) in v.iter() { + top_level.add( + DataDescriptor::from(key.as_str()), + convert_ini_second_to_nu_value(value), + ); + } + Value::Object(top_level) +} + +pub fn from_ini_string_to_value(s: String) -> Result> { + let v: HashMap> = serde_ini::from_str(&s)?; + Ok(convert_ini_top_to_nu_value(&v)) +} + +pub fn from_ini(args: CommandArgs) -> Result { + let out = args.input; + let span = args.name_span; + Ok(out + .map(move |a| match a { + Value::Primitive(Primitive::String(s)) => match from_ini_string_to_value(s) { + Ok(x) => ReturnValue::Value(x), + Err(e) => { + ReturnValue::Value(Value::Error(Box::new(ShellError::maybe_labeled_error( + "Could not parse as INI", + format!("{:#?}", e), + span, + )))) + } + }, + _ => ReturnValue::Value(Value::Error(Box::new(ShellError::maybe_labeled_error( + "Expected string values from pipeline", + "expects strings from pipeline", + span, + )))), + }) + .boxed()) +} diff --git a/src/commands/from_json.rs b/src/commands/from_json.rs index 1624d9c7e1..b8c796f0d3 100644 --- a/src/commands/from_json.rs +++ b/src/commands/from_json.rs @@ -28,19 +28,31 @@ fn convert_json_value_to_nu_value(v: &serde_hjson::Value) -> Value { } } -pub fn from_json_string_to_value(s: String) -> Value { - let v: serde_hjson::Value = serde_hjson::from_str(&s).unwrap(); - convert_json_value_to_nu_value(&v) +pub fn from_json_string_to_value(s: String) -> serde_hjson::Result { + let v: serde_hjson::Value = serde_hjson::from_str(&s)?; + Ok(convert_json_value_to_nu_value(&v)) } pub fn from_json(args: CommandArgs) -> Result { let out = args.input; + let span = args.name_span; Ok(out - .map(|a| match a { - Value::Primitive(Primitive::String(s)) => { - ReturnValue::Value(from_json_string_to_value(s)) - } - _ => ReturnValue::Value(Value::Primitive(Primitive::String("".to_string()))), + .map(move |a| match a { + Value::Primitive(Primitive::String(s)) => match from_json_string_to_value(s) { + Ok(x) => ReturnValue::Value(x), + Err(_) => { + ReturnValue::Value(Value::Error(Box::new(ShellError::maybe_labeled_error( + "Could not parse as JSON", + "piped data failed JSON parse", + span, + )))) + } + }, + _ => ReturnValue::Value(Value::Error(Box::new(ShellError::maybe_labeled_error( + "Expected string values from pipeline", + "expects strings from pipeline", + span, + )))), }) .boxed()) } diff --git a/src/commands/from_toml.rs b/src/commands/from_toml.rs index 59610a8ffd..2021f503af 100644 --- a/src/commands/from_toml.rs +++ b/src/commands/from_toml.rs @@ -1,5 +1,5 @@ -use crate::object::{Primitive, Value, Dictionary, DataDescriptor}; use crate::object::base::OF64; +use crate::object::{DataDescriptor, Dictionary, Primitive, Value}; use crate::prelude::*; fn convert_toml_value_to_nu_value(v: &toml::Value) -> Value { @@ -8,31 +8,50 @@ fn convert_toml_value_to_nu_value(v: &toml::Value) -> Value { toml::Value::Integer(n) => Value::Primitive(Primitive::Int(*n)), toml::Value::Float(n) => Value::Primitive(Primitive::Float(OF64::from(*n))), toml::Value::String(s) => Value::Primitive(Primitive::String(s.clone())), - toml::Value::Array(a) => Value::List(a.iter().map(|x| convert_toml_value_to_nu_value(x)).collect()), + toml::Value::Array(a) => Value::List( + a.iter() + .map(|x| convert_toml_value_to_nu_value(x)) + .collect(), + ), toml::Value::Datetime(dt) => Value::Primitive(Primitive::String(dt.to_string())), toml::Value::Table(t) => { let mut collected = Dictionary::default(); for (k, v) in t.iter() { - collected.add(DataDescriptor::from(k.clone()), convert_toml_value_to_nu_value(v)); + collected.add( + DataDescriptor::from(k.clone()), + convert_toml_value_to_nu_value(v), + ); } Value::Object(collected) } } } -pub fn from_toml_string_to_value(s: String) -> Value { - let v: toml::Value = s.parse::().unwrap(); - convert_toml_value_to_nu_value(&v) +pub fn from_toml_string_to_value(s: String) -> Result> { + let v: toml::Value = s.parse::()?; + Ok(convert_toml_value_to_nu_value(&v)) } pub fn from_toml(args: CommandArgs) -> Result { let out = args.input; + let span = args.name_span; Ok(out - .map(|a| match a { - Value::Primitive(Primitive::String(s)) => { - ReturnValue::Value(from_toml_string_to_value(s)) - } - _ => ReturnValue::Value(Value::Primitive(Primitive::String("".to_string()))), + .map(move |a| match a { + Value::Primitive(Primitive::String(s)) => match from_toml_string_to_value(s) { + Ok(x) => ReturnValue::Value(x), + Err(_) => { + ReturnValue::Value(Value::Error(Box::new(ShellError::maybe_labeled_error( + "Could not parse as TOML", + "piped data failed TOML parse", + span, + )))) + } + }, + _ => ReturnValue::Value(Value::Error(Box::new(ShellError::maybe_labeled_error( + "Expected string values from pipeline", + "expects strings from pipeline", + span, + )))), }) .boxed()) } diff --git a/src/commands/from_xml.rs b/src/commands/from_xml.rs index 83e964e09d..d203005382 100644 --- a/src/commands/from_xml.rs +++ b/src/commands/from_xml.rs @@ -15,7 +15,7 @@ fn from_node_to_value<'a, 'd>(n: &roxmltree::Node<'a, 'd>) -> Value { .filter(|x| match x { Value::Primitive(Primitive::String(f)) => { if f.trim() == "" { - false + false } else { true } @@ -46,22 +46,30 @@ fn from_document_to_value(d: &roxmltree::Document) -> Value { from_node_to_value(&d.root_element()) } -pub fn from_xml_string_to_value(s: String) -> Value { - match roxmltree::Document::parse(&s) { - Ok(doc) => from_document_to_value(&doc), - Err(_) => Value::Error(Box::new(ShellError::string( - "Can't convert string from xml".to_string(), - ))), - } +pub fn from_xml_string_to_value(s: String) -> Result> { + let parsed = roxmltree::Document::parse(&s)?; + Ok(from_document_to_value(&parsed)) } pub fn from_xml(args: CommandArgs) -> Result { let out = args.input; + let span = args.name_span; Ok(out - .map(|a| match a { - Value::Primitive(Primitive::String(s)) => ReturnValue::Value(from_xml_string_to_value(s)), - _ => ReturnValue::Value(Value::Error(Box::new(ShellError::string( - "Trying to convert XML from non-string".to_string(), + .map(move |a| match a { + Value::Primitive(Primitive::String(s)) => match from_xml_string_to_value(s) { + Ok(x) => ReturnValue::Value(x), + Err(_) => { + ReturnValue::Value(Value::Error(Box::new(ShellError::maybe_labeled_error( + "Could not parse as XML", + "piped data failed XML parse", + span, + )))) + } + }, + _ => ReturnValue::Value(Value::Error(Box::new(ShellError::maybe_labeled_error( + "Expected string values from pipeline", + "expects strings from pipeline", + span, )))), }) .boxed()) diff --git a/src/commands/from_yaml.rs b/src/commands/from_yaml.rs index 171ab3ae0d..ac725138d9 100644 --- a/src/commands/from_yaml.rs +++ b/src/commands/from_yaml.rs @@ -36,19 +36,31 @@ fn convert_yaml_value_to_nu_value(v: &serde_yaml::Value) -> Value { } } -pub fn from_yaml_string_to_value(s: String) -> Value { - let v: serde_yaml::Value = serde_yaml::from_str(&s).unwrap(); - convert_yaml_value_to_nu_value(&v) +pub fn from_yaml_string_to_value(s: String) -> serde_yaml::Result { + let v: serde_yaml::Value = serde_yaml::from_str(&s)?; + Ok(convert_yaml_value_to_nu_value(&v)) } pub fn from_yaml(args: CommandArgs) -> Result { let out = args.input; + let span = args.name_span; Ok(out - .map(|a| match a { - Value::Primitive(Primitive::String(s)) => { - ReturnValue::Value(from_yaml_string_to_value(s)) - } - _ => ReturnValue::Value(Value::Primitive(Primitive::String("".to_string()))), + .map(move |a| match a { + Value::Primitive(Primitive::String(s)) => match from_yaml_string_to_value(s) { + Ok(x) => ReturnValue::Value(x), + Err(_) => { + ReturnValue::Value(Value::Error(Box::new(ShellError::maybe_labeled_error( + "Could not parse as YAML", + "piped data failed YAML parse", + span, + )))) + } + }, + _ => ReturnValue::Value(Value::Error(Box::new(ShellError::maybe_labeled_error( + "Expected string values from pipeline", + "expects strings from pipeline", + span, + )))), }) .boxed()) } diff --git a/src/commands/get.rs b/src/commands/get.rs index b3869d97a3..60b835d62f 100644 --- a/src/commands/get.rs +++ b/src/commands/get.rs @@ -1,17 +1,19 @@ use crate::errors::ShellError; use crate::object::Value; +use crate::parser::lexer::Span; use crate::prelude::*; -fn get_member(path: &str, obj: &Value) -> Option { +fn get_member(path: &str, span: Span, obj: &Value) -> Option { let mut current = obj; for p in path.split(".") { match current.get_data_by_key(p) { Some(v) => current = v, None => { - return Some(Value::Error(Box::new(ShellError::string(format!( - "Object field name not found: {}", - p - ))))) + return Some(Value::Error(Box::new(ShellError::labeled_error( + "Unknown field", + "object missing field", + span, + )))); } } } @@ -21,15 +23,11 @@ fn get_member(path: &str, obj: &Value) -> Option { pub fn get(args: CommandArgs) -> Result { if args.positional.len() == 0 { - if let Some(span) = args.name_span { - return Err(ShellError::labeled_error( - "Get requires a field or field path", - "needs parameter", - span, - )); - } else { - return Err(ShellError::string("get requires fields.")); - } + return Err(ShellError::maybe_labeled_error( + "Get requires a field or field path", + "needs parameter", + args.name_span, + )); } let amount = args.positional[0].as_i64(); @@ -44,7 +42,11 @@ pub fn get(args: CommandArgs) -> Result { .boxed()); } - let fields: Result, _> = args.positional.iter().map(|a| a.as_string()).collect(); + let fields: Result, _> = args + .positional + .iter() + .map(|a| (a.as_string().map(|x| (x, a.span)))) + .collect(); let fields = fields?; let stream = args @@ -52,7 +54,7 @@ pub fn get(args: CommandArgs) -> Result { .map(move |item| { let mut result = VecDeque::new(); for field in &fields { - match get_member(field, &item) { + match get_member(&field.0, field.1, &item) { Some(Value::List(l)) => { for item in l { result.push_back(ReturnValue::Value(item.copy())); diff --git a/src/commands/lines.rs b/src/commands/lines.rs new file mode 100644 index 0000000000..b1db3feb2f --- /dev/null +++ b/src/commands/lines.rs @@ -0,0 +1,37 @@ +use crate::errors::ShellError; +use crate::object::{Primitive, Value}; +use crate::prelude::*; + +pub fn lines(args: CommandArgs) -> Result { + let input = args.input; + let span = args.name_span; + + let stream = input + .map(move |v| match v { + Value::Primitive(Primitive::String(s)) => { + let split_result: Vec<_> = s.lines().filter(|s| s.trim() != "").collect(); + + let mut result = VecDeque::new(); + for s in split_result { + result.push_back(ReturnValue::Value(Value::Primitive(Primitive::String( + s.to_string(), + )))); + } + result + } + _ => { + let mut result = VecDeque::new(); + result.push_back(ReturnValue::Value(Value::Error(Box::new( + ShellError::maybe_labeled_error( + "Expected string values from pipeline", + "expects strings from pipeline", + span, + ), + )))); + result + } + }) + .flatten(); + + Ok(stream.boxed()) +} diff --git a/src/commands/ls.rs b/src/commands/ls.rs index 70cbf9d53e..f8205e3a1a 100644 --- a/src/commands/ls.rs +++ b/src/commands/ls.rs @@ -7,8 +7,8 @@ use std::path::{Path, PathBuf}; pub fn ls(args: CommandArgs) -> Result { let env = args.env.lock().unwrap(); - let path = env.last().unwrap().path.to_path_buf(); - let obj = &env.last().unwrap().obj; + let path = env.back().unwrap().path.to_path_buf(); + let obj = &env.back().unwrap().obj; let mut full_path = PathBuf::from(path); match &args.positional.get(0) { Some(Spanned { @@ -31,7 +31,11 @@ pub fn ls(args: CommandArgs) -> Result { s.span, )); } else { - return Err(ShellError::string(e.to_string())); + return Err(ShellError::maybe_labeled_error( + e.to_string(), + e.to_string(), + args.name_span, + )); } } Ok(o) => o, @@ -69,27 +73,46 @@ pub fn ls(args: CommandArgs) -> Result { Some(v) => { viewed = v; } - _ => println!("Idx not found"), + _ => { + return Err(ShellError::maybe_labeled_error( + "Given incorrect index", + format!("path given bad index: {}", idx), + args.name_span, + )) + } }, - _ => println!("idx not a number"), + _ => { + return Err(ShellError::maybe_labeled_error( + "Given incorrect index", + format!( + "path index not a number: {}", + &s[0..finish] + ), + args.name_span, + )) + } } } - _ => println!("obj not some"), - /* - _ => match viewed.get_data_by_key(s) { - Some(v) => { - viewed = v; - } - _ => println!("Obj not Some"), - }, - */ + _ => { + return Err(ShellError::maybe_labeled_error( + "Index not closed", + format!("path missing closing ']'"), + if args.positional.len() > 0 { Some(args.positional[0].span) } else { args.name_span }, + )) + } } } else { match viewed.get_data_by_key(s) { Some(v) => { viewed = v; } - _ => println!("Obj not Some"), + _ => { + return Err(ShellError::maybe_labeled_error( + "Could not find key", + format!("could not find: {}", s), + args.name_span, + )) + } } first = false; } diff --git a/src/commands/open.rs b/src/commands/open.rs index 15392e48d3..0edce69880 100644 --- a/src/commands/open.rs +++ b/src/commands/open.rs @@ -6,14 +6,20 @@ use std::path::{Path, PathBuf}; pub fn open(args: CommandArgs) -> Result { if args.positional.len() == 0 { - return Err(ShellError::string("open requires a filepath or url")); + return Err(ShellError::maybe_labeled_error( + "Open requires a path or url", + "needs path or url", + args.name_span, + )); } + let span = args.name_span; + let cwd = args .env .lock() .unwrap() - .first() + .front() .unwrap() .path() .to_path_buf(); @@ -65,8 +71,8 @@ pub fn open(args: CommandArgs) -> Result { ), Err(_) => { return Err(ShellError::labeled_error( - "File cound not be opened", - "file not found", + "File could not be opened", + "could not be opened", args.positional[0].span, )); } @@ -84,45 +90,111 @@ pub fn open(args: CommandArgs) -> Result { let mut stream = VecDeque::new(); - let open_raw = match args.positional.get(1) { + let file_extension = match args.positional.get(1) { Some(Spanned { item: Value::Primitive(Primitive::String(s)), - .. - }) if s == "--raw" => true, - Some(v) => { - return Err(ShellError::labeled_error( - "Unknown flag for open", - "unknown flag", - v.span, - )) + span, + }) => { + if s == "--raw" { + None + } else if s == "--json" { + Some("json".to_string()) + } else if s == "--xml" { + Some("xml".to_string()) + } else if s == "--ini" { + Some("ini".to_string()) + } else if s == "--yaml" { + Some("yaml".to_string()) + } else if s == "--toml" { + Some("toml".to_string()) + } else { + return Err(ShellError::labeled_error( + "Unknown flag for open", + "unknown flag", + span.clone(), + )); + } } - _ => false, + _ => file_extension, }; match file_extension { - Some(x) if x == "toml" && !open_raw => { + Some(x) if x == "toml" => { stream.push_back(ReturnValue::Value( - crate::commands::from_toml::from_toml_string_to_value(contents), + crate::commands::from_toml::from_toml_string_to_value(contents).map_err( + move |_| { + ShellError::maybe_labeled_error( + "Could not open as TOML", + "could not open as TOML", + span, + ) + }, + )?, )); } - Some(x) if x == "json" && !open_raw => { + Some(x) if x == "json" => { stream.push_back(ReturnValue::Value( - crate::commands::from_json::from_json_string_to_value(contents), + crate::commands::from_json::from_json_string_to_value(contents).map_err( + move |_| { + ShellError::maybe_labeled_error( + "Could not open as JSON", + "could not open as JSON", + span, + ) + }, + )?, )); } - Some(x) if x == "xml" && !open_raw => { + Some(x) if x == "ini" => { stream.push_back(ReturnValue::Value( - crate::commands::from_xml::from_xml_string_to_value(contents), + crate::commands::from_ini::from_ini_string_to_value(contents).map_err( + move |_| { + ShellError::maybe_labeled_error( + "Could not open as INI", + "could not open as INI", + span, + ) + }, + )?, )); } - Some(x) if x == "yml" && !open_raw => { + Some(x) if x == "xml" => { stream.push_back(ReturnValue::Value( - crate::commands::from_yaml::from_yaml_string_to_value(contents), + crate::commands::from_xml::from_xml_string_to_value(contents).map_err( + move |_| { + ShellError::maybe_labeled_error( + "Could not open as XML", + "could not open as XML", + span, + ) + }, + )?, )); } - Some(x) if x == "yaml" && !open_raw => { + Some(x) if x == "yml" => { stream.push_back(ReturnValue::Value( - crate::commands::from_yaml::from_yaml_string_to_value(contents), + crate::commands::from_yaml::from_yaml_string_to_value(contents).map_err( + move |_| { + ShellError::maybe_labeled_error( + "Could not open as YAML", + "could not open as YAML", + span, + ) + }, + )?, + )); + } + Some(x) if x == "yaml" => { + stream.push_back(ReturnValue::Value( + crate::commands::from_yaml::from_yaml_string_to_value(contents).map_err( + move |_| { + ShellError::maybe_labeled_error( + "Could not open as YAML", + "could not open as YAML", + span, + ) + }, + )?, )); } _ => { diff --git a/src/commands/pick.rs b/src/commands/pick.rs index 73e953ad0c..9de5e80683 100644 --- a/src/commands/pick.rs +++ b/src/commands/pick.rs @@ -5,15 +5,11 @@ use crate::prelude::*; pub fn pick(args: CommandArgs) -> Result { if args.positional.len() == 0 { - if let Some(span) = args.name_span { - return Err(ShellError::labeled_error( - "Pick requires fields", - "needs parameter", - span, - )); - } else { - return Err(ShellError::string("pick requires fields.")); - } + return Err(ShellError::maybe_labeled_error( + "Pick requires fields", + "needs parameter", + args.name_span, + )); } let fields: Result, _> = args.positional.iter().map(|a| a.as_string()).collect(); diff --git a/src/commands/reject.rs b/src/commands/reject.rs index 372adcf7c5..ec5703738b 100644 --- a/src/commands/reject.rs +++ b/src/commands/reject.rs @@ -5,15 +5,11 @@ use crate::prelude::*; pub fn reject(args: CommandArgs) -> Result { if args.positional.len() == 0 { - if let Some(span) = args.name_span { - return Err(ShellError::labeled_error( - "Reject requires fields", - "needs parameter", - span, - )); - } else { - return Err(ShellError::string("reject requires fields.")); - } + return Err(ShellError::maybe_labeled_error( + "Reject requires fields", + "needs parameter", + args.name_span, + )); } let fields: Result, _> = args.positional.iter().map(|a| a.as_string()).collect(); diff --git a/src/commands/save.rs b/src/commands/save.rs index 5d94496cf3..3aeb751033 100644 --- a/src/commands/save.rs +++ b/src/commands/save.rs @@ -6,7 +6,11 @@ use std::path::{Path, PathBuf}; pub fn save(args: SinkCommandArgs) -> Result<(), ShellError> { if args.positional.len() == 0 { - return Err(ShellError::string("save requires a filepath")); + return Err(ShellError::maybe_labeled_error( + "Save requires a filepath", + "needs path", + args.name_span, + )); } let cwd = args @@ -14,7 +18,7 @@ pub fn save(args: SinkCommandArgs) -> Result<(), ShellError> { .env .lock() .unwrap() - .first() + .front() .unwrap() .path() .to_path_buf(); @@ -41,6 +45,14 @@ pub fn save(args: SinkCommandArgs) -> Result<(), ShellError> { } toml::to_string(&args.input[0]).unwrap() } + Some(x) if x == "ini" && !save_raw => { + if args.input.len() != 1 { + return Err(ShellError::string( + "saving to ini requires a single object (or use --raw)", + )); + } + serde_ini::to_string(&args.input[0]).unwrap() + } Some(x) if x == "json" && !save_raw => { if args.input.len() != 1 { return Err(ShellError::string( diff --git a/src/commands/size.rs b/src/commands/size.rs index 4fe90e25ff..6fdf78cfae 100644 --- a/src/commands/size.rs +++ b/src/commands/size.rs @@ -6,14 +6,18 @@ use std::fs::File; use std::io::prelude::*; pub fn size(args: CommandArgs) -> Result { - if args.positional.is_empty() { - return Err(ShellError::string("size requires at least one file")); + if args.positional.len() == 0 { + return Err(ShellError::maybe_labeled_error( + "Size requires a filepath", + "needs path", + args.name_span, + )); } let cwd = args .env .lock() .unwrap() - .first() + .front() .unwrap() .path() .to_path_buf(); diff --git a/src/commands/skip.rs b/src/commands/skip.rs index 38af0c1a79..d556151053 100644 --- a/src/commands/skip.rs +++ b/src/commands/skip.rs @@ -3,15 +3,11 @@ use crate::prelude::*; pub fn skip(args: CommandArgs) -> Result { if args.positional.len() == 0 { - if let Some(span) = args.name_span { - return Err(ShellError::labeled_error( - "Skip requires an amount", - "needs parameter", - span, - )); - } else { - return Err(ShellError::string("skip requires an amount.")); - } + return Err(ShellError::maybe_labeled_error( + "Skip requires an amount", + "needs parameter", + args.name_span, + )); } let amount = args.positional[0].as_i64(); diff --git a/src/commands/skip_while.rs b/src/commands/skip_while.rs new file mode 100644 index 0000000000..15cb439812 --- /dev/null +++ b/src/commands/skip_while.rs @@ -0,0 +1,51 @@ +use crate::errors::ShellError; +use crate::parser::registry::PositionalType; +use crate::parser::CommandConfig; +use crate::prelude::*; + +pub struct SkipWhile; + +impl Command for SkipWhile { + fn run(&self, args: CommandArgs) -> Result { + skip_while(args) + } + fn name(&self) -> &str { + "skip-while" + } + + fn config(&self) -> CommandConfig { + CommandConfig { + name: self.name().to_string(), + mandatory_positional: vec![PositionalType::Block("condition".to_string())], + optional_positional: vec![], + rest_positional: false, + named: indexmap::IndexMap::new(), + } + } +} + +pub fn skip_while(args: CommandArgs) -> Result { + if args.positional.len() == 0 { + return Err(ShellError::maybe_labeled_error( + "Where requires a condition", + "needs condition", + args.name_span, + )); + } + + let block = args.positional[0].as_block()?; + let input = args.input; + + let objects = input.skip_while(move |item| { + let result = block.invoke(&item); + + let return_value = match result { + Ok(v) if v.is_true() => true, + _ => false, + }; + + futures::future::ready(return_value) + }); + + Ok(objects.map(|x| ReturnValue::Value(x)).boxed()) +} \ No newline at end of file diff --git a/src/commands/split_column.rs b/src/commands/split_column.rs index c768ec6b83..653b9e6180 100644 --- a/src/commands/split_column.rs +++ b/src/commands/split_column.rs @@ -6,7 +6,15 @@ use log::trace; // TODO: "Amount remaining" wrapper pub fn split_column(args: CommandArgs) -> Result { + if args.positional.len() == 0 { + return Err(ShellError::maybe_labeled_error( + "Split-column needs more information", + "needs parameter (eg split-column \",\")", + args.name_span, + )); + } let input = args.input; + let span = args.name_span; let args = args.positional; Ok(input @@ -53,7 +61,11 @@ pub fn split_column(args: CommandArgs) -> Result { ReturnValue::Value(Value::Object(dict)) } } - _ => ReturnValue::Value(Value::Object(crate::object::Dictionary::default())), + _ => ReturnValue::Value(Value::Error(Box::new(ShellError::maybe_labeled_error( + "Expected string values from pipeline", + "expects strings from pipeline", + span, + )))), }) .boxed()) } diff --git a/src/commands/split_row.rs b/src/commands/split_row.rs index fead9f8e1f..ed382bb761 100644 --- a/src/commands/split_row.rs +++ b/src/commands/split_row.rs @@ -6,7 +6,16 @@ use log::trace; // TODO: "Amount remaining" wrapper pub fn split_row(args: CommandArgs) -> Result { + if args.positional.len() == 0 { + return Err(ShellError::maybe_labeled_error( + "Split-row needs more information", + "needs parameter (eg split-row \"\\n\")", + args.name_span, + )); + } + let input = args.input; + let span = args.name_span; let args = args.positional; let stream = input @@ -27,7 +36,14 @@ pub fn split_row(args: CommandArgs) -> Result { result } _ => { - let result = VecDeque::new(); + let mut result = VecDeque::new(); + result.push_back(ReturnValue::Value(Value::Error(Box::new( + ShellError::maybe_labeled_error( + "Expected string values from pipeline", + "expects strings from pipeline", + span, + ), + )))); result } }) diff --git a/src/commands/sysinfo.rs b/src/commands/sysinfo.rs new file mode 100644 index 0000000000..a474ad6a23 --- /dev/null +++ b/src/commands/sysinfo.rs @@ -0,0 +1,205 @@ +use crate::errors::ShellError; +use crate::object::base::OF64; +use crate::object::Dictionary; +use crate::object::{Primitive, Value}; +use crate::prelude::*; +use sys_info::*; +use sysinfo::{ComponentExt, DiskExt, NetworkExt, SystemExt}; + +pub fn sysinfo(_args: CommandArgs) -> Result { + let mut idx = indexmap::IndexMap::new(); + + if let (Ok(name), Ok(version)) = (os_type(), os_release()) { + let mut os_idx = indexmap::IndexMap::new(); + os_idx.insert( + "name".to_string(), + Value::Primitive(Primitive::String(name)), + ); + os_idx.insert( + "version".to_string(), + Value::Primitive(Primitive::String(version)), + ); + + idx.insert("os".to_string(), Value::Object(Dictionary::from(os_idx))); + } + + if let (Ok(num_cpu), Ok(cpu_speed)) = (cpu_num(), cpu_speed()) { + let mut cpu_idx = indexmap::IndexMap::new(); + cpu_idx.insert( + "num".to_string(), + Value::Primitive(Primitive::Int(num_cpu as i64)), + ); + cpu_idx.insert( + "speed".to_string(), + Value::Primitive(Primitive::Int(cpu_speed as i64)), + ); + + idx.insert("cpu".to_string(), Value::Object(Dictionary::from(cpu_idx))); + } + + if let Ok(x) = loadavg() { + let mut load_idx = indexmap::IndexMap::new(); + load_idx.insert( + "1min".to_string(), + Value::Primitive(Primitive::Float(OF64::from(x.one))), + ); + load_idx.insert( + "5min".to_string(), + Value::Primitive(Primitive::Float(OF64::from(x.five))), + ); + load_idx.insert( + "15min".to_string(), + Value::Primitive(Primitive::Float(OF64::from(x.fifteen))), + ); + + idx.insert( + "load avg".to_string(), + Value::Object(Dictionary::from(load_idx)), + ); + } + + if let Ok(x) = mem_info() { + let mut mem_idx = indexmap::IndexMap::new(); + mem_idx.insert( + "total".to_string(), + Value::Primitive(Primitive::Bytes(x.total as u128 * 1024)), + ); + mem_idx.insert( + "free".to_string(), + Value::Primitive(Primitive::Bytes(x.free as u128 * 1024)), + ); + mem_idx.insert( + "avail".to_string(), + Value::Primitive(Primitive::Bytes(x.avail as u128 * 1024)), + ); + mem_idx.insert( + "buffers".to_string(), + Value::Primitive(Primitive::Bytes(x.buffers as u128 * 1024)), + ); + mem_idx.insert( + "cached".to_string(), + Value::Primitive(Primitive::Bytes(x.cached as u128 * 1024)), + ); + mem_idx.insert( + "swap total".to_string(), + Value::Primitive(Primitive::Bytes(x.swap_total as u128 * 1024)), + ); + mem_idx.insert( + "swap free".to_string(), + Value::Primitive(Primitive::Bytes(x.swap_free as u128 * 1024)), + ); + + idx.insert("mem".to_string(), Value::Object(Dictionary::from(mem_idx))); + } + + /* + if let Ok(x) = disk_info() { + let mut disk_idx = indexmap::IndexMap::new(); + disk_idx.insert( + "total".to_string(), + Value::Primitive(Primitive::Bytes(x.total as u128 * 1024)), + ); + disk_idx.insert( + "free".to_string(), + Value::Primitive(Primitive::Bytes(x.free as u128 * 1024)), + ); + } + */ + + if let Ok(x) = hostname() { + idx.insert( + "hostname".to_string(), + Value::Primitive(Primitive::String(x)), + ); + } + + #[cfg(not(windows))] + { + if let Ok(x) = boottime() { + let mut boottime_idx = indexmap::IndexMap::new(); + boottime_idx.insert( + "days".to_string(), + Value::Primitive(Primitive::Int(x.tv_sec / (24 * 3600))), + ); + boottime_idx.insert( + "hours".to_string(), + Value::Primitive(Primitive::Int((x.tv_sec / 3600) % 24)), + ); + boottime_idx.insert( + "mins".to_string(), + Value::Primitive(Primitive::Int((x.tv_sec / 60) % 60)), + ); + + idx.insert( + "uptime".to_string(), + Value::Object(Dictionary::from(boottime_idx)), + ); + } + } + + let system = sysinfo::System::new(); + let components_list = system.get_components_list(); + if components_list.len() > 0 { + let mut v = vec![]; + for component in components_list { + let mut component_idx = indexmap::IndexMap::new(); + component_idx.insert( + "name".to_string(), + Value::string(component.get_label().to_string()), + ); + component_idx.insert( + "temp".to_string(), + Value::float(component.get_temperature() as f64), + ); + component_idx.insert( + "max".to_string(), + Value::float(component.get_max() as f64), + ); + if let Some(critical) = component.get_critical() { + component_idx.insert("critical".to_string(), Value::float(critical as f64)); + } + v.push(Value::Object(Dictionary::from(component_idx))); + } + idx.insert("temps".to_string(), Value::List(v)); + } + + let disks = system.get_disks(); + if disks.len() > 0 { + let mut v = vec![]; + + for disk in disks { + let mut disk_idx = indexmap::IndexMap::new(); + disk_idx.insert( + "name".to_string(), + Value::string(disk.get_name().to_string_lossy()), + ); + disk_idx.insert( + "available".to_string(), + Value::bytes(disk.get_available_space()), + ); + disk_idx.insert( + "total".to_string(), + Value::bytes(disk.get_total_space()), + ); + v.push(Value::Object(Dictionary::from(disk_idx))); + } + + idx.insert("disks".to_string(), Value::List(v)); + } + + let network = system.get_network(); + let incoming = network.get_income(); + let outgoing = network.get_outcome(); + + let mut network_idx = indexmap::IndexMap::new(); + network_idx.insert("incoming".to_string(), Value::bytes(incoming)); + network_idx.insert("outgoing".to_string(), Value::bytes(outgoing)); + idx.insert("network".to_string(), Value::Object(Dictionary::from(network_idx))); + + // println!("{:#?}", system.get_network()); + + let mut stream = VecDeque::new(); + stream.push_back(ReturnValue::Value(Value::Object(Dictionary::from(idx)))); + + Ok(stream.boxed()) +} diff --git a/src/commands/table.rs b/src/commands/table.rs new file mode 100644 index 0000000000..d8e3ca7f2a --- /dev/null +++ b/src/commands/table.rs @@ -0,0 +1,16 @@ +use crate::commands::command::SinkCommandArgs; +use crate::errors::ShellError; +use crate::format::TableView; +use crate::prelude::*; + +pub fn table(args: SinkCommandArgs) -> Result<(), ShellError> { + if args.input.len() > 0 { + let mut host = args.ctx.host.lock().unwrap(); + let view = TableView::from_list(&args.input); + if let Some(view) = view { + handle_unexpected(&mut *host, |host| crate::format::print_view(&view, host)); + } + } + + Ok(()) +} diff --git a/src/commands/to_ini.rs b/src/commands/to_ini.rs new file mode 100644 index 0000000000..4b23add216 --- /dev/null +++ b/src/commands/to_ini.rs @@ -0,0 +1,17 @@ +use crate::object::{Primitive, Value}; +use crate::prelude::*; + +pub fn to_ini(args: CommandArgs) -> Result { + let out = args.input; + let span = args.name_span; + Ok(out + .map(move |a| match serde_ini::to_string(&a) { + Ok(x) => ReturnValue::Value(Value::Primitive(Primitive::String(x))), + Err(_) => ReturnValue::Value(Value::Error(Box::new(ShellError::maybe_labeled_error( + "Can not convert to INI string", + "can not convert piped data to INI string", + span, + )))), + }) + .boxed()) +} diff --git a/src/commands/to_json.rs b/src/commands/to_json.rs index fa8aadd0a6..6d245c6e18 100644 --- a/src/commands/to_json.rs +++ b/src/commands/to_json.rs @@ -3,7 +3,15 @@ use crate::prelude::*; pub fn to_json(args: CommandArgs) -> Result { let out = args.input; + let span = args.name_span; Ok(out - .map(|a| ReturnValue::Value(Value::Primitive(Primitive::String(serde_json::to_string(&a).unwrap())))) + .map(move |a| match serde_json::to_string(&a) { + Ok(x) => ReturnValue::Value(Value::Primitive(Primitive::String(x))), + Err(_) => ReturnValue::Value(Value::Error(Box::new(ShellError::maybe_labeled_error( + "Can not convert to JSON string", + "can not convert piped data to JSON string", + span, + )))), + }) .boxed()) } diff --git a/src/commands/to_toml.rs b/src/commands/to_toml.rs index ac0fe05a6d..497276223c 100644 --- a/src/commands/to_toml.rs +++ b/src/commands/to_toml.rs @@ -3,7 +3,15 @@ use crate::prelude::*; pub fn to_toml(args: CommandArgs) -> Result { let out = args.input; + let span = args.name_span; Ok(out - .map(|a| ReturnValue::Value(Value::Primitive(Primitive::String(toml::to_string(&a).unwrap())))) + .map(move |a| match toml::to_string(&a) { + Ok(x) => ReturnValue::Value(Value::Primitive(Primitive::String(x))), + Err(_) => ReturnValue::Value(Value::Error(Box::new(ShellError::maybe_labeled_error( + "Can not convert to TOML string", + "can not convert piped data to TOML string", + span, + )))), + }) .boxed()) } diff --git a/src/commands/trim.rs b/src/commands/trim.rs index 2974b4e65b..35887f6521 100644 --- a/src/commands/trim.rs +++ b/src/commands/trim.rs @@ -6,13 +6,18 @@ use crate::prelude::*; pub fn trim(args: CommandArgs) -> Result { let input = args.input; + let span = args.name_span; Ok(input .map(move |v| match v { Value::Primitive(Primitive::String(s)) => { ReturnValue::Value(Value::Primitive(Primitive::String(s.trim().to_string()))) } - x => ReturnValue::Value(x), + _ => ReturnValue::Value(Value::Error(Box::new(ShellError::maybe_labeled_error( + "Expected string values from pipeline", + "expects strings from pipeline", + span, + )))), }) .boxed()) } diff --git a/src/commands/view.rs b/src/commands/view.rs index 30dce91d88..51e29cdbaa 100644 --- a/src/commands/view.rs +++ b/src/commands/view.rs @@ -4,15 +4,11 @@ use prettyprint::PrettyPrinter; pub fn view(args: CommandArgs) -> Result { if args.positional.len() == 0 { - if let Some(span) = args.name_span { - return Err(ShellError::labeled_error( - "View requires a filename", - "needs parameter", - span, - )); - } else { - return Err(ShellError::string("view requires a filename.")); - } + return Err(ShellError::maybe_labeled_error( + "View requires a filename", + "needs parameter", + args.name_span, + )); } let target = match args.positional[0].as_string() { @@ -34,7 +30,7 @@ pub fn view(args: CommandArgs) -> Result { .env .lock() .unwrap() - .first() + .front() .unwrap() .path() .to_path_buf(); diff --git a/src/commands/vtable.rs b/src/commands/vtable.rs new file mode 100644 index 0000000000..827170a2f0 --- /dev/null +++ b/src/commands/vtable.rs @@ -0,0 +1,16 @@ +use crate::commands::command::SinkCommandArgs; +use crate::errors::ShellError; +use crate::format::VTableView; +use crate::prelude::*; + +pub fn vtable(args: SinkCommandArgs) -> Result<(), ShellError> { + if args.input.len() > 0 { + let mut host = args.ctx.host.lock().unwrap(); + let view = VTableView::from_list(&args.input); + if let Some(view) = view { + handle_unexpected(&mut *host, |host| crate::format::print_view(&view, host)); + } + } + + Ok(()) +} diff --git a/src/commands/where_.rs b/src/commands/where_.rs index 45ac0c7fef..045c6f7df6 100644 --- a/src/commands/where_.rs +++ b/src/commands/where_.rs @@ -25,8 +25,12 @@ impl Command for Where { } pub fn r#where(args: CommandArgs) -> Result { - if args.positional.is_empty() { - return Err(ShellError::string("select requires a field")); + if args.positional.len() == 0 { + return Err(ShellError::maybe_labeled_error( + "Where requires a condition", + "needs condition", + args.name_span, + )); } let block = args.positional[0].as_block()?; diff --git a/src/context.rs b/src/context.rs index ff571369d4..931190acad 100644 --- a/src/context.rs +++ b/src/context.rs @@ -13,16 +13,18 @@ pub struct Context { commands: IndexMap>, sinks: IndexMap>, crate host: Arc>, - crate env: Arc>>, + crate env: Arc>>, } impl Context { crate fn basic() -> Result> { + let mut env = VecDeque::new(); + env.push_back(Environment::basic()?); Ok(Context { commands: indexmap::IndexMap::new(), sinks: indexmap::IndexMap::new(), host: Arc::new(Mutex::new(crate::env::host::BasicHost)), - env: Arc::new(Mutex::new(vec![Environment::basic()?])), + env: Arc::new(Mutex::new(env)), }) } diff --git a/src/errors.rs b/src/errors.rs index ddf45f4cd9..520a2633d7 100644 --- a/src/errors.rs +++ b/src/errors.rs @@ -53,6 +53,20 @@ impl ShellError { ) } + crate fn maybe_labeled_error( + msg: impl Into, + label: impl Into, + span: Option, + ) -> ShellError { + match span { + Some(span) => ShellError::diagnostic( + Diagnostic::new(Severity::Error, msg.into()) + .with_label(Label::new_primary(span).with_message(label.into())), + ), + None => ShellError::string(msg), + } + } + crate fn string(title: impl Into) -> ShellError { ShellError::String(StringError::new(title.into(), Value::nothing())) } diff --git a/src/format.rs b/src/format.rs index 9215c18824..53df2db863 100644 --- a/src/format.rs +++ b/src/format.rs @@ -3,6 +3,7 @@ crate mod generic; crate mod list; crate mod table; crate mod tree; +crate mod vtable; use crate::prelude::*; @@ -10,6 +11,7 @@ crate use entries::EntriesView; crate use generic::GenericView; crate use table::TableView; crate use tree::TreeView; +crate use vtable::VTableView; crate trait RenderView { fn render_view(&self, host: &mut dyn Host) -> Result<(), ShellError>; diff --git a/src/format/table.rs b/src/format/table.rs index a1530f0922..8a62b53a0c 100644 --- a/src/format/table.rs +++ b/src/format/table.rs @@ -6,11 +6,6 @@ use prettytable::format::{FormatBuilder, LinePosition, LineSeparator}; use prettytable::{color, Attr, Cell, Row, Table}; -// An entries list is printed like this: -// -// name : ... -// name2 : ... -// another_name : ... #[derive(new)] pub struct TableView { headers: Vec, diff --git a/src/format/vtable.rs b/src/format/vtable.rs new file mode 100644 index 0000000000..86ddd62df7 --- /dev/null +++ b/src/format/vtable.rs @@ -0,0 +1,84 @@ +use crate::format::RenderView; +use crate::object::{DescriptorName, Value}; +use crate::prelude::*; +use derive_new::new; +use prettytable::format::{FormatBuilder, LinePosition, LineSeparator}; + +use prettytable::{color, Attr, Cell, Row, Table}; + +#[derive(new)] +pub struct VTableView { + entries: Vec>, +} + +impl VTableView { + pub fn from_list(values: &[Value]) -> Option { + if values.len() == 0 { + return None; + } + + let item = &values[0]; + let headers = item.data_descriptors(); + + if headers.len() == 0 { + return None; + } + + let mut entries = vec![]; + + for header in headers { + let mut row = vec![]; + + if let DescriptorName::String(s) = &header.name { + row.push(s.clone()); + } else { + row.push("value".to_string()); + } + for value in values { + row.push(value.get_data(&header).borrow().format_leaf(Some(&header))); + } + entries.push(row); + } + + Some(VTableView { entries }) + } +} + +impl RenderView for VTableView { + fn render_view(&self, host: &mut dyn Host) -> Result<(), ShellError> { + if self.entries.len() == 0 { + return Ok(()); + } + + let mut table = Table::new(); + + let fb = FormatBuilder::new() + .separator(LinePosition::Top, LineSeparator::new('-', '+', ' ', ' ')) + .separator(LinePosition::Bottom, LineSeparator::new('-', '+', ' ', ' ')) + .column_separator('|') + .padding(1, 1); + + table.set_format(fb.build()); + + for row in &self.entries { + table.add_row(Row::new( + row.iter() + .enumerate() + .map(|(idx, h)| { + if idx == 0 { + Cell::new(h) + .with_style(Attr::ForegroundColor(color::GREEN)) + .with_style(Attr::Bold) + } else { + Cell::new(h) + } + }) + .collect(), + )); + } + + table.print_term(&mut *host.out_terminal()).unwrap(); + + Ok(()) + } +} diff --git a/src/object/base.rs b/src/object/base.rs index 506de9e8d4..d9a531387c 100644 --- a/src/object/base.rs +++ b/src/object/base.rs @@ -291,7 +291,12 @@ impl Value { crate fn as_string(&self) -> Result { match self { - Value::Primitive(Primitive::String(s)) => Ok(s.clone()), + Value::Primitive(Primitive::String(x)) => Ok(format!("{}", x)), + Value::Primitive(Primitive::Boolean(x)) => Ok(format!("{}", x)), + Value::Primitive(Primitive::Float(x)) => Ok(format!("{}", x.into_inner())), + Value::Primitive(Primitive::Int(x)) => Ok(format!("{}", x)), + Value::Primitive(Primitive::Bytes(x)) => Ok(format!("{}", x)), + //Value::Primitive(Primitive::String(s)) => Ok(s.clone()), // TODO: this should definitely be more general with better errors other => Err(ShellError::string(format!( "Expected string, got {:?}", diff --git a/src/parser/ast/expression.rs b/src/parser/ast/expression.rs index d3c72c0681..8eb35be6fe 100644 --- a/src/parser/ast/expression.rs +++ b/src/parser/ast/expression.rs @@ -383,7 +383,16 @@ impl Leaf { fn as_external_arg(&self) -> String { match self { - Leaf::String(s) => format!("\"{}\"", s), + Leaf::String(s) => { + #[cfg(windows)] + { + format!("{}", s) + } + #[cfg(not(windows))] + { + format!("\"{}\"", s) + } + } Leaf::Bare(path) => format!("{}", path.to_string()), Leaf::Boolean(b) => format!("{}", b), Leaf::Int(i) => format!("{}", i), diff --git a/tests/enter.out b/tests/enter.out new file mode 100644 index 0000000000..10a6a46d7a --- /dev/null +++ b/tests/enter.out @@ -0,0 +1 @@ +markup diff --git a/tests/enter.txt b/tests/enter.txt new file mode 100644 index 0000000000..98dc1b2373 --- /dev/null +++ b/tests/enter.txt @@ -0,0 +1,10 @@ +cd tests +enter test.json +cd glossary +cd GlossDiv +cd GlossList +cd GlossEntry +cd GlossSee +ls | echo $it +exit +exit diff --git a/tests/external_num.out b/tests/external_num.out new file mode 100644 index 0000000000..f599e28b8a --- /dev/null +++ b/tests/external_num.out @@ -0,0 +1 @@ +10 diff --git a/tests/external_num.txt b/tests/external_num.txt new file mode 100644 index 0000000000..b7a3d149dd --- /dev/null +++ b/tests/external_num.txt @@ -0,0 +1,3 @@ +cd tests +open test.json | get glossary.GlossDiv.GlossList.GlossEntry.Height | echo $it +exit diff --git a/tests/lines.out b/tests/lines.out new file mode 100644 index 0000000000..9abbdf551d --- /dev/null +++ b/tests/lines.out @@ -0,0 +1 @@ +rustyline diff --git a/tests/lines.txt b/tests/lines.txt new file mode 100644 index 0000000000..0fbcac891c --- /dev/null +++ b/tests/lines.txt @@ -0,0 +1,3 @@ +cd tests +open test.toml --raw | lines | skip-while $it != "[dependencies]" | skip 1 | first 1 | split-column "=" | get Column1 | trim | echo $it +exit diff --git a/tests/open_ini.out b/tests/open_ini.out new file mode 100644 index 0000000000..81c545efeb --- /dev/null +++ b/tests/open_ini.out @@ -0,0 +1 @@ +1234 diff --git a/tests/open_ini.txt b/tests/open_ini.txt new file mode 100644 index 0000000000..ebb8dd5b4c --- /dev/null +++ b/tests/open_ini.txt @@ -0,0 +1,3 @@ +cd tests +open test.ini | get SectionOne.integer | echo $it +exit diff --git a/tests/test.ini b/tests/test.ini new file mode 100644 index 0000000000..7abedd96b3 --- /dev/null +++ b/tests/test.ini @@ -0,0 +1,19 @@ +[SectionOne] + +key = value +integer = 1234 +real = 3.14 +string1 = 'Case 1' +string2 = "Case 2" + +[SectionTwo] + +; comment line +key = new value +integer = 1234 +real = 3.14 +string1 = 'Case 1' +string2 = "Case 2" +string3 = 'Case 3' + + diff --git a/tests/test.json b/tests/test.json index d5ca56d195..8feebaa0ab 100644 --- a/tests/test.json +++ b/tests/test.json @@ -1,20 +1,24 @@ { "glossary": { "title": "example glossary", - "GlossDiv": { + "GlossDiv": { "title": "S", - "GlossList": { + "GlossList": { "GlossEntry": { "ID": "SGML", - "SortAs": "SGML", - "GlossTerm": "Standard Generalized Markup Language", - "Acronym": "SGML", - "Abbrev": "ISO 8879:1986", - "GlossDef": { + "SortAs": "SGML", + "GlossTerm": "Standard Generalized Markup Language", + "Acronym": "SGML", + "Abbrev": "ISO 8879:1986", + "Height": 10, + "GlossDef": { "para": "A meta-markup language, used to create markup languages such as DocBook.", - "GlossSeeAlso": ["GML", "XML"] + "GlossSeeAlso": [ + "GML", + "XML" + ] }, - "GlossSee": "markup" + "GlossSee": "markup" } } } diff --git a/tests/tests.rs b/tests/tests.rs index 3a1c19c006..802eea0a5a 100644 --- a/tests/tests.rs +++ b/tests/tests.rs @@ -1,9 +1,9 @@ #[cfg(test)] mod tests { - use std::path::PathBuf; - use std::io::prelude::*; - use std::process::{Command, Stdio}; use std::error::Error; + use std::io::prelude::*; + use std::path::PathBuf; + use std::process::{Command, Stdio}; fn test_helper(test_name: &str) { let mut baseline_path = PathBuf::new(); @@ -27,10 +27,10 @@ mod tests { let process = match Command::new(executable) .stdin(Stdio::piped()) .stdout(Stdio::piped()) - .spawn() { - + .spawn() + { Ok(process) => process, - Err(why) => panic!("Can't run test {}", why.description()) + Err(why) => panic!("Can't run test {}", why.description()), }; let baseline_out = std::fs::read_to_string(baseline_path).unwrap(); @@ -38,15 +38,13 @@ mod tests { let input_commands = std::fs::read_to_string(txt_path).unwrap(); match process.stdin.unwrap().write_all(input_commands.as_bytes()) { - Err(why) => panic!("couldn't write to wc stdin: {}", - why.description()), - Ok(_) => {}, + Err(why) => panic!("couldn't write to wc stdin: {}", why.description()), + Ok(_) => {} } let mut s = String::new(); match process.stdout.unwrap().read_to_string(&mut s) { - Err(why) => panic!("couldn't read stdout: {}", - why.description()), + Err(why) => panic!("couldn't read stdout: {}", why.description()), Ok(_) => { let s = s.replace("\r\n", "\n"); assert_eq!(s, baseline_out); @@ -69,6 +67,11 @@ mod tests { test_helper("open_xml"); } + #[test] + fn open_ini() { + test_helper("open_ini"); + } + #[test] fn json_roundtrip() { test_helper("json_roundtrip"); @@ -88,4 +91,20 @@ mod tests { fn split() { test_helper("split"); } + + #[test] + fn enter() { + test_helper("enter"); + } + + #[test] + fn lines() { + test_helper("lines"); + } + + + #[test] + fn external_num() { + test_helper("external_num"); + } }