All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.univocity.parsers.annotations.EnumOptions Maven / Gradle / Ivy

/*******************************************************************************
 * Copyright 2015 uniVocity Software Pty Ltd
 *
 * 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
 *
 * http://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 com.univocity.parsers.annotations;

import com.univocity.parsers.common.processor.*;
import com.univocity.parsers.conversions.*;

import java.lang.annotation.*;

/**
 * The {@code EnumSelector} annotation is meant to be used in conjunction with enumeration attributes.
 *
 * 

Values parsed from the input will be matched against one or more properties of the enumeration type. * By default, values read from the input will be matched against:

*
    *
  • {@link Enum#name()} - the name of the elements in the enumeration type
  • *
  • {@link Enum#ordinal()} - the ordinal of the elements in the enumeration type
  • *
  • {@link Enum#toString()} - the {@code String} representation of the elements in the enumeration type
  • *
* * You can also define a {@link #customElement()} of your enumeration type (an attribute or method), as long as it * uniquely identifies each value of your enumeration type. * *

Use the {@link #selectors()} option to choose which properties to match the parsed input against, and in what order. You will only need to * explicitly add a {@link EnumSelector#CUSTOM_FIELD} or {@link EnumSelector#CUSTOM_METHOD} to the list of {@link #selectors()} if your {@link #customElement()} name * could point to both an attribute and a method in your enumeration.

* *

This will assign an {@link EnumConversion} to this field.

* *

Commonly used for java beans processed using {@link BeanProcessor} and/or {@link BeanWriterProcessor} * * @see BeanProcessor * @see BeanWriterProcessor * * @author uniVocity Software Pty Ltd - [email protected] * */ @Retention(RetentionPolicy.RUNTIME) @Inherited @Target({ElementType.FIELD, ElementType.METHOD, ElementType.ANNOTATION_TYPE}) public @interface EnumOptions { /** *

A list of properties of the enumeration type that will be matched against the parsed input to identify which enum element should be assigned to the annotated field. * By default, values read from the input will be matched against:

*
    *
  • {@link Enum#name()} - the name of the elements in the enumeration type
  • *
  • {@link Enum#ordinal()} - the ordinal of the elements in the enumeration type
  • *
  • {@link Enum#toString()} - the {@code String} representation of the elements in the enumeration type
  • *
* @return the sequence of properties of the enumeration type to match against the parsed input. */ EnumSelector[] selectors() default {EnumSelector.NAME, EnumSelector.ORDINAL, EnumSelector.STRING}; /** * * Defines the name of a custom element (attribute or method) of the annotated enumeration. This will be used to match the parsed input and identify an individual value of the enumeration. * The attribute value, or object returned from the method, should uniquely identify a value of the enumeration; * *

You will only need to explicitly add a {@link EnumSelector#CUSTOM_FIELD} or {@link EnumSelector#CUSTOM_METHOD} to the list of {@link #selectors()} * if your {@link #customElement()} name could point to both an attribute and a method in your enumeration.

* * @return the name of a custom element (attribute or method) of the enumeration which will match the parsed input and identify an enumeration's value. */ String customElement() default ""; }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy