3

非常に特殊な乗算演算子が必要だとします。次のマクロで実装できます。

macro @<<!(op1, op2)
{
    <[ ( $op1 * $op2 ) ]>
}

そして、私はそれを次のように使うことができます

def val = 2 <<! 3

そしてその仕事。

しかし、私が本当に望んでいるのは、現在開発中のDSLIm用の「英語」のような演算子です。

macro @multiply(op1, op2)
{
    <[ ( $op1 * $op2 ) ]>
}

そして私がそれを次のように使おうとすると

def val = 2 multiply 3

コンパイラは'expected;'で失敗します エラー

何が問題ですか?この中置形式のマクロを実装するにはどうすればよいですか?

4

2 に答える 2

7

コンパイラのソースコードから直接:

namespace Nemerle.English
{
  [assembly: Nemerle.Internal.OperatorAttribute ("Nemerle.English", "and", false, 160, 161)]
  [assembly: Nemerle.Internal.OperatorAttribute ("Nemerle.English", "or", false, 150, 151)]
  [assembly: Nemerle.Internal.OperatorAttribute ("Nemerle.English", "not", true, 181, 180)]  

  macro @and (e1, e2) {
    <[ $e1 && $e2 ]>
  }

  macro @or (e1, e2) {
    <[ $e1 || $e2 ]>
  }

  macro @not (e) {
    <[ ! $e ]>
  }

OperatorAttributes を振りかける必要があり、それは機能します。ちなみに、OperatorAttribute は次のように定義されています。

public class OperatorAttribute : NemerleAttribute
{
  public mutable env : string;
  public mutable name : string;
  public mutable IsUnary : bool;
  public mutable left : int;
  public mutable right : int;
}
于 2008-10-21T21:48:38.353 に答える
1

いつものように、私はコミュニティの応答よりも早く答えを見つけました:)したがって、解決策は、マクロを二項演算子として指定する特別なアセンブリレベル属性を単に使用することです:

namespace TestMacroLib
{
  [assembly: Nemerle.Internal.OperatorAttribute ("TestMacroLib", "multiply", false, 160, 161)]
  public macro multiply(op1, op2)
  {
    <[ ( $op1 * $op2 ) ]>
  }
}
于 2008-10-21T21:49:40.860 に答える