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

org.jetbrains.annotations.Contract Maven / Gradle / Ivy

/*
 * Copyright 2000-2013 JetBrains s.r.o.
 *
 * 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.jetbrains.annotations;

import java.lang.annotation.*;

/**
 * Specifies some aspects of the method behavior depending on the arguments. Can be used by tools for advanced data flow analysis.
 * Note that this annotation just describes how the code works and doesn't add any functionality by means of code generation.

* * Method contract has the following syntax:
* contract ::= (clause ';')* clause
* clause ::= args '->' effect
* args ::= ((arg ',')* arg )?
* arg ::= value-constraint
* value-constraint ::= 'any' | 'null' | '!null' | 'false' | 'true'
* effect ::= value-constraint | 'fail'

* * The constraints denote the following:
*

    *
  • _ - any value *
  • null - null value *
  • !null - a value statically proved to be not-null *
  • true - true boolean value *
  • false - false boolean value *
  • fail - the method throws an exception, if the arguments satisfy argument constraints *
* Examples:

* @Contract("_, null -> null") - method returns null if its second argument is null
* @Contract("_, null -> null; _, !null -> !null") - method returns null if its second argument is null and not-null otherwise
* @Contract("true -> fail") - a typical assertFalse method which throws an exception if true is passed to it
* */ @Documented @Retention(RetentionPolicy.CLASS) @Target(ElementType.METHOD) public @interface Contract { /** * Contains the contract clauses describing causal relations between call arguments and the returned value */ String value() default ""; /** * Specifies that the annotated method has no visible side effects, in the following sense. * If its return value is not used, removing its invocation won't * affect program state and change the semantics. Exception throwing is not considered to be a side effect. * * "Invisible" side effects (such as logging) that don't affect the "important" program semantics are allowed.

* * This annotation may be used for more precise data flow analysis, and * to check that the method's return value is actually used in the call place. */ boolean pure() default false; }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy