001package react4j.annotations; 002 003import java.lang.annotation.Documented; 004import java.lang.annotation.ElementType; 005import java.lang.annotation.Target; 006 007/** 008 * Identifies the method invoked to render the view. 009 * There must be exactly one method annotated with this annotation within the view. 010 * The method must return a value of type {@link react4j.ReactNode}. 011 * 012 * <p>The method must also conform to the following constraints:</p> 013 * <ul> 014 * <li>Must not be annotated with any other react4j annotation</li> 015 * <li>Must not be private</li> 016 * <li>Must not be static</li> 017 * <li>Must not be abstract</li> 018 * <li>Must not throw exceptions</li> 019 * <li>Must be accessible from the same package as the class annotated by {@link View}</li> 020 * <li> 021 * Should not be public as not expected to be invoked outside the view. A warning will be generated but can 022 * be suppressed by the {@link SuppressWarnings} or {@link SuppressReact4jWarnings} annotations with a key 023 * "React4j:PublicMethod". This warning is also suppressed by the annotation processor if it is implementing 024 * an interface method. 025 * </li> 026 * <li> 027 * Should not be protected if in the class annotated with the {@link View} annotation as the method is not 028 * expected to be invoked outside the view. A warning will be generated but can be suppressed by the 029 * {@link SuppressWarnings} or {@link SuppressReact4jWarnings} annotations with a key "React4j:ProtectedMethod". 030 * </li> 031 * <li> 032 * Should be annotated with either {@link javax.annotation.Nonnull} or {@link javax.annotation.Nullable}. If neither 033 * annoation is present then a warning will be generated but can be suppressed by the {@link SuppressWarnings} or 034 * {@link SuppressReact4jWarnings} annotations with a key "React4j:MissingRenderNullability". 035 * </li> 036 * </ul> 037 */ 038@Documented 039@Target( ElementType.METHOD ) 040public @interface Render 041{ 042}