org.sonar.gherkin.tree.impl.GherkinTree Maven / Gradle / Ivy
The newest version!
/*
* SonarQube Cucumber Gherkin Analyzer
* Copyright (C) 2016-2017 David RACODON
* [email protected]
*
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 3 of the License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public License
* along with this program; if not, write to the Free Software Foundation,
* Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
*/
package org.sonar.gherkin.tree.impl;
import org.sonar.plugins.gherkin.api.tree.SyntaxToken;
import org.sonar.plugins.gherkin.api.tree.Tree;
import java.util.Iterator;
public abstract class GherkinTree implements Tree {
private Tree parent;
@Override
public Tree parent() {
return parent;
}
@Override
public void setParent(Tree parent) {
this.parent = parent;
}
public int getLine() {
return getFirstToken().line();
}
@Override
public final boolean is(Kind... kind) {
if (getKind() != null) {
for (Kind kindIter : kind) {
if (getKind() == kindIter) {
return true;
}
}
}
return false;
}
@Override
public boolean isLeaf() {
return false;
}
public SyntaxToken getLastToken() {
SyntaxToken lastToken = null;
Iterator childrenIterator = childrenIterator();
while (childrenIterator.hasNext()) {
GherkinTree child = (GherkinTree) childrenIterator.next();
if (child != null) {
SyntaxToken childLastToken = child.getLastToken();
if (childLastToken != null) {
lastToken = childLastToken;
}
}
}
return lastToken;
}
public SyntaxToken getFirstToken() {
Iterator childrenIterator = childrenIterator();
Tree child;
do {
if (childrenIterator.hasNext()) {
child = childrenIterator.next();
} else {
throw new IllegalStateException("Tree has no non-null children " + getKind());
}
} while (child == null);
return ((GherkinTree) child).getFirstToken();
}
}
© 2015 - 2024 Weber Informatics LLC | Privacy Policy