sweet.js:转换重复令牌的出现次数

时间:2016-02-05 14:03:32

标签: sweet.js

我想定义一个转换

的甜蜜宏
{ a, b } # o

{ o.a, o.b }

我目前的尝试是

macro (#) {  
  case infix { { $prop:ident (,) ... } | _ $o } => {
    return #{ { $prop: $o.$prop (,) ... } }
  }
}

然而,这给了我

SyntaxError: [patterns] Ellipses level does not match in the template

我怀疑我并不真正理解...是如何工作的,并且可能需要以某种方式循环$prop的值并为每个值构建语法对象并以某种方式连接它们,但我在关于如何做到这一点的损失。

1 个答案:

答案 0 :(得分:3)

问题是语法扩展器认为您正在尝试展开$o.$prop而不是$prop: $o.$prop。这是解决方案:

macro (#) {  
  rule infix { { $prop:ident (,) ... } | $o:ident } => {
    { $($prop: $o.$prop) (,) ... }
  }
}

请注意,我将代码单元放在自己的$()块中,以消除椭圆扩展的歧义。

示例:var x = { a, b } # o;变为var x = { a: o.a, b: o.b };