/*
 * Copyright (C) 2017 The Android Open Source Project
 * All rights reserved.
 *
 * Redistribution and use in source and binary forms, with or without
 * modification, are permitted provided that the following conditions
 * are met:
 *  * Redistributions of source code must retain the above copyright
 *    notice, this list of conditions and the following disclaimer.
 *  * Redistributions in binary form must reproduce the above copyright
 *    notice, this list of conditions and the following disclaimer in
 *    the documentation and/or other materials provided with the
 *    distribution.
 *
 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
 * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
 * COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
 * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
 * OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
 * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
 * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
 * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
 * SUCH DAMAGE.
 */

#include <tgmath.h>

#include "header_checks.h"

#define TGMATH(f_) f_(f1); f_(d1); f_(ld1);
#define TGMATHC(f_) f_(f1); f_(d1); f_(ld1); f_(fc1); f_(dc1); f_(ldc1);
#define TGMATHCONLY(f_) f_(fc1); f_(dc1); f_(ldc1);
#define TGMATH2(f_) f_(f1, f2); f_(d1, d2); f_(ld1, ld2);
#define TGMATH2C(f_) f_(f1, f2); f_(d1, d2); f_(ld1, ld2); f_(fc1, fc2); f_(dc1, dc2); f_(ldc1, ldc2);
#define TGMATH3(f_) f_(f1, f2, f3); f_(d1, d2, d3); f_(ld1, ld2, ld3);

static void tgmath_h() {
  float f1, f2, f3;
  f1 = f2 = f3 = 0;
  float complex fc1, fc2, fc3;
  fc1 = fc2 = fc3 = 0;
  double d1, d2, d3;
  d1 = d2 = d3 = 0;
  double complex dc1, dc2, dc3;
  dc1 = dc2 = dc3 = 0;
  long double ld1, ld2, ld3;
  ld1 = ld2 = ld3 = 0;
  long double complex ldc1, ldc2, ldc3;
  ldc1 = ldc2 = ldc3 = 0;
  int i = 0;
  long l = 0;

  TGMATHC(acos);
  TGMATHC(asin);
  TGMATHC(atan);
  TGMATHC(acosh);
  TGMATHC(asinh);
  TGMATHC(atanh);
  TGMATHC(cos);
  TGMATHC(sin);
  TGMATHC(tan);
  TGMATHC(cosh);
  TGMATHC(sinh);
  TGMATHC(tanh);
  TGMATHC(exp);
  TGMATHC(log);
  TGMATH2C(pow);
  TGMATHC(sqrt);
  TGMATHC(fabs);

  TGMATH2(atan2);
  TGMATH(cbrt);
  TGMATH(ceil);
  TGMATH2(copysign);
  TGMATH(erf);
  TGMATH(erfc);
  TGMATH(exp2);
  TGMATH(expm1);
  TGMATH2(fdim);
  TGMATH(floor);
  TGMATH3(fma);
  TGMATH2(fmax);
  TGMATH2(fmin);
  TGMATH2(fmod);
  frexp(f1, &i); frexp(d1, &i); frexp(ld1, &i);
  TGMATH2(hypot);
  TGMATH(ilogb);
  ldexp(f1, i); ldexp(d1, i); ldexp(ld1, i);
  TGMATH(lgamma);
  TGMATH(llrint);
  TGMATH(llround);
  TGMATH(log10);
  TGMATH(log1p);
  TGMATH(log2);
  TGMATH(logb);
  TGMATH(lrint);
  TGMATH(lround);
  TGMATH(nearbyint);
  TGMATH2(nextafter);
  TGMATH2(nexttoward);
  TGMATH2(remainder);
  remquo(f1, f2, &i); remquo(d1, d2, &i); remquo(ld1, ld2, &i);
  TGMATH(rint);
  TGMATH(round);
  scalbln(f1, l); scalbln(d1, l); scalbln(ld1, l);
  scalbn(f1, i); scalbn(d1, i); scalbn(ld1, i);
  TGMATH(tgamma);
  TGMATH(trunc);

  TGMATHCONLY(carg);
  TGMATHCONLY(cimag);
  TGMATHCONLY(conj);
  TGMATHCONLY(cproj);
  TGMATHCONLY(creal);
}