resent-1.8/src/main/java/javax/annotation/MatchesPattern.java

36 lines
1.0 KiB
Java
Raw Normal View History

2022-12-27 09:22:08 -08:00
package javax.annotation;
import java.lang.annotation.Documented;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.util.regex.Pattern;
import javax.annotation.meta.TypeQualifier;
import javax.annotation.meta.TypeQualifierValidator;
import javax.annotation.meta.When;
/**
* This annotation is used to denote String values that should always match
* given pattern.
* <p>
* When this annotation is applied to a method it applies to the method return
* value.
*/
@Documented
@TypeQualifier(applicableTo = String.class)
@Retention(RetentionPolicy.RUNTIME)
public @interface MatchesPattern {
2023-01-14 07:56:36 -08:00
@RegEx
String value();
2022-12-27 09:22:08 -08:00
2023-01-14 07:56:36 -08:00
int flags() default 0;
2022-12-27 09:22:08 -08:00
2023-01-14 07:56:36 -08:00
static class Checker implements TypeQualifierValidator<MatchesPattern> {
2022-12-27 09:22:08 -08:00
2023-01-14 07:56:36 -08:00
public When forConstantValue(MatchesPattern annotation, Object value) {
Pattern p = Pattern.compile(annotation.value(), annotation.flags());
if (p.matcher(((String) value)).matches()) return When.ALWAYS;
return When.NEVER;
}
}
2022-12-27 09:22:08 -08:00
}