Remove the im crate dependency (#5161)

This commit is contained in:
JT 2022-04-12 07:01:05 +12:00 committed by GitHub
parent 836f914163
commit 60b5863058
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 22 additions and 67 deletions

43
Cargo.lock generated
View File

@ -262,15 +262,6 @@ version = "1.3.2"
source = "registry+https://github.com/rust-lang/crates.io-index" source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "bef38d45163c2f1dde094a7dfd33ccf595c92905c8f8f4fdc18d06fb1037718a" checksum = "bef38d45163c2f1dde094a7dfd33ccf595c92905c8f8f4fdc18d06fb1037718a"
[[package]]
name = "bitmaps"
version = "2.1.0"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "031043d04099746d8db04daf1fa424b2bc8bd69d92b25962dcde24da39ab64a2"
dependencies = [
"typenum",
]
[[package]] [[package]]
name = "bitpacking" name = "bitpacking"
version = "0.8.4" version = "0.8.4"
@ -1585,20 +1576,6 @@ dependencies = [
"unicode-normalization", "unicode-normalization",
] ]
[[package]]
name = "im"
version = "15.0.0"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "111c1983f3c5bb72732df25cddacee9b546d08325fb584b5ebd38148be7b0246"
dependencies = [
"bitmaps",
"rand_core 0.5.1",
"rand_xoshiro",
"sized-chunks",
"typenum",
"version_check 0.9.4",
]
[[package]] [[package]]
name = "indent_write" name = "indent_write"
version = "2.2.0" version = "2.2.0"
@ -2470,7 +2447,6 @@ dependencies = [
"byte-unit", "byte-unit",
"chrono", "chrono",
"chrono-humanize", "chrono-humanize",
"im",
"indexmap", "indexmap",
"miette 4.2.1", "miette 4.2.1",
"nu-json", "nu-json",
@ -3463,15 +3439,6 @@ dependencies = [
"rand_core 0.5.1", "rand_core 0.5.1",
] ]
[[package]]
name = "rand_xoshiro"
version = "0.4.0"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "a9fcdd2e881d02f1d9390ae47ad8e5696a9e4be7b547a1da2afbc61973217004"
dependencies = [
"rand_core 0.5.1",
]
[[package]] [[package]]
name = "rayon" name = "rayon"
version = "1.5.1" version = "1.5.1"
@ -4020,16 +3987,6 @@ version = "0.3.10"
source = "registry+https://github.com/rust-lang/crates.io-index" source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "7bd3e3206899af3f8b12af284fafc038cc1dc2b41d1b89dd17297221c5d225de" checksum = "7bd3e3206899af3f8b12af284fafc038cc1dc2b41d1b89dd17297221c5d225de"
[[package]]
name = "sized-chunks"
version = "0.6.5"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "16d69225bde7a69b235da73377861095455d298f2b970996eec25ddbb42b3d1e"
dependencies = [
"bitmaps",
"typenum",
]
[[package]] [[package]]
name = "slab" name = "slab"
version = "0.4.5" version = "0.4.5"

View File

@ -16,7 +16,6 @@ chrono = { version="0.4.19", features=["serde"] }
indexmap = { version="1.7", features=["serde-1"] } indexmap = { version="1.7", features=["serde-1"] }
chrono-humanize = "0.2.1" chrono-humanize = "0.2.1"
byte-unit = "4.0.9" byte-unit = "4.0.9"
im = "15.0.0"
serde_json = { version = "1.0", optional = true } serde_json = { version = "1.0", optional = true }
nu-json = { path = "../nu-json", version = "0.60.1" } nu-json = { path = "../nu-json", version = "0.60.1" }
typetag = "0.1.8" typetag = "0.1.8"

View File

@ -166,16 +166,16 @@ impl Default for ScopeFrame {
/// ///
#[derive(Clone)] #[derive(Clone)]
pub struct EngineState { pub struct EngineState {
files: im::Vector<(String, usize, usize)>, files: Vec<(String, usize, usize)>,
file_contents: im::Vector<(Vec<u8>, usize, usize)>, file_contents: Vec<(Vec<u8>, usize, usize)>,
vars: im::Vector<Variable>, vars: Vec<Variable>,
decls: im::Vector<Box<dyn Command + 'static>>, decls: Vec<Box<dyn Command + 'static>>,
aliases: im::Vector<Vec<Span>>, aliases: Vec<Vec<Span>>,
blocks: im::Vector<Block>, blocks: Vec<Block>,
overlays: im::Vector<Overlay>, overlays: Vec<Overlay>,
pub scope: im::Vector<ScopeFrame>, pub scope: Vec<ScopeFrame>,
pub ctrlc: Option<Arc<AtomicBool>>, pub ctrlc: Option<Arc<AtomicBool>>,
pub env_vars: im::HashMap<String, Value>, pub env_vars: HashMap<String, Value>,
#[cfg(feature = "plugin")] #[cfg(feature = "plugin")]
pub plugin_signatures: Option<PathBuf>, pub plugin_signatures: Option<PathBuf>,
} }
@ -189,22 +189,22 @@ pub const ENV_VARIABLE_ID: usize = 3;
impl EngineState { impl EngineState {
pub fn new() -> Self { pub fn new() -> Self {
Self { Self {
files: im::vector![], files: vec![],
file_contents: im::vector![], file_contents: vec![],
vars: im::vector![ vars: vec![
Variable::new(Span::new(0, 0), Type::Any),
Variable::new(Span::new(0, 0), Type::Any), Variable::new(Span::new(0, 0), Type::Any),
Variable::new(Span::new(0, 0), Type::Any), Variable::new(Span::new(0, 0), Type::Any),
Variable::new(Span::new(0, 0), Type::Any), Variable::new(Span::new(0, 0), Type::Any),
Variable::new(Span::new(0, 0), Type::Any), Variable::new(Span::new(0, 0), Type::Any),
Variable::new(Span::new(0, 0), Type::Any)
], ],
decls: im::vector![], decls: vec![],
aliases: im::vector![], aliases: vec![],
blocks: im::vector![], blocks: vec![],
overlays: im::vector![], overlays: vec![],
scope: im::vector![ScopeFrame::new()], scope: vec![ScopeFrame::new()],
ctrlc: None, ctrlc: None,
env_vars: im::HashMap::new(), env_vars: HashMap::new(),
#[cfg(feature = "plugin")] #[cfg(feature = "plugin")]
plugin_signatures: None, plugin_signatures: None,
} }
@ -232,7 +232,7 @@ impl EngineState {
self.blocks.extend(delta.blocks); self.blocks.extend(delta.blocks);
self.overlays.extend(delta.overlays); self.overlays.extend(delta.overlays);
if let Some(last) = self.scope.back_mut() { if let Some(last) = self.scope.last_mut() {
let first = delta.scope.remove(0); let first = delta.scope.remove(0);
for item in first.decls.into_iter() { for item in first.decls.into_iter() {
last.decls.insert(item.0, item.1); last.decls.insert(item.0, item.1);
@ -610,10 +610,9 @@ impl EngineState {
let next_span_end = next_span_start + contents.len(); let next_span_end = next_span_start + contents.len();
self.file_contents self.file_contents
.push_back((contents, next_span_start, next_span_end)); .push((contents, next_span_start, next_span_end));
self.files self.files.push((filename, next_span_start, next_span_end));
.push_back((filename, next_span_start, next_span_end));
self.num_files() - 1 self.num_files() - 1
} }