當前位置: 首頁>>代碼示例>>Java>>正文


Java Result類代碼示例

本文整理匯總了Java中org.checkerframework.framework.source.Result的典型用法代碼示例。如果您正苦於以下問題:Java Result類的具體用法?Java Result怎麽用?Java Result使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


Result類屬於org.checkerframework.framework.source包,在下文中一共展示了Result類的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: visitVariable

import org.checkerframework.framework.source.Result; //導入依賴的package包/類
@Override
public Void visitVariable(VariableTree node, Void p) {
    // is this a field (and not a local variable)?
    if (TreeUtils.elementFromDeclaration(node).getKind().isField()) {
        Set<AnnotationMirror> annotationMirrors = atypeFactory.getAnnotatedType(
                node).getExplicitAnnotations();
        // Fields cannot have commitment annotations.
        for (Class<? extends Annotation> c : atypeFactory.getInitializationAnnotations()) {
            for (AnnotationMirror a : annotationMirrors) {
                if (atypeFactory.isUnclassified(a)) continue; // unclassified is allowed
                if (AnnotationUtils.areSameByClass(a, c)) {
                    checker.report(Result.failure(
                            COMMITMENT_INVALID_FIELD_ANNOTATION, node),
                            node);
                    break;
                }
            }
        }
    }
    return super.visitVariable(node, p);
}
 
開發者ID:reprogrammer,項目名稱:checker-framework,代碼行數:22,代碼來源:InitializationVisitor.java

示例2: visitMethod

import org.checkerframework.framework.source.Result; //導入依賴的package包/類
@Override
public Void visitMethod(MethodTree node, Void p) {
    if (TreeUtils.isConstructor(node)) {
        Collection<? extends AnnotationMirror> returnTypeAnnotations = getExplicitReturnTypeAnnotations(node);
        // check for invalid constructor return type
        for (Class<? extends Annotation> c : atypeFactory.getInvalidConstructorReturnTypeAnnotations()) {
            for (AnnotationMirror a : returnTypeAnnotations) {
                if (AnnotationUtils.areSameByClass(a, c)) {
                    checker.report(Result.failure(
                            COMMITMENT_INVALID_CONSTRUCTOR_RETURN_TYPE,
                            node), node);
                    break;
                }
            }
        }

        // Check that all fields have been initialized at the end of the
        // constructor.
        boolean isStatic = false;
        Store store = atypeFactory.getRegularExitStore(node);
        List<? extends AnnotationMirror> receiverAnnotations = getAllReceiverAnnotations(node);
        checkFieldsInitialized(node, isStatic, store, receiverAnnotations);
    }
    return super.visitMethod(node, p);
}
 
開發者ID:reprogrammer,項目名稱:checker-framework,代碼行數:26,代碼來源:InitializationVisitor.java

示例3: visitNewArray

import org.checkerframework.framework.source.Result; //導入依賴的package包/類
@Override
public Void visitNewArray(NewArrayTree node, Void p) {
    AnnotatedArrayType type = atypeFactory.getAnnotatedType(node);
    AnnotatedTypeMirror componentType = type.getComponentType();
    if (componentType.hasEffectiveAnnotation(NONNULL)
            && !isNewArrayAllZeroDims(node)
            && !isNewArrayInToArray(node)
            && !TypesUtils.isPrimitive(componentType.getUnderlyingType())
            && checker.getLintOption("arrays:forbidnonnullcomponents",
                    false)) {
        checker.report(
                Result.failure("new.array.type.invalid",
                        componentType.getAnnotations(), type.toString()),
                node);
    }

    return super.visitNewArray(node, p);
}
 
開發者ID:reprogrammer,項目名稱:checker-framework,代碼行數:19,代碼來源:NullnessVisitor.java

示例4: checkOverride

