Merge branch 'bug-1520'
This commit is contained in:
@ -27,6 +27,11 @@ SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||
|
||||
|
||||
/**
|
||||
* Added ASTIsOfTypeCondition node, added support for USING IN|OUT|IN_OUT
|
||||
* See PMD Bug #1520
|
||||
*
|
||||
* Andreas Dangel 11/2016
|
||||
*====================================================================
|
||||
* Adjusted ProgramUnit() to allow Pragma(), even though this is not
|
||||
* valid syntax. See PMD Bug #1527.
|
||||
*
|
||||
@ -1368,7 +1373,7 @@ ASTOpenStatement OpenStatement() :
|
||||
{
|
||||
<OPEN> [Expression()]
|
||||
//[LOOKAHEAD(functionCall()) functionCall() | QualifiedName()]
|
||||
[<FOR> Expression() [<USING> Expression() ("," Expression())*]]
|
||||
[<FOR> Expression() [<USING> (<IN> | <OUT> | <IN_OUT>)? Expression() ("," (<IN> | <OUT> | <IN_OUT>)? Expression())*]]
|
||||
{ return jjtThis ; }
|
||||
}
|
||||
|
||||
@ -1967,13 +1972,28 @@ ASTUnaryExpressionNotPlusMinus UnaryExpressionNotPlusMinus() :
|
||||
(<NOT>) {sb.append(" NOT "); }
|
||||
(simpleNode = UnaryExpression(false) ) { sb.append(simpleNode.getImage()); }
|
||||
|
|
||||
(simpleNode = PrimaryExpression() ) { sb.append(simpleNode.getImage()); }
|
||||
(simpleNode = IsOfTypeCondition() ) {sb.append(simpleNode.getImage()); }
|
||||
)
|
||||
{
|
||||
jjtThis.setImage(sb.toString()); return jjtThis;
|
||||
}
|
||||
}
|
||||
|
||||
ASTIsOfTypeCondition IsOfTypeCondition() :
|
||||
{ PLSQLNode simpleNode = null; PLSQLNode name = null; StringBuilder sb = new StringBuilder(); }
|
||||
{
|
||||
(
|
||||
LOOKAHEAD(<IDENTIFIER> <IS>)
|
||||
((name = Name()) {sb.append(name.getImage());} <IS> {sb.append(" IS");} [<NOT> {sb.append(" NOT");}] <OF> {sb.append(" OF");} [<TYPE>]
|
||||
"(" [<ONLY>] Name() ("," [<ONLY>] Name() )* ")")
|
||||
|
|
||||
(simpleNode = PrimaryExpression() ) { sb.append(simpleNode.getImage()); }
|
||||
)
|
||||
{
|
||||
jjtThis.setImage(sb.toString()); return jjtThis;
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* 2006-05-23 - Matthias Hendler - Added lookahead otherwise warning encountered.
|
||||
* Warning arised while adding methode triggerUnit().
|
||||
@ -3248,6 +3268,7 @@ TOKEN [IGNORE_CASE]:
|
||||
* Added: <MERGE: "MERGE">, <AFTER: "AFTER">, <BEFORE: "BEFORE">,
|
||||
* <INSTEADOF: "INSTEAD OF">, <FOREACHROW: "FOR EACH ROW">, <REFERENCING: "REFERENCING">,
|
||||
* <OLD: "OLD">, <PARENT: "PARENT">
|
||||
* 2016-11-04 - Andreas Dangel - Added <ONLY: "ONLY">, <IN_OUT: "IN_OUT">
|
||||
*/
|
||||
|
||||
TOKEN [IGNORE_CASE]:
|
||||
@ -3347,6 +3368,7 @@ TOKEN [IGNORE_CASE]:
|
||||
<IF: "IF"> |
|
||||
<IMMEDIATE: "IMMEDIATE"> |
|
||||
<IN: "IN"> |
|
||||
<IN_OUT: "IN_OUT"> |
|
||||
<INDEX: "INDEX"> |
|
||||
<INDICES: "INDICES"> |
|
||||
<INCLUDING: "INCLUDING"> |
|
||||
@ -3408,6 +3430,7 @@ TOKEN [IGNORE_CASE]:
|
||||
<OF: "OF"> |
|
||||
<OID: "OID"> |
|
||||
<ON: "ON"> |
|
||||
<ONLY: "ONLY"> |
|
||||
<OPAQUE: "OPAQUE"> |
|
||||
<OPEN: "OPEN"> |
|
||||
<OPERATOR: "OPERATOR"> |
|
||||
|
@ -690,4 +690,8 @@ public class PLSQLParserVisitorAdapter implements PLSQLParserVisitor {
|
||||
return visit((PLSQLNode) node, data);
|
||||
}
|
||||
|
||||
@Override
|
||||
public Object visit(ASTIsOfTypeCondition node, Object data) {
|
||||
return visit((PLSQLNode) node, data);
|
||||
}
|
||||
}
|
||||
|
@ -785,6 +785,10 @@ public abstract class AbstractPLSQLRule extends AbstractRule implements PLSQLPar
|
||||
public Object visit(ASTAccessibleByClause node, Object data) {
|
||||
return visit((PLSQLNode) node, data);
|
||||
}
|
||||
@Override
|
||||
public Object visit(ASTIsOfTypeCondition node, Object data) {
|
||||
return visit((PLSQLNode) node, data);
|
||||
}
|
||||
|
||||
/*
|
||||
* Treat all Executable Code
|
||||
|
@ -50,4 +50,14 @@ public class PLSQLParserTest extends AbstractPLSQLParserTst {
|
||||
public void testBug1527() throws Exception {
|
||||
parsePLSQL(IOUtils.toString(PLSQLParserTest.class.getResourceAsStream("ast/InlinePragmaProcError.pls")));
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testBug1520IsOfType() throws Exception {
|
||||
parsePLSQL(IOUtils.toString(PLSQLParserTest.class.getResourceAsStream("ast/IsOfType.pls")));
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testBug1520Using() throws Exception {
|
||||
parsePLSQL(IOUtils.toString(PLSQLParserTest.class.getResourceAsStream("ast/Using.pls")));
|
||||
}
|
||||
}
|
||||
|
@ -0,0 +1,23 @@
|
||||
PROCEDURE IsOfType (
|
||||
inChannelID IN number,
|
||||
inOperID IN number,
|
||||
inClientId IN number,
|
||||
ioFPOobj IN FPO_OBJ,
|
||||
inPackageIDout IN number,
|
||||
inStatusId IN number)
|
||||
is
|
||||
loFPOGE_OBJ FPOGE_OBJ;
|
||||
BEGIN
|
||||
|
||||
IF ioFPOobj IS OF (FPOGE_OBJ) THEN
|
||||
loFPOGE_OBJ:=treat(ioFPOobj AS FPOGE_OBJ);
|
||||
end if;
|
||||
|
||||
IF ioFPOobj IS NOT OF TYPE (ONLY FPOGE_OBJ) THEN
|
||||
loFPOGE_OBJ:=treat(ioFPOobj AS FPOGE_OBJ);
|
||||
end if;
|
||||
|
||||
loFPOGE_OBJ:=SELECT A FROM persons p WHERE IS OF TYPE (employee_t);
|
||||
loFPOGE_OBJ:=SELECT A FROM persons p WHERE IS NOT OF TYPE (ONLY employee_t, other_t);
|
||||
|
||||
end;
|
@ -0,0 +1,16 @@
|
||||
/*
|
||||
* From: https://docs.oracle.com/cd/B13789_01/appdev.101/b10807/13_elems034.htm
|
||||
*/
|
||||
DECLARE
|
||||
TYPE EmpCurTyp IS REF CURSOR; -- define weak REF CURSOR type
|
||||
emp_cv EmpCurTyp; -- declare cursor variable
|
||||
my_ename VARCHAR2(15);
|
||||
my_sal NUMBER := 1000;
|
||||
BEGIN
|
||||
OPEN emp_cv FOR -- open cursor variable
|
||||
'SELECT ename, sal FROM emp WHERE sal > :s' USING my_sal;
|
||||
open cursor for 'query' USING variable;
|
||||
open cursor for 'query' USING IN variable;
|
||||
open cursor for 'query' USING OUT variable, IN othervariable;
|
||||
open cursor for 'query' USING IN_OUT variable;
|
||||
END;
|
@ -1265,7 +1265,7 @@ IS
|
||||
/** Unreserved Keyword Word ONLINE **/
|
||||
ONLINE VARCHAR2(240);
|
||||
/** Unreserved Keyword Word ONLY **/
|
||||
ONLY VARCHAR2(240);
|
||||
-- ONLY VARCHAR2(240);
|
||||
/** Unreserved Keyword Word OPAQUE **/
|
||||
OPAQUE VARCHAR2(240);
|
||||
/** Unreserved Keyword Word OPAQUE_TRANSFORM **/
|
||||
@ -2726,7 +2726,7 @@ BEGIN
|
||||
OLD := 'OLD' ; -- OLD VARCHAR2(240)
|
||||
OLD_PUSH_PRED := 'OLD_PUSH_PRED' ; -- OLD_PUSH_PRED VARCHAR2(240)
|
||||
ONLINE := 'ONLINE' ; -- ONLINE VARCHAR2(240)
|
||||
ONLY := 'ONLY' ; -- ONLY VARCHAR2(240)
|
||||
--ONLY := 'ONLY' ; -- ONLY VARCHAR2(240)
|
||||
--SRT 20110508 OPAQUE := 'OPAQUE' ; -- OPAQUE VARCHAR2(240)
|
||||
OPAQUE_TRANSFORM := 'OPAQUE_TRANSFORM' ; -- OPAQUE_TRANSFORM VARCHAR2(240)
|
||||
OPAQUE_XCANONICAL := 'OPAQUE_XCANONICAL' ; -- OPAQUE_XCANONICAL VARCHAR2(240)
|
||||
|
@ -1263,7 +1263,7 @@ TYPE typ_unreserved_keywords AS OBJECT
|
||||
/** Unreserved Keyword Word ONLINE **/
|
||||
ONLINE VARCHAR2(240),
|
||||
/** Unreserved Keyword Word ONLY **/
|
||||
ONLY VARCHAR2(240),
|
||||
-- ONLY VARCHAR2(240),
|
||||
/** Unreserved Keyword Word OPAQUE **/
|
||||
OPAQUE VARCHAR2(240),
|
||||
/** Unreserved Keyword Word OPAQUE_TRANSFORM **/
|
||||
|
@ -1263,7 +1263,7 @@ PACKAGE pkg_unreserved AS
|
||||
/** Unreserved Keyword Word ONLINE **/
|
||||
ONLINE VARCHAR2(240);
|
||||
/** Unreserved Keyword Word ONLY **/
|
||||
ONLY VARCHAR2(240);
|
||||
-- ONLY VARCHAR2(240);
|
||||
/** Unreserved Keyword Word OPAQUE **/
|
||||
OPAQUE VARCHAR2(240);
|
||||
/** Unreserved Keyword Word OPAQUE_TRANSFORM **/
|
||||
|
@ -1266,7 +1266,7 @@ prc_test_unreserved_keyword
|
||||
/** Unreserved Keyword Word ONLINE **/
|
||||
ONLINE IN OUT VARCHAR2,
|
||||
/** Unreserved Keyword Word ONLY **/
|
||||
ONLY IN OUT VARCHAR2,
|
||||
-- ONLY IN OUT VARCHAR2,
|
||||
/** Unreserved Keyword Word OPAQUE **/
|
||||
OPAQUE IN OUT VARCHAR2,
|
||||
/** Unreserved Keyword Word OPAQUE_TRANSFORM **/
|
||||
@ -2729,7 +2729,7 @@ BEGIN
|
||||
OLD := 'OLD' ; -- OLD VARCHAR2(240)
|
||||
OLD_PUSH_PRED := 'OLD_PUSH_PRED' ; -- OLD_PUSH_PRED VARCHAR2(240)
|
||||
ONLINE := 'ONLINE' ; -- ONLINE VARCHAR2(240)
|
||||
ONLY := 'ONLY' ; -- ONLY VARCHAR2(240)
|
||||
-- ONLY := 'ONLY' ; -- ONLY VARCHAR2(240)
|
||||
--SRT 20110508 OPAQUE := 'OPAQUE' ; -- OPAQUE VARCHAR2(240)
|
||||
OPAQUE_TRANSFORM := 'OPAQUE_TRANSFORM' ; -- OPAQUE_TRANSFORM VARCHAR2(240)
|
||||
OPAQUE_XCANONICAL := 'OPAQUE_XCANONICAL' ; -- OPAQUE_XCANONICAL VARCHAR2(240)
|
||||
|
@ -1264,7 +1264,7 @@ TYPE typ_unreserved_keywords AS OBJECT
|
||||
/** Unreserved Keyword Word ONLINE **/
|
||||
ONLINE VARCHAR2(240),
|
||||
/** Unreserved Keyword Word ONLY **/
|
||||
ONLY VARCHAR2(240),
|
||||
-- ONLY VARCHAR2(240),
|
||||
/** Unreserved Keyword Word OPAQUE **/
|
||||
OPAQUE VARCHAR2(240),
|
||||
/** Unreserved Keyword Word OPAQUE_TRANSFORM **/
|
||||
|
@ -1283,7 +1283,7 @@ AS
|
||||
/** Unreserved Keyword Word ONLINE **/
|
||||
ONLINE VARCHAR2(240);
|
||||
/** Unreserved Keyword Word ONLY **/
|
||||
ONLY VARCHAR2(240);
|
||||
-- ONLY VARCHAR2(240);
|
||||
/** Unreserved Keyword Word OPAQUE **/
|
||||
OPAQUE VARCHAR2(240);
|
||||
/** Unreserved Keyword Word OPAQUE_TRANSFORM **/
|
||||
@ -2744,7 +2744,7 @@ BEGIN
|
||||
OLD := 'OLD' ; -- OLD VARCHAR2(240)
|
||||
OLD_PUSH_PRED := 'OLD_PUSH_PRED' ; -- OLD_PUSH_PRED VARCHAR2(240)
|
||||
ONLINE := 'ONLINE' ; -- ONLINE VARCHAR2(240)
|
||||
ONLY := 'ONLY' ; -- ONLY VARCHAR2(240)
|
||||
-- ONLY := 'ONLY' ; -- ONLY VARCHAR2(240)
|
||||
--SRT 20110508 OPAQUE := 'OPAQUE' ; -- OPAQUE VARCHAR2(240)
|
||||
OPAQUE_TRANSFORM := 'OPAQUE_TRANSFORM' ; -- OPAQUE_TRANSFORM VARCHAR2(240)
|
||||
OPAQUE_XCANONICAL := 'OPAQUE_XCANONICAL' ; -- OPAQUE_XCANONICAL VARCHAR2(240)
|
||||
|
@ -1267,7 +1267,7 @@ AS
|
||||
/** Unreserved Keyword Word ONLINE **/
|
||||
ONLINE VARCHAR2(240);
|
||||
/** Unreserved Keyword Word ONLY **/
|
||||
ONLY VARCHAR2(240);
|
||||
-- ONLY VARCHAR2(240);
|
||||
/** Unreserved Keyword Word OPAQUE **/
|
||||
OPAQUE VARCHAR2(240);
|
||||
/** Unreserved Keyword Word OPAQUE_TRANSFORM **/
|
||||
@ -2740,7 +2740,7 @@ BEGIN
|
||||
OLD := 'OLD' ; -- OLD VARCHAR2(240)
|
||||
OLD_PUSH_PRED := 'OLD_PUSH_PRED' ; -- OLD_PUSH_PRED VARCHAR2(240)
|
||||
ONLINE := 'ONLINE' ; -- ONLINE VARCHAR2(240)
|
||||
ONLY := 'ONLY' ; -- ONLY VARCHAR2(240)
|
||||
-- ONLY := 'ONLY' ; -- ONLY VARCHAR2(240)
|
||||
--SRT 20110508 OPAQUE := 'OPAQUE' ; -- OPAQUE VARCHAR2(240)
|
||||
OPAQUE_TRANSFORM := 'OPAQUE_TRANSFORM' ; -- OPAQUE_TRANSFORM VARCHAR2(240)
|
||||
OPAQUE_XCANONICAL := 'OPAQUE_XCANONICAL' ; -- OPAQUE_XCANONICAL VARCHAR2(240)
|
||||
|
@ -1263,7 +1263,7 @@ AS
|
||||
/** Unreserved Keyword Word ONLINE **/
|
||||
ONLINE VARCHAR2(240);
|
||||
/** Unreserved Keyword Word ONLY **/
|
||||
ONLY VARCHAR2(240);
|
||||
-- ONLY VARCHAR2(240);
|
||||
/** Unreserved Keyword Word OPAQUE **/
|
||||
OPAQUE VARCHAR2(240);
|
||||
/** Unreserved Keyword Word OPAQUE_TRANSFORM **/
|
||||
|
@ -55,6 +55,7 @@
|
||||
* java-typeresolution/SignatureDeclareThrowsException
|
||||
* [#1535](https://sourceforge.net/p/pmd/bugs/1535/): \[java] SignatureDeclareThrowsException: ClassCastException with Annotation
|
||||
* PLSQL
|
||||
* [#1520](https://sourceforge.net/p/pmd/bugs/1520/): \[plsql] Missing PL/SQL language constructs in parser: Is Of Type, Using
|
||||
* [#1527](https://sourceforge.net/p/pmd/bugs/1527/): \[plsql] PRAGMA AUTONOMOUS_TRANSACTION gives processing errors
|
||||
* [#1531](https://sourceforge.net/p/pmd/bugs/1531/): \[plsql] OOM/Endless loop while parsing (PL)SQL
|
||||
* General
|
||||
|
Reference in New Issue
Block a user