Initial revision
authorroland <roland>
Wed, 12 Jun 1991 18:26:25 +0000 (18:26 +0000)
committerroland <roland>
Wed, 12 Jun 1991 18:26:25 +0000 (18:26 +0000)
sysdeps/ieee754/copysign.c [new file with mode: 0644]

diff --git a/sysdeps/ieee754/copysign.c b/sysdeps/ieee754/copysign.c
new file mode 100644 (file)
index 0000000..7aa3f8d
--- /dev/null
@@ -0,0 +1,46 @@
+/* Copyright (C) 1991 Free Software Foundation, Inc.
+This file is part of the GNU C Library.
+
+The GNU C Library is free software; you can redistribute it and/or
+modify it under the terms of the GNU Library General Public License as
+published by the Free Software Foundation; either version 2 of the
+License, or (at your option) any later version.
+
+The GNU C Library is distributed in the hope that it will be useful,
+but WITHOUT ANY WARRANTY; without even the implied warranty of
+MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+Library General Public License for more details.
+
+You should have received a copy of the GNU Library General Public
+License along with the GNU C Library; see the file COPYING.LIB.  If
+not, write to the Free Software Foundation, Inc., 675 Mass Ave,
+Cambridge, MA 02139, USA.  */
+
+#include <ansidecl.h>
+#include <math.h>
+
+/* Return X with its signed changed to Y's.  */
+double
+DEFUN(__copysign, (x, y), double x AND double y)
+{
+  union
+    {
+      double d;
+      /* This is the IEEE 754 double-precision format.  */
+      struct
+       {
+         unsigned int negative:1;
+         int exponent:11;
+         /* Together these comprise the signed mantissa.  */
+         int mantissa0:20;
+         unsigned int mantissa1:32;
+       } ieee;
+    } ux, uy;
+
+  ux.d = x;
+  uy.d = y;
+
+  ux.ieee.negative = uy.ieee.negative;
+
+  return ux.d;
+}