我正在尝试创建一个自定义运算符,它是点(成员访问)运算符的同义词,这样会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 => ...)
还是我错了?