import org.checkerframework.framework.source.Result; //導入依賴的package包/類
@Override
protected boolean checkOverride(MethodTree overriderTree,
        AnnotatedDeclaredType enclosingType,
        AnnotatedExecutableType overridden,
        AnnotatedDeclaredType overriddenType,
        Void p) {

    List<String> overriderLocks = methodHolding(TreeUtils.elementFromDeclaration(overriderTree));
    List<String> overriddenLocks = methodHolding(overridden.getElement());

    boolean isValid = overriddenLocks.containsAll(overriderLocks);

    if (!isValid) {
        checker.report(Result.failure("override.holding.invalid",
                TreeUtils.elementFromDeclaration(overriderTree),
                overridden.getElement(),
                overriderLocks, overriddenLocks), overriderTree);
    }

    return super.checkOverride(overriderTree, enclosingType, overridden, overriddenType, p) && isValid;
}
 
開發者ID:reprogrammer,項目名稱:checker-framework,代碼行數:22,代碼來源:LockVisitor.java

示例5: visitCompoundAssignment

import org.checkerframework.framework.source.Result; //導入依賴的package包/類
@Override
public Void visitCompoundAssignment(CompoundAssignmentTree node, Void p) {
    ExpressionTree var = node.getVariable();
    ExpressionTree expr = node.getExpression();
    AnnotatedTypeMirror varType = atypeFactory.getAnnotatedType(var);
    AnnotatedTypeMirror exprType = atypeFactory.getAnnotatedType(expr);

    Kind kind = node.getKind();

    if ( (kind == Kind.PLUS_ASSIGNMENT || kind == Kind.MINUS_ASSIGNMENT)) {
        if (!atypeFactory.getTypeHierarchy().isSubtype(exprType, varType)) {
            checker.report(Result.failure("compound.assignment.type.incompatible",
                    varType, exprType), node);
        }
    } else if (exprType.getAnnotation(UnknownUnits.class) == null) {
        // Only allow mul/div with unqualified units
        checker.report(Result.failure("compound.assignment.type.incompatible",
                varType, exprType), node);
    }

    return null; // super.visitCompoundAssignment(node, p);
}
 
開發者ID:reprogrammer,項目名稱:checker-framework,代碼行數:23,代碼來源:UnitsVisitor.java

示例6: checkContractsSubset

import org.checkerframework.framework.source.Result; //導入依賴的package包/類
/**
 * Checks that {@code mustSubset} is a subset of {@code set} in the
 * following sense: For every expression in {@code mustSubset} there must be the
 * same expression in {@code set}, with the same (or a stronger) annotation.
 */
private void checkContractsSubset(String subCl, String superCl, Set<Pair<Receiver, AnnotationMirror>> mustSubset,
        Set<Pair<Receiver, AnnotationMirror>> set, /*@CompilerMessageKey*/ String messageKey) {
    for (Pair<Receiver, AnnotationMirror> a : mustSubset) {
        boolean found = false;

        for (Pair<Receiver, AnnotationMirror> b : set) {
            // are we looking at a contract of the same receiver?
            if (a.first.equals(b.first)) {
                // check subtyping relationship of annotations
                QualifierHierarchy qualifierHierarchy = atypeFactory.getQualifierHierarchy();
                if (qualifierHierarchy.isSubtype(a.second, b.second)) {
                    found = true;
                    break;
                }
            }
        }

        if (!found) {
            MethodTree method = visitorState.getMethodTree();
            checker.report(Result.failure(messageKey, a.first, method
                    .getName().toString(), subCl, superCl), method);
        }
    }
}
 
開發者ID:reprogrammer,項目名稱:checker-framework,代碼行數:30,代碼來源:BaseTypeVisitor.java

示例7: checkAccess

