net.sf.staccatocommons.defs.Applicative Maven / Gradle / Ivy
/**
* Copyright (c) 2010-2012, The StaccatoCommons Team
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU Lesser General Public License as published by
* the Free Software Foundation; version 3 of the License.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Lesser General Public License for more details.
*/
package net.sf.staccatocommons.defs;
import java.lang.annotation.Documented;
import java.lang.annotation.ElementType;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;
import net.sf.staccatocommons.restrictions.Restriction;
import net.sf.staccatocommons.restrictions.check.NonNull;
import net.sf.staccatocommons.restrictions.effect.SideEffectFree;
import net.sf.staccatocommons.restrictions.effect.Transparent;
import net.sf.staccatocommons.restrictions.value.Immutable;
/**
* {@link Applicable} is an annotation for abstract types that have
* code-block/command/strategy/closure/lambda semantics, with an only abstract
* method that implements such code, called applicative method.
*
*
* In order to remain as general purposes as possible, such types does not
* impose any {@link Restriction} over the type itself nor its applicative
* method. There are however some recommendations for implementing it, that will
* maximize the reusability of concrete classes.
*
*
* - Implementors should be {@link Transparent}, or at least
* {@link SideEffectFree}. An obvious case where this is not generally possible
* is for {@link Applicable} that return {@link Void}, which will be applied for
* its side effects only
* - Implementors should be {@link Immutable}, regardless
* they are {@link SideEffectFree} or not
* - Public available implementorsshould be
* {@link Serializable}
*
*
* Methods that return {@link Applicative}s must be
* {@link NonNull} and {@link Transparent}.
*
*
* In addition, methods that return {@link Applicative}s and are annotated with
* restrictions, alter {@link Restriction} semantic in some way: they do not
* indicate that the method is restricted, but that the applicative's method is
* restricted. For example, in the following code:
*
*
* @Transparent
* Thunk<Integer> foo();
*
*
* The {@link Transparent} annotations does not indicate that method foo() is
* transparent, but that the applicative method of the returned Thunks, that is,
* Thunk.value(), is transparent.
*
* @author flbulgarelli
*/
@Documented
@Retention(RetentionPolicy.SOURCE)
@Target(ElementType.TYPE)
public @interface Applicative {
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy