diff --git a/include/__locale b/include/__locale index 601f0d1ec..c293b81fb 100644 --- a/include/__locale +++ b/include/__locale @@ -24,11 +24,7 @@ #elif defined(_AIX) # include #elif defined(__ANDROID__) -// Android gained the locale aware functions in L (API level 21) -# include -# if __ANDROID_API__ <= 20 -# include -# endif +# include #elif defined(__sun__) # include # include diff --git a/include/support/android/locale_bionic.h b/include/support/android/locale_bionic.h index 081035d45..796b8d827 100644 --- a/include/support/android/locale_bionic.h +++ b/include/support/android/locale_bionic.h @@ -24,7 +24,44 @@ extern "C" { } #endif +#if defined(__ANDROID__) + +#include + +// Android gained most locale aware functions in L (API level 21) +#if __ANDROID_API__ < 21 #include +#endif + +// The strto* family was added in O (API Level 26) +#if __ANDROID_API__ < 26 + +#if defined(__cplusplus) +extern "C" { +#endif + +inline _LIBCPP_ALWAYS_INLINE float strtof_l(const char* __nptr, char** __endptr, + locale_t) { + return ::strtof(__nptr, __endptr); +} + +inline _LIBCPP_ALWAYS_INLINE double strtod_l(const char* __nptr, + char** __endptr, locale_t) { + return ::strtod(__nptr, __endptr); +} + +inline _LIBCPP_ALWAYS_INLINE long strtol_l(const char* __nptr, char** __endptr, + int __base, locale_t) { + return ::strtol(__nptr, __endptr, __base); +} + +#if defined(__cplusplus) +} +#endif + +#endif // __ANDROID_API__ < 26 + +#endif // defined(__ANDROID__) #endif // defined(__BIONIC__) #endif // _LIBCPP_SUPPORT_ANDROID_LOCALE_BIONIC_H