Museum

Home

Lab Overview

Retrotechnology Articles

Online Manuals

⇒ ecvt(3C) — Reliant UNIX 5.44c4

Media Vault

Software Library

Restoration Projects

Artifacts Sought

Related Articles

setlocale(3C)

printf(3S)

stdlib(5)

ecvt(3C)                                                           ecvt(3C)

NAME
     ecvt, fcvt, gcvt - convert floating-point number to string

SYNOPSIS
     #include <stdlib.h>

     char *ecvt(double value, int ndigit, int *decpt, int *sign);

     char *fcvt(double value, int ndigit, int *decpt, int *sign);

     char *gcvt(double value, int ndigit, char *buf);

DESCRIPTION
     The ecvt(), fcvt() and gcvt() functions convert floating-point numbers
     to null-terminated strings.

     ecvt() converts value to a null-terminated string of ndigit digits
     (where ndigit is reduced to an unspecified limit determined by the
     precision of a double) and returns a pointer to the string. The high-
     order digit is non-zero, unless the value is 0. The low-order digit is
     rounded. The position of the radix character relative to the beginning
     of the string is stored in the integer pointed to by decpt (negative
     means to the left of the returned digits). The radix character is not
     included in the returned string. If the sign of the result is nega-
     tive, the integer pointed to by sign is non-zero, otherwise it is 0.

     If the converted value is out of range or is not representable, the
     contents of the returned string are unspecified.

     fcvt() is identical to ecvt() except that ndigit specifies the number
     of digits desired after the radix point. The total number of digits in
     the result string is restricted to an unspecified limit as determined
     by the precision of a double.

     gcvt() converts value to a null-terminated string (similar to that of
     the %g format of printf()) in the array pointed to by buf and returns
     buf. It produces ndigit significant digits (limited to an unspecified
     value determined by the precision of a double) in %f if possible, or
     %e (scientific notation) otherwise. A minus sign is included in the
     returned string if value is less than 0. A radix character is included
     in the returned string if value is not a whole number. Trailing zeros
     are suppressed where value is not a whole number. The radix character
     is determined by the current locale. If setlocale() has not been
     called successfully, the default locale, "POSIX", is used. The default
     locale specifies a period (.) as the radix character. The LCNUMERIC
     category determines the value of the radix character within the
     current locale.








Page 1                       Reliant UNIX 5.44                Printed 11/98

ecvt(3C)                                                           ecvt(3C)

RETURN VALUE
     The ecvt() and fcvt() functions return a pointer to a null-terminated
     string of digits.

     The gcvt() function returns buf.

NOTES
     The values returned by ecvt() and fcvt() point to a single static data
     array whose content is overwritten by each call.

SEE ALSO
     setlocale(3C), printf(3S), stdlib(5).










































Page 2                       Reliant UNIX 5.44                Printed 11/98

Typewritten Software • bear@typewritten.org • Edmonds, WA 98026