2 * CDE - Common Desktop Environment
4 * Copyright (c) 1993-2012, The Open Group. All rights reserved.
6 * These libraries and programs are free software; you can
7 * redistribute them and/or modify them under the terms of the GNU
8 * Lesser General Public License as published by the Free Software
9 * Foundation; either version 2 of the License, or (at your option)
12 * These libraries and programs are distributed in the hope that
13 * they will be useful, but WITHOUT ANY WARRANTY; without even the
14 * implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
15 * PURPOSE. See the GNU Lesser General Public License for more
18 * You should have received a copy of the GNU Lesser General Public
19 * License along with these librararies and programs; if not, write
20 * to the Free Software Foundation, Inc., 51 Franklin Street, Fifth
21 * Floor, Boston, MA 02110-1301 USA
23 /* $XConsortium: sfputd.c /main/3 1995/11/01 18:33:55 rswiston $ */
24 /***************************************************************
26 * AT&T - PROPRIETARY *
28 * THIS IS PROPRIETARY SOURCE CODE LICENSED BY *
31 * Copyright (c) 1995 AT&T Corp. *
32 * All Rights Reserved *
34 * This software is licensed by AT&T Corp. *
35 * under the terms and conditions of the license in *
36 * http://www.research.att.com/orgs/ssr/book/reuse *
38 * This software was created by the *
39 * Software Engineering Research Department *
40 * AT&T Bell Laboratories *
42 * For further information contact *
43 * gsf@research.att.com *
45 ***************************************************************/
48 /* Write out a double value in a portable format
50 ** Written by Kiem-Phong Vo (08/05/90)
54 _sfputd(Sfio_t* f, reg double v)
61 #define N_ARRAY (16*sizeof(double))
68 if(f->mode != SF_WRITE && _sfmode(f,SF_WRITE,0) < 0)
72 /* get the sign of v */
79 /* make the magnitude of v < 1 */
84 /* code the sign of v and exp */
90 /* write out the signs and the exp */
92 if(sfputc(f,n) < 0 || (w = sfputu(f,w)) < 0)
97 s = (ends = &c[0])+sizeof(c);
99 { /* get 2^SF_PRECIS precision at a time */
100 n = (int)(x = ldexp(v,SF_PRECIS));
106 /* last byte is not SF_MORE */
107 ends = &c[0] + sizeof(c) -1;
110 /* write out coded bytes */
112 w = SFWRITE(f,(Void_t*)s,n) == n ? w+n : -1;