package org.richfaces.cdk.annotations; import java.lang.annotation.ElementType; import java.lang.annotation.Retention; import java.lang.annotation.RetentionPolicy; import java.lang.annotation.Target; import javax.faces.validator.Validator; /** * This annotation defines concrete class as JSF {@link Validator}, or abstract class as the base for generated Validator * implementation. * * @author akolonitsky * @since Jan 13, 2010 */ @Retention(RetentionPolicy.SOURCE) @Target(ElementType.TYPE) public @interface JsfValidator { String NAME = "org.richfaces.cdk.annotations.JsfValidator"; /** * <p class="changed_added_4_0"> * The "validator-id" element represents the identifier under which the corresponding Validator class should be registered. * </p> * * @return */ String id(); /** * <p class="changed_added_4_0"> * fully qualified class name of the generated Converter implementation. Default value means nothing to genrate from * concrete class, or infer name by convention for abstract class. * </p> * * @return */ String generate() default ""; /** * <p class="changed_added_4_0"> * Tag description. If generated tags require special handlers, provide separate description for every type of tag, JSP and * Facelets. Otherwise, the only one tag tag description with name and type {@link TagType#All}. * </p> * * @return */ Tag[] tag() default {}; /** * <p class="changed_added_4_0"> * Description to include into generated faces-config and taglib. * </p> * * @return */ Description description() default @Description(); /** * <p class="changed_added_4_0"> * Defines file names for fragment of faces-config.xml that contain standard attribute definitions. All names relative to * the META-INF/cdk/attributes/ folder in classpath. CDK also tries to read META-INF/cdk/attributes/[classname].xml file for * all component superclasses and interfaces. Therefore, it is not necessary to explicitly include definitions for Converter * and any other standard JSF classes. * </p> * * @return */ String[] attributes() default {}; /** * <p class="changed_added_4_0"> * Interfaces that should be implemented in the generated class. CDK processes all {@link Attribute} annotations in these * interfaces * </p> * * @return */ Class<?>[] interfaces() default {}; }