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

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

/*
 *  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 method that is to be called just before a code generated immutable bean is built.
 * 

* This is used when an immutable bean wants to perform an action on the builder just * before it is built into a bean. The action might include validation (normally done * using {@link ImmutableValidator}) and defaulting (normally done using {@link ImmutableDefaults}). *

* The special use case for this annotation is the ability to default the value of one property * from the value of another. For example, consider a bean with two dates, where one is derived * from the other (such as the second being the first adjusted to a valid business day). * Use of this annotation allows the second date to be set to the same as the first date if * a value is not set. *

* The method must be a private static void instance method that takes a single argument of the type 'Builder'. * The method will be called at the start of the {@code build()} method of the builder. * For example: *

 *   {@literal @}ImmutablePreBuild
 *   private static void preBuild(Builder builder) {
 *     if (builder.date2 == null) {
 *       builder.date2 = builder.date1;  // default date2 to be same as date1
 *     }
 *   }
 * 
*/ @Retention(RetentionPolicy.RUNTIME) @Target(ElementType.METHOD) public @interface ImmutablePreBuild { }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy