Start line:  
End line:  

Snippet Preview

Snippet HTML Code

Stack Overflow Questions
  /*
   * 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.facebook.presto.type;
 
 
 import static com.facebook.presto.metadata.OperatorType.ADD;
 import static com.facebook.presto.metadata.OperatorType.BETWEEN;
 import static com.facebook.presto.metadata.OperatorType.CAST;
 import static com.facebook.presto.metadata.OperatorType.DIVIDE;
 import static com.facebook.presto.metadata.OperatorType.EQUAL;
 import static com.facebook.presto.metadata.OperatorType.GREATER_THAN;
 import static com.facebook.presto.metadata.OperatorType.GREATER_THAN_OR_EQUAL;
 import static com.facebook.presto.metadata.OperatorType.HASH_CODE;
 import static com.facebook.presto.metadata.OperatorType.LESS_THAN;
 import static com.facebook.presto.metadata.OperatorType.LESS_THAN_OR_EQUAL;
 import static com.facebook.presto.metadata.OperatorType.MODULUS;
 import static com.facebook.presto.metadata.OperatorType.MULTIPLY;
 import static com.facebook.presto.metadata.OperatorType.NEGATION;
 import static com.facebook.presto.metadata.OperatorType.NOT_EQUAL;
 import static com.facebook.presto.metadata.OperatorType.SUBTRACT;
 import static com.facebook.presto.spi.StandardErrorCode.DIVISION_BY_ZERO;
 import static java.nio.charset.StandardCharsets.UTF_8;
 
 public final class BigintOperators
 {
     private BigintOperators()
     {
     }
 
     @ScalarOperator()
     public static long add(@SqlType(.long left, @SqlType(.long right)
     {
         return left + right;
     }
 
     public static long subtract(@SqlType(.long left, @SqlType(.long right)
     {
         return left - right;
     }
 
     public static long multiply(@SqlType(.long left, @SqlType(.long right)
     {
         return left * right;
     }
 
     public static long divide(@SqlType(.long left, @SqlType(.long right)
     {
         try {
             return left / right;
         }
         catch (ArithmeticException e) {
             throw new PrestoException(e);
         }
     }
 
     public static long modulus(@SqlType(.long left, @SqlType(.long right)
     {
         try {
             return left % right;
         }
         catch (ArithmeticException e) {
             throw new PrestoException(e);
         }
     }
 
     public static long negate(@SqlType(.long value)
     {
         return -value;
     }
 
    public static boolean equal(@SqlType(.long left, @SqlType(.long right)
    {
        return left == right;
    }
    public static boolean notEqual(@SqlType(.long left, @SqlType(.long right)
    {
        return left != right;
    }
    public static boolean lessThan(@SqlType(.long left, @SqlType(.long right)
    {
        return left < right;
    }
    public static boolean lessThanOrEqual(@SqlType(.long left, @SqlType(.long right)
    {
        return left <= right;
    }
    public static boolean greaterThan(@SqlType(.long left, @SqlType(.long right)
    {
        return left > right;
    }
    public static boolean greaterThanOrEqual(@SqlType(.long left, @SqlType(.long right)
    {
        return left >= right;
    }
    public static boolean between(@SqlType(.long value, @SqlType(.long min, @SqlType(.long max)
    {
        return min <= value && value <= max;
    }
    public static boolean castToBoolean(@SqlType(.long value)
    {
        return value != 0;
    }
    public static double castToDouble(@SqlType(.long value)
    {
        return value;
    }
    public static Slice castToVarchar(@SqlType(.long value)
    {
        // todo optimize me
        return Slices.copiedBuffer(String.valueOf(value), );
    }
    public static long hashCode(@SqlType(.long value)
    {
        return (int) (value ^ (value >>> 32));
    }
New to GrepCode? Check out our FAQ X