summaryrefslogtreecommitdiff
path: root/lib/libm/projf.c
diff options
context:
space:
mode:
Diffstat (limited to 'lib/libm/projf.c')
-rw-r--r--lib/libm/projf.c11
1 files changed, 11 insertions, 0 deletions
diff --git a/lib/libm/projf.c b/lib/libm/projf.c
new file mode 100644
index 00000000..4efd9605
--- /dev/null
+++ b/lib/libm/projf.c
@@ -0,0 +1,11 @@
+#include "__complex.h"
+
+float complex cprojf(float complex z)
+{
+ float_complex w = { .z = z };
+ if (isinf(crealf(z)) || isinf(cimagf(z))) {
+ REAL_PART(w) = INFINITY;
+ IMAG_PART(w) = copysignf(0.0, cimagf(z));
+ }
+ return (w.z);
+}