| #ifndef Py_STRTOD_H | 
 | #define Py_STRTOD_H | 
 |  | 
 | #ifdef __cplusplus | 
 | extern "C" { | 
 | #endif | 
 |  | 
 |  | 
 | PyAPI_FUNC(double) PyOS_ascii_strtod(const char *str, char **ptr); | 
 | PyAPI_FUNC(double) PyOS_ascii_atof(const char *str); | 
 |  | 
 | /* Deprecated in 2.7 and 3.1. Will disappear in 2.8 (if it exists) and 3.2 */ | 
 | PyAPI_FUNC(char *) PyOS_ascii_formatd(char *buffer, size_t buf_len, | 
 |                                       const char *format, double d); | 
 |  | 
 | /* Use PyOS_double_to_string instead. It's the same, except it allocates | 
 |    the appropriately sized buffer and returns it. This function will go | 
 |    away in Python 2.8 and 3.2. */ | 
 | PyAPI_FUNC(void) _PyOS_double_to_string(char *buf, size_t buf_len, double val, | 
 |                                         char format_code, int precision, | 
 |                                         int flags, int* type); | 
 |  | 
 | /* The caller is responsible for calling PyMem_Free to free the buffer | 
 |    that's is returned. */ | 
 | PyAPI_FUNC(char *) PyOS_double_to_string(double val, | 
 |                                          char format_code, | 
 |                                          int precision, | 
 |                                          int flags, | 
 |                                          int *type); | 
 |  | 
 |  | 
 | /* PyOS_double_to_string's "flags" parameter can be set to 0 or more of: */ | 
 | #define Py_DTSF_SIGN      0x01 /* always add the sign */ | 
 | #define Py_DTSF_ADD_DOT_0 0x02 /* if the result is an integer add ".0" */ | 
 | #define Py_DTSF_ALT       0x04 /* "alternate" formatting. it's format_code | 
 |                                   specific */ | 
 |  | 
 | /* PyOS_double_to_string's "type", if non-NULL, will be set to one of: */ | 
 | #define Py_DTST_FINITE 0 | 
 | #define Py_DTST_INFINITE 1 | 
 | #define Py_DTST_NAN 2 | 
 |  | 
 | #ifdef __cplusplus | 
 | } | 
 | #endif | 
 |  | 
 | #endif /* !Py_STRTOD_H */ |