11 #ifndef PQXX_H_STRCONV
12 #define PQXX_H_STRCONV
14 #if !defined(PQXX_HEADER_PRE)
15 # error "Include libpqxx headers as <pqxx/header>, not <pqxx/header.hxx>."
27 #if defined(PQXX_HAVE_RANGES)
31 #include "pqxx/except.hxx"
32 #include "pqxx/util.hxx"
33 #include "pqxx/zview.hxx"
79 template<
typename TYPE>
90 template<
typename TYPE,
typename ENABLE =
void>
struct nullness
99 static bool is_null(TYPE
const &value);
107 [[nodiscard]]
static TYPE
null();
138 [[nodiscard]]
static constexpr
bool is_null(TYPE
const &) noexcept
187 [[nodiscard]]
static inline zview
188 to_buf(
char *begin,
char *end, TYPE
const &value);
198 static inline char *
into_buf(
char *begin,
char *end, TYPE
const &value);
206 [[nodiscard]]
static inline TYPE
from_string(std::string_view text);
214 [[nodiscard]]
static inline std::size_t
249 static constexpr
bool converts_to_string{
false};
250 static constexpr
bool converts_from_string{
false};
251 [[noreturn]]
static zview to_buf(
char *,
char *, TYPE
const &)
253 oops_forbidden_conversion<TYPE>();
255 [[noreturn]]
static char *into_buf(
char *,
char *, TYPE
const &)
257 oops_forbidden_conversion<TYPE>();
259 [[noreturn]]
static TYPE
from_string(std::string_view)
261 oops_forbidden_conversion<TYPE>();
263 [[noreturn]]
static std::size_t
size_buffer(TYPE
const &) noexcept
265 oops_forbidden_conversion<TYPE>();
339 template<
typename ENUM>
362 using impl_type = std::underlying_type_t<ENUM>;
365 static constexpr
bool converts_to_string{
true};
366 static constexpr
bool converts_from_string{
true};
368 [[nodiscard]]
static constexpr
zview
369 to_buf(
char *begin,
char *end, ENUM
const &value)
374 static constexpr
char *into_buf(
char *begin,
char *end, ENUM
const &value)
379 [[nodiscard]]
static ENUM from_string(std::string_view text)
384 [[nodiscard]]
static std::size_t size_buffer(ENUM
const &value) noexcept
391 static constexpr impl_type to_underlying(ENUM
const &value) noexcept
393 return static_cast<impl_type
>(value);
415 #define PQXX_DECLARE_ENUM_CONVERSION(ENUM) \
416 template<> struct string_traits<ENUM> : pqxx::internal::enum_traits<ENUM> \
418 template<> inline std::string_view const type_name<ENUM> \
439 template<
typename TYPE>
454 [[nodiscard]]
inline std::string_view
from_string(std::string_view text)
468 template<
typename T>
inline void from_string(std::string_view text, T &value)
470 value = from_string<T>(text);
480 template<
typename TYPE>
inline std::string
to_string(TYPE
const &value);
491 template<
typename... TYPE>
492 [[nodiscard]]
inline std::vector<std::string_view>
493 to_buf(
char *here,
char const *end, TYPE... value)
495 PQXX_ASSUME(here <= end);
496 return {[&here, end](
auto v) {
500 auto len{
static_cast<std::size_t
>(here - begin) - 1};
501 return std::string_view{begin, len};
509 template<
typename TYPE>
510 inline void into_string(TYPE
const &value, std::string &out);
514 template<
typename TYPE>
515 [[nodiscard]]
inline constexpr
bool is_null(TYPE
const &value) noexcept
525 template<
typename... TYPE>
526 [[nodiscard]]
inline std::size_t
size_buffer(TYPE
const &...value) noexcept
570 template<
typename TYPE>
inline constexpr
format param_format(TYPE
const &)
586 template<
typename TYPE>
595 return {begin, traits::into_buf(begin, end, value) - begin - 1};
599 #if defined(PQXX_HAVE_CONCEPTS) && defined(PQXX_HAVE_RANGES)
608 concept binary = std::ranges::contiguous_range<TYPE> and
609 std::is_same_v<strip_t<value_type<TYPE>>, std::byte>;
615 #include "pqxx/internal/conversions.hxx"
Marker-type wrapper: zero-terminated std::string_view.
Definition: zview.hxx:37
static constexpr bool always_null
Are all values of this type null?
Definition: strconv.hxx:131
std::string const type_name
A human-readable name for a type, used in error messages and such.
Definition: strconv.hxx:80
static constexpr bool is_null(TYPE const &) noexcept
Does a given value correspond to an SQL null value?
Definition: strconv.hxx:138
static zview to_buf(char *begin, char *end, TYPE const &value)
Return a string_view representing value, plus terminating zero.
Internal items for libpqxx' own use. Do not use these yourself.
Definition: encodings.cxx:32
std::size_t size_buffer(TYPE const &...value) noexcept
Estimate how much buffer space is needed to represent values as a string.
Definition: strconv.hxx:526
Helper class for defining enum conversions.
Definition: strconv.hxx:360
T from_string(field const &value)
Convert a field's value to type T.
Definition: field.hxx:548
std::vector< std::string_view > to_buf(char *here, char const *end, TYPE...value)
Convert multiple values to strings inside a single buffer.
Definition: strconv.hxx:493
static TYPE from_string(std::string_view text)
Parse a string representation of a TYPE value.
static bool has_null
Does this type have a null value?
Definition: strconv.hxx:93
PQXX_LIBEXPORT std::string to_string(field const &value)
Convert a field to a string.
format
Format code: is data text or binary?
Definition: types.hxx:69
constexpr bool is_null(TYPE const &value) noexcept
Is value null?
Definition: strconv.hxx:515
constexpr bool is_unquoted_safe
Can we use this type in arrays and composite types without quoting them?
Definition: strconv.hxx:555
static constexpr bool converts_from_string
Is conversion from string_view to TYPE supported?
Definition: strconv.hxx:165
static TYPE null()
Return a null value.
The home of all libpqxx classes, functions, templates, etc.
Definition: array.cxx:26
zview generic_to_buf(char *begin, char *end, TYPE const &value)
Implement string_traits::to_buf by calling into_buf.
Definition: strconv.hxx:587
void oops_forbidden_conversion() noexcept
Nonexistent function to indicate a disallowed type conversion.
Nullness traits describing a type which does not have a null value.
Definition: strconv.hxx:112
static constexpr bool has_null
Does TYPE have a "built-in null value"?
Definition: strconv.hxx:125
Traits class for use in string conversions.
Definition: strconv.hxx:153
static constexpr bool converts_to_string
Is conversion from TYPE to strings supported?
Definition: strconv.hxx:159
static bool always_null
Is this type always null?
Definition: strconv.hxx:96
std::string demangle_type_name(char const raw[])
Attempt to demangle std::type_info::name() to something human-readable.
Definition: strconv.cxx:227
Traits describing a type's "null value," if any.
Definition: strconv.hxx:90
static char * into_buf(char *begin, char *end, TYPE const &value)
Write value's string representation into buffer at begin.
static bool is_null(TYPE const &value)
Is value a null?
constexpr char array_separator
Element separator between SQL array elements of this type.
Definition: strconv.hxx:559
String traits for a forbidden type conversion.
Definition: strconv.hxx:247
std::remove_cv_t< std::remove_reference_t< TYPE >> strip_t
Remove any constness, volatile, and reference-ness from a type.
Definition: types.hxx:80
constexpr bool is_sql_array
Does this type translate to an SQL array?
Definition: strconv.hxx:539
static std::size_t size_buffer(TYPE const &value) noexcept
Estimate how much buffer space is needed to represent value.