import org.checkerframework.framework.source.Result; //導入依賴的package包/類
protected void checkAccess(IdentifierTree node, Void p) {
    MemberSelectTree memberSel = enclosingMemberSelect();
    ExpressionTree tree;
    Element elem;

    if (memberSel == null) {
        tree = node;
        elem = TreeUtils.elementFromUse(node);
    } else {
        tree = memberSel;
        elem = TreeUtils.elementFromUse(memberSel);
    }

    if (elem == null || !elem.getKind().isField())
        return;

    AnnotatedTypeMirror receiver = atypeFactory.getReceiverType(tree);

    if (!isAccessAllowed(elem, receiver, tree)) {
        checker.report(Result.failure("unallowed.access", elem, receiver), node);
    }
}
 
開發者ID:reprogrammer,項目名稱:checker-framework,代碼行數:23,代碼來源:BaseTypeVisitor.java

示例8: evaluateUnaryOperator

import org.checkerframework.framework.source.Result; //導入依賴的package包/類
private AnnotationMirror evaluateUnaryOperator(
        AnnotationMirror argAnno, String operation, Class<?> argClass,
        UnaryTree tree) {
    try {
        Class<?>[] argClasses = new Class<?>[] { argClass };
        Method m = Operators.class.getMethod(operation, argClasses);

        List<?> annoValues = AnnotationUtils.getElementValueArray(
                argAnno, "value", argClass, true);
        ArrayList<Object> results = new ArrayList<Object>(
                annoValues.size());

        for (Object val : annoValues) {
            results.add(m.invoke(null, new Object[] { val }));
        }
        return resultAnnotationHandler(m.getReturnType(), results);
    } catch (ReflectiveOperationException e) {
        checker.report(Result
                .warning("operator.unary.evaluation.failed", operation,
                        argClass), tree);
        return null;
    }
}
 
開發者ID:reprogrammer,項目名稱:checker-framework,代碼行數:24,代碼來源:ValueAnnotatedTypeFactory.java

示例9: checkReportUse

import org.checkerframework.framework.source.Result; //導入依賴的package包/類
/**
 * Check for uses of the {@link ReportUse} annotation.
 * This method has to be called for every explicit or implicit use of a type,
 * most cases are simply covered by the type validator.
 *
 * @param node The tree for error reporting only.
 * @param member The element from which to start looking.
 */
private void checkReportUse(Tree node, Element member) {
    Element loop = member;
    while (loop != null) {
        boolean report = this.atypeFactory.getDeclAnnotation(loop, ReportUse.class) != null;
        if (report) {
            checker.report(Result.failure("usage", node,
                    ElementUtils.getVerboseName(loop), loop.getKind(),
                    ElementUtils.getVerboseName(member), member.getKind()), node);
            break;
        } else {
            if (loop.getKind() == ElementKind.PACKAGE) {
                loop = ElementUtils.parentPackage(elements, (PackageElement)loop);
                continue;
            }
        }
        // Package will always be the last iteration.
        loop = loop.getEnclosingElement();
    }
}
 
開發者ID:reprogrammer,項目名稱:checker-framework,代碼行數:28,代碼來源:ReportVisitor.java

示例10: visitClass

import org.checkerframework.framework.source.Result; //導入依賴的package包/類
@Override
public Void visitClass(ClassTree node, Void p) {
    TypeElement member = TreeUtils.elementFromDeclaration(node);
    boolean report = false;
    // No need to check on the declaring class itself
    // this.atypeFactory.getDeclAnnotation(member, ReportInherit.class) != null;

    // Check whether any superclass/interface had the ReportInherit annotation.
    List<TypeElement> suptypes = ElementUtils.getSuperTypes(member);
    for (TypeElement sup : suptypes) {
        report = this.atypeFactory.getDeclAnnotation(sup, ReportInherit.class) != null;
        if (report) {
            checker.report(Result.failure("inherit", node, ElementUtils.getVerboseName(sup)), node);
        }
    }
    return super.visitClass(node, p);
}
 
開發者ID:reprogrammer,項目名稱:checker-framework,代碼行數:18,代碼來源:ReportVisitor.java

示例11: visitMethod

