forked from extern/nushell
Remove the im crate dependency (#5161)
This commit is contained in:
parent
836f914163
commit
60b5863058
43
Cargo.lock
generated
43
Cargo.lock
generated
@ -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"
|
||||||
|
@ -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"
|
||||||
|
@ -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
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user