1

我正在尝试创建一个自定义运算符,它是点(成员访问)运算符的同义词,这样会a>>=b导致a.b.

我的第一次尝试没有编译

operator >>= left 19 = (left, right) => {
    return #`${left}.${right}]`;
};

如果我在 return 语句中更改.&&那么它会编译。

由于以前的方法行不通,我尝试使用计算成员访问:

operator >>= left 19 = (left, right) => {
  let r = right.name.token.value; // string representation of an identifier
  let dummy = #`dummy`.get(0);
  return #`${left} [${fromStringLiteral(dummy, r)}]`;
};

这种方法可以编译简单的表达式,例如a>>=b,但不是 for a>>=b.then(res => ...),因为right现在是一个调用表达式:b.then(...),我不明白,因为我为我的自定义运算符选择了 19 的优先级,这也是[]概念上的优先级,这意味着我的表达式应该等于(a>>b).then(res => ...)还是我错了?

4

0 回答 0