Search in sources :

Example 1 with ASTIfStatement

use of net.sourceforge.pmd.lang.plsql.ast.ASTIfStatement in project pmd by pmd.

the class StatementAndBraceFinder method visit.

@Override
public Object visit(ASTElseClause node, Object data) {
    if (!(data instanceof Structure)) {
        return data;
    }
    Structure dataFlow = (Structure) data;
    if (node.jjtGetParent() instanceof ASTIfStatement) {
        dataFlow.pushOnStack(NodeType.IF_LAST_STATEMENT, dataFlow.getLast());
        if (LOGGER.isLoggable(Level.FINEST)) {
            LOGGER.finest("pushOnStack (Visit ASTElseClause) IF_LAST_STATEMENT: line " + node.getBeginLine() + ", column " + node.getBeginColumn());
            LOGGER.finest("ElseClause) super.visit line");
        }
    } else {
        // SRT dataFlow.createNewNode(node);
        dataFlow.pushOnStack(NodeType.SWITCH_LAST_DEFAULT_STATEMENT, dataFlow.getLast());
        if (LOGGER.isLoggable(Level.FINEST)) {
            LOGGER.finest("pushOnStack SWITCH_LAST_DEFAULT_STATEMENT: line " + node.getBeginLine() + ", column " + node.getBeginColumn());
        }
    }
    super.visit(node, data);
    return data;
}
Also used : ASTIfStatement(net.sourceforge.pmd.lang.plsql.ast.ASTIfStatement) Structure(net.sourceforge.pmd.lang.dfa.Structure)

Example 2 with ASTIfStatement

use of net.sourceforge.pmd.lang.plsql.ast.ASTIfStatement in project pmd by pmd.

the class StatementAndBraceFinder method visit.

