本文整理匯總了Java中org.eclipse.xtext.nodemodel.INode.getSemanticElement方法的典型用法代碼示例。如果您正苦於以下問題:Java INode.getSemanticElement方法的具體用法?Java INode.getSemanticElement怎麽用?Java INode.getSemanticElement使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類org.eclipse.xtext.nodemodel.INode
的用法示例。
在下文中一共展示了INode.getSemanticElement方法的3個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。
示例1: handleLastCompleteNodeIsAtEndOfDatatypeNode
import org.eclipse.xtext.nodemodel.INode; //導入方法依賴的package包/類
@Override
protected void handleLastCompleteNodeIsAtEndOfDatatypeNode() {
String prefix = getPrefix(lastCompleteNode);
INode previousNode = getLastCompleteNodeByOffset(rootNode, lastCompleteNode.getOffset());
EObject previousModel = previousNode.getSemanticElement();
INode currentDatatypeNode = getContainingDatatypeRuleNode(currentNode);
Collection<FollowElement> followElements = getParser().getFollowElements(rootNode, 0,
lastCompleteNode.getOffset(), true);
int prevSize = contextBuilders.size();
doCreateContexts(previousNode, currentDatatypeNode, prefix, previousModel, followElements);
if (lastCompleteNode instanceof ILeafNode && lastCompleteNode.getGrammarElement() == null
&& contextBuilders.size() != prevSize) {
handleLastCompleteNodeHasNoGrammarElement(contextBuilders.subList(prevSize, contextBuilders.size()),
previousModel);
}
}
示例2: filterLeafsWithKeywordInsteadOfComma
import org.eclipse.xtext.nodemodel.INode; //導入方法依賴的package包/類
/**
* Returns nodes which represent keywords and specified in keywords.
*
* @param keywords
* keywords in natural order used in Arrays#s
*/
protected List<ILeafNode> filterLeafsWithKeywordInsteadOfComma(EObject semanticElement, String stopAtKeyword,
ICompositeNode node,
final String... keywords) {
List<ILeafNode> filteredLeaves = null;
for (BidiTreeIterator<INode> iter = node.getAsTreeIterable().iterator(); iter.hasNext();) {
INode child = iter.next();
EObject childSemElement = child.getSemanticElement();
if (child != node && childSemElement != null && childSemElement != semanticElement) {
iter.prune();
} else if (child instanceof ILeafNode) {
ILeafNode leaf = (ILeafNode) child;
EObject grammarElement = leaf.getGrammarElement();
if (grammarElement instanceof Keyword) {
String value = ((Keyword) grammarElement).getValue();
if (stopAtKeyword.equals(value)) {
break;
}
if (Arrays.binarySearch(keywords, value) >= 0) {
if (grammarElement.eContainer() instanceof Alternatives) {
AbstractElement first = ((Alternatives) (grammarElement.eContainer())).getElements().get(0);
boolean inCommaAlternative = (first instanceof Keyword && ",".equals(((Keyword) first)
.getValue()));
if (inCommaAlternative) {
if (filteredLeaves == null) {
filteredLeaves = new ArrayList<>(5);
}
filteredLeaves.add(leaf);
}
}
}
}
}
}
return filteredLeaves == null ? Collections.emptyList() : filteredLeaves;
}
示例3: doFindLeafWithKeyword
import org.eclipse.xtext.nodemodel.INode; //導入方法依賴的package包/類
/**
* Returns the first keyword with the given value, or null if no such keyword is found.
*/
private ILeafNode doFindLeafWithKeyword(EObject semanticElement, String stopAtKeyword, ICompositeNode node,
String keyWord,
boolean commaAlternative, int hitNumber) {
EObject grammarElement;
int foundHits = 0;
for (BidiTreeIterator<INode> iter = node.getAsTreeIterable().iterator(); iter.hasNext();) {
INode child = iter.next();
EObject childSemElement = child.getSemanticElement();
if (child != node && childSemElement != null && childSemElement != semanticElement) {
iter.prune();
} else if (child instanceof ILeafNode) {
ILeafNode leaf = (ILeafNode) child;
grammarElement = leaf.getGrammarElement();
if (grammarElement instanceof Keyword) {
String value = ((Keyword) grammarElement).getValue();
if (stopAtKeyword.equals(value)) {
return null;
}
if (keyWord.equals(value)) {
if (grammarElement.eContainer() instanceof Alternatives) {
AbstractElement first = ((Alternatives) (grammarElement.eContainer())).getElements().get(0);
boolean inCommaAlternative = (first instanceof Keyword && ",".equals(((Keyword) first)
.getValue()));
if (inCommaAlternative == commaAlternative) {
foundHits++;
if (foundHits >= hitNumber) {
return leaf;
}
}
} else {
if (!commaAlternative) {
foundHits++;
if (foundHits >= hitNumber) {
return leaf;
}
}
}
}
}
}
}
return null;
}