Desugar away named nil in table literals
This commit is contained in:
parent
39099037a5
commit
736174d470
1 changed files with 12 additions and 2 deletions
|
|
@ -1,4 +1,4 @@
|
||||||
use crate::ast::{Lit, TableLit, TableLitElem};
|
use crate::ast::{Expr, Lit, TableLit, TableLitElem};
|
||||||
|
|
||||||
impl TableLitElem {
|
impl TableLitElem {
|
||||||
pub fn desugar(self) -> (Self, bool) {
|
pub fn desugar(self) -> (Self, bool) {
|
||||||
|
|
@ -32,7 +32,17 @@ impl TableLitElem {
|
||||||
impl TableLit {
|
impl TableLit {
|
||||||
pub fn desugar(self) -> (Self, bool) {
|
pub fn desugar(self) -> (Self, bool) {
|
||||||
let (elems, desugared) = self.0.desugar(|e| e.desugar());
|
let (elems, desugared) = self.0.desugar(|e| e.desugar());
|
||||||
(elems.table_lit(), desugared)
|
if desugared {
|
||||||
|
(elems.table_lit(), true)
|
||||||
|
} else {
|
||||||
|
let (elems, removed) = elems.remove_map(|e| match e {
|
||||||
|
TableLitElem::Named { value, .. } if matches!(*value, Expr::Lit(Lit::Nil(_))) => {
|
||||||
|
Err(())
|
||||||
|
}
|
||||||
|
e => Ok(e),
|
||||||
|
});
|
||||||
|
(elems.table_lit(), !removed.is_empty())
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue