#include <complex.h>
#include <fenv.h>
#include <math.h>
#include "math_private.h"
__complex__ long double
__ccoshl (__complex__ long double x)
{
__complex__ long double retval;
int rcls = fpclassify (__real__ x);
int icls = fpclassify (__imag__ x);
if (rcls >= FP_ZERO)
{
if (icls >= FP_ZERO)
{
long double sinh_val = sinhl (__real__ x);
long double cosh_val = coshl (__real__ x);
long double sinix, cosix;
sincosl (__imag__ x, &sinix, &cosix);
__real__ retval = cosh_val * cosix;
__imag__ retval = sinh_val * sinix;
}
else
{
__imag__ retval = __real__ x == 0.0 ? 0.0 : nanl ("");
__real__ retval = nanl ("") + nanl ("");
#ifdef FE_INVALID
if (icls == FP_INFINITE)
feraiseexcept (FE_INVALID);
#endif
}
}
else if (rcls == FP_INFINITE)
{
if (icls == FP_ZERO)
{
__real__ retval = HUGE_VALL;
__imag__ retval = __imag__ x * copysignl (1.0, __real__ x);
}
else if (icls > FP_ZERO)
{
long double sinix, cosix;
sincosl (__imag__ x, &sinix, &cosix);
__real__ retval = copysignl (HUGE_VALL, cosix);
__imag__ retval = (copysignl (HUGE_VALL, sinix)
* copysignl (1.0, __real__ x));
}
else
{
__real__ retval = HUGE_VALL;
__imag__ retval = nanl ("") + nanl ("");
#ifdef FE_INVALID
if (icls == FP_INFINITE)
feraiseexcept (FE_INVALID);
#endif
}
}
else
{
__real__ retval = nanl ("");
__imag__ retval = __imag__ x == 0.0 ? __imag__ x : nanl ("");
}
return retval;
}
weak_alias (__ccoshl, ccoshl)