1

以下は私のDSLのXtext文法です。

Model:
  variableTypes=VariableTypes predicateTypes=PredicateTypes variableDeclarations=
  VariableDeclarations rules=Rules;

VariableType:
  name=ID;

VariableTypes:
  'var types' (variableTypes+=VariableType)+;

PredicateTypes:
  'predicate types' (predicateTypes+=PredicateType)+;

PredicateType:
  name=ID '(' (variableTypes+=[VariableType|ID])+ ')';

VariableDeclarations:
  'vars' (variableDeclarations+=VariableDeclaration)+;

VariableDeclaration:
  name=ID ':' type=[VariableType|ID];

Rules:
  'rules' (rules+=Rule)+;

Rule:
  head=Head ':-' body=Body;

Head:
  predicate=Predicate;

Body:
  (predicates+=Predicate)+;

Predicate:
  predicateType=[PredicateType|ID] '(' (terms+=Term)+ ')';

Term:
  variable=Variable;

Variable:
  variableDeclaration=[VariableDeclaration|ID];

terminal WS:
  (' ' | '\t' | '\r' | '\n' | ',')+;

そして、以下は上記DSLのプログラムです。

var types
  Node

predicate types
  Edge(Node, Node)
  Path(Node, Node)

vars
  x : Node
  y : Node
  z : Node

rules
  Path(x, y) :- Edge(x, y)
  Path(x, y) :- Path(x, z) Path(z, y)

以下は、生成されたクラスのサブクラスであり、ノードでnullを返すSwitchことを示しています。getPredicateType()Predicate

public class ModelPrinter extends MyDSLSwitch<Object> {

    protected Object visitChildren(EObject object) {
        for (EObject eobj : object.eContents()) {
            doSwitch(eobj);
        }   
        return object;
    }

    @Override
    public Object casePredicate(Predicate object) {
        System.out.println(object.getPredicateType());
        return object;
    }

    @Override
    public Object defaultCase(EObject object) {
        return visitChildren(object);
    }

}

このクラスを使用しModelPrinterて、上記のプログラムに対応するEMFオブジェクトモデルをトラバースすると、ノードが適切にリンクされていないことに気付きました。たとえば、ノードのgetPredicateType()メソッドはを返します。Xtextユーザーガイドを読んだ後、私の印象では、Xtextのデフォルトのリンクセマンティクスは私のDSLで機能するはずです。しかし、何らかの理由で、DSLのASTノードが適切にリンクされていません。誰かがこの問題を診断するのを手伝ってくれますか?Predicatenull

4

2 に答える 2

1

最後に、私は問題を理解しました。モデルを正しくロードしていなかったため、リンクが正しく設定されていませんでした。モデルをロードするためにパーサーを使用したところです。だから、私はリンクを取得できませんでした。したがって、 Xtext FAQの次のコードスニペットを使用して、モデルを正しくロードしました。次に、返されたモデルをスイッチクラスに渡しました。

// "workspace" is a string that contains the path to the workspace containing the DSL program.
new org.eclipse.emf.mwe.utils.StandaloneSetup().setPlatformUri(workspace);

Injector injector = new MyDslStandaloneSetup().createInjectorAndDoEMFRegistration();
XtextResourceSet resourceSet = injector.getInstance(XtextResourceSet.class);
resourceSet.addLoadOption(XtextResource.OPTION_RESOLVE_ALL, Boolean.TRUE);

// "DSLProgram" is a string that contains the path to the file of the DSL program relative to the workspace set above.
Resource resource = resourceSet.getResource(URI.createURI("platform:/resource/" + DSLProgram), true);
Model model = (Model) resource.getContents().get(0);
于 2010-05-02T22:34:57.053 に答える
0

私はそれを試しましたが、Switchに精通していません。むしろ、Xpand / Xtendを使用してPredicateからpredicateTypesにアクセスし、それらの名前を生成しました。

Template.xpt:

«インポートmyDsl»;

«モデルのメインを定義-»
«ファイル"output.txt"-»
«FOREACHthis.rules.rules.body.last()。predicatesASp-»
«p.predicateType.name»
«ENDFOREACH-»
«ENDFILE-»
«ENDDEFINE»

およびoutput.txt:

道
道

これは予想される動作だと思います。

于 2010-05-01T23:27:30.523 に答える