import org.checkerframework.framework.source.Result; //導入依賴的package包/類
@Override
public Void visitMethod(MethodTree node, Void p) {
    ExecutableElement method = TreeUtils.elementFromDeclaration(node);
    boolean report = false;

    // Check all overridden methods.
    Map<AnnotatedDeclaredType, ExecutableElement> overriddenMethods =
        AnnotatedTypes.overriddenMethods(elements, atypeFactory, method);
    for (Map.Entry<AnnotatedDeclaredType, ExecutableElement> pair: overriddenMethods.entrySet()) {
        // AnnotatedDeclaredType overriddenType = pair.getKey();
        ExecutableElement exe = pair.getValue();
        report = this.atypeFactory.getDeclAnnotation(exe, ReportOverride.class) != null;
        if (report) {
            // Set method to report the right method, if found.
            method = exe;
            break;
        }
    }

    if (report) {
        checker.report(Result.failure("override", node,
                ElementUtils.getVerboseName(method)), node);
    }
    return super.visitMethod(node, p);
}
 
開發者ID:reprogrammer,項目名稱:checker-framework,代碼行數:26,代碼來源:ReportVisitor.java

示例12: scan

import org.checkerframework.framework.source.Result; //導入依賴的package包/類
@Override
public Void scan(Tree tree, Void p) {
    if (TreeUtils.isExpressionTree(tree)) {
        ExpressionTree expTree = (ExpressionTree) tree;
        TreeSpec treeSpec =
            new TreeSpec(expTree.toString().trim(),
                    root.getLineMap().getLineNumber(((JCTree)expTree).pos));
        if (expected.containsKey(treeSpec)) {
            String actualType = canonizeTypeString(atypeFactory.getAnnotatedType(expTree).toString());
            String expectedType = expected.get(treeSpec);
            if (!actualType.equals(expectedType)) {
                /*>>>
                // The key is added above using a setProperty call, which is not supported by the CompilerMessageChecker
                @SuppressWarnings("compilermessages")
                */
                Result res = Result.failure("type.unexpected", tree.toString(), actualType, expectedType);
                FactoryTestChecker.this.report(res, tree);
            }
        }
    }
    return super.scan(tree, p);
}
 
開發者ID:reprogrammer,項目名稱:checker-framework,代碼行數:23,代碼來源:FactoryTestChecker.java

示例13: visitMethodInvocation

import org.checkerframework.framework.source.Result; //導入依賴的package包/類
@Override
public TransferResult<AffinePointerValue, AffinePointerStore>
       visitMethodInvocation(MethodInvocationNode n, TransferInput<AffinePointerValue, AffinePointerStore> in) {
	
	TransferResult<AffinePointerValue, AffinePointerStore> result = super.visitMethodInvocation(n, in);
	
	int i = 0;
	List<? extends VariableElement> argumentTypes = n.getTarget().getMethod().getParameters();
	for (Node operand : n.getArguments()) {
		//We should invalidate the variable if it and the argument both have type @Affine.
		//If the argument has type @Shared or @Borrowed, doing nothing whatsoever correctly models
		//borrowing.
		if (argumentHasAnnotation(argumentTypes.get(i), AFFINE)
				&& hasAnnotation(result, operand, AFFINE)) {
			if (borrowTracker.isBorrowed(elementOf(operand))) {
				checker.report(Result.failure("use.of.borrowed.variable", operand), operand.getTree());
			} else {
				changeAnnotation(result, operand, UNUSABLE);
			}
		} else if (argumentHasAnnotation(argumentTypes.get(i), BORROWED)) {
			if (!borrowTracker.canMutablyBorrow(elementOf(operand))) {
				checker.report(Result.failure("cannot.borrow.borrowed", operand), operand.getTree());
			}
		} else if (argumentHasAnnotation(argumentTypes.get(i), SHARED)) {
			if (!borrowTracker.canImmutablyBorrow(elementOf(operand))) {
				checker.report(Result.failure("cannot.share.borrowed", operand), operand.getTree());
			}
		}
		i++;
	}
	return result;
}
 
