feat: hashmap with_capacity
This commit is contained in:
@@ -38,7 +38,7 @@ pub enum OpCode {
|
||||
JmpIfFalse { step: usize },
|
||||
|
||||
/// push an empty attribute set onto stack
|
||||
AttrSet,
|
||||
AttrSet { cap: usize },
|
||||
/// finalize the recursive attribute set at TOS
|
||||
FinalizeRec,
|
||||
/// [ .. set value ] consume 1 element, push a static kv pair (`name`, `value`) into `set`
|
||||
|
||||
@@ -97,7 +97,7 @@ impl Compile for ir::Thunk {
|
||||
|
||||
impl Compile for ir::Attrs {
|
||||
fn compile(self, comp: &mut Compiler) {
|
||||
comp.push(OpCode::AttrSet);
|
||||
comp.push(OpCode::AttrSet { cap: self.stcs.len() + self.dyns.len() });
|
||||
for stc in self.stcs {
|
||||
stc.1.compile(comp);
|
||||
if !self.rec {
|
||||
@@ -250,17 +250,17 @@ impl Compile for ir::HasAttr {
|
||||
for attr in self.rhs {
|
||||
match attr {
|
||||
ir::Attr::Str(sym) => {
|
||||
comp.push(OpCode::AttrSet);
|
||||
comp.push(OpCode::AttrSet { cap: 0 });
|
||||
comp.push(OpCode::SelectOrDefault { sym })
|
||||
}
|
||||
ir::Attr::Dynamic(dynamic) => {
|
||||
dynamic.compile(comp);
|
||||
comp.push(OpCode::AttrSet);
|
||||
comp.push(OpCode::AttrSet { cap: 0 });
|
||||
comp.push(OpCode::SelectDynamicOrDefault);
|
||||
}
|
||||
ir::Attr::Strs(string) => {
|
||||
string.compile(comp);
|
||||
comp.push(OpCode::AttrSet);
|
||||
comp.push(OpCode::AttrSet { cap: 0 });
|
||||
comp.push(OpCode::SelectDynamicOrDefault);
|
||||
}
|
||||
}
|
||||
@@ -281,17 +281,17 @@ impl Compile for ir::Select {
|
||||
for attr in self.attrpath {
|
||||
match attr {
|
||||
ir::Attr::Str(sym) => {
|
||||
comp.push(OpCode::AttrSet);
|
||||
comp.push(OpCode::AttrSet { cap: 0 });
|
||||
comp.push(OpCode::SelectOrDefault { sym })
|
||||
}
|
||||
ir::Attr::Dynamic(dynamic) => {
|
||||
dynamic.compile(comp);
|
||||
comp.push(OpCode::AttrSet);
|
||||
comp.push(OpCode::AttrSet { cap: 0 });
|
||||
comp.push(OpCode::SelectDynamicOrDefault);
|
||||
}
|
||||
ir::Attr::Strs(string) => {
|
||||
string.compile(comp);
|
||||
comp.push(OpCode::AttrSet);
|
||||
comp.push(OpCode::AttrSet { cap: 0 });
|
||||
comp.push(OpCode::SelectDynamicOrDefault);
|
||||
}
|
||||
}
|
||||
|
||||
@@ -1,3 +1,5 @@
|
||||
use std::hash::Hash;
|
||||
|
||||
use hashbrown::{HashMap, HashSet};
|
||||
|
||||
use derive_more::Constructor;
|
||||
@@ -22,6 +24,10 @@ impl<'vm> AttrSet<'vm> {
|
||||
}
|
||||
}
|
||||
|
||||
pub fn with_capacity(cap: usize) -> Self {
|
||||
AttrSet { data: HashMap::with_capacity(cap) }
|
||||
}
|
||||
|
||||
pub fn push_attr_force(&mut self, sym: usize, val: Value<'vm>) {
|
||||
self.data.insert(sym, val);
|
||||
}
|
||||
|
||||
@@ -182,8 +182,8 @@ impl<'vm, 'jit: 'vm> VM<'jit> {
|
||||
let elem = stack.pop();
|
||||
stack.tos_mut()?.push(elem);
|
||||
}
|
||||
OpCode::AttrSet => {
|
||||
stack.push(Value::AttrSet(AttrSet::empty().into()))?;
|
||||
OpCode::AttrSet { cap } => {
|
||||
stack.push(Value::AttrSet(AttrSet::with_capacity(cap).into()))?;
|
||||
}
|
||||
OpCode::FinalizeRec => {
|
||||
let env = env.clone().enter(
|
||||
|
||||
Reference in New Issue
Block a user