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

org.joda.beans.gen.BeanDefinition Maven / Gradle / Ivy

The newest version!
/*
 *  Copyright 2001-present Stephen Colebourne
 *
 *  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 org.joda.beans.gen;

import java.lang.annotation.ElementType;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;

/**
 * Annotation defining a bean for code generation.
 * 

* This annotation must be used on classes that should be treated as beans. */ @Retention(RetentionPolicy.RUNTIME) @Target(ElementType.TYPE) public @interface BeanDefinition { /** * The style of bean generation. *

* By default, this follows 'smart' rules. * Set to 'minimal' to generate a minimal amount of code. * Set to 'full' to generate the full code. * Set to 'light' to generate a light immutable bean using reflection internally. * * @return the style, defaulted to 'smart' */ String style() default "smart"; /** * The scope of the generated constructor. *

* Only applicable to immutable beans. By default, this follows 'smart' * rules, which generate a private constructor when needed by the builder. * Set to 'private' to generate a private constructor. * Set to 'package' to generate a package-scoped constructor. * Set to 'protected' to generate a protected constructor. * Set to 'public' to generate a public constructor. * Set to 'public@ConstructorProperties' to generate an annotated public constructor. * * @return the constructor scope, defaulted to 'smart' */ String constructorScope() default "smart"; /** * The scope of the meta-bean class. *

* By default, this follows 'smart' rules, which generate a public meta-bean. * Set to 'private' to generate a private meta-bean. * Set to 'package' to generate a package-scoped meta-bean. * Set to 'public' to generate a public meta-bean. * * @return the meta scope, defaulted to 'smart' */ String metaScope() default "smart"; /** * The interfaces to add to the meta-bean class declaration. *

* By default, this adds no interfaces to the implements clause. * This option is only useful if the meta bean is a generated class. * * @return the meta scope, defaulted to '' */ String metaImplements() default ""; /** * The scope of the builder class. *

* By default, this follows 'smart' rules, which generate a public builder for * immutable beans and no builder for mutable beans. * Set to 'private' to generate a private builder. * Set to 'package' to generate a package-scoped builder. * Set to 'public' to generate a public builder. * * @return the builder scope, defaulted to 'smart' */ String builderScope() default "smart"; /** * The name of the manual builder class. *

* This is used when there is a desire to manually write the builder. * By default, this is not set, and a builder is generated based on the scope. * Set to 'FooBuilder' to generate code that expects a manually written builder named FooBuilder * (which may be an inner class or a top-level class). * * @return the builder scope, defaulted to '' */ String builderName() default ""; /** * The name of the factory method. *

* By default, this is an empty string and no factory is generated. * Set to 'of' to generate a factory method named 'of'. * * @return the factory name, defaulted to '' */ String factoryName() default ""; /** * Information about the bean hierarchy. *

* This is needed to add information that cannot be derived. * Set to 'immutable' for a subclass of an immutable bean. * * @return the hierarchy, defaulted to '' */ String hierarchy() default ""; /** * The configuration for generating clone methods. *

* This flag controls generation of the {@code clone} method. * The default is 'smart'. *

* The valid values are: *

    *
  • 'omit' - omit the clone method *
  • 'smart' - process intelligently, generating it for mutable and not generating for immutable *
  • 'generate' - generate the clone method *
* * @return the clone style, defaulted to 'smart' */ String cloneStyle() default "smart"; /** * Whether to generate code to cache the hash code. *

* Setting this to true will cause the hash code to be cached using the racy single check idiom. * The setting only applies to immutable beans. * * @return true if the hash code is to be cached */ boolean cacheHashCode() default false; }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy