// ===================================================================================================================== // fennec, a free and open source game engine // Copyright © 2025 Medusa Slockbower // // This program is free software: you can redistribute it and/or modify // it under the terms of the GNU General Public License as published by // the Free Software Foundation, either version 3 of the License, or // (at your option) any later version. // // This program is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the // GNU General Public License for more details. // // You should have received a copy of the GNU General Public License // along with this program. If not, see . // ===================================================================================================================== /// /// \file charconv.h /// \brief /// /// /// \details /// \author Medusa Slockbower /// /// \copyright Copyright © 2025 Medusa Slockbower ([GPLv3](https://www.gnu.org/licenses/gpl-3.0.en.html)) /// /// #define __cpp_lib_to_chars #include #include #include #include namespace fennec { char* to_chars(char* first, char* last, char x, int base) { auto res = std::to_chars(first, last, x, base); assertf(res.ec == std::errc(), std::make_error_code(res.ec).message().c_str()); return res.ptr; } char* to_chars(char* first, char* last, signed char x, int base) { auto res = std::to_chars(first, last, x, base); assertf(res.ec == std::errc(), std::make_error_code(res.ec).message().c_str()); return res.ptr; } char* to_chars(char* first, char* last, unsigned char x, int base) { auto res = std::to_chars(first, last, x, base); assertf(res.ec == std::errc(), std::make_error_code(res.ec).message().c_str()); return res.ptr; } char* to_chars(char* first, char* last, signed short x, int base) { auto res = std::to_chars(first, last, x, base); assertf(res.ec == std::errc(), std::make_error_code(res.ec).message().c_str()); return res.ptr; } char* to_chars(char* first, char* last, unsigned short x, int base) { auto res = std::to_chars(first, last, x, base); assertf(res.ec == std::errc(), std::make_error_code(res.ec).message().c_str()); return res.ptr; } char* to_chars(char* first, char* last, signed int x, int base) { auto res = std::to_chars(first, last, x, base); assertf(res.ec == std::errc(), std::make_error_code(res.ec).message().c_str()); return res.ptr; } char* to_chars(char* first, char* last, unsigned int x, int base) { auto res = std::to_chars(first, last, x, base); assertf(res.ec == std::errc(), std::make_error_code(res.ec).message().c_str()); return res.ptr; } char* to_chars(char* first, char* last, signed long x, int base) { auto res = std::to_chars(first, last, x, base); assertf(res.ec == std::errc(), std::make_error_code(res.ec).message().c_str()); return res.ptr; } char* to_chars(char* first, char* last, unsigned long x, int base) { auto res = std::to_chars(first, last, x, base); assertf(res.ec == std::errc(), std::make_error_code(res.ec).message().c_str()); return res.ptr; } char* to_chars(char* first, char* last, signed long long x, int base) { auto res = std::to_chars(first, last, x, base); assertf(res.ec == std::errc(), std::make_error_code(res.ec).message().c_str()); return res.ptr; } char* to_chars(char* first, char* last, unsigned long long x, int base) { auto res = std::to_chars(first, last, x, base); assertf(res.ec == std::errc(), std::make_error_code(res.ec).message().c_str()); return res.ptr; } std::chars_format ctofmt(char c) { switch (c) { default: return std::chars_format::general; case 'a': case 'A': return std::chars_format::hex; case 'f': case 'F': return std::chars_format::fixed; case 'e': case 'E': return std::chars_format::scientific; } } char* to_chars(char* first, char* last, float x) { auto res = std::to_chars(first, last, x); assertf(res.ec == std::errc(), std::make_error_code(res.ec).message().c_str()); return res.ptr; } char* to_chars(char* first, char* last, float x, char fmt) { auto res = std::to_chars(first, last, x, ctofmt(fmt)); assertf(res.ec == std::errc(), std::make_error_code(res.ec).message().c_str()); return res.ptr; } char* to_chars(char* first, char* last, float x, char fmt, int precision) { auto res = std::to_chars(first, last, x, ctofmt(fmt), precision); assertf(res.ec == std::errc(), std::make_error_code(res.ec).message().c_str()); return res.ptr; } char* to_chars(char* first, char* last, double x) { auto res = std::to_chars(first, last, x); assertf(res.ec == std::errc(), std::make_error_code(res.ec).message().c_str()); return res.ptr; } char* to_chars(char* first, char* last, double x, char fmt) { auto res = std::to_chars(first, last, x, ctofmt(fmt)); assertf(res.ec == std::errc(), std::make_error_code(res.ec).message().c_str()); return res.ptr; } char* to_chars(char* first, char* last, double x, char fmt, int precision) { auto res = std::to_chars(first, last, x, ctofmt(fmt), precision); assertf(res.ec == std::errc(), std::make_error_code(res.ec).message().c_str()); return res.ptr; } }