eccodes/src/functions.c

207 lines
3.7 KiB
C

/*
* (C) Copyright 2005- ECMWF.
*
* This software is licensed under the terms of the Apache Licence Version 2.0
* which can be obtained at http://www.apache.org/licenses/LICENSE-2.0.
*
* In applying this licence, ECMWF does not waive the privileges and immunities granted to it by
* virtue of its status as an intergovernmental organisation nor does it submit to any jurisdiction.
*/
#include "grib_api_internal.h"
long grib_op_eq(long a, long b)
{
return a == b;
}
long grib_op_ne(long a, long b)
{
return a != b;
}
long grib_op_lt(long a, long b)
{
return a < b;
}
long grib_op_gt(long a, long b)
{
return a > b;
}
long grib_op_and(long a, long b)
{
return a && b;
}
long grib_op_or(long a, long b)
{
return a || b;
}
long grib_op_ge(long a, long b)
{
return a >= b;
}
long grib_op_le(long a, long b)
{
return a <= b;
}
long grib_op_bit(long a, long b)
{
return a & (1 << b);
}
long grib_op_bitoff(long a, long b)
{
return !grib_op_bit(a, b);
}
long grib_op_not(long a)
{
return !a;
}
long grib_op_neg(long a)
{
return -a;
}
double grib_op_neg_d(double a)
{
return -a;
}
long grib_op_pow(long a, long b)
{
/* Note: This is actually 'a' to the power 'b' */
return grib_power(b, a);
}
long grib_op_add(long a, long b)
{
return a + b;
}
long grib_op_sub(long a, long b)
{
return a - b;
}
long grib_op_div(long a, long b)
{
return a / b;
}
long grib_op_mul(long a, long b)
{
return a * b;
}
long grib_op_modulo(long a, long b)
{
return a % b;
}
double grib_op_mul_d(double a, double b)
{
return a * b;
}
double grib_op_div_d(double a, double b)
{
return a / b;
}
double grib_op_add_d(double a, double b)
{
return a + b;
}
double grib_op_sub_d(double a, double b)
{
return a - b;
}
double grib_op_eq_d(double a, double b)
{
return a == b;
}
double grib_op_ne_d(double a, double b)
{
return a != b;
}
double grib_op_lt_d(double a, double b)
{
return a < b;
}
double grib_op_gt_d(double a, double b)
{
return a > b;
}
double grib_op_ge_d(double a, double b)
{
return a >= b;
}
double grib_op_le_d(double a, double b)
{
return a <= b;
}
#define LOOKUP(a) \
if (proc == a) { \
return "&" #a; \
}
const char* grib_binop_long_proc_name(grib_binop_long_proc proc)
{
if (!proc)
return "NULL";
LOOKUP(grib_op_eq);
LOOKUP(grib_op_ne);
LOOKUP(grib_op_lt);
LOOKUP(grib_op_gt);
LOOKUP(grib_op_and);
LOOKUP(grib_op_or);
LOOKUP(grib_op_ge);
LOOKUP(grib_op_le);
LOOKUP(grib_op_bit);
LOOKUP(grib_op_bitoff);
LOOKUP(grib_op_pow);
LOOKUP(grib_op_add);
LOOKUP(grib_op_sub);
LOOKUP(grib_op_div);
LOOKUP(grib_op_mul);
LOOKUP(grib_op_modulo);
fprintf(stderr, "Cannot find grib_binop_long_proc\n");
Assert(0);
return NULL;
}
const char* grib_binop_double_proc_name(grib_binop_double_proc proc)
{
if (!proc)
return "NULL";
LOOKUP(grib_op_mul_d);
LOOKUP(grib_op_div_d);
LOOKUP(grib_op_add_d);
LOOKUP(grib_op_sub_d);
LOOKUP(grib_op_eq_d);
LOOKUP(grib_op_ne_d);
LOOKUP(grib_op_lt_d);
LOOKUP(grib_op_gt_d);
LOOKUP(grib_op_ge_d);
LOOKUP(grib_op_le_d);
fprintf(stderr, "Cannot find grib_binop_double_proc_name\n");
Assert(0);
return NULL;
}
const char* grib_unop_long_proc_name(grib_unop_long_proc proc)
{
if (!proc)
return "NULL";
LOOKUP(grib_op_not);
LOOKUP(grib_op_neg);
fprintf(stderr, "Cannot find grib_unop_long_proc_name\n");
Assert(0);
return NULL;
}
const char* grib_unop_double_proc_name(grib_unop_double_proc proc)
{
if (!proc)
return "NULL";
LOOKUP(grib_op_neg_d);
fprintf(stderr, "Cannot find grib_unop_double_proc_name\n");
Assert(0);
return NULL;
}