reduce allocations for @if
This commit is contained in:
parent
33f81f5bbe
commit
aa209702d2
103
src/parse/mod.rs
103
src/parse/mod.rs
@ -543,17 +543,30 @@ impl<'a> Parser<'a> {
|
||||
Some(t) => t.pos,
|
||||
None => return Err(("Expected expression.", self.span_before).into()),
|
||||
};
|
||||
|
||||
if self.toks.peek().is_none() {
|
||||
return Err(("expected \"}\".", span_before).into());
|
||||
}
|
||||
|
||||
self.whitespace_or_comment();
|
||||
|
||||
if self.parse_value_from_vec(init_cond_toks)?.is_true() {
|
||||
found_true = true;
|
||||
let mut init_toks = read_until_closing_curly_brace(self.toks)?;
|
||||
if let Some(tok) = self.toks.next() {
|
||||
init_toks.push(tok);
|
||||
} else {
|
||||
return Err(("expected \"}\".", span_before).into());
|
||||
body = Parser {
|
||||
toks: self.toks,
|
||||
map: self.map,
|
||||
path: self.path,
|
||||
scopes: self.scopes,
|
||||
global_scope: self.global_scope,
|
||||
super_selectors: self.super_selectors,
|
||||
span_before: self.span_before,
|
||||
content: self.content,
|
||||
flags: self.flags | ContextFlags::IN_CONTROL_FLOW,
|
||||
at_root: self.at_root,
|
||||
at_root_has_selector: self.at_root_has_selector,
|
||||
extender: self.extender,
|
||||
}
|
||||
body = init_toks;
|
||||
.parse_stmt()?;
|
||||
} else {
|
||||
self.throw_away_until_closing_curly_brace();
|
||||
}
|
||||
@ -572,7 +585,7 @@ impl<'a> Parser<'a> {
|
||||
} else {
|
||||
break;
|
||||
}
|
||||
self.whitespace();
|
||||
self.whitespace_or_comment();
|
||||
if let Some(tok) = self.toks.peek().cloned() {
|
||||
match tok.kind {
|
||||
'i' if matches!(
|
||||
@ -587,38 +600,8 @@ impl<'a> Parser<'a> {
|
||||
self.toks.next();
|
||||
if !found_true && self.parse_value_from_vec(cond)?.is_true() {
|
||||
found_true = true;
|
||||
body = read_until_closing_curly_brace(self.toks)?;
|
||||
// todo: ensure there is a `{`
|
||||
self.toks.next();
|
||||
} else {
|
||||
self.throw_away_until_closing_curly_brace();
|
||||
}
|
||||
self.whitespace();
|
||||
}
|
||||
'{' => {
|
||||
self.toks.next();
|
||||
if found_true {
|
||||
self.throw_away_until_closing_curly_brace();
|
||||
} else {
|
||||
found_true = true;
|
||||
body = read_until_closing_curly_brace(self.toks)?;
|
||||
self.toks.next();
|
||||
}
|
||||
break;
|
||||
}
|
||||
_ => {
|
||||
return Err(("expected \"{\".", tok.pos()).into());
|
||||
}
|
||||
}
|
||||
} else {
|
||||
break;
|
||||
}
|
||||
}
|
||||
self.whitespace();
|
||||
|
||||
if found_true {
|
||||
Parser {
|
||||
toks: &mut body.into_iter().peekmore(),
|
||||
body = Parser {
|
||||
toks: self.toks,
|
||||
map: self.map,
|
||||
path: self.path,
|
||||
scopes: self.scopes,
|
||||
@ -631,10 +614,48 @@ impl<'a> Parser<'a> {
|
||||
at_root_has_selector: self.at_root_has_selector,
|
||||
extender: self.extender,
|
||||
}
|
||||
.parse()
|
||||
.parse_stmt()?;
|
||||
// todo: ensure there is a `{`
|
||||
self.toks.next();
|
||||
} else {
|
||||
Ok(Vec::new())
|
||||
self.throw_away_until_closing_curly_brace();
|
||||
}
|
||||
self.whitespace();
|
||||
}
|
||||
'{' => {
|
||||
self.toks.next();
|
||||
if found_true {
|
||||
self.throw_away_until_closing_curly_brace();
|
||||
break;
|
||||
} else {
|
||||
return Parser {
|
||||
toks: self.toks,
|
||||
map: self.map,
|
||||
path: self.path,
|
||||
scopes: self.scopes,
|
||||
global_scope: self.global_scope,
|
||||
super_selectors: self.super_selectors,
|
||||
span_before: self.span_before,
|
||||
content: self.content,
|
||||
flags: self.flags | ContextFlags::IN_CONTROL_FLOW,
|
||||
at_root: self.at_root,
|
||||
at_root_has_selector: self.at_root_has_selector,
|
||||
extender: self.extender,
|
||||
}
|
||||
.parse_stmt();
|
||||
}
|
||||
}
|
||||
_ => {
|
||||
return Err(("expected \"{\".", tok.pos()).into());
|
||||
}
|
||||
}
|
||||
} else {
|
||||
break;
|
||||
}
|
||||
}
|
||||
self.whitespace();
|
||||
|
||||
Ok(body)
|
||||
}
|
||||
|
||||
fn parse_for(&mut self) -> SassResult<Vec<Stmt>> {
|
||||
|
Loading…
x
Reference in New Issue
Block a user