LongDef


@Retention(value = AnnotationRetention.SOURCE)
@Target(allowedTargets = [AnnotationTarget.ANNOTATION_CLASS])
public annotation LongDef


Denotes that the annotated long element represents a logical type and that its value should be one of the explicitly named constants. If the LongDef#flag() attribute is set to true, multiple constants can be combined.

Example:

@Retention(SOURCE)
@LongDef({NAVIGATION_MODE_STANDARD, NAVIGATION_MODE_LIST, NAVIGATION_MODE_TABS})
public @interface NavigationMode {}
public static final long NAVIGATION_MODE_STANDARD = 0;
public static final long NAVIGATION_MODE_LIST = 1;
public static final long NAVIGATION_MODE_TABS = 2;
...

public abstract void setNavigationMode(@NavigationMode long mode);
@NavigationMode
public
abstract long getNavigationMode();

For a flag, set the flag attribute:

@LongDef(
flag = true,
value = {NAVIGATION_MODE_STANDARD, NAVIGATION_MODE_LIST, NAVIGATION_MODE_TABS}
)
See also
IntDef

Summary

Public constructors

LongDef(long... value, boolean flag, boolean open)

Public methods

final boolean

Defines whether the constants can be used as a flag, or just as an enum (the default)

final boolean

Whether any other values are allowed.

final @NonNull long[]

Defines the allowed constants for this element

Public constructors

LongDef

Added in 1.10.0-rc01
public LongDef(long... value, boolean flag, boolean open)

Public methods

getFlag

public final boolean getFlag()

Defines whether the constants can be used as a flag, or just as an enum (the default)

getOpen

public final boolean getOpen()

Whether any other values are allowed. Normally this is not the case, but this allows you to specify a set of expected constants, which helps code completion in the IDE and documentation generation and so on, but without flagging compilation warnings if other values are specified.

getValue

public final @NonNull long[] getValue()

Defines the allowed constants for this element