/***********************************************************************1* *2* This software is part of the ast package *3* Copyright (c) 1985-2011 AT&T Intellectual Property *4* and is licensed under the *5* Eclipse Public License, Version 1.0 *6* by AT&T Intellectual Property *7* *8* A copy of the License is available at *9* http://www.eclipse.org/org/documents/epl-v10.html *10* (with md5 checksum b35adb5213ca9657e911e9befb180842) *11* *12* Information and Software Systems Research *13* AT&T Research *14* Florham Park NJ *15* *16* Glenn Fowler <[email protected]> *17* David Korn <[email protected]> *18* Phong Vo <[email protected]> *19* *20***********************************************************************/21#include "sfhdr.h"2223/* Return the length of a double value if coded in a portable format24**25** Written by Kiem-Phong Vo26*/2728#if __STD_C29int _sfdlen(Sfdouble_t v)30#else31int _sfdlen(v)32Sfdouble_t v;33#endif34{35#define N_ARRAY (16*sizeof(Sfdouble_t))36reg int n, w;37Sfdouble_t x;38int exp;3940if(v < 0)41v = -v;4243/* make the magnitude of v < 1 */44if(v != 0.)45v = frexpl(v,&exp);46else exp = 0;4748for(w = 1; w <= N_ARRAY; ++w)49{ /* get 2^SF_PRECIS precision at a time */50n = (int)(x = ldexpl(v,SF_PRECIS));51v = x-n;52if(v <= 0.)53break;54}5556return 1 + sfulen(exp) + w;57}585960