6#if !defined(__XTD_TO_STRING_INTERNAL__)
7#error "Do not include this file: Internal use only. Include <xtd/to_string> or <xtd/to_string.hpp> instead."
16template<
typename range_t>
17[[nodiscard]]
auto __xtd_range_to_string(
const range_t& values,
const xtd::string& fmt,
const std::locale& loc) -> std::string;
19template<
typename value_t>
21 if constexpr(std::is_polymorphic_v<value_t>)
return __to_string_polymorphic(value, fmt, loc);
22 else if constexpr(std::is_enum_v<value_t>)
return __enum_formatter<char>(fmt, value, loc);
23 #if defined(__xtd__cpp_lib_ranges)
24 else if constexpr(std::ranges::range<value_t> && !std::is_same_v<value_t, xtd::string>)
return __xtd_range_to_string(value, fmt, loc);
27 auto ss = std::stringstream {};
35 return __boolean_formatter(fmt.chars(), value, loc);
40 return __numeric_formatter(fmt.chars(), value, loc);
45 return __character_formatter(fmt.chars(), value, loc);
50 return __numeric_formatter(fmt.chars(), value, loc);
55 return __numeric_formatter(fmt.chars(), value, loc);
60 return __numeric_formatter(fmt.chars(), value, loc);
65 return __numeric_formatter(fmt.chars(), value, loc);
70 return __numeric_formatter(fmt.chars(), value, loc);
75 return __numeric_formatter(fmt.chars(), value, loc);
80 return __numeric_formatter(fmt.chars(), value, loc);
85 return __numeric_formatter(fmt.chars(), value, loc);
90 return __numeric_formatter(fmt.chars(), value, loc);
95 return __floating_point_formatter(fmt.chars(), value, loc);
100 return __floating_point_formatter(fmt.chars(), value, loc);
105 return __floating_point_formatter(fmt.chars(), value, loc);
110 return __date_time_formatter(fmt.chars(), std::chrono::system_clock::to_time_t(value), std::chrono::duration_cast<std::chrono::nanoseconds>(
value.time_since_epoch()).count() % 1000000000, loc);
115 return __date_time_formatter(fmt.chars(), value, 0, loc);
118template<
typename type_t,
typename period_t>
120 return __duration_formatter(fmt.chars(), value, loc);
125 return __character_formatter(fmt.chars(), value, loc);
130 return __character_formatter(fmt.chars(), value, loc);
135 return __character_formatter(fmt.chars(), value, loc);
140 return __character_formatter(fmt.chars(), value, loc);
143template<
typename value_t>
145 return to_string(value, fmt, std::locale());
149 return to_string(value, fmt, std::locale());
154 if (value == std::partial_ordering::less)
return "less";
155 if (value == std::partial_ordering::greater)
return "greater";
161 if (value == std::strong_ordering::less)
return "less";
162 if (value == std::strong_ordering::greater)
return "greater";
168 if (value == std::weak_ordering::less)
return "less";
169 if (value == std::weak_ordering::greater)
return "greater";
173template<
typename value_t>
175 if (!value)
return "(null)";
176 return __numeric_formatter(fmt.chars(),
reinterpret_cast<intptr>(value), loc);
179template<
typename value_t>
181 if (!value)
return "(null)";
182 return __numeric_formatter(fmt.chars(),
reinterpret_cast<intptr>(value), loc);
185template<
typename type_t>
187 if (!value)
return "(null)";
188 return __numeric_formatter(fmt.chars(),
reinterpret_cast<intptr>(
value.get()), loc);
191template<
typename type_t>
193 if (!value)
return "(null)";
194 return __numeric_formatter(fmt.chars(),
reinterpret_cast<intptr>(
value.get()), loc);
199 auto iterator = __any_stringer__.find(std::type_index(
value.type()));
203template<
typename type_t>
205 return !
value.has_value() ?
"(null)" : std::string {
"("} +
to_string(
value.value(), fmt, loc).chars() + std::string {
")"};
218template<
typename type1_t,
typename type2_t>
220 return std::string {
"("} +
to_string(
value.first, fmt, loc).chars() + std::string {
", "} +
to_string(
value.second, fmt, loc).chars() + std::string {
")"};
223template<
typename type_t,
unsigned n_t,
unsigned last_t>
224[[nodiscard]]
inline auto xtd::__xtd_tuple_stringer<type_t, n_t, last_t>::to_string(
const std::string& str,
const type_t& value,
const xtd::string& fmt,
const std::locale& loc) ->
xtd::string {
225 return __xtd_tuple_stringer < type_t, n_t + 1, last_t >::to_string(str +
xtd::to_string(std::get<n_t>(value), fmt, loc).chars() +
", ",
value, fmt, loc);
228template<
typename type_t,
unsigned n_t>
229[[nodiscard]]
inline auto xtd::__xtd_tuple_stringer<type_t, n_t, n_t>::to_string(
const std::string& str,
const type_t& value,
const xtd::string& fmt,
const std::locale& loc) ->
xtd::string {
230 return str +
xtd::to_string(std::get<n_t>(value), fmt, loc).chars();
233template<
typename ...types_t>
235 return __xtd_tuple_stringer < std::tuple<types_t ...>, 0,
sizeof...(types_t) - 1 >::to_string(std::string {
"("},
value, fmt, loc) +
")";
238template<
typename iterator_t>
239[[nodiscard]]
inline auto __xtd_iterator_to_string(
const std::string& str, iterator_t iterator,
const iterator_t& begin,
const iterator_t& end,
const xtd::string& fmt,
const std::locale& loc) -> std::string {
240 if (iterator == end)
return str;
242 return __xtd_iterator_to_string(new_str, ++iterator, begin, end, fmt, loc);
245template<
typename iterator_t>
246[[nodiscard]]
inline auto __xtd_sequence_container_to_string(
const iterator_t& begin,
const iterator_t& end,
const xtd::string& fmt,
const std::locale& loc) -> std::string {
247 return __xtd_iterator_to_string(
"[", begin, begin, end, fmt, loc) +
"]";
250template<
typename range_t>
251[[nodiscard]]
inline auto __xtd_range_to_string(
const range_t& values,
const xtd::string& fmt,
const std::locale& loc) -> std::string {
252 std::ostringstream oss;
256 for (
auto&& v : values) {
257 if (!first) oss <<
", ";
265template<
typename type_t, xtd::usize size>
267 return __xtd_sequence_container_to_string(values.begin(), values.end(), fmt, loc);
270template<xtd::usize size>
273 for (
auto index =
xtd::usize {0}; index < values.length(); ++index)
274 result += (index ?
", " :
"") +
to_string(
static_cast<bool>(values[index]), fmt, loc);
278template<
typename type_t,
typename allocator_t>
280 return __xtd_sequence_container_to_string(values.begin(), values.end(), fmt, loc);
283template<
typename type_t,
typename allocator_t>
285 return __xtd_sequence_container_to_string(values.begin(), values.end(), fmt, loc);
288template<
typename type_t>
290 return __xtd_sequence_container_to_string(values.begin(), values.end(), fmt, loc);
293template<
typename type_t,
typename allocator_t>
295 return __xtd_sequence_container_to_string(values.begin(), values.end(), fmt, loc);
298template<
typename type_t,
typename container_t>
300 struct std_queue :
public std::queue<type_t> {
301 std_queue(
const std::queue<type_t>& queue) :
ptr {reinterpret_cast<const std_queue*>(&
queue)} {}
302 auto begin()
const {
return ptr->c.begin();}
303 auto end()
const {
return ptr->c.end();}
304 const std_queue*
ptr;
306 auto items = std_queue {values};
307 return __xtd_sequence_container_to_string(items.begin(), items.end(), fmt, loc);
310template<
typename type_t,
typename container_t>
312 struct std_priority_queue :
public std::queue<type_t> {
313 std_priority_queue(
const std::priority_queue<type_t>& queue) :
ptr {reinterpret_cast<const std_priority_queue*>(&
queue)} {}
314 auto begin()
const {
return ptr->c.begin();}
315 auto end()
const {
return ptr->c.end();}
316 const std_priority_queue*
ptr;
318 auto items = std_priority_queue {values};
319 return __xtd_sequence_container_to_string(items.begin(), items.end(), fmt, loc);
322template<
typename type_t,
typename container_t>
324 struct std_stack :
public std::stack<type_t> {
325 std_stack(
const std::stack<type_t>& queue) :
ptr {reinterpret_cast<const std_stack*>(&
queue)} {}
326 auto begin()
const {
return ptr->c.begin();}
327 auto end()
const {
return ptr->c.end();}
328 const std_stack*
ptr;
330 auto items = std_stack {values};
331 return __xtd_sequence_container_to_string(items.begin(), items.end(), fmt, loc);
334template<
typename type_t>
336 return __xtd_sequence_container_to_string(std::begin(values), std::end(values), fmt, loc);
339template<
typename type_t,
typename allocator_t>
341 return __xtd_sequence_container_to_string(values.begin(), values.end(), fmt, loc);
344template<
typename iterator_t>
345[[nodiscard]]
inline auto __xtd_associative_container_to_string(
const iterator_t& begin,
const iterator_t& end,
const xtd::string& fmt,
const std::locale& loc) -> std::string {
346 return __xtd_iterator_to_string(
"{", begin, begin, end, fmt, loc) +
"}";
349template<
typename key_t,
typename value_t,
typename compare_t,
typename allocator_t>
351 return __xtd_associative_container_to_string(values.begin(), values.end(), fmt, loc);
354template<
typename key_t,
typename value_t,
typename compare_t,
typename allocator_t>
356 return __xtd_associative_container_to_string(values.begin(), values.end(), fmt, loc);
359template<
typename key_t,
typename compare_t,
typename allocator_t>
361 return __xtd_associative_container_to_string(values.begin(), values.end(), fmt, loc);
364template<
typename key_t,
typename compare_t,
typename allocator_t>
366 return __xtd_associative_container_to_string(values.begin(), values.end(), fmt, loc);
369template<
typename key_t,
typename value_t,
typename compare_t,
typename allocator_t>
370[[nodiscard]]
inline auto xtd::to_string(
const std::unordered_map<key_t, value_t, compare_t, allocator_t>& values,
const xtd::string& fmt,
const std::locale& loc) ->
xtd::string {
371 return __xtd_associative_container_to_string(values.begin(), values.end(), fmt, loc);
374template<
typename key_t,
typename value_t,
typename compare_t,
typename allocator_t>
375[[nodiscard]]
inline auto xtd::to_string(
const std::unordered_multimap<key_t, value_t, compare_t, allocator_t>& values,
const xtd::string& fmt,
const std::locale& loc) ->
xtd::string {
376 return __xtd_associative_container_to_string(values.begin(), values.end(), fmt, loc);
379template<
typename key_t,
typename compare_t,
typename allocator_t>
381 return __xtd_associative_container_to_string(values.begin(), values.end(), fmt, loc);
384template<
typename key_t,
typename compare_t,
typename allocator_t>
386 return __xtd_associative_container_to_string(values.begin(), values.end(), fmt, loc);
389template<
typename ...args_t>
391 if (
value.valueless_by_exception())
return "(valueless_by_exception)";
395template<
typename type_t>
396[[nodiscard]]
inline auto xtd::to_string(type_t value,
const std::initializer_list<std::pair<type_t, xtd::string>>& il) ->
xtd::string {
397 std::map<type_t, xtd::string, std::greater<type_t>> values;
398 for (
const auto& item : il) values[item.first] = item.second;
402#if defined(__xtd__cpp_lib_ranges)
403template <std::ranges::range range_t>
405 return __xtd_range_to_string(values, fmt, loc);
409template<
typename type_t>
411 return __xtd_sequence_container_to_string(values.begin(), values.end(), fmt, loc);
414template<
typename type_t>
416 return __xtd_sequence_container_to_string(values.begin(), values.end(), fmt, loc);
419template<
typename type_t,
typename string_t>
420[[nodiscard]]
inline auto xtd::to_string(type_t value,
const std::map<type_t, string_t, std::greater<type_t>>& values) -> string_t {
421 auto it = values.find(value);
422 if (it != values.end())
return it->second;
424 long long rest =
static_cast<long long>(
value);
425 for (
const auto& item : values) {
426 if (
static_cast<long long>(item.first) != 0 && (rest &
static_cast<long long>(item.first)) ==
static_cast<long long>(item.first)) {
427 if (!result.empty()) result = string_t {
',',
' '} + result;
428 result = item.second + result;
429 rest -=
static_cast<long long>(item.first);
432 if (!result.empty())
return result;
433 return to_string(
static_cast<long long>(value), string_t {
'G'}, std::locale());
436template<
typename type_t,
typename string_t>
437[[nodiscard]]
inline auto xtd::to_string(type_t value,
const std::map<type_t, string_t>& values) -> string_t {
438 std::map<type_t, string_t, std::greater<type_t>> descending_values;
439 for (
const auto& item : values) descending_values[item.first] = item.second;
440 return to_string(value, descending_values);
443template<
typename char_t,
typename value_t>
444[[nodiscard]]
inline auto __string_formatter(
const std::basic_string<char_t>& fmt, value_t value,
const std::locale& loc) -> std::basic_string<char_t> {
445 return __format_stringer<char_t>(value);
449[[nodiscard]]
inline auto __format_stringer<char, bool&>(
bool& value) -> std::string {
454[[nodiscard]]
inline auto __format_stringer<char, xtd::sbyte&>(
xtd::sbyte& value) -> std::string {
459[[nodiscard]]
inline auto __format_stringer<char, const unsigned char&>(
const unsigned char& value) -> std::string {
464[[nodiscard]]
inline auto __format_stringer<char, unsigned char&>(
unsigned char& value) -> std::string {
469[[nodiscard]]
inline auto __format_stringer<char, short&>(
short& value) -> std::string {
474[[nodiscard]]
inline auto __format_stringer<char, unsigned short&>(
unsigned short& value) -> std::string {
479[[nodiscard]]
inline auto __format_stringer<char, int&>(
int& value) -> std::string {
484[[nodiscard]]
inline auto __format_stringer<char, unsigned int&>(
unsigned int& value) -> std::string {
489[[nodiscard]]
inline auto __format_stringer<char, long&>(
long& value) -> std::string {
494[[nodiscard]]
inline auto __format_stringer<char, unsigned long&>(
unsigned long& value) -> std::string {
499[[nodiscard]]
inline auto __format_stringer<char, long long&>(
long long& value) -> std::string {
504[[nodiscard]]
inline auto __format_stringer<char, unsigned long long&>(
unsigned long long& value) -> std::string {
509[[nodiscard]]
inline auto __format_stringer<char, float&>(
float& value) -> std::string {
514[[nodiscard]]
inline auto __format_stringer<char, double&>(
double& value) -> std::string {
519[[nodiscard]]
inline auto __format_stringer<char, long double&>(
long double& value) -> std::string {
524[[nodiscard]]
inline auto __format_stringer<char, std::chrono::system_clock::time_point&>(std::chrono::system_clock::time_point& value) -> std::string {
529[[nodiscard]]
inline auto __format_stringer<char, std::tm&>(tm& value) -> std::string {
534[[nodiscard]]
inline auto __format_stringer<char, xtd::wchar&>(
xtd::wchar& value) -> std::string {
539[[nodiscard]]
inline auto __format_stringer<char, xtd::char8&>(
xtd::char8& value) -> std::string {
544[[nodiscard]]
inline auto __format_stringer<char, xtd::char16&>(
xtd::char16& value) -> std::string {
549[[nodiscard]]
inline auto __format_stringer<char, xtd::char32&>(
xtd::char32& value) -> std::string {
553template<
typename char_t,
typename type_t,
typename period_t = std::ratio<1>>
554auto operator <<(std::basic_ostream<char_t>& os,
const std::chrono::duration<type_t, period_t>& value) -> std::basic_ostream<char_t>& {
555 return os <<
xtd::to_string(value, std::basic_string<char_t> {
'G'}, std::locale());
558template <
class char_t,
typename type_t >
559struct __enum_ostream__<char_t, type_t, std::false_type> {
560 auto to_stream(std::basic_ostream < char_t >& os,
const type_t& value)
noexcept -> std::basic_ostream<char_t>& {
562 return os <<
xtd::to_string(value, std::basic_string < char_t > {}, std::locale {});
Internal vector-like container used as a storage backend for xtd collections.
Definition raw_array.hpp:29
Exposes the enumerator, which supports a simple iteration over a collection of a specified type.
Definition ienumerable.hpp:40
static auto throws(xtd::helpers::exception_case exception_case, const source_location &location=source_location::current()) -> void
Throws an exption with specified exception case.
Definition stream_insertable.hpp:13
generic::queue< xtd::any_object > queue
Represents a first-in, first-out collection of objects.
Definition queue.hpp:27
@ value
Represnets the constant operator precedence (42).
Definition operator_precedence.hpp:30
@ format
The format is not valid.
Definition exception_case.hpp:51
xtd::basic_string< char > string
Represents text as a sequence of UTF-8 code units.
Definition __string_definitions.hpp:43
char8_t char8
Represents a 8-bit unicode character.
Definition char8.hpp:26
std::int8_t sbyte
Represents a 8-bit signed integer.
Definition sbyte.hpp:23
wchar_t wchar
Represents a wide character.
Definition wchar.hpp:24
std::intmax_t intptr
Represent a pointer or a handle.
Definition intptr.hpp:23
char16_t char16
Represents a 16-bit unicode character.
Definition char16.hpp:26
xtd::sptr< type_t > ptr
The xtd::ptr object is a shared pointer.
Definition ptr.hpp:27
std::size_t usize
Represents an unsigned size of any object in bytes.
Definition usize.hpp:22
char32_t char32
Represents a 32-bit unicode character.
Definition char32.hpp:23
std::any any
Represents the any alias on std::any.
Definition any.hpp:24
const xtd::collections::generic::helpers::wrap_pointer_iterator< pointer > iterator
Represents the iterator of read_only_span value type.
Definition read_only_span.hpp:71
auto first() const -> read_only_span< type_t, count >
Obtains a subspan consisting of the first count elements of the sequence.
Definition read_only_span.hpp:249
auto begin() const -> const_iterator
Returns an iterator to the beginning.
Definition read_only_span.hpp:186
auto to_string() const noexcept -> xtd::string override
Returns the string representation of this xtd::read_only_span <type_t> object.
Definition read_only_span.hpp:342
auto end() const -> const_iterator
Returns an iterator to the end.
Definition read_only_span.hpp:205
Contains xtd::stream_insertable concept.
Contains xtd::to_string methods.