org.intellij.lang.annotations.MagicConstant Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of annotations-java5 Show documentation
Show all versions of annotations-java5 Show documentation
A set of annotations used for code inspection support and code documentation.
/*
* Copyright 2000-2021 JetBrains s.r.o.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* https://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.intellij.lang.annotations;
import org.jetbrains.annotations.NonNls;
import java.lang.annotation.*;
/**
* This annotation intended to help IntelliJ IDEA and other IDEs to detect and auto-complete int and String constants used as an enumeration.
* For example, in the {@link java.awt.Label#Label(String, int)} constructor the alignment
parameter can be one of the following
* int constants: {@link java.awt.Label#LEFT}, {@link java.awt.Label#CENTER} or {@link java.awt.Label#RIGHT}
*
*
So, if @MagicConstant
annotation applied to this constructor, the IDE will check the constructor usages for the allowed values.
*
E.g.
*
{@code
* new Label("text", 0); // 0 is not allowed
* new Label("text", Label.LEFT); // OK
* }
*
*
* @MagicConstant
can be applied to:
*
* - Field, local variable, parameter.
*
*
E.g.
* {@code @MagicConstant(intValues = {TOP, CENTER, BOTTOM})
* int textPosition;
* }
* The IDE will check expressions assigned to the variable for allowed values:
* {@code
* textPosition = 0; // not allowed
* textPosition = TOP; // OK
* }
*
* - Method
*
*
E.g.
* {@code @MagicConstant(flagsFromClass = java.lang.reflect.Modifier.class)
* public native int getModifiers();
* }
*
* The IDE will analyse getModifiers() method calls and check if its return value is used with allowed values:
* {@code
* if (aClass.getModifiers() == 3) // not allowed
* if (aClass.getModifiers() == Modifier.PUBLIC) // OK
* }
*
* - Annotation class
* Annotation class annotated with @MagicConstant
created alias you can use to annotate
* everything as if it was annotated with @MagicConstant
itself.
*
*
E.g.
* {@code @MagicConstant(flags = {Font.PLAIN, Font.BOLD, Font.ITALIC}) }
* {@code @interface FontStyle {} }
*
* The IDE will check constructs annotated with @FontStyle for allowed values:
* @FontStyle int myStyle = 3; // not allowed
* @FontStyle int myStyle = Font.BOLD | Font.ITALIC; // OK
*
*
*
* The @MagicConstant
annotation has SOURCE retention, i.e. it is removed upon compilation and does not create any runtime overhead.
*/
@Documented
@Retention(RetentionPolicy.SOURCE)
@Target({
ElementType.FIELD, ElementType.PARAMETER, ElementType.LOCAL_VARIABLE,
ElementType.ANNOTATION_TYPE,
ElementType.METHOD
})
public @interface MagicConstant {
/**
* @return int values (typically named constants) which are allowed here.
* E.g.
*
* {@code
* void setConfirmOpenNewProject(@MagicConstant(intValues = {OPEN_PROJECT_ASK, OPEN_PROJECT_NEW_WINDOW, OPEN_PROJECT_SAME_WINDOW})
* int confirmOpenNewProject);
* }
*/
long[] intValues() default {};
/**
* @return String values (typically named constants) which are allowed here.
*/
@NonNls String[] stringValues() default {};
/**
* @return allowed int flags (i.e. values (typically named constants) which can be combined with bitwise OR operator (|).
* The difference from the {@link #intValues()} is that flags are allowed to be combined (via plus:+ or bitwise OR: |) whereas values aren't.
* The literals "0" and "-1" are also allowed to denote absence and presense of all flags respectively.
*
* E.g.
*
* {@code @MagicConstant(flags = {HierarchyEvent.PARENT_CHANGED,HierarchyEvent.DISPLAYABILITY_CHANGED,HierarchyEvent.SHOWING_CHANGED})
* int hFlags;
*
* hFlags = 3; // not allowed; should be "magic" constant.
* if (hFlags & (HierarchyEvent.PARENT_CHANGED | HierarchyEvent.SHOWING_CHANGED) != 0); // OK: combined several constants via bitwise OR
* }
*/
long[] flags() default {};
/**
* @return allowed values which are defined in the specified class static final constants.
*
* E.g.
*
* {@code @MagicConstant(valuesFromClass = Cursor.class)
* int cursorType;
*
* cursorType = 11; // not allowed; should be "magic" constant.
* cursorType = Cursor.E_RESIZE_CURSOR; // OK: "magic" constant used.
* }
*/
Class> valuesFromClass() default void.class;
/**
* @return allowed int flags which are defined in the specified class static final constants.
* The difference from the {@link #valuesFromClass()} is that flags are allowed to be combined (via plus:+ or bitwise OR: |) whereas values aren't.
* The literals "0" and "-1" are also allowed to denote absence and presense of all flags respectively.
*
* E.g.
*
* {@code @MagicConstant(flagsFromClass = java.awt.InputEvent.class)
* int eventMask;
*
* eventMask = 10; // not allowed; should be "magic" constant.
* eventMask = InputEvent.CTRL_MASK | InputEvent.ALT_MASK; // OK: combined several constants via bitwise OR
* }
*/
Class> flagsFromClass() default void.class;
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy