166e84b9ff30de7c75b510cb9117205368cf5bd25Jesse Wilsonpackage javax.annotation.meta;
266e84b9ff30de7c75b510cb9117205368cf5bd25Jesse Wilson
366e84b9ff30de7c75b510cb9117205368cf5bd25Jesse Wilsonimport java.lang.annotation.Documented;
466e84b9ff30de7c75b510cb9117205368cf5bd25Jesse Wilsonimport java.lang.annotation.Retention;
566e84b9ff30de7c75b510cb9117205368cf5bd25Jesse Wilsonimport java.lang.annotation.RetentionPolicy;
666e84b9ff30de7c75b510cb9117205368cf5bd25Jesse Wilson
766e84b9ff30de7c75b510cb9117205368cf5bd25Jesse Wilson/**
866e84b9ff30de7c75b510cb9117205368cf5bd25Jesse Wilson * This annotation can be applied to the value() element of an annotation that
966e84b9ff30de7c75b510cb9117205368cf5bd25Jesse Wilson * is annotated as a TypeQualifier.
1066e84b9ff30de7c75b510cb9117205368cf5bd25Jesse Wilson *
1166e84b9ff30de7c75b510cb9117205368cf5bd25Jesse Wilson * For example, the following defines a type qualifier such that if you know a
1266e84b9ff30de7c75b510cb9117205368cf5bd25Jesse Wilson * value is {@literal @Foo(1)}, then the value cannot be {@literal @Foo(2)} or {{@literal @Foo(3)}.
1366e84b9ff30de7c75b510cb9117205368cf5bd25Jesse Wilson *
1466e84b9ff30de7c75b510cb9117205368cf5bd25Jesse Wilson * <code>
1566e84b9ff30de7c75b510cb9117205368cf5bd25Jesse Wilson * @TypeQualifier @interface Foo {
1666e84b9ff30de7c75b510cb9117205368cf5bd25Jesse Wilson *     @Exclusive int value();
1766e84b9ff30de7c75b510cb9117205368cf5bd25Jesse Wilson *     }
1866e84b9ff30de7c75b510cb9117205368cf5bd25Jesse Wilson *  </code>
1966e84b9ff30de7c75b510cb9117205368cf5bd25Jesse Wilson *
2066e84b9ff30de7c75b510cb9117205368cf5bd25Jesse Wilson */
2166e84b9ff30de7c75b510cb9117205368cf5bd25Jesse Wilson
2266e84b9ff30de7c75b510cb9117205368cf5bd25Jesse Wilson@Documented
2366e84b9ff30de7c75b510cb9117205368cf5bd25Jesse Wilson@Retention(RetentionPolicy.RUNTIME)
2466e84b9ff30de7c75b510cb9117205368cf5bd25Jesse Wilsonpublic @interface Exclusive {
2566e84b9ff30de7c75b510cb9117205368cf5bd25Jesse Wilson
2666e84b9ff30de7c75b510cb9117205368cf5bd25Jesse Wilson}
27