開發者ID:PPewt,項目名稱:affinechecker,代碼行數:33,代碼來源:AffinePointerTransfer.java

示例14: checkFieldIsImmutable

import org.checkerframework.framework.source.Result; //導入依賴的package包/類
private void checkFieldIsImmutable(ClassTree deepestClassTree, Tree containingTree, TypeElement immediateContainingElement, Element element, boolean alsoCheckFinal) {
    AnnotatedTypeMirror fieldType = atypeFactory.getAnnotatedType(element);
    if (!typeIsImmutable(fieldType)) {
        if (alsoCheckFinal) {
            checker.report(Result.failure("glacier.mutablemember", deepestClassTree.getSimpleName(), immediateContainingElement, element), deepestClassTree);
        } else {
            if (fieldType.getUnderlyingType().getKind() == TypeKind.ARRAY) {
                AnnotatedArrayType arrayType = (AnnotatedArrayType)fieldType;
                if (!arrayType.hasAnnotation(Immutable.class)) {
                    checker.report(Result.failure("glacier.mutable.wholearray.invalid"), element);
                }
                else {
                    checker.report(Result.failure("glacier.mutable.array.invalid"), element);
                }
            }
            else {
                checker.report(Result.failure("glacier.mutable.invalid"), element);
            }
        }
    }

    if (alsoCheckFinal) {
        if (!ElementUtils.isFinal(element)) {
            checker.report(Result.failure("glacier.nonfinalmember", deepestClassTree.getSimpleName(), immediateContainingElement, element), deepestClassTree);
        }
    }
}
 
開發者ID:mcoblenz,項目名稱:Glacier,代碼行數:28,代碼來源:GlacierVisitor.java

示例15: checkTypeArguments

import org.checkerframework.framework.source.Result; //導入依賴的package包/類
protected void checkTypeArguments(Tree toptree, List<? extends AnnotatedTypeParameterBounds> paramBounds, List<? extends AnnotatedTypeMirror> typeargs, List<? extends Tree> typeargTrees) {
    super.checkTypeArguments(toptree, paramBounds, typeargs, typeargTrees);

    AnnotatedTypeMirror toptreeType = atypeFactory.getAnnotatedType(toptree);

    if (toptreeType.hasAnnotation(Immutable.class) && (toptree.getKind() == Kind.CLASS || toptree.getKind() == Kind.PARAMETERIZED_TYPE)) {
        // Cases for toptree: ParameterizedTypeTree; MethodInvocationTree; NewClassTree.

        // Make sure all the type arguments have the @Immutable annotation.
        for (AnnotatedTypeMirror typearg : typeargs) {
            // Ignore type variables because we only want to check concrete types.
            if (typearg.getKind() != TypeKind.TYPEVAR && !typearg.hasAnnotation(Immutable.class)) {
                // One last-ditch check: maybe typearg is a wildcard. If so, it suffices if the upper bound is immutable or a type variable.
                boolean reportError = false;

                if (typearg.getKind() == TypeKind.WILDCARD) {
                    AnnotatedTypeMirror.AnnotatedWildcardType annotatedWildcardType = (AnnotatedTypeMirror.AnnotatedWildcardType) typearg;
                    AnnotatedTypeMirror extendsBound = annotatedWildcardType.getExtendsBound();
                    if (extendsBound.getKind() != TypeKind.TYPEVAR && !extendsBound.hasAnnotation(Immutable.class)) {
                        reportError = true;
                    }
                }
                else {
                    reportError = true;
                }

                if (reportError) {

                    checker.report(Result.failure("glacier.typeparameter.mutable", toptree, typearg), toptree);

                }
            }
        }
    }
}
 
開發者ID:mcoblenz,項目名稱:Glacier,代碼行數:36,代碼來源:GlacierVisitor.java


注:本文中的org.checkerframework.framework.source.Result類示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。