From 9860af59a386cf12938f9db88d50399177e6d5dc Mon Sep 17 00:00:00 2001 From: Aosen Xiong Date: Thu, 2 Jan 2025 11:24:32 -0800 Subject: [PATCH 1/5] Fixes Javadoc link --- .../dataflow/cfg/builder/UnconditionalJump.java | 2 +- .../checkerframework/framework/type/AnnotatedTypeMirror.java | 4 +++- 2 files changed, 4 insertions(+), 2 deletions(-) diff --git a/dataflow/src/main/java/org/checkerframework/dataflow/cfg/builder/UnconditionalJump.java b/dataflow/src/main/java/org/checkerframework/dataflow/cfg/builder/UnconditionalJump.java index 0d92c27ac88..df1749339db 100644 --- a/dataflow/src/main/java/org/checkerframework/dataflow/cfg/builder/UnconditionalJump.java +++ b/dataflow/src/main/java/org/checkerframework/dataflow/cfg/builder/UnconditionalJump.java @@ -52,7 +52,7 @@ public FlowRule getFlowRule() { * Produce a string representation. * * @return a string representation - * @see org.checkerframework.dataflow.cfg.builder.CFGBuilder.PhaseOneResult#nodeToString + * @see org.checkerframework.dataflow.cfg.builder.PhaseOneResult#nodeToString */ @Override public String toString() { diff --git a/framework/src/main/java/org/checkerframework/framework/type/AnnotatedTypeMirror.java b/framework/src/main/java/org/checkerframework/framework/type/AnnotatedTypeMirror.java index afef59f6f87..235a940982b 100644 --- a/framework/src/main/java/org/checkerframework/framework/type/AnnotatedTypeMirror.java +++ b/framework/src/main/java/org/checkerframework/framework/type/AnnotatedTypeMirror.java @@ -1,5 +1,6 @@ package org.checkerframework.framework.type; +import com.sun.source.tree.NewClassTree; import com.sun.tools.javac.code.Symbol.MethodSymbol; import org.checkerframework.checker.formatter.qual.FormatMethod; @@ -1226,7 +1227,8 @@ private AnnotatedExecutableType(ExecutableType type, AnnotatedTypeFactory factor * The varargs type is the last element of {@link paramTypes} if the method or constructor * accepts a variable number of arguments and the {@link paramTypes} has not been expanded * yet. This type needs to be stored in the field to avoid being affected by calling {@link - * AnnotatedTypes#adaptParameters(AnnotatedTypeFactory, AnnotatedExecutableType, List)}. + * AnnotatedTypes#adaptParameters(AnnotatedTypeFactory, AnnotatedExecutableType, List, + * NewClassTree)}. */ private @MonotonicNonNull AnnotatedArrayType varargType = null; From e88ea24a2adbe3c7701ff7b1f51308b7e9816139 Mon Sep 17 00:00:00 2001 From: Werner Dietl Date: Thu, 2 Jan 2025 14:33:26 -0500 Subject: [PATCH 2/5] Use qualified name --- .../checkerframework/framework/type/AnnotatedTypeMirror.java | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/framework/src/main/java/org/checkerframework/framework/type/AnnotatedTypeMirror.java b/framework/src/main/java/org/checkerframework/framework/type/AnnotatedTypeMirror.java index 235a940982b..5e3d3d1cdbb 100644 --- a/framework/src/main/java/org/checkerframework/framework/type/AnnotatedTypeMirror.java +++ b/framework/src/main/java/org/checkerframework/framework/type/AnnotatedTypeMirror.java @@ -1,6 +1,5 @@ package org.checkerframework.framework.type; -import com.sun.source.tree.NewClassTree; import com.sun.tools.javac.code.Symbol.MethodSymbol; import org.checkerframework.checker.formatter.qual.FormatMethod; @@ -1228,7 +1227,7 @@ private AnnotatedExecutableType(ExecutableType type, AnnotatedTypeFactory factor * accepts a variable number of arguments and the {@link paramTypes} has not been expanded * yet. This type needs to be stored in the field to avoid being affected by calling {@link * AnnotatedTypes#adaptParameters(AnnotatedTypeFactory, AnnotatedExecutableType, List, - * NewClassTree)}. + * com.sun.source.tree.NewClassTree)}. */ private @MonotonicNonNull AnnotatedArrayType varargType = null; From bdd0f820a520be41f6a7a9691ecce29cb838591a Mon Sep 17 00:00:00 2001 From: Aosen Xiong Date: Thu, 2 Jan 2025 13:58:44 -0800 Subject: [PATCH 3/5] Add javacJar and try --- build.gradle | 3 +++ 1 file changed, 3 insertions(+) diff --git a/build.gradle b/build.gradle index 73a9d578bd3..6f7999493a9 100644 --- a/build.gradle +++ b/build.gradle @@ -736,6 +736,9 @@ def createJavadocTask(taskName, taskDescription, memberLevel) { } classpath = configurations.allProjects + if (isJava8) { + classpath += configurations.javacJar + } destinationDir.deleteDir() options.memberLevel = memberLevel From b72d862af397a4e33a2dc37578fde60102cd3e6d Mon Sep 17 00:00:00 2001 From: Aosen Xiong Date: Thu, 2 Jan 2025 15:10:15 -0800 Subject: [PATCH 4/5] Fixed more errors and use qualified name for parameter type in nested classes for Java8 --- build.gradle | 3 -- .../index/upperbound/UpperBoundTransfer.java | 17 +++++----- .../common/basetype/BaseTypeVisitor.java | 2 +- .../framework/type/AnnotatedTypeMirror.java | 32 +++++++++---------- 4 files changed, 26 insertions(+), 28 deletions(-) diff --git a/build.gradle b/build.gradle index 6f7999493a9..73a9d578bd3 100644 --- a/build.gradle +++ b/build.gradle @@ -736,9 +736,6 @@ def createJavadocTask(taskName, taskDescription, memberLevel) { } classpath = configurations.allProjects - if (isJava8) { - classpath += configurations.javacJar - } destinationDir.deleteDir() options.memberLevel = memberLevel diff --git a/checker/src/main/java/org/checkerframework/checker/index/upperbound/UpperBoundTransfer.java b/checker/src/main/java/org/checkerframework/checker/index/upperbound/UpperBoundTransfer.java index b0ccca0ff3a..933b4452c19 100644 --- a/checker/src/main/java/org/checkerframework/checker/index/upperbound/UpperBoundTransfer.java +++ b/checker/src/main/java/org/checkerframework/checker/index/upperbound/UpperBoundTransfer.java @@ -175,10 +175,11 @@ public TransferResult visitAssignment( * {@code node} is known to be {@code typeOfNode}. If the node is a plus or a minus then the * types of the left and right operands can be refined to include offsets. If the node is a * multiplication, its operands can also be refined. See {@link - * #propagateToAdditionOperand(LessThanLengthOf, Node, Node, TransferInput, CFStore)}, {@link - * #propagateToSubtractionOperands(LessThanLengthOf, NumericalSubtractionNode, TransferInput, - * CFStore)}, and {@link #propagateToMultiplicationOperand(LessThanLengthOf, Node, Node, - * TransferInput, CFStore)} for details. + * #propagateToAdditionOperand(UBQualifier.LessThanLengthOf, Node, Node, TransferInput, + * CFStore)}, {@link #propagateToSubtractionOperands(UBQualifier.LessThanLengthOf, + * NumericalSubtractionNode, TransferInput, CFStore)}, and {@link + * #propagateToMultiplicationOperand(UBQualifier.LessThanLengthOf, Node, Node, TransferInput, + * CFStore)} for details. */ private void propagateToOperands( LessThanLengthOf typeOfNode, @@ -234,10 +235,10 @@ private void propagateToMultiplicationOperand( * *

This means that the left node is less than or equal to the length of the array when the * right node is subtracted from the left node. Note that unlike {@link - * #propagateToAdditionOperand(LessThanLengthOf, Node, Node, TransferInput, CFStore)} and {@link - * #propagateToMultiplicationOperand(LessThanLengthOf, Node, Node, TransferInput, CFStore)}, - * this method takes the NumericalSubtractionNode instead of the two operand nodes. This - * implements case 4. + * #propagateToAdditionOperand(UBQualifier.LessThanLengthOf, Node, Node, TransferInput, + * CFStore)} and {@link #propagateToMultiplicationOperand(UBQualifier.LessThanLengthOf, Node, + * Node, TransferInput, CFStore)}, this method takes the NumericalSubtractionNode instead of the + * two operand nodes. This implements case 4. * * @param typeOfSubtraction type of node * @param node subtraction node that has typeOfSubtraction diff --git a/framework/src/main/java/org/checkerframework/common/basetype/BaseTypeVisitor.java b/framework/src/main/java/org/checkerframework/common/basetype/BaseTypeVisitor.java index 21f5bbaf089..6cb489b93f6 100644 --- a/framework/src/main/java/org/checkerframework/common/basetype/BaseTypeVisitor.java +++ b/framework/src/main/java/org/checkerframework/common/basetype/BaseTypeVisitor.java @@ -3815,7 +3815,7 @@ protected void reportMethodInvocabilityError( * constructor result type. This is equivalent to down-casting. * *

For type checking of the enclosing expression of inner type instantiations, see {@link - * #checkEnclosingExpr(NewClassTree, AnnotatedExecutableType)} + * #checkEnclosingExpr(NewClassTree, AnnotatedTypeMirror.AnnotatedExecutableType)} * * @param invocation the AnnotatedDeclaredType of the constructor invocation * @param constructor the AnnotatedExecutableType of the constructor declaration diff --git a/framework/src/main/java/org/checkerframework/framework/type/AnnotatedTypeMirror.java b/framework/src/main/java/org/checkerframework/framework/type/AnnotatedTypeMirror.java index 5e3d3d1cdbb..99bd9f76596 100644 --- a/framework/src/main/java/org/checkerframework/framework/type/AnnotatedTypeMirror.java +++ b/framework/src/main/java/org/checkerframework/framework/type/AnnotatedTypeMirror.java @@ -1213,7 +1213,7 @@ private AnnotatedExecutableType(ExecutableType type, AnnotatedTypeFactory factor /** The parameter types; an unmodifiable list. */ private @MonotonicNonNull List paramTypes = null; - /** Whether {@link paramTypes} has been computed. */ + /** Whether {@link #paramTypes} has been computed. */ private boolean paramTypesComputed = false; /** @@ -1223,33 +1223,33 @@ private AnnotatedExecutableType(ExecutableType type, AnnotatedTypeFactory factor private @Nullable AnnotatedDeclaredType receiverType; /** - * The varargs type is the last element of {@link paramTypes} if the method or constructor - * accepts a variable number of arguments and the {@link paramTypes} has not been expanded + * The varargs type is the last element of {@link #paramTypes} if the method or constructor + * accepts a variable number of arguments and the {@link #paramTypes} has not been expanded * yet. This type needs to be stored in the field to avoid being affected by calling {@link - * AnnotatedTypes#adaptParameters(AnnotatedTypeFactory, AnnotatedExecutableType, List, - * com.sun.source.tree.NewClassTree)}. + * AnnotatedTypes#adaptParameters(AnnotatedTypeFactory, + * AnnotatedTypeMirror.AnnotatedExecutableType, List, com.sun.source.tree.NewClassTree)}. */ private @MonotonicNonNull AnnotatedArrayType varargType = null; - /** Whether {@link receiverType} has been computed. */ + /** Whether {@link #receiverType} has been computed. */ private boolean receiverTypeComputed = false; /** The return type. */ private AnnotatedTypeMirror returnType; - /** Whether {@link returnType} has been computed. */ + /** Whether {@link #returnType} has been computed. */ private boolean returnTypeComputed = false; /** The thrown types; an unmodifiable list. */ private List thrownTypes; - /** Whether {@link thrownTypes} has been computed. */ + /** Whether {@link #thrownTypes} has been computed. */ private boolean thrownTypesComputed = false; /** The type variables; an unmodifiable list. */ private List typeVarTypes; - /** Whether {@link typeVarTypes} has been computed. */ + /** Whether {@link #typeVarTypes} has been computed. */ private boolean typeVarTypesComputed = false; /** @@ -1286,7 +1286,7 @@ public void addAnnotation(AnnotationMirror annotation) { /** * Sets the parameter types of this executable type, excluding the receiver.If paramTypes * has been computed and this type is a varargs method, computes and store {@link - * varargType} before calling this method, @see {@link varargType} + * #varargType} before calling this method, @see {@link #varargType} * * @param params an unmodifiable list of parameter types to be captured by this method, * excluding the receiver @@ -1345,11 +1345,11 @@ public List getParameterTypes() { } /** - * Computes the vararg type of this executable type and stores it in {@link varargType}. + * Computes the vararg type of this executable type and stores it in {@link #varargType}. * - *

This method computes {@link varargType} using the {@link paramTypes} of this - * executable type. To use the {@link paramTypes} from different executable type, use {@link - * #computeVarargType(AnnotatedExecutableType)}. + *

This method computes {@link #varargType} using the {@link #paramTypes} of this + * executable type. To use the {@link #paramTypes} from different executable type, use + * {@link #computeVarargType(AnnotatedTypeMirror.AnnotatedExecutableType)}. */ /*package-private*/ void computeVarargType() { computeVarargType(paramTypes); @@ -1357,7 +1357,7 @@ public List getParameterTypes() { /** * Computes the vararg type using the passed executable type and stores it in this {@link - * varargType}. + * #varargType}. * * @param annotatedExecutableType an AnnotatedExecutableType */ @@ -1368,7 +1368,7 @@ public List getParameterTypes() { /** * Helper function for {@link #computeVarargType()} and {@link - * #computeVarargType(AnnotatedExecutableType)}. + * #computeVarargType(AnnotatedTypeMirror.AnnotatedExecutableType)}. * * @param paramTypes the parameter types to determine the vararg type */ From 0710319536b27cacd1e5800beb8de45aeb5a9feb Mon Sep 17 00:00:00 2001 From: Aosen Xiong Date: Thu, 2 Jan 2025 15:23:20 -0800 Subject: [PATCH 5/5] Add params Javadoc --- .../checker/index/upperbound/UpperBoundTransfer.java | 5 +++++ 1 file changed, 5 insertions(+) diff --git a/checker/src/main/java/org/checkerframework/checker/index/upperbound/UpperBoundTransfer.java b/checker/src/main/java/org/checkerframework/checker/index/upperbound/UpperBoundTransfer.java index 933b4452c19..37fe1b85bab 100644 --- a/checker/src/main/java/org/checkerframework/checker/index/upperbound/UpperBoundTransfer.java +++ b/checker/src/main/java/org/checkerframework/checker/index/upperbound/UpperBoundTransfer.java @@ -180,6 +180,11 @@ public TransferResult visitAssignment( * NumericalSubtractionNode, TransferInput, CFStore)}, and {@link * #propagateToMultiplicationOperand(UBQualifier.LessThanLengthOf, Node, Node, TransferInput, * CFStore)} for details. + * + * @param typeOfNode type of node + * @param node the node + * @param in the TransferInput before propagate to this operand + * @param store location to store the refined type */ private void propagateToOperands( LessThanLengthOf typeOfNode,