/* $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() */ #define EXP_DIGS 2 #if __STDC__ #include #if DBL_MAX_10_EXP >= 100 #undef EXP_DIGS #define EXP_DIGS 3 #endif #endif 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 - (4+EXP_DIGS)) < 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); }