本文整理匯總了Java中org.walkmod.javalang.ast.expr.Expression.getSymbolData方法的典型用法代碼示例。如果您正苦於以下問題:Java Expression.getSymbolData方法的具體用法?Java Expression.getSymbolData怎麽用?Java Expression.getSymbolData使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類org.walkmod.javalang.ast.expr.Expression
的用法示例。
在下文中一共展示了Expression.getSymbolData方法的7個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。
示例1: visit
import org.walkmod.javalang.ast.expr.Expression; //導入方法依賴的package包/類
@Override
public void visit(SuperExpr n, A arg) {
Expression classExpr = n.getClassExpr();
Symbol<?> s = null;
if (classExpr == null) {
s = symbolTable.lookUpSymbolForRead("super", null, ReferenceType.VARIABLE);
} else {
classExpr.accept(this, arg);
SymbolData sd = classExpr.getSymbolData();
Class<?> aux = sd.getClazz().getSuperclass();
if (aux == null) {
aux = Object.class;
}
s = symbolTable.lookUpSymbolForRead(aux.getCanonicalName(), null, ReferenceType.TYPE);
}
if (n.getSymbolData() == null && s != null) {
n.setSymbolData(s.getType());
}
}
示例2: visit
import org.walkmod.javalang.ast.expr.Expression; //導入方法依賴的package包/類
@Override
public void visit(ArrayInitializerExpr n, A arg) {
if (n.getValues() != null) {
List<Expression> values = n.getValues();
SymbolType st = null;
for (Expression expr : values) {
expr.accept(this, arg);
SymbolData sd = expr.getSymbolData();
if (st == null && sd != null) {
st = (SymbolType) sd;
st = st.clone();
} else if (sd != null) {
st = (SymbolType) st.merge(sd);
}
}
if (values != null && !values.isEmpty() && st != null) {
st.setArrayCount(st.getArrayCount() + 1);
}
n.setSymbolData(st);
}
}
示例3: argTypes
import org.walkmod.javalang.ast.expr.Expression; //導入方法依賴的package包/類
private ArgTypes argTypes(List<Expression> args, A arg) {
boolean hasFunctionalExpressions = false;
SymbolType[] symbolTypes = null;
if (args != null) {
symbolTypes = new SymbolType[args.size()];
int i = 0;
for (Expression e : args) {
if (!(e instanceof LambdaExpr) && !(e instanceof MethodReferenceExpr)) {
e.accept(this, arg);
SymbolType argType = null;
if (e instanceof ObjectCreationExpr) {
ObjectCreationExpr aux = (ObjectCreationExpr) e;
argType = (SymbolType) aux.getType().getSymbolData();
} else {
argType = (SymbolType) e.getSymbolData();
}
symbolTypes[i] = argType;
} else {
hasFunctionalExpressions = true;
}
i++;
}
} else {
symbolTypes = new SymbolType[0];
}
return new ArgTypes(symbolTypes, hasFunctionalExpressions);
}
示例4: testMethodsThatReturnsMatrixs
import org.walkmod.javalang.ast.expr.Expression; //導入方法依賴的package包/類
@Test
public void testMethodsThatReturnsMatrixs() throws Exception {
CompilationUnit cu = run(
"public class A { char[][] bar(){ return new char[0][0]; } void foo(String s) { int i = bar().length; }}");
MethodDeclaration md = (MethodDeclaration) cu.getTypes().get(0).getMembers().get(1);
ExpressionStmt stmt = (ExpressionStmt) md.getBody().getStmts().get(0);
VariableDeclarationExpr vexpr = (VariableDeclarationExpr) stmt.getExpression();
Expression expr = vexpr.getVars().get(0).getInit();
SymbolData sd = expr.getSymbolData();
Assert.assertNotNull(sd);
Assert.assertEquals("int", sd.getName());
}
示例5: filter
import org.walkmod.javalang.ast.expr.Expression; //導入方法依賴的package包/類
@Override
public boolean filter(Class<?> candidate) {
boolean isCompatible = true;
List<Method> methods = new LinkedList<Method>();
boolean returnTypeCompatible = false;
methods.addAll(Arrays.asList(candidate.getDeclaredMethods()));
methods.addAll(Arrays.asList(candidate.getMethods()));
Iterator<Method> it = methods.iterator();
while (it.hasNext() && !returnTypeCompatible) {
Method currentMethod = it.next();
// checking method name
if (currentMethod.getName().equals(requiredMethod.getName())) {
List<Expression> args = requiredMethod.getArgs();
Class<?>[] parameterTypes = currentMethod.getParameterTypes();
if (args != null) {
boolean compatibleArgs = true;
int k = 0;
for (Expression argExpr : args) {
argExpr.accept(visitor, ctx);
SymbolType typeArg = (SymbolType) argExpr.getSymbolData();
if (!Types.isCompatible(typeArg.getClazz(), parameterTypes[k])) {
compatibleArgs = false;
}
k++;
}
returnTypeCompatible = compatibleArgs;
} else {
returnTypeCompatible = true;
}
}
}
isCompatible = returnTypeCompatible;
return isCompatible;
}
示例6: filter
import org.walkmod.javalang.ast.expr.Expression; //導入方法依賴的package包/類
public boolean filter(java.lang.reflect.Type[] genericTypes, Class<?> declaringClass) throws Exception {
boolean found = false;
boolean containsLambda = false;
SymbolType[] inferredTypes = null;
if (previousPredicate != null) {
inferredTypes = previousPredicate.getInferredMethodArgs();
}
if (args != null && !args.isEmpty()) {
Iterator<Expression> it = args.iterator();
int i = 0;
while (it.hasNext() && !found) {
SymbolType argType = null;
if (inferredTypes != null) {
argType = inferredTypes[i];
}
Expression current = it.next();
if (current instanceof LambdaExpr || current instanceof MethodReferenceExpr) {
containsLambda = true;
Class<?> interfaceToInspect = null;
if (inferredTypes[i].getClazz().isInterface()) {
interfaceToInspect = inferredTypes[i].getClazz();
} else if (isVarArgs && i == params.length - 1) {
Class<?> componentType = inferredTypes[i].getClazz();
if (componentType.isInterface()) {
interfaceToInspect = componentType;
}
}
if (interfaceToInspect != null) {
if (current instanceof LambdaExpr) {
found = filter((LambdaExpr) current, interfaceToInspect, genericTypes[i], argType,
declaringClass);
if (found) {
calculatedTypeArgs[i] = (SymbolType) current.getSymbolData();
}
} else {
found = filter((MethodReferenceExpr) current, interfaceToInspect, genericTypes[i], argType,
declaringClass);
if (found) {
calculatedTypeArgs[i] = (SymbolType) current.getSymbolData();
}
}
}
}
if (i < params.length - 1) {
i++;
}
}
}
return (found && containsLambda) || !containsLambda;
}
示例7: build
import org.walkmod.javalang.ast.expr.Expression; //導入方法依賴的package包/類
@Override
public MethodCallExpr build(MethodCallExpr n) throws Exception {
List<Expression> args = n.getArgs();
MethodSymbolData st = n.getSymbolData();
if (args != null) {
int i = 0;
if (st == null) {
Expression scope = n.getScope();
String scopeName = "empty";
if (scope != null) {
scopeName = scope.getSymbolData().toString();
}
String argsTypeName = "empty";
List<Expression> argExpr = n.getArgs();
if (argExpr != null) {
argsTypeName = "[";
Iterator<Expression> it = argExpr.iterator();
while (it.hasNext()) {
Expression arg = it.next();
if (arg != null && arg.getSymbolData() != null) {
argsTypeName += " " + arg.getSymbolData().toString();
} else {
argsTypeName += " null";
}
if (it.hasNext()) {
argsTypeName += ",";
}
}
argsTypeName += "]";
}
throw new Exception("Ops! The method call " + n.toString() + " is not resolved. The scope is ["
+ scopeName + "] , and the args are : " + argsTypeName);
}
java.lang.reflect.Type[] argClasses = st.getMethod().getGenericParameterTypes();
int paramCount = st.getMethod().getParameterTypes().length;
for (Expression argument : args) {
if (argument instanceof MethodReferenceExpr) {
SymbolType aux = null;
if (i < paramCount) {
aux = SymbolType.valueOf(argClasses[i], typeMapping);
} else {
java.lang.reflect.Type componentType = null;
java.lang.reflect.Type lastArg = argClasses[argClasses.length - 1];
if (lastArg instanceof Class<?>) {
componentType = ((Class<?>) lastArg).getComponentType();
} else if (lastArg instanceof GenericArrayType) {
componentType = ((GenericArrayType) lastArg).getGenericComponentType();
}
aux = SymbolType.valueOf(componentType, typeMapping);
}
argument.setSymbolData(aux);
argument.accept(visitor, ctxt);
}
i++;
}
}
return null;
}