@Override
public Object visit(ASTExpression node, Object data) {
    if (LOGGER.isLoggable(Level.FINEST)) {
        LOGGER.finest("Entry ASTExpression: line " + node.getBeginLine() + ", column " + node.getBeginColumn());
    }
    if (!(data instanceof Structure)) {
        if (LOGGER.isLoggable(Level.FINEST)) {
            LOGGER.finest("immediate return ASTExpression: line " + node.getBeginLine() + ", column " + node.getBeginColumn());
        }
        return data;
    }
    Structure dataFlow = (Structure) data;
    // an UnLabelledStatement
    if (node.jjtGetParent() instanceof ASTUnlabelledStatement) {
        if (LOGGER.isLoggable(Level.FINEST)) {
            LOGGER.finest("createNewNode ASTSUnlabelledStatement: line " + node.getBeginLine() + ", column " + node.getBeginColumn());
        }
        dataFlow.createNewNode(node);
    } else if (node.jjtGetParent() instanceof ASTIfStatement) {
        // TODO what about throw stmts?
        // START IF
        dataFlow.createNewNode(node);
        dataFlow.pushOnStack(NodeType.IF_EXPR, dataFlow.getLast());
        if (LOGGER.isLoggable(Level.FINEST)) {
            LOGGER.finest("pushOnStack parent IF_EXPR: line " + node.getBeginLine() + ", column " + node.getBeginColumn());
        }
    } else if (node.jjtGetParent() instanceof ASTElsifClause) {
        if (LOGGER.isLoggable(Level.FINEST)) {
            LOGGER.finest("parent (Elsif) IF_EXPR at  " + node.getBeginLine() + ", column " + node.getBeginColumn());
        }
        // START IF
        dataFlow.createNewNode(node);
        dataFlow.pushOnStack(NodeType.IF_EXPR, dataFlow.getLast());
        if (LOGGER.isLoggable(Level.FINEST)) {
            LOGGER.finest("pushOnStack parent (Elsif) IF_EXPR: line " + node.getBeginLine() + ", column " + node.getBeginColumn());
        }
    } else if (node.jjtGetParent() instanceof ASTWhileStatement) {
        // START WHILE
        dataFlow.createNewNode(node);
        dataFlow.pushOnStack(NodeType.WHILE_EXPR, dataFlow.getLast());
        if (LOGGER.isLoggable(Level.FINEST)) {
            LOGGER.finest("pushOnStack parent WHILE_EXPR: line " + node.getBeginLine() + ", column " + node.getBeginColumn());
        }
    } else if (node.jjtGetParent() instanceof ASTCaseStatement) {
        // START SWITCH
        dataFlow.createNewNode(node);
        dataFlow.pushOnStack(NodeType.SWITCH_START, dataFlow.getLast());
        if (LOGGER.isLoggable(Level.FINEST)) {
            LOGGER.finest("pushOnStack parent SWITCH_START: line " + node.getBeginLine() + ", column " + node.getBeginColumn());
        }
    } else if (node.jjtGetParent() instanceof ASTForStatement) {
        /*
             * A PL/SQL loop control: [<REVERSE>] Expression()[".."Expression()]
             */
        if (node.equals(node.jjtGetParent().getFirstChildOfType(ASTExpression.class))) {
            // FOR EXPR
            dataFlow.createNewNode(node);
            dataFlow.pushOnStack(NodeType.FOR_EXPR, dataFlow.getLast());
            if (LOGGER.isLoggable(Level.FINEST)) {
                LOGGER.finest("pushOnStack parent FOR_EXPR: line " + node.getBeginLine() + ", column " + node.getBeginColumn());
            }
        }
        if (LOGGER.isLoggable(Level.FINEST)) {
            LOGGER.finest("parent (ASTForStatement): line " + node.getBeginLine() + ", column " + node.getBeginColumn());
        }
    } else if (node.jjtGetParent() instanceof ASTLoopStatement) {
        // DO EXPR
        dataFlow.createNewNode(node);
        dataFlow.pushOnStack(NodeType.DO_EXPR, dataFlow.getLast());
        if (LOGGER.isLoggable(Level.FINEST)) {
            LOGGER.finest("pushOnStack parent DO_EXPR: line " + node.getBeginLine() + ", column " + node.getBeginColumn());
        }
    }
    return super.visit(node, data);
}
Also used : ASTWhileStatement(net.sourceforge.pmd.lang.plsql.ast.ASTWhileStatement) ASTCaseStatement(net.sourceforge.pmd.lang.plsql.ast.ASTCaseStatement) ASTIfStatement(net.sourceforge.pmd.lang.plsql.ast.ASTIfStatement) ASTElsifClause(net.sourceforge.pmd.lang.plsql.ast.ASTElsifClause) ASTLoopStatement(net.sourceforge.pmd.lang.plsql.ast.ASTLoopStatement) Structure(net.sourceforge.pmd.lang.dfa.Structure) ASTForStatement(net.sourceforge.pmd.lang.plsql.ast.ASTForStatement) ASTUnlabelledStatement(net.sourceforge.pmd.lang.plsql.ast.ASTUnlabelledStatement)

Aggregations

Structure (net.sourceforge.pmd.lang.dfa.Structure)2 ASTIfStatement (net.sourceforge.pmd.lang.plsql.ast.ASTIfStatement)2 ASTCaseStatement (net.sourceforge.pmd.lang.plsql.ast.ASTCaseStatement)1 ASTElsifClause (net.sourceforge.pmd.lang.plsql.ast.ASTElsifClause)1 ASTForStatement (net.sourceforge.pmd.lang.plsql.ast.ASTForStatement)1 ASTLoopStatement (net.sourceforge.pmd.lang.plsql.ast.ASTLoopStatement)1 ASTUnlabelledStatement (net.sourceforge.pmd.lang.plsql.ast.ASTUnlabelledStatement)1 ASTWhileStatement (net.sourceforge.pmd.lang.plsql.ast.ASTWhileStatement)1