Main Page | Alphabetical List | Class List | File List | Class Members | File Members

strtod.h File Reference

contains the strtod() function and defines for strtof() More...

#include <nlibc.h>

Include dependency graph for strtod.h:

Include dependency graph

This graph shows which files directly or indirectly include this file:

Included by dependency graph

Go to the source code of this file.

Defines

#define _STRTOD_NAN_INF_STRINGS   1
#define _STRTOD_HEXADECIMAL_FLOATS   1
#define _STRTOD_LOG_SCALING   1
#define _STRTOD_ERRNO   1
#define _STRTOD_ENDPTR   1
#define _STRTOD_RESTRICT_EXP   1
#define _STRTOD_RESTRICT_DIGITS   1
#define _STRTOD_ZERO_CHECK   1
#define _STRTOD_ENDPTR   1
#define _STRTOD_RESTRICT_EXP   1
#define _STRTOD_RESTRICT_DIGITS   1
#define _STRTOD_ZERO_CHECK   1
#define _ISOC99_SOURCE   1
#define _STRTOD_HEXADECIMAL_FLOATS   1
#define FPMAX_TYPE   2
#define FPMAX_MIN_10_EXP   DBL_MIN_10_EXP
#define NEED_STRTOD_WRAPPER
#define NEED_STRTOF_WRAPPER
#define __FPMAX_ZERO_OR_INF_CHECK(x)   ((x) == ((x)/4) )
#define EXP_DENORM_ADJUST   DECIMAL_DIG
#define MAX_ALLOWED_EXP   (DECIMAL_DIG + EXP_DENORM_ADJUST - FPMAX_MIN_10_EXP)
#define _STRTOD_NEED_NUM_DIGITS   1
#define strtof(NPTR, ENDPTR)   strtod((NPTR),(ENDPTR))
#define strtold(NPTR, ENDPTR)   strtod((NPTR),(ENDPTR))

Typedefs

typedef double __fpmax_t

Functions

__fpmax_t strtod (const char *cstr, char **endptr)


Detailed Description

contains the strtod() function and defines for strtof()

Definition in file strtod.h.


Define Documentation

#define __FPMAX_ZERO_OR_INF_CHECK  )     ((x) == ((x)/4) )
 

Check if the double x is zero or infinity probably not the most clever way to do it on apeNEXT but it will do for the moment

Definition at line 137 of file strtod.h.

#define _ISOC99_SOURCE   1
 

Definition at line 117 of file strtod.h.

#define _STRTOD_ENDPTR   1
 

Definition at line 109 of file strtod.h.

#define _STRTOD_ENDPTR   1
 

Definition at line 109 of file strtod.h.

#define _STRTOD_ERRNO   1
 

Definition at line 82 of file strtod.h.

#define _STRTOD_HEXADECIMAL_FLOATS   1
 

Definition at line 119 of file strtod.h.

#define _STRTOD_HEXADECIMAL_FLOATS   1
 

Definition at line 119 of file strtod.h.

#define _STRTOD_LOG_SCALING   1
 

Definition at line 72 of file strtod.h.

#define _STRTOD_NAN_INF_STRINGS   1
 

Definition at line 62 of file strtod.h.

#define _STRTOD_NEED_NUM_DIGITS   1
 

Definition at line 156 of file strtod.h.

#define _STRTOD_RESTRICT_DIGITS   1
 

Definition at line 111 of file strtod.h.

#define _STRTOD_RESTRICT_DIGITS   1
 

Definition at line 111 of file strtod.h.

#define _STRTOD_RESTRICT_EXP   1
 

Definition at line 110 of file strtod.h.

#define _STRTOD_RESTRICT_EXP   1
 

Definition at line 110 of file strtod.h.

#define _STRTOD_ZERO_CHECK   1
 

Definition at line 112 of file strtod.h.

#define _STRTOD_ZERO_CHECK   1
 

Definition at line 112 of file strtod.h.

#define EXP_DENORM_ADJUST   DECIMAL_DIG
 

Definition at line 142 of file strtod.h.

#define FPMAX_MIN_10_EXP   DBL_MIN_10_EXP
 

Definition at line 127 of file strtod.h.

#define FPMAX_TYPE   2
 

Definition at line 125 of file strtod.h.

#define MAX_ALLOWED_EXP   (DECIMAL_DIG + EXP_DENORM_ADJUST - FPMAX_MIN_10_EXP)
 

Definition at line 143 of file strtod.h.

#define NEED_STRTOD_WRAPPER
 

Definition at line 129 of file strtod.h.

#define NEED_STRTOF_WRAPPER
 

Definition at line 130 of file strtod.h.

#define strtof NPTR,
ENDPTR   )     strtod((NPTR),(ENDPTR))
 

Definition at line 508 of file strtod.h.

#define strtold NPTR,
ENDPTR   )     strtod((NPTR),(ENDPTR))
 

Definition at line 509 of file strtod.h.


Typedef Documentation

typedef double __fpmax_t
 

Definition at line 126 of file strtod.h.


Function Documentation

__fpmax_t strtod const char *  cstr,
char **  endptr
 

NAME
strtod, strtof, strtold - convert ASCII string to floating
point number

SYNOPSIS
#include <stdlib.h>

double strtod(const char *nptr, char **endptr);
float strtof(const char *nptr, char **endptr);
long double strtold(const char *nptr, char **endptr);

DESCRIPTION
The strtod, strtof, and strtold functions convert the ini­
tial portion of the string pointed to by nptr to double,
float, and long double representation, respectively.

The expected form of the (initial portion of the) string
is optional leading white space as recognized by is­
space(3), an optional plus (``+'') or minus sign (``-'')
and then either (i) a decimal number, or (ii) a hexadeci­
mal number, or (iii) an infinity, or (iv) a NAN (not-a-
number).

A decimal number consists of a nonempty sequence of deci­
mal digits possibly containing a radix character (decimal
point, locale dependent, usually ``.''), optionally fol­
lowed by a decimal exponent. A decimal exponent consists
of an ``E'' or ``e'', followed by an optional plus or
minus sign, followed by a non-empty sequence of decimal
digits, and indicates multiplication by a power of 10.

A hexadecimal number consists of a ``0x'' or ``0X'' fol­
lowed by a nonempty sequence of hexadecimal digits possi­
bly containing a radix character, optionally followed by a
binary exponent. A binary exponent consists of a ``P'' or
``p'', followed by an optional plus or minus sign, fol­
lowed by a non-empty sequence of decimal digits, and indi­
cates multiplication by a power of 2. At least one of
radix character and binary exponent must be present.

An infinity is either ``INF'' or ``INFINITY'', disregard­
ing case.


A NAN is ``NAN'' (disregarding case) optionally followed
by `(', a sequence of characters, followed by ')'. The
character string specifies in an implementation-dependent
way the type of NAN.


RETURN VALUE
These functions return the converted value, if any.

If endptr is not NULL, a pointer to the character after
the last character used in the conversion is stored in the
location referenced by endptr.

If no conversion is performed, zero is returned and the
value of nptr is stored in the location referenced by
endptr.

If the correct value would cause overflow, plus or minus
HUGE_VAL (HUGE_VALF, HUGE_VALL) is returned (according to
the sign of the value), and ERANGE is stored in errno. If
the correct value would cause underflow, zero is returned
and ERANGE is stored in errno.

ERRORS
ERANGE Overflow or underflow occurred.

IMPLEMENTATION for apeNEXT:
done with some restrictions:
  • endptr contains (if defined) a pointer to a location in some 'virtual' array of char that is located at the same address as the packed string nptr.
    I.e. in order to find the invalid character position, one has to calculate the difference between endptr and nptr.
  • This implementation is bases in the one in uClibc. Changes include removal of all locale and Wchar stuff and the wrapper functions.
OPTIMIZATIONS for apeNEXT:
None so far.


Generated on Mon Feb 20 15:54:50 2006 for nlibc by doxygen 1.3.5