我是Xtext的新手。我在我的dsl中使用了一个模型类:
Model abc:
variable1
variable2
并导入类:
import a.b.c
当我说导入a.b.c(这是同一目录中的java类)时,我想要做的是。编辑器必须识别这个a.b.c类并将其称为模型,如:
modelname = classname
变量名=类中的变量。
我也写了一个不同的类,它获取了模型类中变量的引用。所以,如果我在该类中说变量1并且在所有模型中没有名为variable1的变量,则会出现语法错误。它在我在dsl中编写模型类时有效,但是我无法使用我的导入类。
感谢您的帮助。
答案 0 :(得分:0)
这里可能是一个起点
grammar org.xtext.example.mydsl.MyDsl with org.eclipse.xtext.xbase.Xbase
generate myDsl "http://www.xtext.org/example/mydsl/MyDsl"
import "http://www.eclipse.org/xtext/common/JavaVMTypes" as types
Model:
imports=XImportSection?
elements+=Element*
;
Element:
"element" "{"
"modelname" "=" type=JvmTypeReference
"variable" "names" "=" memberReferences+=MemberReference ("," memberReferences+=MemberReference)*
"}"
;
MemberReference:
member=[types::JvmField|ID]
;
并遵循范围提供者
package org.xtext.example.mydsl.scoping
import org.eclipse.emf.ecore.EObject
import org.eclipse.emf.ecore.EReference
import org.eclipse.xtext.EcoreUtil2
import org.xtext.example.mydsl.myDsl.Element
import org.xtext.example.mydsl.myDsl.MyDslPackage
import org.eclipse.xtext.scoping.IScope
import org.eclipse.xtext.scoping.Scopes
import org.eclipse.xtext.common.types.JvmDeclaredType
import org.eclipse.xtext.naming.QualifiedName
class MyDslScopeProvider extends AbstractMyDslScopeProvider {
override getScope(EObject context, EReference reference) {
if (reference == MyDslPackage.Literals.MEMBER_REFERENCE__MEMBER) {
val element = EcoreUtil2.getContainerOfType(context, Element)
if (element != null) {
val type = element.type.type
if (type instanceof JvmDeclaredType) {
return Scopes.scopeFor(type.declaredFields, [QualifiedName.create(simpleName)], IScope.NULLSCOPE)
}
}
return IScope.NULLSCOPE
}
super.getScope(context, reference)
}
}
提案提供者
class MyDslProposalProvider extends AbstractMyDslProposalProvider {
override protected isKeywordWorthyToPropose(Keyword keyword) {
true
}
}