blob: 4ade00b0d2c46a196bd90d2ed82667deb19073ee [file] [log] [blame]
/* Generated By:JJTree&JavaCC: Do not edit this line. DDLParser.java */
/*******************************************************************************
* Copyright (c) 2011 Oracle. All rights reserved.
* This program and the accompanying materials are made available under the
* terms of the Eclipse Public License v1.0 and Eclipse Distribution License v. 1.0
* which accompanies this distribution.
* The Eclipse Public License is available at http://www.eclipse.org/legal/epl-v10.html
* and the Eclipse Distribution License is available at
* http://www.eclipse.org/org/documents/edl-v10.php.
*
* Contributors:
* Mike Norman - June 10 2011, created DDL parser package
******************************************************************************/
package org.eclipse.persistence.tools.oracleddl.parser;
//javase imports
import java.io.InputStream;
import java.util.List;
import java.util.HashMap;
import java.util.Map;
//metadata imports
import org.eclipse.persistence.tools.oracleddl.metadata.ArgumentType;
import org.eclipse.persistence.tools.oracleddl.metadata.ArgumentTypeDirection;
import org.eclipse.persistence.tools.oracleddl.metadata.BlobType;
import org.eclipse.persistence.tools.oracleddl.metadata.CharType;
import org.eclipse.persistence.tools.oracleddl.metadata.ClobType;
import org.eclipse.persistence.tools.oracleddl.metadata.CompositeDatabaseType;
import org.eclipse.persistence.tools.oracleddl.metadata.DatabaseType;
import org.eclipse.persistence.tools.oracleddl.metadata.DecimalType;
import org.eclipse.persistence.tools.oracleddl.metadata.DoubleType;
import org.eclipse.persistence.tools.oracleddl.metadata.FieldType;
import org.eclipse.persistence.tools.oracleddl.metadata.FloatType;
import org.eclipse.persistence.tools.oracleddl.metadata.FunctionType;
import org.eclipse.persistence.tools.oracleddl.metadata.IntervalDayToSecond;
import org.eclipse.persistence.tools.oracleddl.metadata.IntervalYearToMonth;
import org.eclipse.persistence.tools.oracleddl.metadata.LongType;
import org.eclipse.persistence.tools.oracleddl.metadata.LongRawType;
import org.eclipse.persistence.tools.oracleddl.metadata.NCharType;
import org.eclipse.persistence.tools.oracleddl.metadata.NClobType;
import org.eclipse.persistence.tools.oracleddl.metadata.NumericType;
import org.eclipse.persistence.tools.oracleddl.metadata.NVarChar2Type;
import org.eclipse.persistence.tools.oracleddl.metadata.ObjectType;
import org.eclipse.persistence.tools.oracleddl.metadata.ObjectTableType;
import org.eclipse.persistence.tools.oracleddl.metadata.PLSQLCollectionType;
import org.eclipse.persistence.tools.oracleddl.metadata.PLSQLCursorType;
import org.eclipse.persistence.tools.oracleddl.metadata.PLSQLPackageType;
import org.eclipse.persistence.tools.oracleddl.metadata.PLSQLRecordType;
import org.eclipse.persistence.tools.oracleddl.metadata.PLSQLType;
import org.eclipse.persistence.tools.oracleddl.metadata.PLSQLSubType;
import org.eclipse.persistence.tools.oracleddl.metadata.ProcedureType;
import org.eclipse.persistence.tools.oracleddl.metadata.RawType;
import org.eclipse.persistence.tools.oracleddl.metadata.RealType;
import org.eclipse.persistence.tools.oracleddl.metadata.TableType;
import org.eclipse.persistence.tools.oracleddl.metadata.TimeStampType;
import org.eclipse.persistence.tools.oracleddl.metadata.URowIdType;
import org.eclipse.persistence.tools.oracleddl.metadata.UnresolvedSizedType;
import org.eclipse.persistence.tools.oracleddl.metadata.UnresolvedType;
import org.eclipse.persistence.tools.oracleddl.metadata.VarCharType;
import org.eclipse.persistence.tools.oracleddl.metadata.VarChar2Type;
import org.eclipse.persistence.tools.oracleddl.metadata.VArrayType;
import org.eclipse.persistence.tools.oracleddl.util.DatabaseTypesRepository;
import static org.eclipse.persistence.tools.oracleddl.metadata.ScalarDatabaseTypeEnum.BFILE_TYPE;
import static org.eclipse.persistence.tools.oracleddl.metadata.ScalarDatabaseTypeEnum.BINARY_INTEGER_TYPE;
import static org.eclipse.persistence.tools.oracleddl.metadata.ScalarDatabaseTypeEnum.BINARY_FLOAT_TYPE;
import static org.eclipse.persistence.tools.oracleddl.metadata.ScalarDatabaseTypeEnum.BINARY_DOUBLE_TYPE;
import static org.eclipse.persistence.tools.oracleddl.metadata.ScalarDatabaseTypeEnum.BOOLEAN_TYPE;
import static org.eclipse.persistence.tools.oracleddl.metadata.ScalarDatabaseTypeEnum.DATE_TYPE;
import static org.eclipse.persistence.tools.oracleddl.metadata.ScalarDatabaseTypeEnum.INTEGER_TYPE;
import static org.eclipse.persistence.tools.oracleddl.metadata.ScalarDatabaseTypeEnum.MLSLABEL_TYPE;
import static org.eclipse.persistence.tools.oracleddl.metadata.ScalarDatabaseTypeEnum.NATURAL_TYPE;
import static org.eclipse.persistence.tools.oracleddl.metadata.ScalarDatabaseTypeEnum.PLS_INTEGER_TYPE;
import static org.eclipse.persistence.tools.oracleddl.metadata.ScalarDatabaseTypeEnum.POSITIVE_TYPE;
import static org.eclipse.persistence.tools.oracleddl.metadata.ScalarDatabaseTypeEnum.ROWID_TYPE;
import static org.eclipse.persistence.tools.oracleddl.metadata.ScalarDatabaseTypeEnum.SIGN_TYPE;
import static org.eclipse.persistence.tools.oracleddl.metadata.ScalarDatabaseTypeEnum.SIMPLE_INTEGER_TYPE;
import static org.eclipse.persistence.tools.oracleddl.metadata.ScalarDatabaseTypeEnum.SIMPLE_DOUBLE_TYPE;
import static org.eclipse.persistence.tools.oracleddl.metadata.ScalarDatabaseTypeEnum.SIMPLE_FLOAT_TYPE;
import static org.eclipse.persistence.tools.oracleddl.metadata.ScalarDatabaseTypeEnum.SMALLINT_TYPE;
import static org.eclipse.persistence.tools.oracleddl.metadata.ScalarDatabaseTypeEnum.SYS_REFCURSOR_TYPE;
import static org.eclipse.persistence.tools.oracleddl.metadata.ScalarDatabaseTypeEnum.TIME_TYPE;
@SuppressWarnings("all")
public class DDLParser/*@bgen(jjtree)*/implements DDLParserTreeConstants, DDLParserConstants {/*@bgen(jjtree)*/
protected JJTDDLParserState jjtree = new JJTDDLParserState();
protected Map<String, DatabaseType> localTypes = new HashMap<String, DatabaseType>();
protected DatabaseTypesRepository typesRepository = new DatabaseTypesRepository();
public DDLParser() {
super();
}
public void setTypesRepository(DatabaseTypesRepository typesRepository) {
this.typesRepository = typesRepository;
}
public DatabaseTypesRepository getTypesRepository() {
return typesRepository;
}
// stripped-down version of PLSQL grammar: only parses package/top-level DDL specifications
// PLSQLPackage at 'top-level'
final public PLSQLPackageType parsePLSQLPackage() throws ParseException {
String schema = null;
String packageName = null;
PLSQLPackageType packageType = new PLSQLPackageType();
jj_consume_token(K_CREATE);
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case K_OR:
jj_consume_token(K_OR);
jj_consume_token(K_REPLACE);
break;
default:
;
}
jj_consume_token(K_PACKAGE);
if (jj_2_1(2)) {
schema = OracleObjectName();
jj_consume_token(O_DOT);
} else {
;
}
packageName = OracleObjectName();
if (schema != null) {
packageType.setSchema(schema);
}
packageType.setPackageName(packageName);
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case K_AUTHID:
jj_consume_token(K_AUTHID);
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case K_CURRENT_USER:
case K_DEFINER:
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case K_CURRENT_USER:
jj_consume_token(K_CURRENT_USER);
break;
case K_DEFINER:
jj_consume_token(K_DEFINER);
break;
default:
jj_consume_token(-1);
throw new ParseException();
}
break;
default:
;
}
break;
default:
;
}
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case K_AS:
case K_IS:
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case K_AS:
jj_consume_token(K_AS);
break;
case K_IS:
jj_consume_token(K_IS);
break;
default:
jj_consume_token(-1);
throw new ParseException();
}
break;
default:
;
}
label_1:
while (true) {
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case K_CURSOR:
case K_FUNCTION:
case K_PRAGMA:
case K_PROCEDURE:
case K_SUBTYPE:
case K_TYPE:
case S_IDENTIFIER:
;
break;
default:
break label_1;
}
packageDeclaration(packageType);
}
jj_consume_token(K_END);
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case S_IDENTIFIER:
case S_QUOTED_IDENTIFIER:
OracleObjectName();
break;
default:
;
}
jj_consume_token(O_SEMICOLON);
jj_consume_token(0);
typesRepository.setDatabaseType(packageName, packageType);
{if (true) return packageType;}
throw new Error("Missing return statement in function");
}
// procedure at 'top-level'
final public ProcedureType parseTopLevelProcedure() throws ParseException {
ProcedureType procedureType = null;
String schema = null;
String procedureName = null;
jj_consume_token(K_CREATE);
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case K_OR:
jj_consume_token(K_OR);
jj_consume_token(K_REPLACE);
break;
default:
;
}
jj_consume_token(K_PROCEDURE);
if (jj_2_2(2)) {
schema = OracleObjectName();
jj_consume_token(O_DOT);
} else {
;
}
procedureName = OracleObjectName();
procedureType = new ProcedureType(procedureName);
if (schema != null) {
procedureType.setSchema(schema);
}
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case O_OPENPAREN:
jj_consume_token(O_OPENPAREN);
argumentList(procedureType);
jj_consume_token(O_CLOSEPAREN);
break;
default:
;
}
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case K_AS:
case K_IS:
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case K_AS:
jj_consume_token(K_AS);
break;
case K_IS:
jj_consume_token(K_IS);
break;
default:
jj_consume_token(-1);
throw new ParseException();
}
break;
default:
;
}
skipToEnd();
typesRepository.setDatabaseType(procedureName, procedureType);
{if (true) return procedureType;}
throw new Error("Missing return statement in function");
}
// function at 'top-level'
final public FunctionType parseTopLevelFunction() throws ParseException {
FunctionType functionType = null;
String schema = null;
String functionName = null;
ArgumentType returnType = null;
jj_consume_token(K_CREATE);
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case K_OR:
jj_consume_token(K_OR);
jj_consume_token(K_REPLACE);
break;
default:
;
}
jj_consume_token(K_FUNCTION);
if (jj_2_3(2)) {
schema = OracleObjectName();
jj_consume_token(O_DOT);
} else {
;
}
functionName = OracleObjectName();
functionType = new FunctionType(functionName);
if (schema != null) {
functionType.setSchema(schema);
}
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case O_OPENPAREN:
jj_consume_token(O_OPENPAREN);
argumentList(functionType);
jj_consume_token(O_CLOSEPAREN);
break;
default:
;
}
returnType = functionReturnSpec();
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case K_AS:
case K_IS:
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case K_AS:
jj_consume_token(K_AS);
break;
case K_IS:
jj_consume_token(K_IS);
break;
default:
jj_consume_token(-1);
throw new ParseException();
}
break;
default:
;
}
skipToEnd();
functionType.setReturnArgument(returnType);
typesRepository.setDatabaseType(functionName, functionType);
{if (true) return functionType;}
throw new Error("Missing return statement in function");
}
// table at 'top-level'
final public TableType parseTable() throws ParseException {
TableType tableType = null;
String schema = null;
String tableName = null;
Token iot = null;
jj_consume_token(K_CREATE);
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case K_GLOBAL:
jj_consume_token(K_GLOBAL);
jj_consume_token(K_TEMPORARY);
break;
default:
;
}
jj_consume_token(K_TABLE);
if (jj_2_4(2)) {
schema = OracleObjectName();
jj_consume_token(O_DOT);
} else {
;
}
tableName = OracleObjectName();
tableType = new TableType(tableName);
if (schema != null) {
tableType.setSchema(schema);
}
jj_consume_token(O_OPENPAREN);
columnDeclarations(tableType);
jj_consume_token(O_CLOSEPAREN);
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case K_ORGANIZATION:
jj_consume_token(K_ORGANIZATION);
break;
default:
;
}
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case K_INDEX:
iot = jj_consume_token(K_INDEX);
break;
default:
;
}
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case K_NOCOMPRESS:
jj_consume_token(K_NOCOMPRESS);
break;
default:
;
}
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case K_OVERFLOW:
jj_consume_token(K_OVERFLOW);
break;
default:
;
}
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case K_ON:
jj_consume_token(K_ON);
jj_consume_token(K_COMMIT);
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case K_DELETE:
case K_PRESERVE:
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case K_DELETE:
jj_consume_token(K_DELETE);
break;
case K_PRESERVE:
jj_consume_token(K_PRESERVE);
break;
default:
jj_consume_token(-1);
throw new ParseException();
}
break;
default:
;
}
jj_consume_token(K_ROWS);
break;
default:
;
}
jj_consume_token(O_SEMICOLON);
jj_consume_token(0);
if (iot != null) {
tableType.setIOT(true);
}
typesRepository.setDatabaseType(tableName, tableType);
{if (true) return tableType;}
throw new Error("Missing return statement in function");
}
// type at 'top-level'
final public CompositeDatabaseType parseType() throws ParseException {
CompositeDatabaseType databaseType = null;
DatabaseType enclosedType = null;
String schema = null;
String typeName = null;
Token vsize = null;
boolean varray = false;
boolean nestedTable = false;
jj_consume_token(K_CREATE);
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case K_OR:
jj_consume_token(K_OR);
jj_consume_token(K_REPLACE);
break;
default:
;
}
jj_consume_token(K_TYPE);
if (jj_2_5(2)) {
schema = OracleObjectName();
jj_consume_token(O_DOT);
} else {
;
}
typeName = OracleObjectName();
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case K_FORCE:
jj_consume_token(K_FORCE);
break;
default:
;
}
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case K_OID:
jj_consume_token(K_OID);
jj_consume_token(S_CHAR_LITERAL);
break;
default:
;
}
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case K_AUTHID:
jj_consume_token(K_AUTHID);
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case K_CURRENT_USER:
case K_DEFINER:
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case K_CURRENT_USER:
jj_consume_token(K_CURRENT_USER);
break;
case K_DEFINER:
jj_consume_token(K_DEFINER);
break;
default:
jj_consume_token(-1);
throw new ParseException();
}
break;
default:
;
}
break;
default:
;
}
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case K_AS:
jj_consume_token(K_AS);
break;
case K_IS:
jj_consume_token(K_IS);
break;
default:
jj_consume_token(-1);
throw new ParseException();
}
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case K_OBJECT:
case K_TABLE:
case K_VARRAY:
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case K_OBJECT:
jj_consume_token(K_OBJECT);
jj_consume_token(O_OPENPAREN);
databaseType = new ObjectType(typeName);
if (schema != null) {
((ObjectType)databaseType).setSchema(schema);
}
columnDeclarations(databaseType);
jj_consume_token(O_CLOSEPAREN);
break;
case K_VARRAY:
jj_consume_token(K_VARRAY);
jj_consume_token(O_OPENPAREN);
vsize = jj_consume_token(S_NUMBER);
jj_consume_token(O_CLOSEPAREN);
jj_consume_token(K_OF);
databaseType = new VArrayType(typeName);
if (schema != null) {
((VArrayType)databaseType).setSchema(schema);
}
if (vsize != null) {
Long size = Long.decode(vsize.image);
((VArrayType)databaseType).setSize(size);
}
enclosedType = columnTypeSpec(databaseType);
break;
case K_TABLE:
jj_consume_token(K_TABLE);
jj_consume_token(K_OF);
databaseType = new ObjectTableType(typeName);
if (schema != null) {
((ObjectTableType)databaseType).setSchema(schema);
}
enclosedType = columnTypeSpec(databaseType);
break;
default:
jj_consume_token(-1);
throw new ParseException();
}
break;
default:
;
}
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case K_FINAL:
case K_INSTANTIABLE:
case K_NOT:
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case K_NOT:
jj_consume_token(K_NOT);
break;
default:
;
}
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case K_FINAL:
jj_consume_token(K_FINAL);
break;
case K_INSTANTIABLE:
jj_consume_token(K_INSTANTIABLE);
break;
default:
jj_consume_token(-1);
throw new ParseException();
}
break;
default:
;
}
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case O_SEMICOLON:
jj_consume_token(O_SEMICOLON);
break;
default:
;
}
jj_consume_token(0);
if (enclosedType != null) {
((CompositeDatabaseType)databaseType).addCompositeType(enclosedType);
}
typesRepository.setDatabaseType(typeName, databaseType);
{if (true) return databaseType;}
throw new Error("Missing return statement in function");
}
final public void columnDeclarations(CompositeDatabaseType enclosingType) throws ParseException {
columnDeclaration(enclosingType);
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case O_COMMA:
jj_consume_token(O_COMMA);
columnDeclarations(enclosingType);
break;
default:
;
}
}
final public void columnDeclaration(CompositeDatabaseType enclosingType) throws ParseException {
String s = null;
String pk = null;
boolean notNull = false;
DatabaseType columnType = null;
FieldType column = null;
if (jj_2_6(2)) {
s = OracleObjectName();
column = new FieldType(s);
if (enclosingType != null) {
enclosingType.addCompositeType(column);
}
columnType = columnTypeSpec(enclosingType);
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case K_NOT:
jj_consume_token(K_NOT);
jj_consume_token(K_NULL);
jj_consume_token(K_ENABLE);
notNull = true;
break;
default:
;
}
} else if (jj_2_7(2)) {
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case K_CONSTRAINT:
jj_consume_token(K_CONSTRAINT);
break;
default:
;
}
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case S_IDENTIFIER:
case S_QUOTED_IDENTIFIER:
OracleObjectName();
break;
default:
;
}
jj_consume_token(K_PRIMARY);
jj_consume_token(K_KEY);
jj_consume_token(O_OPENPAREN);
pkList((TableType)enclosingType);
jj_consume_token(O_CLOSEPAREN);
jj_consume_token(K_ENABLE);
} else {
jj_consume_token(-1);
throw new ParseException();
}
if (column != null) {
column.setDataType(columnType);
if (columnType instanceof UnresolvedType) {
((UnresolvedType)columnType).setOwningType(column);
}
if (notNull) {
column.setNotNull();
}
}
}
final public DatabaseType columnTypeSpec(CompositeDatabaseType enclosingType) throws ParseException {
String s = null;
Token t = null;
DatabaseType dt = null;
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case K_BFILE:
case K_BINARY_DOUBLE:
case K_BINARY_FLOAT:
case K_BINARY_INTEGER:
case K_BLOB:
case K_BOOLEAN:
case K_CHAR:
case K_CHARACTER:
case K_CLOB:
case K_DATE:
case K_DEC:
case K_DECIMAL:
case K_DOUBLE:
case K_FLOAT:
case K_INT:
case K_INTEGER:
case K_INTERVAL:
case K_LONG:
case K_MLSLABEL:
case K_NATIONAL:
case K_NATURAL:
case K_NCHAR:
case K_NCLOB:
case K_NUMBER:
case K_NUMERIC:
case K_NVARCHAR2:
case K_NVARCHAR:
case K_PLS_INTEGER:
case K_POSITIVE:
case K_RAW:
case K_REAL:
case K_ROWID:
case K_SIGNTYPE:
case K_SIMPLE_INTEGER:
case K_SIMPLE_DOUBLE:
case K_SIMPLE_FLOAT:
case K_SMALLINT:
case K_SYS_REFCURSOR:
case K_TIME:
case K_TIMESTAMP:
case K_UROWID:
case K_VARCHAR2:
case K_VARCHAR:
dt = datatype();
break;
case S_IDENTIFIER:
case S_QUOTED_IDENTIFIER:
s = columnSpec();
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case O_OPENPAREN:
jj_consume_token(O_OPENPAREN);
t = jj_consume_token(S_NUMBER);
jj_consume_token(O_CLOSEPAREN);
break;
default:
;
}
break;
default:
jj_consume_token(-1);
throw new ParseException();
}
if (s != null) {
for (String typeName : localTypes.keySet()) {
if (typeName.equals(s)) {
dt = localTypes.get(s);
break;
}
}
if (dt == null) {
if (t != null) {
Long size = Long.decode(t.image);
dt = new UnresolvedSizedType(s, size);
}
else {
dt = new UnresolvedType(s);
}
((UnresolvedType)dt).setOwningType(enclosingType);
}
}
{if (true) return dt;}
throw new Error("Missing return statement in function");
}
final public void pkList(TableType tableType) throws ParseException {
pk(tableType);
label_2:
while (true) {
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case O_COMMA:
;
break;
default:
break label_2;
}
jj_consume_token(O_COMMA);
pk(tableType);
}
}
final public void pk(TableType tableType) throws ParseException {
String s = null;
s = OracleObjectName();
List<FieldType> columns = tableType.getColumns();
for (FieldType column : columns) {
if (column.getFieldName().equals(s)) {
column.setPk();
break;
}
}
}
final public void packageDeclaration(PLSQLPackageType packageType) throws ParseException {
if (jj_2_8(2)) {
variableDeclaration(packageType);
} else {
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case K_SUBTYPE:
case K_TYPE:
typeOrSubTypeDeclaration(packageType);
break;
case K_CURSOR:
cursorDeclaration(packageType);
break;
case K_PROCEDURE:
procedureSpec(packageType);
break;
case K_FUNCTION:
functionSpec(packageType);
break;
case S_IDENTIFIER:
exceptionDeclaration(packageType);
break;
case K_PRAGMA:
pragmaDeclaration(packageType);
break;
default:
jj_consume_token(-1);
throw new ParseException();
}
}
}
final public void variableDeclaration(PLSQLPackageType packageType) throws ParseException {
Token varName = null;
DatabaseType varType;
varName = jj_consume_token(S_IDENTIFIER);
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case K_CONSTANT:
jj_consume_token(K_CONSTANT);
break;
default:
;
}
varType = typeSpec();
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case K_NOT:
jj_consume_token(K_NOT);
jj_consume_token(K_NULL);
break;
default:
;
}
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case K_DEFAULT:
case O_ASSIGN:
variableDefaultAssignment();
break;
default:
;
}
jj_consume_token(O_SEMICOLON);
FieldType variable = new FieldType(varName.image);
variable.setDataType(varType);
packageType.addLocalVariable(variable);
}
final public void variableDefaultAssignment() throws ParseException {
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case O_ASSIGN:
jj_consume_token(O_ASSIGN);
break;
case K_DEFAULT:
jj_consume_token(K_DEFAULT);
break;
default:
jj_consume_token(-1);
throw new ParseException();
}
skipToSemiColon();
}
final public DatabaseType datatype() throws ParseException {
Token t = null;
DatabaseType dt = null;
Token precision = null;
Long sl;
Long pl;
Token scale = null;
Token withTimeZone = null;
Token withLocalTimeZone = null;
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case K_BINARY_INTEGER:
jj_consume_token(K_BINARY_INTEGER);
{if (true) return BINARY_INTEGER_TYPE;}
break;
case K_BINARY_FLOAT:
jj_consume_token(K_BINARY_FLOAT);
{if (true) return BINARY_FLOAT_TYPE;}
break;
case K_BINARY_DOUBLE:
jj_consume_token(K_BINARY_DOUBLE);
{if (true) return BINARY_DOUBLE_TYPE;}
break;
case K_NATURAL:
jj_consume_token(K_NATURAL);
{if (true) return NATURAL_TYPE;}
break;
case K_POSITIVE:
jj_consume_token(K_POSITIVE);
{if (true) return POSITIVE_TYPE;}
break;
case K_SIGNTYPE:
jj_consume_token(K_SIGNTYPE);
{if (true) return SIGN_TYPE;}
break;
case K_DEC:
case K_DECIMAL:
case K_NUMBER:
case K_NUMERIC:
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case K_NUMBER:
t = jj_consume_token(K_NUMBER);
break;
case K_NUMERIC:
t = jj_consume_token(K_NUMERIC);
break;
case K_DECIMAL:
t = jj_consume_token(K_DECIMAL);
break;
case K_DEC:
t = jj_consume_token(K_DEC);
break;
default:
jj_consume_token(-1);
throw new ParseException();
}
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case O_OPENPAREN:
jj_consume_token(O_OPENPAREN);
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case O_ASTERISK:
case S_NUMBER:
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case O_ASTERISK:
precision = jj_consume_token(O_ASTERISK);
break;
case S_NUMBER:
precision = jj_consume_token(S_NUMBER);
break;
default:
jj_consume_token(-1);
throw new ParseException();
}
break;
default:
;
}
label_3:
while (true) {
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case O_COMMA:
;
break;
default:
break label_3;
}
jj_consume_token(O_COMMA);
scale = jj_consume_token(S_NUMBER);
}
jj_consume_token(O_CLOSEPAREN);
break;
default:
;
}
if (t.kind == K_NUMBER || t.kind == K_NUMERIC) {
if (precision != null && precision.image.equals("*")) {
precision = null;
}
if (precision == null) {
if (scale != null && scale.image.equals("0")) {
dt = INTEGER_TYPE;
}
else {
dt = new NumericType();
}
}
else {
pl = Long.decode(precision.image);
if (scale == null) {
dt = new NumericType(pl);
}
else {
sl = Long.decode(scale.image);
dt = new NumericType(pl, sl);
}
}
//sometimes need to know difference between NUMERIC and NUMBER
if (dt != INTEGER_TYPE && t.kind == K_NUMBER) {
((NumericType)dt).setNumberSynonym(true);
}
}
else if (t.kind == K_DECIMAL || t.kind == K_DEC) {
if (precision != null && precision.image.equals("*")) {
precision = null;
}
if (precision == null) {
dt = new DecimalType();
}
else {
pl = Long.decode(precision.image);
if (scale == null) {
dt = new DecimalType(pl);
}
else {
sl = Long.decode(scale.image);
dt = new DecimalType(pl, sl);
}
}
}
{if (true) return dt;}
break;
case K_LONG:
jj_consume_token(K_LONG);
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case K_RAW:
t = jj_consume_token(K_RAW);
break;
default:
;
}
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case O_OPENPAREN:
jj_consume_token(O_OPENPAREN);
precision = jj_consume_token(S_NUMBER);
jj_consume_token(O_CLOSEPAREN);
break;
default:
;
}
if (t == null) {
if (precision == null) {
dt = new LongType();
}
else {
pl = Long.decode(precision.image);
dt = new LongType(pl);
}
}
else {
if (precision == null) {
dt = new LongRawType();
}
else {
pl = Long.decode(precision.image);
dt = new LongRawType(pl);
}
}
{if (true) return dt;}
break;
case K_RAW:
jj_consume_token(K_RAW);
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case O_OPENPAREN:
jj_consume_token(O_OPENPAREN);
precision = jj_consume_token(S_NUMBER);
jj_consume_token(O_CLOSEPAREN);
break;
default:
;
}
if (precision == null) {
dt = new RawType();
}
else {
pl = Long.decode(precision.image);
dt = new RawType(pl);
}
{if (true) return dt;}
break;
case K_BOOLEAN:
jj_consume_token(K_BOOLEAN);
{if (true) return BOOLEAN_TYPE;}
break;
case K_DATE:
jj_consume_token(K_DATE);
{if (true) return DATE_TYPE;}
break;
default:
if (jj_2_17(2)) {
jj_consume_token(K_INTERVAL);
jj_consume_token(K_DAY);
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case O_OPENPAREN:
jj_consume_token(O_OPENPAREN);
precision = jj_consume_token(S_NUMBER);
jj_consume_token(O_CLOSEPAREN);
break;
default:
;
}
jj_consume_token(K_TO);
jj_consume_token(K_SECOND);
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case O_OPENPAREN:
jj_consume_token(O_OPENPAREN);
scale = jj_consume_token(S_NUMBER);
jj_consume_token(O_CLOSEPAREN);
break;
default:
;
}
if (precision == null) {
dt = new IntervalDayToSecond();
}
else {
pl = Long.decode(precision.image);
if (scale == null) {
dt = new IntervalDayToSecond(pl);
}
else {
sl = Long.decode(scale.image);
dt = new IntervalDayToSecond(pl, sl);
}
}
{if (true) return dt;}
} else {
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case K_INTERVAL:
jj_consume_token(K_INTERVAL);
jj_consume_token(K_YEAR);
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case O_OPENPAREN:
jj_consume_token(O_OPENPAREN);
jj_consume_token(S_NUMBER);
jj_consume_token(O_CLOSEPAREN);
break;
default:
;
}
jj_consume_token(K_TO);
jj_consume_token(K_MONTH);
if (precision == null) {
dt = new IntervalYearToMonth();
}
else {
pl = Long.decode(precision.image);
dt = new IntervalYearToMonth(pl);
}
{if (true) return dt;}
break;
case K_TIME:
jj_consume_token(K_TIME);
{if (true) return TIME_TYPE;}
break;
case K_TIMESTAMP:
jj_consume_token(K_TIMESTAMP);
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case O_OPENPAREN:
jj_consume_token(O_OPENPAREN);
precision = jj_consume_token(S_NUMBER);
jj_consume_token(O_CLOSEPAREN);
break;
default:
;
}
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case K_WITH:
jj_consume_token(K_WITH);
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case K_LOCAL:
withLocalTimeZone = jj_consume_token(K_LOCAL);
break;
default:
;
}
withTimeZone = jj_consume_token(K_TIME);
jj_consume_token(K_ZONE);
break;
default:
;
}
if (precision == null) {
dt = new TimeStampType();
}
else {
pl = Long.decode(precision.image);
dt = new TimeStampType(pl);
}
if (withLocalTimeZone != null) {
((TimeStampType)dt).setWithLocalTimeZone();
}
else if (withTimeZone != null) {
((TimeStampType)dt).setWithTimeZone();
}
{if (true) return dt;}
break;
case K_INTEGER:
jj_consume_token(K_INTEGER);
{if (true) return INTEGER_TYPE;}
break;
case K_INT:
jj_consume_token(K_INT);
{if (true) return INTEGER_TYPE;}
break;
case K_SMALLINT:
jj_consume_token(K_SMALLINT);
{if (true) return SMALLINT_TYPE;}
break;
case K_FLOAT:
jj_consume_token(K_FLOAT);
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case O_OPENPAREN:
jj_consume_token(O_OPENPAREN);
precision = jj_consume_token(S_NUMBER);
jj_consume_token(O_CLOSEPAREN);
break;
default:
;
}
if (precision == null) {
{if (true) return new FloatType();}
}
else {
pl = Long.decode(precision.image);
FloatType ft = new FloatType(pl);
{if (true) return ft;}
}
break;
case K_REAL:
jj_consume_token(K_REAL);
{if (true) return new RealType();}
break;
case K_MLSLABEL:
jj_consume_token(K_MLSLABEL);
{if (true) return MLSLABEL_TYPE;}
break;
case K_PLS_INTEGER:
jj_consume_token(K_PLS_INTEGER);
{if (true) return PLS_INTEGER_TYPE;}
break;
case K_SIMPLE_INTEGER:
jj_consume_token(K_SIMPLE_INTEGER);
{if (true) return SIMPLE_INTEGER_TYPE;}
break;
case K_SIMPLE_FLOAT:
jj_consume_token(K_SIMPLE_FLOAT);
{if (true) return SIMPLE_FLOAT_TYPE;}
break;
case K_SIMPLE_DOUBLE:
jj_consume_token(K_SIMPLE_DOUBLE);
{if (true) return SIMPLE_DOUBLE_TYPE;}
break;
case K_SYS_REFCURSOR:
jj_consume_token(K_SYS_REFCURSOR);
{if (true) return SYS_REFCURSOR_TYPE;}
break;
case K_BLOB:
jj_consume_token(K_BLOB);
{if (true) return new BlobType();}
break;
case K_NCLOB:
jj_consume_token(K_NCLOB);
{if (true) return new NClobType();}
break;
case K_BFILE:
jj_consume_token(K_BFILE);
{if (true) return BFILE_TYPE;}
break;
case K_ROWID:
jj_consume_token(K_ROWID);
{if (true) return ROWID_TYPE;}
break;
case K_UROWID:
jj_consume_token(K_UROWID);
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case O_OPENPAREN:
jj_consume_token(O_OPENPAREN);
precision = jj_consume_token(S_NUMBER);
jj_consume_token(O_CLOSEPAREN);
break;
default:
;
}
if (precision == null) {
{if (true) return new URowIdType();}
}
else {
pl = Long.decode(precision.image);
{if (true) return new URowIdType(pl);}
}
break;
case K_DOUBLE:
jj_consume_token(K_DOUBLE);
jj_consume_token(K_PRECISION);
{if (true) return new DoubleType();}
break;
case K_CHAR:
jj_consume_token(K_CHAR);
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case K_VARYING:
t = jj_consume_token(K_VARYING);
break;
default:
;
}
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case O_OPENPAREN:
jj_consume_token(O_OPENPAREN);
precision = jj_consume_token(S_NUMBER);
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case K_BYTE:
case K_CHAR:
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case K_BYTE:
jj_consume_token(K_BYTE);
break;
case K_CHAR:
jj_consume_token(K_CHAR);
break;
default:
jj_consume_token(-1);
throw new ParseException();
}
break;
default:
;
}
jj_consume_token(O_CLOSEPAREN);
break;
default:
;
}
if (jj_2_10(2)) {
jj_consume_token(K_CHARACTER);
jj_consume_token(K_SET);
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case S_IDENTIFIER:
case S_QUOTED_IDENTIFIER:
if (jj_2_9(2)) {
jj_consume_token(S_IDENTIFIER);
} else {
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case S_IDENTIFIER:
case S_QUOTED_IDENTIFIER:
columnSpec();
jj_consume_token(K_CHARSET);
break;
default:
jj_consume_token(-1);
throw new ParseException();
}
}
break;
default:
;
}
} else {
;
}
if (t == null) {
if (precision == null) {
{if (true) return new CharType();}
}
else {
pl = Long.decode(precision.image);
{if (true) return new CharType(pl);}
}
}
else {
// ANSI syntax for VARCHAR2
if (precision == null) {
{if (true) return new VarChar2Type();}
}
else {
pl = Long.decode(precision.image);
{if (true) return new VarChar2Type(pl);}
}
}
break;
case K_VARCHAR:
jj_consume_token(K_VARCHAR);
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case K_VARYING:
jj_consume_token(K_VARYING);
break;
default:
;
}
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case O_OPENPAREN:
jj_consume_token(O_OPENPAREN);
precision = jj_consume_token(S_NUMBER);
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case K_BYTE:
case K_CHAR:
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case K_BYTE:
jj_consume_token(K_BYTE);
break;
case K_CHAR:
jj_consume_token(K_CHAR);
break;
default:
jj_consume_token(-1);
throw new ParseException();
}
break;
default:
;
}
jj_consume_token(O_CLOSEPAREN);
break;
default:
;
}
if (jj_2_12(2)) {
jj_consume_token(K_CHARACTER);
jj_consume_token(K_SET);
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case S_IDENTIFIER:
case S_QUOTED_IDENTIFIER:
if (jj_2_11(2)) {
jj_consume_token(S_IDENTIFIER);
} else {
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case S_IDENTIFIER:
case S_QUOTED_IDENTIFIER:
columnSpec();
jj_consume_token(K_CHARSET);
break;
default:
jj_consume_token(-1);
throw new ParseException();
}
}
break;
default:
;
}
} else {
;
}
if (precision == null) {
{if (true) return new VarCharType();}
}
else {
pl = Long.decode(precision.image);
{if (true) return new VarCharType(pl);}
}
break;
case K_VARCHAR2:
jj_consume_token(K_VARCHAR2);
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case K_VARYING:
jj_consume_token(K_VARYING);
break;
default:
;
}
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case O_OPENPAREN:
jj_consume_token(O_OPENPAREN);
precision = jj_consume_token(S_NUMBER);
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case K_BYTE:
case K_CHAR:
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case K_BYTE:
jj_consume_token(K_BYTE);
break;
case K_CHAR:
jj_consume_token(K_CHAR);
break;
default:
jj_consume_token(-1);
throw new ParseException();
}
break;
default:
;
}
jj_consume_token(O_CLOSEPAREN);
break;
default:
;
}
if (jj_2_14(2)) {
jj_consume_token(K_CHARACTER);
jj_consume_token(K_SET);
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case S_IDENTIFIER:
case S_QUOTED_IDENTIFIER:
if (jj_2_13(2)) {
jj_consume_token(S_IDENTIFIER);
} else {
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case S_IDENTIFIER:
case S_QUOTED_IDENTIFIER:
columnSpec();
jj_consume_token(K_CHARSET);
break;
default:
jj_consume_token(-1);
throw new ParseException();
}
}
break;
default:
;
}
} else {
;
}
if (precision == null) {
{if (true) return new VarChar2Type();}
}
else {
pl = Long.decode(precision.image);
{if (true) return new VarChar2Type(pl);}
}
break;
case K_CHARACTER:
jj_consume_token(K_CHARACTER);
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case K_VARYING:
t = jj_consume_token(K_VARYING);
break;
default:
;
}
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case O_OPENPAREN:
jj_consume_token(O_OPENPAREN);
precision = jj_consume_token(S_NUMBER);
jj_consume_token(O_CLOSEPAREN);
break;
default:
;
}
if (t == null) {
if (precision == null) {
{if (true) return new CharType();}
}
else {
pl = Long.decode(precision.image);
{if (true) return new CharType(pl);}
}
}
else {
// ANSI syntax for VARCHAR
if (precision == null) {
{if (true) return new VarCharType();}
}
else {
pl = Long.decode(precision.image);
{if (true) return new VarCharType(pl);}
}
}
break;
case K_NCHAR:
jj_consume_token(K_NCHAR);
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case K_VARYING:
t = jj_consume_token(K_VARYING);
break;
default:
;
}
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case O_OPENPAREN:
jj_consume_token(O_OPENPAREN);
precision = jj_consume_token(S_NUMBER);
jj_consume_token(O_CLOSEPAREN);
break;
default:
;
}
if (t == null) {
if (precision == null) {
{if (true) return new NCharType();}
}
else {
pl = Long.decode(precision.image);
{if (true) return new NCharType(pl);}
}
}
else {
// ANSI syntax for NVARCHAR2
if (precision == null) {
{if (true) return new NVarChar2Type();}
}
else {
pl = Long.decode(precision.image);
{if (true) return new NVarChar2Type(pl);}
}
}
break;
case K_NVARCHAR:
jj_consume_token(K_NVARCHAR);
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case O_OPENPAREN:
jj_consume_token(O_OPENPAREN);
precision = jj_consume_token(S_NUMBER);
jj_consume_token(O_CLOSEPAREN);
break;
default:
;
}
if (precision == null) {
{if (true) return new NVarChar2Type();}
}
else {
pl = Long.decode(precision.image);
{if (true) return new NVarChar2Type(pl);}
}
break;
case K_NVARCHAR2:
jj_consume_token(K_NVARCHAR2);
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case O_OPENPAREN:
jj_consume_token(O_OPENPAREN);
precision = jj_consume_token(S_NUMBER);
jj_consume_token(O_CLOSEPAREN);
break;
default:
;
}
if (precision == null) {
{if (true) return new NVarChar2Type();}
}
else {
pl = Long.decode(precision.image);
{if (true) return new NVarChar2Type(pl);}
}
break;
case K_NATIONAL:
jj_consume_token(K_NATIONAL);
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case K_CHARACTER:
jj_consume_token(K_CHARACTER);
break;
case K_CHAR:
jj_consume_token(K_CHAR);
break;
default:
jj_consume_token(-1);
throw new ParseException();
}
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case K_VARYING:
t = jj_consume_token(K_VARYING);
break;
default:
;
}
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case O_OPENPAREN:
jj_consume_token(O_OPENPAREN);
precision = jj_consume_token(S_NUMBER);
jj_consume_token(O_CLOSEPAREN);
break;
default:
;
}
if (t == null) {
if (precision == null) {
{if (true) return new NCharType();}
}
else {
pl = Long.decode(precision.image);
{if (true) return new NCharType(pl);}
}
}
else {
// ANSI syntax for NVARCHAR2
if (precision == null) {
{if (true) return new NVarChar2Type();}
}
else {
pl = Long.decode(precision.image);
{if (true) return new NVarChar2Type(pl);}
}
}
break;
case K_CLOB:
jj_consume_token(K_CLOB);
if (jj_2_16(2)) {
jj_consume_token(K_CHARACTER);
jj_consume_token(K_SET);
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case S_IDENTIFIER:
case S_QUOTED_IDENTIFIER:
if (jj_2_15(2)) {
jj_consume_token(S_IDENTIFIER);
} else {
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case S_IDENTIFIER:
case S_QUOTED_IDENTIFIER:
columnSpec();
jj_consume_token(K_CHARSET);
break;
default:
jj_consume_token(-1);
throw new ParseException();
}
}
break;
default:
;
}
} else {
;
}
{if (true) return new ClobType();}
break;
default:
jj_consume_token(-1);
throw new ParseException();
}
}
}
throw new Error("Missing return statement in function");
}
final public DatabaseType typeSpec() throws ParseException {
DatabaseType dataType = null;
String s = null;
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case K_BFILE:
case K_BINARY_DOUBLE:
case K_BINARY_FLOAT:
case K_BINARY_INTEGER:
case K_BLOB:
case K_BOOLEAN:
case K_CHAR:
case K_CHARACTER:
case K_CLOB:
case K_DATE:
case K_DEC:
case K_DECIMAL:
case K_DOUBLE:
case K_FLOAT:
case K_INT:
case K_INTEGER:
case K_INTERVAL:
case K_LONG:
case K_MLSLABEL:
case K_NATIONAL:
case K_NATURAL:
case K_NCHAR:
case K_NCLOB:
case K_NUMBER:
case K_NUMERIC:
case K_NVARCHAR2:
case K_NVARCHAR:
case K_PLS_INTEGER:
case K_POSITIVE:
case K_RAW:
case K_REAL:
case K_ROWID:
case K_SIGNTYPE:
case K_SIMPLE_INTEGER:
case K_SIMPLE_DOUBLE:
case K_SIMPLE_FLOAT:
case K_SMALLINT:
case K_SYS_REFCURSOR:
case K_TIME:
case K_TIMESTAMP:
case K_UROWID:
case K_VARCHAR2:
case K_VARCHAR:
dataType = datatype();
break;
case S_IDENTIFIER:
case S_QUOTED_IDENTIFIER:
s = columnSpec();
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case K_ROWTYPE:
case K_TYPE2:
case O_OPENPAREN:
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case O_OPENPAREN:
jj_consume_token(O_OPENPAREN);
jj_consume_token(S_NUMBER);
jj_consume_token(O_CLOSEPAREN);
break;
case K_TYPE2:
jj_consume_token(K_TYPE2);
s += tokenImage[K_TYPE2].substring(1, tokenImage[K_TYPE2].length() - 1);
break;
case K_ROWTYPE:
jj_consume_token(K_ROWTYPE);
s += tokenImage[K_ROWTYPE].substring(1, tokenImage[K_ROWTYPE].length() - 1);
break;
default:
jj_consume_token(-1);
throw new ParseException();
}
break;
default:
;
}
break;
default:
jj_consume_token(-1);
throw new ParseException();
}
if (dataType == null && localTypes != null) {
for (String typeName : localTypes.keySet()) {
if (typeName.equals(s)) {
dataType = localTypes.get(s);
break;
}
}
}
if (dataType == null) {
dataType = new UnresolvedType(s);
}
{if (true) return dataType;}
throw new Error("Missing return statement in function");
}
final public String columnSpec() throws ParseException {
String s1 = null;
String s2 = null;
String s3 = null;
s1 = OracleObjectName();
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case O_DOT:
jj_consume_token(O_DOT);
s2 = OracleObjectName();
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case O_DOT:
jj_consume_token(O_DOT);
s3 = OracleObjectName();
break;
default:
;
}
break;
default:
;
}
StringBuilder sb = new StringBuilder(s1);
if (s2 != null) {
sb.append('.');
sb.append(s2);
if (s3 != null) {
sb.append('.');
sb.append(s3);
}
}
{if (true) return sb.toString();}
throw new Error("Missing return statement in function");
}
final public String tableSpec() throws ParseException {
OracleObjectName();
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case O_DOT:
jj_consume_token(O_DOT);
OracleObjectName();
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case O_ATSIGN:
jj_consume_token(O_ATSIGN);
jj_consume_token(S_IDENTIFIER);
break;
default:
;
}
break;
default:
;
}
{if (true) return token.image;}
throw new Error("Missing return statement in function");
}
final public String typeName() throws ParseException {
OracleObjectName();
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case O_DOT:
jj_consume_token(O_DOT);
OracleObjectName();
break;
default:
;
}
{if (true) return token.image;}
throw new Error("Missing return statement in function");
}
final public void typeOrSubTypeDeclaration(PLSQLPackageType packageType) throws ParseException {
String s = null;
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case K_TYPE:
typeDeclaration(packageType);
break;
case K_SUBTYPE:
subtypeDeclaration(packageType);
break;
default:
jj_consume_token(-1);
throw new ParseException();
}
}
final public void typeDeclaration(PLSQLPackageType packageType) throws ParseException {
String s = null;
jj_consume_token(K_TYPE);
s = typeName();
jj_consume_token(K_IS);
aTypeDeclaration(packageType, s);
jj_consume_token(O_SEMICOLON);
}
final public void aTypeDeclaration(PLSQLPackageType packageType, String typeName) throws ParseException {
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case K_RECORD:
recordDeclaration(packageType, typeName);
break;
case K_TABLE:
plsqlTableDeclaration(packageType, typeName);
break;
case K_VARRAY:
case K_VARYING:
varrayDeclaration(packageType);
break;
case K_REF:
refCursorDeclaration(packageType, typeName);
break;
default:
jj_consume_token(-1);
throw new ParseException();
}
}
final public void recordDeclaration(PLSQLPackageType packageType, String typeName) throws ParseException {
PLSQLRecordType plsqlRecordType = new PLSQLRecordType(typeName);
plsqlRecordType.setParentType(packageType);
jj_consume_token(K_RECORD);
jj_consume_token(O_OPENPAREN);
fieldDeclarations(plsqlRecordType);
jj_consume_token(O_CLOSEPAREN);
packageType.addType(plsqlRecordType);
localTypes.put(typeName, plsqlRecordType);
}
final public void fieldDeclarations(PLSQLRecordType plsqlRecordType) throws ParseException {
fieldDeclaration(plsqlRecordType);
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case O_COMMA:
jj_consume_token(O_COMMA);
fieldDeclarations(plsqlRecordType);
break;
default:
;
}
}
final public void fieldDeclaration(PLSQLRecordType plsqlRecordType) throws ParseException {
String s = null;
DatabaseType dataType = null;
FieldType fieldType = null;
s = typeName();
dataType = typeSpec();
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case K_NOT:
jj_consume_token(K_NOT);
jj_consume_token(K_NULL);
break;
default:
;
}
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case K_DEFAULT:
case O_ASSIGN:
fieldDefaultAssignment();
break;
default:
;
}
fieldType = new FieldType(s);
fieldType.setDataType(dataType);
plsqlRecordType.addCompositeType(fieldType);
if (dataType instanceof UnresolvedType) {
((UnresolvedType)dataType).setOwningType(plsqlRecordType);
}
}
final public void fieldDefaultAssignment() throws ParseException {
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case O_ASSIGN:
jj_consume_token(O_ASSIGN);
break;
case K_DEFAULT:
jj_consume_token(K_DEFAULT);
break;
default:
jj_consume_token(-1);
throw new ParseException();
}
skipToNextArg();
}
final public void subtypeDeclaration(PLSQLPackageType packageType) throws ParseException {
String subtypeName;
DatabaseType subtype;
Token notNull = null;
Token rangeStart = null;
Token rangeEnd = null;
jj_consume_token(K_SUBTYPE);
subtypeName = OracleObjectName();
jj_consume_token(K_IS);
subtype = typeSpec();
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case K_RANGE:
jj_consume_token(K_RANGE);
rangeStart = jj_consume_token(S_NUMBER);
jj_consume_token(O_DOUBLEDOT);
rangeEnd = jj_consume_token(S_NUMBER);
break;
default:
;
}
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case K_NOT:
jj_consume_token(K_NOT);
notNull = jj_consume_token(K_NULL);
break;
default:
;
}
jj_consume_token(O_SEMICOLON);
PLSQLSubType newPLSQLSubType = new PLSQLSubType(subtypeName);
newPLSQLSubType.addCompositeType(subtype);
packageType.addType(newPLSQLSubType);
if (notNull != null) {
newPLSQLSubType.setNotNull(true);
}
if (rangeStart != null) {
long rStart = Long.decode(rangeStart.image).longValue();
long rEnd = Long.decode(rangeEnd.image).longValue();
newPLSQLSubType.setHasRange(true);
newPLSQLSubType.setRangeStart(rStart);
newPLSQLSubType.setRangeEnd(rEnd);
}
localTypes.put(subtypeName, newPLSQLSubType);
}
final public void plsqlTableDeclaration(PLSQLPackageType packageType, String typeName) throws ParseException {
PLSQLCollectionType plsqlTable = new PLSQLCollectionType(typeName);
plsqlTable.setParentType(packageType);
DatabaseType nestedType;
jj_consume_token(K_TABLE);
jj_consume_token(K_OF);
nestedType = typeSpec();
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case K_NOT:
jj_consume_token(K_NOT);
jj_consume_token(K_NULL);
break;
default:
;
}
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case K_INDEX:
jj_consume_token(K_INDEX);
jj_consume_token(K_BY);
plsqlTableIndexByDeclaration(plsqlTable);
break;
default:
;
}
if (nestedType instanceof UnresolvedType) {
((UnresolvedType)nestedType).setOwningType(plsqlTable);
}
plsqlTable.addCompositeType(nestedType);
packageType.addType(plsqlTable);
// TODO - TBD typesRepository.setDatabaseType(typeName, plsqlTable);
localTypes.put(typeName, plsqlTable);
}
final public void plsqlTableIndexByDeclaration(PLSQLCollectionType plsqlTable) throws ParseException {
DatabaseType indexType = null;
Token precision = null;
Token otherIndexByType = null;
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case K_PLS_INTEGER:
jj_consume_token(K_PLS_INTEGER);
indexType = PLS_INTEGER_TYPE;
break;
case K_BINARY_INTEGER:
jj_consume_token(K_BINARY_INTEGER);
indexType = BINARY_INTEGER_TYPE;
break;
case K_VARCHAR2:
jj_consume_token(K_VARCHAR2);
jj_consume_token(O_OPENPAREN);
precision = jj_consume_token(S_NUMBER);
jj_consume_token(O_CLOSEPAREN);
if (precision == null) {
indexType = new VarChar2Type();
}
else {
Long pl = Long.decode(precision.image);
indexType = new VarChar2Type(pl);
}
break;
case K_STRING:
otherIndexByType = jj_consume_token(K_STRING);
jj_consume_token(O_OPENPAREN);
jj_consume_token(S_NUMBER);
jj_consume_token(O_CLOSEPAREN);
String indexTypename = otherIndexByType.image;
for (String typeName : localTypes.keySet()) {
if (typeName.equals(indexTypename)) {
indexType = localTypes.get(indexTypename);
break;
}
}
//what else can INDEX BY be? Unresolved for now ...
if (indexType == null) {
indexType = new UnresolvedType(indexTypename);
((UnresolvedType)indexType).setOwningType(plsqlTable);
}
break;
default:
jj_consume_token(-1);
throw new ParseException();
}
plsqlTable.setIndexed(true);
plsqlTable.setIndexType(indexType);
}
final public void varrayDeclaration(PLSQLPackageType packageType) throws ParseException {
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case K_VARRAY:
jj_consume_token(K_VARRAY);
break;
case K_VARYING:
jj_consume_token(K_VARYING);
jj_consume_token(K_ARRAY);
break;
default:
jj_consume_token(-1);
throw new ParseException();
}
jj_consume_token(O_OPENPAREN);
jj_consume_token(S_NUMBER);
jj_consume_token(O_CLOSEPAREN);
jj_consume_token(K_OF);
datatype();
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case K_NOT:
jj_consume_token(K_NOT);
jj_consume_token(K_NULL);
break;
default:
;
}
}
final public void refCursorDeclaration(PLSQLPackageType packageType, String cursorTypeName) throws ParseException {
PLSQLCursorType cursorType = null;
jj_consume_token(K_REF);
jj_consume_token(K_CURSOR);
cursorType = new PLSQLCursorType(cursorTypeName);
packageType.addCursor(cursorType);
localTypes.put(cursorTypeName, cursorType);
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case K_RETURN:
refCursorTypeSpec(cursorType);
break;
default:
;
}
}
final public void refCursorTypeSpec(PLSQLCursorType cursorType) throws ParseException {
String s = null;
jj_consume_token(K_RETURN);
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case S_IDENTIFIER:
case S_QUOTED_IDENTIFIER:
if (jj_2_18(3)) {
s = columnSpec();
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case K_TYPE2:
jj_consume_token(K_TYPE2);
s += tokenImage[K_TYPE2].substring(1, tokenImage[K_TYPE2].length() - 1);
break;
default:
;
}
} else if (jj_2_19(3)) {
s = tableSpec();
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case K_ROWTYPE:
jj_consume_token(K_ROWTYPE);
s += tokenImage[K_ROWTYPE].substring(1, tokenImage[K_ROWTYPE].length() - 1);
break;
default:
;
}
} else {
jj_consume_token(-1);
throw new ParseException();
}
break;
default:
;
}
cursorType.setDataType(new UnresolvedType(s));
}
final public void cursorDeclaration(PLSQLPackageType packageType) throws ParseException {
Token t = null;
jj_consume_token(K_CURSOR);
t = jj_consume_token(S_IDENTIFIER);
jj_consume_token(O_SEMICOLON);
}
// Procedure Specification
final public void procedureSpec(PLSQLPackageType packageType) throws ParseException {
Token t = null;
ProcedureType procedureType = null;
jj_consume_token(K_PROCEDURE);
t = jj_consume_token(S_IDENTIFIER);
procedureType = new ProcedureType(t.image);
procedureType.setCatalogName(packageType.getPackageName());
procedureType.setSchema(packageType.getSchema());
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case O_OPENPAREN:
jj_consume_token(O_OPENPAREN);
argumentList(procedureType);
jj_consume_token(O_CLOSEPAREN);
break;
default:
;
}
jj_consume_token(O_SEMICOLON);
packageType.addProcedure(procedureType);
}
final public void argumentList(ProcedureType procedureType) throws ParseException {
argument(procedureType);
label_4:
while (true) {
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case O_COMMA:
;
break;
default:
break label_4;
}
jj_consume_token(O_COMMA);
argument(procedureType);
}
}
// Function Specification
final public void functionSpec(PLSQLPackageType packageType) throws ParseException {
Token t = null;
FunctionType functionType = null;
ArgumentType returnDataType = null;
jj_consume_token(K_FUNCTION);
t = jj_consume_token(S_IDENTIFIER);
functionType = new FunctionType(t.image);
functionType.setCatalogName(packageType.getPackageName());
functionType.setSchema(packageType.getSchema());
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case O_OPENPAREN:
jj_consume_token(O_OPENPAREN);
argumentList(functionType);
jj_consume_token(O_CLOSEPAREN);
break;
default:
;
}
returnDataType = functionReturnSpec();
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case K_DETERMINISTIC:
case K_PARALLEL_ENABLE:
case K_PIPELINED:
case K_RESULT_CACHE:
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case K_DETERMINISTIC:
jj_consume_token(K_DETERMINISTIC);
break;
case K_PIPELINED:
jj_consume_token(K_PIPELINED);
break;
case K_PARALLEL_ENABLE:
jj_consume_token(K_PARALLEL_ENABLE);
break;
case K_RESULT_CACHE:
jj_consume_token(K_RESULT_CACHE);
break;
default:
jj_consume_token(-1);
throw new ParseException();
}
break;
default:
;
}
jj_consume_token(O_SEMICOLON);
functionType.setReturnArgument(returnDataType);
packageType.addProcedure(functionType);
}
final public ArgumentType functionReturnSpec() throws ParseException {
DatabaseType dataType = null;
jj_consume_token(K_RETURN);
dataType = typeSpec();
ArgumentType returnType = new ArgumentType(null);
returnType.setDirection(ArgumentTypeDirection.RETURN);
returnType.setDataType(dataType);
if (dataType instanceof UnresolvedType) {
((UnresolvedType)dataType).setOwningType(returnType);
}
{if (true) return returnType;}
throw new Error("Missing return statement in function");
}
final public void argument(ProcedureType procedureType) throws ParseException {
Token t = null;
ArgumentType argumentType = null;
DatabaseType argumentDataType = null;
ArgumentTypeDirection argDirection = ArgumentTypeDirection.IN; // by default, arguments are IN
String direction = null;
boolean defaultAssignment = false;
t = jj_consume_token(S_IDENTIFIER);
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case K_IN:
case K_OUT:
direction = direction();
break;
default:
;
}
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case K_NOCOPY:
jj_consume_token(K_NOCOPY);
break;
default:
;
}
argumentDataType = typeSpec();
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case K_DEFAULT:
case O_ASSIGN:
defaultAssignment = argumentDefaultAssignment();
break;
default:
;
}
argumentType = new ArgumentType(t.image);
argumentType.setDataType(argumentDataType);
if (argumentDataType instanceof UnresolvedType) {
((UnresolvedType)argumentDataType).setOwningType(argumentType);
}
if (direction != null) {
if ("OUT".equals(direction)) {
argDirection = ArgumentTypeDirection.OUT;
}
else if ("IN OUT".equals(direction)) {
argDirection = ArgumentTypeDirection.INOUT;
}
argumentType.setDirection(argDirection);
}
if (defaultAssignment) {
argumentType.setOptional();
}
procedureType.addCompositeType(argumentType);
}
final public String direction() throws ParseException {
if (jj_2_20(2)) {
jj_consume_token(K_IN);
jj_consume_token(K_OUT);
{if (true) return "IN OUT";}
} else {
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case K_IN:
jj_consume_token(K_IN);
{if (true) return "IN";}
break;
case K_OUT:
jj_consume_token(K_OUT);
{if (true) return "OUT";}
break;
default:
jj_consume_token(-1);
throw new ParseException();
}
}
throw new Error("Missing return statement in function");
}
final public boolean argumentDefaultAssignment() throws ParseException {
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case O_ASSIGN:
jj_consume_token(O_ASSIGN);
break;
case K_DEFAULT:
jj_consume_token(K_DEFAULT);
break;
default:
jj_consume_token(-1);
throw new ParseException();
}
skipToNextArg();
{if (true) return true;}
throw new Error("Missing return statement in function");
}
final public void exceptionDeclaration(PLSQLPackageType packageType) throws ParseException {
jj_consume_token(S_IDENTIFIER);
jj_consume_token(K_EXCEPTION);
jj_consume_token(O_SEMICOLON);
}
final public void pragmaDeclaration(PLSQLPackageType packageType) throws ParseException {
jj_consume_token(K_PRAGMA);
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case K_AUTONOMOUS_TRANSACTION:
case K_EXCEPTION_INIT:
case K_INLINE:
case K_RESTRICT_REFERENCES:
case K_SERIALLY_REUSABLE:
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case K_AUTONOMOUS_TRANSACTION:
jj_consume_token(K_AUTONOMOUS_TRANSACTION);
break;
case K_EXCEPTION_INIT:
jj_consume_token(K_EXCEPTION_INIT);
jj_consume_token(O_OPENPAREN);
jj_consume_token(S_IDENTIFIER);
jj_consume_token(O_COMMA);
jj_consume_token(S_NUMBER);
jj_consume_token(O_CLOSEPAREN);
break;
case K_SERIALLY_REUSABLE:
jj_consume_token(K_SERIALLY_REUSABLE);
break;
case K_INLINE:
jj_consume_token(K_INLINE);
jj_consume_token(O_OPENPAREN);
jj_consume_token(S_IDENTIFIER);
jj_consume_token(O_COMMA);
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case K_NO:
case K_YES:
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case K_YES:
jj_consume_token(K_YES);
break;
case K_NO:
jj_consume_token(K_NO);
break;
default:
jj_consume_token(-1);
throw new ParseException();
}
break;
default:
;
}
jj_consume_token(O_CLOSEPAREN);
break;
case K_RESTRICT_REFERENCES:
jj_consume_token(K_RESTRICT_REFERENCES);
jj_consume_token(O_OPENPAREN);
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case K_DEFAULT:
case S_IDENTIFIER:
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case S_IDENTIFIER:
jj_consume_token(S_IDENTIFIER);
break;
case K_DEFAULT:
jj_consume_token(K_DEFAULT);
break;
default:
jj_consume_token(-1);
throw new ParseException();
}
break;
default:
;
}
label_5:
while (true) {
jj_consume_token(O_COMMA);
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case K_RNDS:
case K_RNPS:
case K_TRUST:
case K_WNDS:
case K_WNPS:
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case K_RNDS:
jj_consume_token(K_RNDS);
break;
case K_WNDS:
jj_consume_token(K_WNDS);
break;
case K_RNPS:
jj_consume_token(K_RNPS);
break;
case K_WNPS:
jj_consume_token(K_WNPS);
break;
case K_TRUST:
jj_consume_token(K_TRUST);
break;
default:
jj_consume_token(-1);
throw new ParseException();
}
break;
default:
;
}
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case O_COMMA:
;
break;
default:
break label_5;
}
}
jj_consume_token(O_CLOSEPAREN);
break;
default:
jj_consume_token(-1);
throw new ParseException();
}
break;
default:
;
}
jj_consume_token(O_SEMICOLON);
}
final public String OracleObjectName() throws ParseException {
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case S_IDENTIFIER:
jj_consume_token(S_IDENTIFIER);
{if (true) return token.image;}
break;
case S_QUOTED_IDENTIFIER:
jj_consume_token(S_QUOTED_IDENTIFIER);
String s = token.image;
{if (true) return s.substring(1, s.length() - 1);} // strip-off quotes
break;
default:
jj_consume_token(-1);
throw new ParseException();
}
throw new Error("Missing return statement in function");
}
final public void skipToSemiColon() throws ParseException {
Token t = getNextToken();
while (t.kind != O_SEMICOLON) {
t = getNextToken();
}
token_source.input_stream.backup(1);
}
final public void skipToNextArg() throws ParseException {
Token t = getNextToken();
while (t.kind != O_COMMA && t.kind != O_CLOSEPAREN) {
t = getNextToken();
}
token_source.input_stream.backup(1);
}
final public void skipToEnd() throws ParseException {
/** skip through all the tokens. */
Token t = getNextToken();
while (t.kind != EOF) {
t = getNextToken();
}
}
private boolean jj_2_1(int xla) {
jj_la = xla; jj_lastpos = jj_scanpos = token;
try { return !jj_3_1(); }
catch(LookaheadSuccess ls) { return true; }
}
private boolean jj_2_2(int xla) {
jj_la = xla; jj_lastpos = jj_scanpos = token;
try { return !jj_3_2(); }
catch(LookaheadSuccess ls) { return true; }
}
private boolean jj_2_3(int xla) {
jj_la = xla; jj_lastpos = jj_scanpos = token;
try { return !jj_3_3(); }
catch(LookaheadSuccess ls) { return true; }
}
private boolean jj_2_4(int xla) {
jj_la = xla; jj_lastpos = jj_scanpos = token;
try { return !jj_3_4(); }
catch(LookaheadSuccess ls) { return true; }
}
private boolean jj_2_5(int xla) {
jj_la = xla; jj_lastpos = jj_scanpos = token;
try { return !jj_3_5(); }
catch(LookaheadSuccess ls) { return true; }
}
private boolean jj_2_6(int xla) {
jj_la = xla; jj_lastpos = jj_scanpos = token;
try { return !jj_3_6(); }
catch(LookaheadSuccess ls) { return true; }
}
private boolean jj_2_7(int xla) {
jj_la = xla; jj_lastpos = jj_scanpos = token;
try { return !jj_3_7(); }
catch(LookaheadSuccess ls) { return true; }
}
private boolean jj_2_8(int xla) {
jj_la = xla; jj_lastpos = jj_scanpos = token;
try { return !jj_3_8(); }
catch(LookaheadSuccess ls) { return true; }
}
private boolean jj_2_9(int xla) {
jj_la = xla; jj_lastpos = jj_scanpos = token;
try { return !jj_3_9(); }
catch(LookaheadSuccess ls) { return true; }
}
private boolean jj_2_10(int xla) {
jj_la = xla; jj_lastpos = jj_scanpos = token;
try { return !jj_3_10(); }
catch(LookaheadSuccess ls) { return true; }
}
private boolean jj_2_11(int xla) {
jj_la = xla; jj_lastpos = jj_scanpos = token;
try { return !jj_3_11(); }
catch(LookaheadSuccess ls) { return true; }
}
private boolean jj_2_12(int xla) {
jj_la = xla; jj_lastpos = jj_scanpos = token;
try { return !jj_3_12(); }
catch(LookaheadSuccess ls) { return true; }
}
private boolean jj_2_13(int xla) {
jj_la = xla; jj_lastpos = jj_scanpos = token;
try { return !jj_3_13(); }
catch(LookaheadSuccess ls) { return true; }
}
private boolean jj_2_14(int xla) {
jj_la = xla; jj_lastpos = jj_scanpos = token;
try { return !jj_3_14(); }
catch(LookaheadSuccess ls) { return true; }
}
private boolean jj_2_15(int xla) {
jj_la = xla; jj_lastpos = jj_scanpos = token;
try { return !jj_3_15(); }
catch(LookaheadSuccess ls) { return true; }
}
private boolean jj_2_16(int xla) {
jj_la = xla; jj_lastpos = jj_scanpos = token;
try { return !jj_3_16(); }
catch(LookaheadSuccess ls) { return true; }
}
private boolean jj_2_17(int xla) {
jj_la = xla; jj_lastpos = jj_scanpos = token;
try { return !jj_3_17(); }
catch(LookaheadSuccess ls) { return true; }
}
private boolean jj_2_18(int xla) {
jj_la = xla; jj_lastpos = jj_scanpos = token;
try { return !jj_3_18(); }
catch(LookaheadSuccess ls) { return true; }
}
private boolean jj_2_19(int xla) {
jj_la = xla; jj_lastpos = jj_scanpos = token;
try { return !jj_3_19(); }
catch(LookaheadSuccess ls) { return true; }
}
private boolean jj_2_20(int xla) {
jj_la = xla; jj_lastpos = jj_scanpos = token;
try { return !jj_3_20(); }
catch(LookaheadSuccess ls) { return true; }
}
private boolean jj_3R_58() {
if (jj_scan_token(K_CHARACTER)) return true;
return false;
}
private boolean jj_3_9() {
if (jj_scan_token(S_IDENTIFIER)) return true;
return false;
}
private boolean jj_3_14() {
if (jj_scan_token(K_CHARACTER)) return true;
if (jj_scan_token(K_SET)) return true;
return false;
}
private boolean jj_3R_57() {
if (jj_scan_token(K_VARCHAR2)) return true;
return false;
}
private boolean jj_3R_11() {
if (jj_scan_token(K_TYPE2)) return true;
return false;
}
private boolean jj_3_12() {
if (jj_scan_token(K_CHARACTER)) return true;
if (jj_scan_token(K_SET)) return true;
return false;
}
private boolean jj_3R_13() {
if (jj_scan_token(K_ROWTYPE)) return true;
return false;
}
private boolean jj_3_5() {
if (jj_3R_6()) return true;
if (jj_scan_token(O_DOT)) return true;
return false;
}
private boolean jj_3R_56() {
if (jj_scan_token(K_VARCHAR)) return true;
return false;
}
private boolean jj_3R_30() {
Token xsp;
xsp = jj_scanpos;
if (jj_scan_token(120)) {
jj_scanpos = xsp;
if (jj_scan_token(121)) {
jj_scanpos = xsp;
if (jj_scan_token(48)) {
jj_scanpos = xsp;
if (jj_scan_token(47)) return true;
}
}
}
return false;
}
private boolean jj_3R_29() {
if (jj_scan_token(K_SIGNTYPE)) return true;
return false;
}
private boolean jj_3R_28() {
if (jj_scan_token(K_POSITIVE)) return true;
return false;
}
private boolean jj_3R_27() {
if (jj_scan_token(K_NATURAL)) return true;
return false;
}
private boolean jj_3R_26() {
if (jj_scan_token(K_BINARY_DOUBLE)) return true;
return false;
}
private boolean jj_3R_25() {
if (jj_scan_token(K_BINARY_FLOAT)) return true;
return false;
}
private boolean jj_3R_20() {
if (jj_scan_token(O_DOT)) return true;
if (jj_3R_6()) return true;
return false;
}
private boolean jj_3R_21() {
Token xsp;
xsp = jj_scanpos;
if (jj_3R_24()) {
jj_scanpos = xsp;
if (jj_3R_25()) {
jj_scanpos = xsp;
if (jj_3R_26()) {
jj_scanpos = xsp;
if (jj_3R_27()) {
jj_scanpos = xsp;
if (jj_3R_28()) {
jj_scanpos = xsp;
if (jj_3R_29()) {
jj_scanpos = xsp;
if (jj_3R_30()) {
jj_scanpos = xsp;
if (jj_3R_31()) {
jj_scanpos = xsp;
if (jj_3R_32()) {
jj_scanpos = xsp;
if (jj_3R_33()) {
jj_scanpos = xsp;
if (jj_3R_34()) {
jj_scanpos = xsp;
if (jj_3_17()) {
jj_scanpos = xsp;
if (jj_3R_35()) {
jj_scanpos = xsp;
if (jj_3R_36()) {
jj_scanpos = xsp;
if (jj_3R_37()) {
jj_scanpos = xsp;
if (jj_3R_38()) {
jj_scanpos = xsp;
if (jj_3R_39()) {
jj_scanpos = xsp;
if (jj_3R_40()) {
jj_scanpos = xsp;
if (jj_3R_41()) {
jj_scanpos = xsp;
if (jj_3R_42()) {
jj_scanpos = xsp;
if (jj_3R_43()) {
jj_scanpos = xsp;
if (jj_3R_44()) {
jj_scanpos = xsp;
if (jj_3R_45()) {
jj_scanpos = xsp;
if (jj_3R_46()) {
jj_scanpos = xsp;
if (jj_3R_47()) {
jj_scanpos = xsp;
if (jj_3R_48()) {
jj_scanpos = xsp;
if (jj_3R_49()) {
jj_scanpos = xsp;
if (jj_3R_50()) {
jj_scanpos = xsp;
if (jj_3R_51()) {
jj_scanpos = xsp;
if (jj_3R_52()) {
jj_scanpos = xsp;
if (jj_3R_53()) {
jj_scanpos = xsp;
if (jj_3R_54()) {
jj_scanpos = xsp;
if (jj_3R_55()) {
jj_scanpos = xsp;
if (jj_3R_56()) {
jj_scanpos = xsp;
if (jj_3R_57()) {
jj_scanpos = xsp;
if (jj_3R_58()) {
jj_scanpos = xsp;
if (jj_3R_59()) {
jj_scanpos = xsp;
if (jj_3R_60()) {
jj_scanpos = xsp;
if (jj_3R_61()) {
jj_scanpos = xsp;
if (jj_3R_62()) {
jj_scanpos = xsp;
if (jj_3R_63()) return true;
}
}
}
}
}
}
}
}
}
}
}
}
}
}
}
}
}
}
}
}
}
}
}
}
}
}
}
}
}
}
}
}
}
}
}
}
}
}
}
}
return false;
}
private boolean jj_3R_24() {
if (jj_scan_token(K_BINARY_INTEGER)) return true;
return false;
}
private boolean jj_3_10() {
if (jj_scan_token(K_CHARACTER)) return true;
if (jj_scan_token(K_SET)) return true;
return false;
}
private boolean jj_3_18() {
if (jj_3R_10()) return true;
Token xsp;
xsp = jj_scanpos;
if (jj_3R_11()) jj_scanpos = xsp;
return false;
}
private boolean jj_3R_55() {
if (jj_scan_token(K_CHAR)) return true;
return false;
}
private boolean jj_3R_19() {
if (jj_scan_token(O_DOT)) return true;
if (jj_3R_6()) return true;
return false;
}
private boolean jj_3R_54() {
if (jj_scan_token(K_DOUBLE)) return true;
return false;
}
private boolean jj_3_19() {
if (jj_3R_12()) return true;
Token xsp;
xsp = jj_scanpos;
if (jj_3R_13()) jj_scanpos = xsp;
return false;
}
private boolean jj_3_4() {
if (jj_3R_6()) return true;
if (jj_scan_token(O_DOT)) return true;
return false;
}
private boolean jj_3R_12() {
if (jj_3R_6()) return true;
Token xsp;
xsp = jj_scanpos;
if (jj_3R_20()) jj_scanpos = xsp;
return false;
}
private boolean jj_3R_53() {
if (jj_scan_token(K_UROWID)) return true;
return false;
}
private boolean jj_3R_52() {
if (jj_scan_token(K_ROWID)) return true;
return false;
}
private boolean jj_3_15() {
if (jj_scan_token(S_IDENTIFIER)) return true;
return false;
}
private boolean jj_3R_51() {
if (jj_scan_token(K_BFILE)) return true;
return false;
}
private boolean jj_3R_50() {
if (jj_scan_token(K_NCLOB)) return true;
return false;
}
private boolean jj_3R_9() {
if (jj_scan_token(S_IDENTIFIER)) return true;
Token xsp;
xsp = jj_scanpos;
if (jj_scan_token(35)) jj_scanpos = xsp;
if (jj_3R_18()) return true;
return false;
}
private boolean jj_3R_49() {
if (jj_scan_token(K_BLOB)) return true;
return false;
}
private boolean jj_3R_48() {
if (jj_scan_token(K_SYS_REFCURSOR)) return true;
return false;
}
private boolean jj_3R_47() {
if (jj_scan_token(K_SIMPLE_DOUBLE)) return true;
return false;
}
private boolean jj_3R_46() {
if (jj_scan_token(K_SIMPLE_FLOAT)) return true;
return false;
}
private boolean jj_3R_45() {
if (jj_scan_token(K_SIMPLE_INTEGER)) return true;
return false;
}
private boolean jj_3R_44() {
if (jj_scan_token(K_PLS_INTEGER)) return true;
return false;
}
private boolean jj_3R_43() {
if (jj_scan_token(K_MLSLABEL)) return true;
return false;
}
private boolean jj_3R_42() {
if (jj_scan_token(K_REAL)) return true;
return false;
}
private boolean jj_3R_10() {
if (jj_3R_6()) return true;
Token xsp;
xsp = jj_scanpos;
if (jj_3R_19()) jj_scanpos = xsp;
return false;
}
private boolean jj_3_8() {
if (jj_3R_9()) return true;
return false;
}
private boolean jj_3R_41() {
if (jj_scan_token(K_FLOAT)) return true;
return false;
}
private boolean jj_3R_40() {
if (jj_scan_token(K_SMALLINT)) return true;
return false;
}
private boolean jj_3_3() {
if (jj_3R_6()) return true;
if (jj_scan_token(O_DOT)) return true;
return false;
}
private boolean jj_3R_39() {
if (jj_scan_token(K_INT)) return true;
return false;
}
private boolean jj_3R_38() {
if (jj_scan_token(K_INTEGER)) return true;
return false;
}
private boolean jj_3R_15() {
if (jj_scan_token(S_QUOTED_IDENTIFIER)) return true;
return false;
}
private boolean jj_3R_14() {
if (jj_scan_token(S_IDENTIFIER)) return true;
return false;
}
private boolean jj_3R_6() {
Token xsp;
xsp = jj_scanpos;
if (jj_3R_14()) {
jj_scanpos = xsp;
if (jj_3R_15()) return true;
}
return false;
}
private boolean jj_3_16() {
if (jj_scan_token(K_CHARACTER)) return true;
if (jj_scan_token(K_SET)) return true;
return false;
}
private boolean jj_3R_23() {
if (jj_3R_10()) return true;
return false;
}
private boolean jj_3R_22() {
if (jj_3R_21()) return true;
return false;
}
private boolean jj_3R_37() {
if (jj_scan_token(K_TIMESTAMP)) return true;
return false;
}
private boolean jj_3R_36() {
if (jj_scan_token(K_TIME)) return true;
return false;
}
private boolean jj_3R_18() {
Token xsp;
xsp = jj_scanpos;
if (jj_3R_22()) {
jj_scanpos = xsp;
if (jj_3R_23()) return true;
}
return false;
}
private boolean jj_3_2() {
if (jj_3R_6()) return true;
if (jj_scan_token(O_DOT)) return true;
return false;
}
private boolean jj_3R_63() {
if (jj_scan_token(K_CLOB)) return true;
return false;
}
private boolean jj_3R_35() {
if (jj_scan_token(K_INTERVAL)) return true;
return false;
}
private boolean jj_3R_8() {
if (jj_3R_6()) return true;
return false;
}
private boolean jj_3_20() {
if (jj_scan_token(K_IN)) return true;
if (jj_scan_token(K_OUT)) return true;
return false;
}
private boolean jj_3R_17() {
if (jj_3R_10()) return true;
return false;
}
private boolean jj_3_1() {
if (jj_3R_6()) return true;
if (jj_scan_token(O_DOT)) return true;
return false;
}
private boolean jj_3R_16() {
if (jj_3R_21()) return true;
return false;
}
private boolean jj_3R_62() {
if (jj_scan_token(K_NATIONAL)) return true;
return false;
}
private boolean jj_3R_7() {
Token xsp;
xsp = jj_scanpos;
if (jj_3R_16()) {
jj_scanpos = xsp;
if (jj_3R_17()) return true;
}
return false;
}
private boolean jj_3_17() {
if (jj_scan_token(K_INTERVAL)) return true;
if (jj_scan_token(K_DAY)) return true;
return false;
}
private boolean jj_3R_34() {
if (jj_scan_token(K_DATE)) return true;
return false;
}
private boolean jj_3R_33() {
if (jj_scan_token(K_BOOLEAN)) return true;
return false;
}
private boolean jj_3R_61() {
if (jj_scan_token(K_NVARCHAR2)) return true;
return false;
}
private boolean jj_3R_32() {
if (jj_scan_token(K_RAW)) return true;
return false;
}
private boolean jj_3_7() {
Token xsp;
xsp = jj_scanpos;
if (jj_scan_token(36)) jj_scanpos = xsp;
xsp = jj_scanpos;
if (jj_3R_8()) jj_scanpos = xsp;
if (jj_scan_token(K_PRIMARY)) return true;
if (jj_scan_token(K_KEY)) return true;
return false;
}
private boolean jj_3R_60() {
if (jj_scan_token(K_NVARCHAR)) return true;
return false;
}
private boolean jj_3_6() {
if (jj_3R_6()) return true;
if (jj_3R_7()) return true;
return false;
}
private boolean jj_3_13() {
if (jj_scan_token(S_IDENTIFIER)) return true;
return false;
}
private boolean jj_3R_31() {
if (jj_scan_token(K_LONG)) return true;
return false;
}
private boolean jj_3R_59() {
if (jj_scan_token(K_NCHAR)) return true;
return false;
}
private boolean jj_3_11() {
if (jj_scan_token(S_IDENTIFIER)) return true;
return false;
}
/** Generated Token Manager. */
public DDLParserTokenManager token_source;
JavaCharStream jj_input_stream;
/** Current token. */
public Token token;
/** Next token. */
public Token jj_nt;
private int jj_ntk;
private Token jj_scanpos, jj_lastpos;
private int jj_la;
/** Constructor with InputStream. */
public DDLParser(java.io.InputStream stream) {
this(stream, null);
}
/** Constructor with InputStream and supplied encoding */
public DDLParser(java.io.InputStream stream, String encoding) {
try { jj_input_stream = new JavaCharStream(stream, encoding, 1, 1); } catch(java.io.UnsupportedEncodingException e) { throw new RuntimeException(e); }
token_source = new DDLParserTokenManager(jj_input_stream);
token = new Token();
jj_ntk = -1;
}
/** Reinitialise. */
public void ReInit(java.io.InputStream stream) {
ReInit(stream, null);
}
/** Reinitialise. */
public void ReInit(java.io.InputStream stream, String encoding) {
try { jj_input_stream.ReInit(stream, encoding, 1, 1); } catch(java.io.UnsupportedEncodingException e) { throw new RuntimeException(e); }
token_source.ReInit(jj_input_stream);
token = new Token();
jj_ntk = -1;
jjtree.reset();
}
/** Constructor. */
public DDLParser(java.io.Reader stream) {
jj_input_stream = new JavaCharStream(stream, 1, 1);
token_source = new DDLParserTokenManager(jj_input_stream);
token = new Token();
jj_ntk = -1;
}
/** Reinitialise. */
public void ReInit(java.io.Reader stream) {
jj_input_stream.ReInit(stream, 1, 1);
token_source.ReInit(jj_input_stream);
token = new Token();
jj_ntk = -1;
jjtree.reset();
}
/** Constructor with generated Token Manager. */
public DDLParser(DDLParserTokenManager tm) {
token_source = tm;
token = new Token();
jj_ntk = -1;
}
/** Reinitialise. */
public void ReInit(DDLParserTokenManager tm) {
token_source = tm;
token = new Token();
jj_ntk = -1;
jjtree.reset();
}
private Token jj_consume_token(int kind) throws ParseException {
Token oldToken;
if ((oldToken = token).next != null) token = token.next;
else token = token.next = token_source.getNextToken();
jj_ntk = -1;
if (token.kind == kind) {
return token;
}
token = oldToken;
throw generateParseException();
}
static private final class LookaheadSuccess extends java.lang.Error { }
final private LookaheadSuccess jj_ls = new LookaheadSuccess();
private boolean jj_scan_token(int kind) {
if (jj_scanpos == jj_lastpos) {
jj_la--;
if (jj_scanpos.next == null) {
jj_lastpos = jj_scanpos = jj_scanpos.next = token_source.getNextToken();
} else {
jj_lastpos = jj_scanpos = jj_scanpos.next;
}
} else {
jj_scanpos = jj_scanpos.next;
}
if (jj_scanpos.kind != kind) return true;
if (jj_la == 0 && jj_scanpos == jj_lastpos) throw jj_ls;
return false;
}
/** Get the next Token. */
final public Token getNextToken() {
if (token.next != null) token = token.next;
else token = token.next = token_source.getNextToken();
jj_ntk = -1;
return token;
}
/** Get the specific Token. */
final public Token getToken(int index) {
Token t = token;
for (int i = 0; i < index; i++) {
if (t.next != null) t = t.next;
else t = t.next = token_source.getNextToken();
}
return t;
}
private int jj_ntk() {
if ((jj_nt=token.next) == null)
return (jj_ntk = (token.next=token_source.getNextToken()).kind);
else
return (jj_ntk = jj_nt.kind);
}
/** Generate ParseException. */
public ParseException generateParseException() {
Token errortok = token.next;
int line = errortok.beginLine, column = errortok.beginColumn;
String mess = (errortok.kind == 0) ? tokenImage[0] : errortok.image;
return new ParseException("Parse error at line " + line + ", column " + column + ". Encountered: " + mess);
}
/** Enable tracing. */
final public void enable_tracing() {
}
/** Disable tracing. */
final public void disable_tracing() {
}
}