| //===----------------------------------------------------------------------===// |
| // |
| // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. |
| // See https://llvm.org/LICENSE.txt for license information. |
| // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception |
| // |
| //===----------------------------------------------------------------------===// |
| |
| #include <charconv> |
| #include <string.h> |
| |
| #include "include/to_chars_floating_point.h" |
| |
| _LIBCPP_BEGIN_NAMESPACE_STD |
| |
| #ifndef _LIBCPP_ABI_DO_NOT_EXPORT_TO_CHARS_BASE_10 |
| |
| namespace __itoa |
| { |
| |
| _LIBCPP_FUNC_VIS char* |
| __u32toa(uint32_t value, char* buffer) noexcept |
| { |
| return __base_10_u32(buffer, value); |
| } |
| |
| _LIBCPP_FUNC_VIS char* |
| __u64toa(uint64_t value, char* buffer) noexcept |
| { |
| return __base_10_u64(buffer, value); |
| } |
| |
| } // namespace __itoa |
| |
| #endif // _LIBCPP_ABI_DO_NOT_EXPORT_TO_CHARS_BASE_10 |
| |
| // The original version of floating-point to_chars was written by Microsoft and |
| // contributed with the following license. |
| |
| // Copyright (c) Microsoft Corporation. |
| // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception |
| |
| // This implementation is dedicated to the memory of Mary and Thavatchai. |
| |
| to_chars_result to_chars(char* __first, char* __last, float __value) { |
| return _Floating_to_chars<_Floating_to_chars_overload::_Plain>(__first, __last, __value, chars_format{}, 0); |
| } |
| |
| to_chars_result to_chars(char* __first, char* __last, double __value) { |
| return _Floating_to_chars<_Floating_to_chars_overload::_Plain>(__first, __last, __value, chars_format{}, 0); |
| } |
| |
| to_chars_result to_chars(char* __first, char* __last, long double __value) { |
| return _Floating_to_chars<_Floating_to_chars_overload::_Plain>(__first, __last, static_cast<double>(__value), |
| chars_format{}, 0); |
| } |
| |
| to_chars_result to_chars(char* __first, char* __last, float __value, chars_format __fmt) { |
| return _Floating_to_chars<_Floating_to_chars_overload::_Format_only>(__first, __last, __value, __fmt, 0); |
| } |
| |
| to_chars_result to_chars(char* __first, char* __last, double __value, chars_format __fmt) { |
| return _Floating_to_chars<_Floating_to_chars_overload::_Format_only>(__first, __last, __value, __fmt, 0); |
| } |
| |
| to_chars_result to_chars(char* __first, char* __last, long double __value, chars_format __fmt) { |
| return _Floating_to_chars<_Floating_to_chars_overload::_Format_only>(__first, __last, static_cast<double>(__value), |
| __fmt, 0); |
| } |
| |
| to_chars_result to_chars(char* __first, char* __last, float __value, chars_format __fmt, int __precision) { |
| return _Floating_to_chars<_Floating_to_chars_overload::_Format_precision>(__first, __last, __value, __fmt, |
| __precision); |
| } |
| |
| to_chars_result to_chars(char* __first, char* __last, double __value, chars_format __fmt, int __precision) { |
| return _Floating_to_chars<_Floating_to_chars_overload::_Format_precision>(__first, __last, __value, __fmt, |
| __precision); |
| } |
| |
| to_chars_result to_chars(char* __first, char* __last, long double __value, chars_format __fmt, int __precision) { |
| return _Floating_to_chars<_Floating_to_chars_overload::_Format_precision>( |
| __first, __last, static_cast<double>(__value), __fmt, __precision); |
| } |
| |
| _LIBCPP_END_NAMESPACE_STD |