Rosetta
Classes | Namespaces | Macros | Typedefs | Functions
ranges.h File Reference
#include <initializer_list>
#include <type_traits>
#include "format.h"

Classes

struct  formatting_base< Char >
 
struct  formatting_range< Char, Enable >
 
struct  formatting_tuple< Char, Enable >
 
class  detail::is_like_std_string< T >
 Return true value if T has std::string interface, like std::string_view. More...
 
struct  detail::is_like_std_string< fmt::basic_string_view< Char > >
 
struct  detail::conditional_helper< Ts >
 
struct  detail::is_range_< T, _ >
 
struct  detail::is_range_< T, conditional_t< false, conditional_helper< decltype(std::declval< T >().begin()), decltype(std::declval< T >().end())>, void > >
 
class  detail::is_tuple_like_< T >
 tuple_size and tuple_element check. More...
 
struct  detail::integer_sequence< T, N >
 
struct  detail::make_integer_sequence< T, N, Ns >
 
struct  detail::make_integer_sequence< T, 0, Ns... >
 
struct  is_tuple_like< T >
 
struct  formatter< TupleT, Char, enable_if_t< fmt::is_tuple_like< TupleT >::value > >
 
struct  formatter< TupleT, Char, enable_if_t< fmt::is_tuple_like< TupleT >::value > >::format_each< FormatContext >
 
struct  is_range< T, Char >
 
struct  formatter< T, Char, enable_if_t< fmt::is_range< T, Char >::value &&(has_formatter< detail::value_type< T >, format_context >::value||detail::has_fallback_formatter< detail::value_type< T >, format_context >::value) > >
 
struct  tuple_arg_join< Char, T >
 
struct  formatter< tuple_arg_join< Char, T... >, Char >
 

Namespaces

 detail
 

Macros

#define FMT_RANGE_OUTPUT_LENGTH_LIMIT   256
 

Typedefs

template<size_t... N>
using detail::index_sequence = integer_sequence< size_t, N... >
 
template<size_t N>
using detail::make_index_sequence = make_integer_sequence< size_t, N >
 
template<typename Range >
using detail::value_type = remove_cvref_t< decltype(*std::declval< Range >().begin())>
 

Functions

template<typename RangeT , typename OutputIterator >
OutputIterator detail::copy (const RangeT &range, OutputIterator out)
 
template<typename OutputIterator >
OutputIterator detail::copy (const char *str, OutputIterator out)
 
template<typename OutputIterator >
OutputIterator detail::copy (char ch, OutputIterator out)
 
template<class Tuple , class F , size_t... Is>
void detail::for_each (index_sequence< Is... >, Tuple &&tup, F &&f) FMT_NOEXCEPT
 
template<class T >
FMT_CONSTEXPR make_index_sequence< std::tuple_size< T >::valuedetail::get_indexes (T const &)
 
template<class Tuple , class F >
void detail::for_each (Tuple &&tup, F &&f)
 
template<typename Arg , FMT_ENABLE_IF(!is_like_std_string< typename std::decay< Arg >::type >::value) >
FMT_CONSTEXPR const char * detail::format_str_quoted (bool add_space, const Arg &)
 
FMT_CONSTEXPR const char * detail::format_str_quoted (bool add_space, const char *)
 
FMT_CONSTEXPR const wchar_t * detail::format_str_quoted (bool add_space, const wchar_t *)
 
FMT_CONSTEXPR const char * detail::format_str_quoted (bool add_space, const char)
 
FMT_CONSTEXPR const wchar_t * detail::format_str_quoted (bool add_space, const wchar_t)
 
template<typename... T>
FMT_CONSTEXPR tuple_arg_join< char, T... > join (const std::tuple< T... > &tuple, string_view sep)
 
template<typename... T>
FMT_CONSTEXPR tuple_arg_join< wchar_t, T... > join (const std::tuple< T... > &tuple, wstring_view sep)
 
template<typename T >
arg_join< const T *, const T *, char > join (std::initializer_list< T > list, string_view sep)
 
template<typename T >
arg_join< const T *, const T *, wchar_t > join (std::initializer_list< T > list, wstring_view sep)
 

Macro Definition Documentation

◆ FMT_RANGE_OUTPUT_LENGTH_LIMIT

#define FMT_RANGE_OUTPUT_LENGTH_LIMIT   256

Function Documentation

◆ join() [1/4]

template<typename... T>
FMT_CONSTEXPR tuple_arg_join<char, T...> join ( const std::tuple< T... > &  tuple,
string_view  sep 
)

\rst Returns an object that formats tuple with elements separated by sep.

Example**::

std::tuple<int, char> t = {1, 'a'}; fmt::print("{}", fmt::join(t, ", ")); Output: "1, a" \endrst

References basic::options::OptionKeys::sc::sep.

Referenced by join().

◆ join() [2/4]

template<typename... T>
FMT_CONSTEXPR tuple_arg_join<wchar_t, T...> join ( const std::tuple< T... > &  tuple,
wstring_view  sep 
)

◆ join() [3/4]

template<typename T >
arg_join<const T*, const T*, char> join ( std::initializer_list< T list,
string_view  sep 
)

\rst Returns an object that formats initializer_list with elements separated by sep.

Example**::

fmt::print("{}", fmt::join({1, 2, 3}, ", ")); Output: "1, 2, 3" \endrst

References begin, end, join(), basic::options::OptionKeys::in::file::list, and basic::options::OptionKeys::sc::sep.

◆ join() [4/4]

template<typename T >
arg_join<const T*, const T*, wchar_t> join ( std::initializer_list< T list,
wstring_view  sep 
)