⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 qeconvert.c

📁 操作系统SunOS 4.1.3版本的源码
💻 C
字号:
#if !defined(lint) && defined(SCCSIDS)static char     sccsid[] = "@(#)qeconvert.c 1.1 92/07/30 SMI";#endif/* * Copyright (c) 1988 by Sun Microsystems, Inc. */#include "base_conversion.h"char           *qeconvert(arg, ndigits, decpt, sign, buf)	quadruple         *arg;	int             ndigits, *decpt, *sign;	char           *buf;{	decimal_mode    dm;	decimal_record  dr;	fp_exception_field_type ef;	int             i;	static char     *nanstring = "NaN";	static char     *infstring = "Infinity";	char           *pc;	int             nc;	dm.rd = fp_direction;	/* Rounding direction. */	dm.df = floating_form;	/* E format. */	dm.ndigits = ndigits;	/* Number of significant digits. */	quadruple_to_decimal(arg, &dm, &dr, &ef);	*sign = dr.sign;	switch (dr.fpclass) {	case fp_normal:	case fp_subnormal:		*decpt = dr.exponent + ndigits;		for (i = 0; i < ndigits; i++)			buf[i] = dr.ds[i];		buf[ndigits] = 0;		break;	case fp_zero:		*decpt = 1;		for (i = 0; i < ndigits; i++)			buf[i] = '0';		buf[ndigits] = 0;		break;	case fp_infinity:		*decpt = 0;		pc = infstring;		if (ndigits < 8)			nc = 3;		else			nc = 8;		goto movestring;	case fp_quiet:	case fp_signaling:		*decpt = 0;		pc = nanstring;		nc = 3;movestring:		for (i = 0; i < nc; i++)			buf[i] = pc[i];		buf[nc] = 0;		break;	}	return buf;		/* For compatibility with ecvt. */}char           *qfconvert(arg, ndigits, decpt, sign, buf)	quadruple         *arg;	int             ndigits, *decpt, *sign;	char           *buf;{	decimal_mode    dm;	decimal_record  dr;	fp_exception_field_type ef;	int             i;	dm.rd = fp_direction;	/* Rounding direction. */	dm.df = fixed_form;	/* F format. */	dm.ndigits = ndigits;	/* Number of digits after point. */	quadruple_to_decimal(arg, &dm, &dr, &ef);	*sign = dr.sign;	switch (dr.fpclass) {	case fp_normal:	case fp_subnormal:		if (ndigits >= 0)			*decpt = dr.ndigits - ndigits;		else			*decpt = dr.ndigits;		for (i = 0; i < dr.ndigits; i++)			buf[i] = dr.ds[i];		buf[dr.ndigits] = 0;		break;	case fp_zero:		*decpt = 0;		buf[0] = '0';		for (i = 1; i < ndigits; i++)			buf[i] = '0';		buf[i] = 0;		break;	case fp_infinity:		*decpt = 0;		if (ndigits < 8)			buf = "Inf";		else			buf = "Infinity";		break;	case fp_quiet:	case fp_signaling:		*decpt = 0;		buf = "NaN";		break;	}	return buf;		/* For compatibility with fcvt. */}extern void    _gcvt();char           *qgconvert(number, ndigit, trailing, buf)	quadruple         *number;	int             ndigit, trailing;	char           *buf;{	decimal_mode    dm;	decimal_record  dr;	fp_exception_field_type fef;	dm.rd = fp_direction;	dm.df = floating_form;	dm.ndigits = ndigit;	quadruple_to_decimal(number, &dm, &dr, &fef);	_gcvt(ndigit, &dr, trailing, buf);	return (buf);}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -