ack/lang/pc/libpc/wrr.c
2018-06-17 22:30:27 +02:00

73 lines
1.2 KiB
C

/* $Id$ */
/*
* (c) copyright 1983 by the Vrije Universiteit, Amsterdam, The Netherlands.
*
* This product is part of the Amsterdam Compiler Kit.
*
* Permission to use, sell, duplicate or disclose this software must be
* obtained in writing. Requests for such permissions may be sent to
*
* Dr. Andrew S. Tanenbaum
* Wiskundig Seminarium
* Vrije Universiteit
* Postbox 7161
* 1007 MC Amsterdam
* The Netherlands
*
*/
/* Author: J.W. Stevenson */
#include "pc.h"
#define PREC_DIG 80 /* maximum digits produced by _ecvt() */
void _wsr(int w, double r, struct file* f)
{
char *p, *b;
int s, d, i;
char buf[PREC_DIG + 7];
if (w < 0)
_trp(EWIDTH);
p = buf;
if ((i = w - 6) < 2)
i = 2;
b = _ecvt(r, i, &d, &s);
*p++ = s ? '-' : ' ';
if (*b == '0')
d++;
*p++ = *b++;
*p++ = '.';
while (--i > 0)
*p++ = *b++;
*p++ = 'e';
d--;
if (d < 0)
{
d = -d;
*p++ = '-';
}
else
*p++ = '+';
if (d >= 1000)
{
*p++ = '*';
*p++ = '*';
*p++ = '*';
}
else
{
*p++ = '0' + d / 100;
*p++ = '0' + (d / 10) % 10;
*p++ = '0' + d % 10;
}
_wstrin(w, (int)(p - buf), buf, f);
}
void _wrr(double r, struct file* f)
{
_wsr(13, r, f);
}