org.checkerframework.checker.signature.qual.BinaryName Maven / Gradle / Ivy
package org.checkerframework.checker.signature.qual;
import java.lang.annotation.ElementType;
import java.lang.annotation.Target;
import org.checkerframework.framework.qual.ImplicitFor;
import org.checkerframework.framework.qual.SubtypeOf;
/**
* Represents a binary name as defined in the Java Language
* Specification, section 13.1.
*
* For example, in
*
*
* package org.checkerframework.checker.signature;
* public class SignatureChecker {
* private class Inner {}
* }
*
*
* the binary names for the two types are org.checkerframework.checker.signature.SignatureChecker
* and org.checkerframework.checker.signature.SignatureChecker$Inner.
*
* Binary names and {@linkplain FullyQualifiedName fully qualified names} are the same for
* top-level classes and only differ by '$' vs. '.' for inner classes.
*
*
The binary name should not be confused with the {@linkplain InternalForm internal form}, which
* is a variant of the binary name that actually appears in the class file.
*
* @checker_framework.manual #signature-checker Signature Checker
*/
@SubtypeOf(SignatureUnknown.class)
@ImplicitFor(
stringPatterns =
"^[A-Za-z_][A-Za-z_0-9]*(\\.[A-Za-z_][A-Za-z_0-9]*)*(\\$[A-Za-z_0-9]+)*(\\[\\])*$"
)
@Target({ElementType.TYPE_USE, ElementType.TYPE_PARAMETER})
public @interface BinaryName {}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy