As soon as a DSL introduces more involved features, such as nested blocks or inheritance relations, the scope provider must be customized according to the semantics of the language.
The Xtext generator generates an Xtend stub class for implementing a custom scope provider. In the SmallJava DSL it is SmallJavaScopeProvider
.
One way of customizing the scope provider is to redefine the method getScope
; this requires you to manually check the reference and the context's class, for example:
override getScope(EObject context, EReference reference) { if (reference == SmallJavaPackage::eINSTANCE.SJSymbolRef_Symbol) { if (context instanceof ...) ... } else if (reference == SmallJavaPackage::eINSTANCE.SJMemberSelection_Member) { ... } else { super.getScope(context, reference) } }
Xtext provides an easier declarative way of customizing the scope that reflects the mechanisms for customizations as we have seen in Chapter 6, Customizations, using a convention...