
net.sf.staccatocommons.restrictions.Constant Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of staccatissimo-restrictions Show documentation
Show all versions of staccatissimo-restrictions Show documentation
Library of annotations that express restrictions, that can be used to indicate preconditions,
postconditions and invariants over objects and messages, focused on documentation reuse.
The newest version!
/**
* 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.restrictions;
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.check.NonNull;
import net.sf.staccatocommons.restrictions.effect.SideEffectFree;
import net.sf.staccatocommons.restrictions.effect.Transparent;
/**
* {@link Restriction} that denotes that the return value of a method is always
* the same object. This does not necessary mean that the returned
* object is a singleton.
*
* Although theoretically a method may be constant and still not
* {@link Transparent} - because of not being {@link SideEffectFree}, in
* practice this is a bug source. Thus, {@link Constant} annotated methods
* must be {@link Transparent}, and they do not need to be
* annotated with that annotation too, as it is implied.
*
*
* Constant methods must be not null, thus they do not need to
* be annotated as {@link NonNull}, as it is implied
*
*
* @author flbulgarelli
*/
@Documented
@Restriction
@Target(ElementType.METHOD)
@Retention(RetentionPolicy.CLASS)
public @interface Constant {
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy