add deprecated (removed from posix) [efg]cvt() functions

these have not been heavily tested, but they should work as described
in the old standards. probably broken for non-finite values...
This commit is contained in:
Rich Felker 2012-02-06 01:14:23 -05:00
parent 5a09a53010
commit f4ad36c4bf
4 changed files with 55 additions and 0 deletions

View File

@ -134,6 +134,9 @@ void *valloc (size_t);
void *memalign(size_t, size_t);
int clearenv(void);
int ptsname_r(int, char *, size_t);
char *ecvt(double, int, int *, int *);
char *fcvt(double, int, int *, int *);
char *gcvt(double, int, char *);
#endif

19
src/stdlib/ecvt.c Normal file
View File

@ -0,0 +1,19 @@
#include <stdlib.h>
#include <stdio.h>
char *ecvt(double x, int n, int *dp, int *sign)
{
static char buf[16];
char tmp[32];
int i, j;
if (n-1U > 15) n = 15;
sprintf(tmp, "%.*e", n-1, x);
i = *sign = (tmp[0]=='-');
for (j=0; tmp[i]!='e'; j+=(tmp[i++]!='.'))
buf[j] = tmp[i];
buf[j] = 0;
*dp = atoi(tmp+i+1);
return buf;
}

25
src/stdlib/fcvt.c Normal file
View File

@ -0,0 +1,25 @@
#define _GNU_SOURCE
#include <stdlib.h>
#include <stdio.h>
#include <string.h>
char *fcvt(double x, int n, int *dp, int *sign)
{
char tmp[1500];
int i, lz;
if (n > 1400U) n = 1400;
sprintf(tmp, "%.*f", n, x);
i = (tmp[0] == '-');
if (tmp[i] == '0') lz = strspn(tmp+i+2, "0");
else lz = -(int)strcspn(tmp+i, ".");
if (n<=lz) {
*sign = i;
*dp = 0;
if (n>14U) n = 14;
return "000000000000000"+14-n;
}
return ecvt(x, n-lz, dp, sign);
}

8
src/stdlib/gcvt.c Normal file
View File

@ -0,0 +1,8 @@
#include <stdlib.h>
#include <stdio.h>
char *gcvt(double x, int n, char *b)
{
sprintf(b, "%.*g", n, x);
return b;
}