![JAR search and dependency download from the Maven repository](/logo.png)
com.speedment.runtime.compute.trait.HasPlus Maven / Gradle / Ivy
/*
*
* Copyright (c) 2006-2020, Speedment, Inc. 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 com.speedment.runtime.compute.trait;
import com.speedment.runtime.compute.ToByte;
import com.speedment.runtime.compute.ToDouble;
import com.speedment.runtime.compute.ToInt;
import com.speedment.runtime.compute.ToLong;
/**
* Trait that describes an expression that has several
* {@link #plus(int)}-methods for generating new expressions for the sum of this
* value and something else.
*
* @param the input type
* @author Emil Forslund
* @since 3.1.0
*/
public interface HasPlus {
/**
* Creates and returns an expression that returns the sum of the result from
* the current expression and the other term. For an example, if the result
* of the current expression was {@code 9} and the other term was set to
* {@code 3}, then the result of the returned expression would be {@code
* 12}.
*
* If this expression is nullable and the result was {@code null}, then the
* result of the returned expression will also be {@code null}.
*
* @param other the other term used for the addition
* @return the new expression
*/
HasPlus plus(byte other);
/**
* Creates and returns an expression that returns the sum of the result from
* the current expression and the other term. For an example, if the result
* of the current expression was {@code 9} and the other term was set to
* {@code 3}, then the result of the returned expression would be {@code
* 12}.
*
* If this expression is nullable and the result was {@code null}, then the
* result of the returned expression will also be {@code null}.
*
* @param other the other term used for the addition
* @return the new expression
*/
@SuppressWarnings("overloads")
HasPlus plus(ToByte other);
/**
* Creates and returns an expression that returns the sum of the result from
* the current expression and the other term. For an example, if the result
* of the current expression was {@code 9} and the other term was set to
* {@code 3}, then the result of the returned expression would be {@code
* 12}.
*
* If this expression is nullable and the result was {@code null}, then the
* result of the returned expression will also be {@code null}.
*
* @param other the other term used for the addition
* @return the new expression
*/
HasPlus plus(int other);
/**
* Creates and returns an expression that returns the sum of the result from
* the current expression and the other term. For an example, if the result
* of the current expression was {@code 9} and the other term was set to
* {@code 3}, then the result of the returned expression would be {@code
* 12}.
*
* If this expression is nullable and the result was {@code null}, then the
* result of the returned expression will also be {@code null}.
*
* @param other the other term used for the addition
* @return the new expression
*/
@SuppressWarnings("overloads")
HasPlus plus(ToInt other);
/**
* Creates and returns an expression that returns the sum of the result from
* the current expression and the other term. For an example, if the result
* of the current expression was {@code 9} and the other term was set to
* {@code 3}, then the result of the returned expression would be {@code
* 12}.
*
* If this expression is nullable and the result was {@code null}, then the
* result of the returned expression will also be {@code null}.
*
* @param other the other term used for the addition
* @return the new expression
*/
HasPlus plus(long other);
/**
* Creates and returns an expression that returns the sum of the result from
* the current expression and the other term. For an example, if the result
* of the current expression was {@code 9} and the other term was set to
* {@code 3}, then the result of the returned expression would be {@code
* 12}.
*
* If this expression is nullable and the result was {@code null}, then the
* result of the returned expression will also be {@code null}.
*
* @param other the other term used for the addition
* @return the new expression
*/
@SuppressWarnings("overloads")
HasPlus plus(ToLong other);
/**
* Creates and returns an expression that returns the sum of the result from
* the current expression and the other term. For an example, if the result
* of the current expression was {@code 9} and the other term was set to
* {@code 3}, then the result of the returned expression would be {@code
* 12}.
*
* If this expression is nullable and the result was {@code null}, then the
* result of the returned expression will also be {@code null}.
*
* @param other the other term used for the addition
* @return the new expression
*/
ToDouble plus(double other);
/**
* Creates and returns an expression that returns the sum of the result from
* the current expression and the other term. For an example, if the result
* of the current expression was {@code 9} and the other term was set to
* {@code 3}, then the result of the returned expression would be {@code
* 12}.
*
* If this expression is nullable and the result was {@code null}, then the
* result of the returned expression will also be {@code null}.
*
* @param other the other term used for the addition
* @return the new expression
*/
@SuppressWarnings("overloads")
ToDouble plus(ToDouble other);
}