本文整理汇总了Java中com.github.javaparser.ast.stmt.SwitchEntryStmt类的典型用法代码示例。如果您正苦于以下问题:Java SwitchEntryStmt类的具体用法?Java SwitchEntryStmt怎么用?Java SwitchEntryStmt使用的例子?那么恭喜您, 这里精选的类代码示例或许可以为您提供帮助。
SwitchEntryStmt类属于com.github.javaparser.ast.stmt包,在下文中一共展示了SwitchEntryStmt类的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Java代码示例。
示例1: visit
import com.github.javaparser.ast.stmt.SwitchEntryStmt; //导入依赖的package包/类
@Override
public void visit(final SwitchStmt n, final Void arg) {
if (canAddNewLine(n)) printer.println();
printJavaComment(n.getComment(), arg);
printer.print("switch (");
n.getSelector().accept(this, arg);
printer.println(") {");
if (n.getEntries() != null) {
for (final SwitchEntryStmt e : n.getEntries()) {
e.accept(this, arg);
}
}
printer.print("}");
if (getNext(n) != null) printer.println();
}
示例2: visit
import com.github.javaparser.ast.stmt.SwitchEntryStmt; //导入依赖的package包/类
@Override
public void visit(final SwitchStmt n, final Object arg) {
printer.printLn("SwitchStmt");
printJavaComment(n.getComment(), arg);
printer.print("switch(");
n.getSelector().accept(this, arg);
printer.printLn(") {");
if (n.getEntries() != null) {
printer.indent();
for (final SwitchEntryStmt e : n.getEntries()) {
e.accept(this, arg);
}
printer.unindent();
}
printer.print("}");
}
示例3: visit
import com.github.javaparser.ast.stmt.SwitchEntryStmt; //导入依赖的package包/类
@Override
public JCTree visit(final SwitchEntryStmt n, final Object arg) {
//ARG0: JCExpression pat
JCExpression arg0 = null;
if (n.getLabel() != null) {
arg0 = (JCExpression) n.getLabel().accept(this, arg);
}
//ARG1: List<JCStatement> stats
List<JCStatement> arg1 = List.<JCStatement>nil();
if (n.getStmts() != null) {
for (final Statement s : n.getStmts()) {
arg1 = arg1.append((JCStatement) s.accept(this, arg));
}
}
return new AJCCase(make.Case(arg0, arg1), ((n.getComment() != null) ? n.getComment().getContent() : null));
}
示例4: visit
import com.github.javaparser.ast.stmt.SwitchEntryStmt; //导入依赖的package包/类
@Override public void visit(final SwitchEntryStmt n, final Object arg) {
printJavaComment(n.getComment(), arg);
if (n.getLabel() != null) {
printer.print("case ");
n.getLabel().accept(this, arg);
printer.print(":");
} else {
printer.print("default:");
}
printer.printLn();
printer.indent();
if (n.getStmts() != null) {
for (final Statement s : n.getStmts()) {
s.accept(this, arg);
printer.printLn();
}
}
printer.unindent();
}
示例5: visit
import com.github.javaparser.ast.stmt.SwitchEntryStmt; //导入依赖的package包/类
@Override public void visit(final SwitchEntryStmt n, final Object arg) {
printJavaComment(n.getComment(), arg);
if (n.getLabel() != null) {
printer.print("case ");
n.getLabel().accept(this, arg);
printer.print(":");
} else {
printer.print("default:");
}
printer.printLn();
printer.indent();
if (n.getStmts() != null) {
for (final Statement s : n.getStmts()) {
s.accept(this, arg);
printer.printLn();
}
}
printer.unindent();
}
示例6: parseSwitchStatement
import com.github.javaparser.ast.stmt.SwitchEntryStmt; //导入依赖的package包/类
/**
*
* @param switchStmt
* a github javaparser SwithStatement
* @param attributes
* the list of attributes of the class,
* to potentially get a type from the name
* @param bd
* a body declaration
* @return
* a SwitchStatement structure
*/
private SwitchStatement parseSwitchStatement(SwitchStmt switchStmt, List<Attribute> attributes, BodyDeclaration bd) {
SwitchStatement switchStatement = new SwitchStatement();
switchStatement.setCondition(parseExpression(switchStmt.getSelector(), attributes, bd.getBeginLine()));
if (switchStmt.getEntries() != null) {
List<CaseClause> caseClauses = new ArrayList<>();
for (SwitchEntryStmt switchEntry : switchStmt.getEntries()) {
CaseClause caseClause = new CaseClause();
List<Expr> conditions = new ArrayList<>();
if (switchEntry.getLabel() != null) {
conditions.add(parseExpression(switchEntry.getLabel(), attributes, bd.getBeginLine()));
caseClause.setConditions(conditions);
} else {
if (switchEntry.getStmts() != null) {
switchStatement.setDefaultStmt(parseListStmt(switchEntry.getStmts(), attributes, bd));
}
}
if (switchEntry.getStmts() != null) {
List<Stmt> body = new ArrayList<>();
body.addAll(parseListStmt(switchEntry.getStmts(), attributes, bd));
caseClause.setBody(body);
}
caseClauses.add(caseClause);
}
switchStatement.setCaseClauses(caseClauses);
}
return switchStatement;
}
示例7: doMerge
import com.github.javaparser.ast.stmt.SwitchEntryStmt; //导入依赖的package包/类
@Override public SwitchEntryStmt doMerge(SwitchEntryStmt first, SwitchEntryStmt second) {
SwitchEntryStmt ses = new SwitchEntryStmt();
ses.setLabel(mergeSingle(first.getLabel(),second.getLabel()));
ses.setStmts(mergeCollections(first.getStmts(),second.getStmts()));
return ses;
}
示例8: visit
import com.github.javaparser.ast.stmt.SwitchEntryStmt; //导入依赖的package包/类
@Override public Boolean visit(final SwitchEntryStmt n1, final Node arg) {
final SwitchEntryStmt n2 = (SwitchEntryStmt) arg;
if (!nodeEquals(n1.getLabel(), n2.getLabel())) {
return Boolean.FALSE;
}
if (!nodesEquals(n1.getStmts(), n2.getStmts())) {
return Boolean.FALSE;
}
return Boolean.TRUE;
}
示例9: visit
import com.github.javaparser.ast.stmt.SwitchEntryStmt; //导入依赖的package包/类
@Override public void visit(final SwitchEntryStmt n, final A arg) {
visitComment(n.getComment(), arg);
if (n.getLabel() != null) {
n.getLabel().accept(this, arg);
}
if (n.getStmts() != null) {
for (final Statement s : n.getStmts()) {
s.accept(this, arg);
}
}
}
示例10: visit
import com.github.javaparser.ast.stmt.SwitchEntryStmt; //导入依赖的package包/类
@Override public void visit(final SwitchEntryStmt n, final A arg) {
jw.write(n);
visitComment(n.getComment(), arg);
if (n.getLabel() != null) {
n.getLabel().accept(this, arg);
}
if (n.getStmts() != null) {
for (final Statement s : n.getStmts()) {
s.accept(this, arg);
}
}
}
示例11: visit
import com.github.javaparser.ast.stmt.SwitchEntryStmt; //导入依赖的package包/类
@Override public Node visit(final SwitchEntryStmt n, final A arg) {
if (n.getLabel() != null) {
n.setLabel((Expression) n.getLabel().accept(this, arg));
}
final List<Statement> stmts = n.getStmts();
if (stmts != null) {
for (int i = 0; i < stmts.size(); i++) {
stmts.set(i, (Statement) stmts.get(i).accept(this, arg));
}
removeNulls(stmts);
}
return n;
}
示例12: visit
import com.github.javaparser.ast.stmt.SwitchEntryStmt; //导入依赖的package包/类
@Override public Boolean visit(final SwitchEntryStmt n1, final Node arg) {
final SwitchEntryStmt n2 = (SwitchEntryStmt) arg;
if (!nodeEquals(n1.getLabel(), n2.getLabel())) {
return false;
}
if (!nodesEquals(n1.getStmts(), n2.getStmts())) {
return false;
}
return true;
}
示例13: visit
import com.github.javaparser.ast.stmt.SwitchEntryStmt; //导入依赖的package包/类
@Override
public Node visit(SwitchStmt _n, Object _arg) {
Expression selector = cloneNodes(_n.getSelector(), _arg);
List<SwitchEntryStmt> entries = visit(_n.getEntries(), _arg);
Comment comment = cloneNodes(_n.getComment(), _arg);
SwitchStmt r = new SwitchStmt(
_n.getRange(),
selector, entries
);
r.setComment(comment);
return r;
}
示例14: visit
import com.github.javaparser.ast.stmt.SwitchEntryStmt; //导入依赖的package包/类
@Override public Node visit(final SwitchEntryStmt n, final A arg) {
visitComment(n, arg);
if (n.getLabel() != null) {
n.setLabel((Expression) n.getLabel().accept(this, arg));
}
final List<Statement> stmts = n.getStmts();
if (stmts != null) {
for (int i = 0; i < stmts.size(); i++) {
stmts.set(i, (Statement) stmts.get(i).accept(this, arg));
}
removeNulls(stmts);
}
return n;
}
示例15: solveSymbol
import com.github.javaparser.ast.stmt.SwitchEntryStmt; //导入依赖的package包/类
@Override
public SymbolReference<? extends ValueDeclaration> solveSymbol(String name, TypeSolver typeSolver) {
SwitchStmt switchStmt = (SwitchStmt) getParentNode(wrappedNode);
Type type = JavaParserFacade.get(typeSolver).getType(switchStmt.getSelector());
if (type.isReferenceType() && type.asReferenceType().getTypeDeclaration().isEnum()) {
if (type instanceof ReferenceTypeImpl) {
ReferenceTypeImpl typeUsageOfTypeDeclaration = (ReferenceTypeImpl) type;
if (typeUsageOfTypeDeclaration.getTypeDeclaration().hasField(name)) {
return SymbolReference.solved(typeUsageOfTypeDeclaration.getTypeDeclaration().getField(name));
}
} else {
throw new UnsupportedOperationException();
}
}
// look for declaration in other switch statements
for (SwitchEntryStmt seStmt : switchStmt.getEntries()) {
if (!seStmt.equals(wrappedNode)) {
for (Statement stmt : seStmt.getStatements()) {
SymbolDeclarator symbolDeclarator = JavaParserFactory.getSymbolDeclarator(stmt, typeSolver);
SymbolReference<? extends ValueDeclaration> symbolReference = solveWith(symbolDeclarator, name);
if (symbolReference.isSolved()) {
return symbolReference;
}
}
}
}
return getParent().solveSymbol(name, typeSolver);
}