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

jp.objectfanatics.assertion.constraints.Range Maven / Gradle / Ivy

/*
 * Copyright (C) 2005-2009 Makoto Sato. All Rights Reserved.
 * Copyright (C) 2010 OBJECT FANATICS Co.,Ltd. All Rights Reserved.
 *
 * 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 jp.objectfanatics.assertion.constraints;

import static java.lang.annotation.ElementType.METHOD;
import static java.lang.annotation.ElementType.PARAMETER;
import static java.lang.annotation.RetentionPolicy.RUNTIME;

import java.lang.annotation.Documented;
import java.lang.annotation.Retention;
import java.lang.annotation.Target;

//DOUBLE_CHECKED 04.04.2010
/**
 * TODO: 文言
 * The annotated element must be non-null, and equals to or greater than the specified value.
 * 

* Supported types are: *

    *
  • byte
  • *
  • short
  • *
  • int
  • *
  • long
  • *
  • float
  • *
  • double
  • *
  • Byte
  • *
  • Short
  • *
  • Integer
  • *
  • Long
  • *
  • Float
  • *
  • Double
  • *
  • BigInteger
  • *
  • BigDecimal
  • *
  • AtomicInteger
  • *
  • AtomicLong
  • *
*

* * @author Makoto Sato * @author Hirokatsu Endo */ @Documented @Retention(RUNTIME) @Target( { METHOD, PARAMETER }) @ConstraintAnnotation public @interface Range { // TODO: MaxやMinのような数値比較を行う場合のパラメータについては、文字列で指定するようにして、文字列から適切な型に変換するようにする。 // この場合、コンパイラによる文字列チェックをいれることはできないが、ウィービング時にエラーとなるので、実害はない。 // 現状は、すべて double として扱われるため、long のような double よりも精度の大きい数を扱う場合に、暗黙的条件が入るので、よろしくない。 // また、入力値をdoubleとして受け取るので、実際に入力した文字列がわからない(100L, 10E2, 100.0等)。 // javadoc として、この考え方を残しておきましょう。 double min(); double max(); }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy