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 {
|
|
|
|
@RegEx
|
|
|
|
String value();
|
|
|
|
|
|
|
|
int flags() default 0;
|
|
|
|
|
2023-01-01 10:26:38 -08:00
|
|
|
class Checker implements TypeQualifierValidator<MatchesPattern> {
|
|
|
|
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
|
|
|
|
2023-01-01 10:26:38 -08:00
|
|
|
}
|
2022-12-27 09:22:08 -08:00
|
|
|
}
|