libpqxx
String conversion

Namespaces

 pqxx::internal
 Private namespace for libpqxx's internal use; do not access.
 

Classes

struct  pqxx::string_traits< T >
 Traits class for use in string conversions. More...
 
struct  pqxx::string_traits< const char * >
 String traits for C-style string ("pointer to const char") More...
 
struct  pqxx::string_traits< char * >
 String traits for non-const C-style string ("pointer to char") More...
 
struct  pqxx::string_traits< char[N]>
 String traits for C-style string constant ("array of char") More...
 
struct  pqxx::string_traits< std::string >
 
struct  pqxx::string_traits< const std::string >
 
struct  pqxx::string_traits< std::stringstream >
 

Macros

#define PQXX_DECLARE_STRING_TRAITS_SPECIALIZATION(T)
 

Functions

template<typename T >
void pqxx::from_string (const char Str[], T &Obj)
 Attempt to convert postgres-generated string to given built-in type. More...
 
template<typename T >
void pqxx::from_string (const char Str[], T &Obj, size_t)
 Conversion with known string length (for strings that may contain nuls) More...
 
template<>
void pqxx::from_string< std::string > (const char Str[], std::string &Obj, size_t len)
 
template<typename T >
void pqxx::from_string (const std::string &Str, T &Obj)
 
template<typename T >
void pqxx::from_string (const std::stringstream &Str, T &Obj)
 
template<>
void pqxx::from_string (const std::string &Str, std::string &Obj)
 
template<typename T >
std::string pqxx::to_string (const T &Obj)
 Convert built-in type to a readable string that PostgreSQL will understand. More...
 

Detailed Description

For purposes of communication with the server, values need to be converted from and to a human-readable string format that (unlike the various functions and templates in the C and C++ standard libraries) is not sensitive to locale settings and internationalization. This section contains functionality that is used extensively by libpqxx itself, but is also available for use by other programs.

Macro Definition Documentation

◆ PQXX_DECLARE_STRING_TRAITS_SPECIALIZATION

#define PQXX_DECLARE_STRING_TRAITS_SPECIALIZATION (   T)
Value:
template<> struct PQXX_LIBEXPORT string_traits<T> \
{ \
static constexpr const char *name() noexcept { return #T; } \
static constexpr bool has_null() noexcept { return false; } \
static bool is_null(T) { return false; } \
[[noreturn]] static T null() \
{ internal::throw_null_conversion(name()); } \
static void from_string(const char Str[], T &Obj); \
static std::string to_string(T Obj); \
};
std::string to_string(const T &Obj)
Convert built-in type to a readable string that PostgreSQL will understand.
Definition: strconv.hxx:231
void from_string(const std::string &Str, std::string &Obj)
Definition: strconv.hxx:213

Helper: declare a typical string_traits specialisation.

It'd be great to do this without a preprocessor macro. The problem is that we want to represent the parameter type's name to programmers. There's probably a better way in newer C++ versions, but I don't think there is one in C++11.

Function Documentation

◆ from_string() [1/5]

template<typename T >
void pqxx::from_string ( const char  Str[],
T &  Obj 
)

Attempt to convert postgres-generated string to given built-in type.

If the form of the value found in the string does not match the expected type, e.g. if a decimal point is found when converting to an integer type, the conversion fails. Overflows (e.g. converting "9999999999" to a 16-bit C++ type) are also treated as errors. If in some cases this behaviour should be inappropriate, convert to something bigger such as long int first and then truncate the resulting value.

Only the simplest possible conversions are supported. No fancy features such as hexadecimal or octal, spurious signs, or exponent notation will work. No whitespace is stripped away. Only the kinds of strings that come out of PostgreSQL and out of to_string() can be converted.

References pqxx::from_string().

Referenced by pqxx::internal::throw_null_conversion().

◆ from_string() [2/5]

template<typename T >
void pqxx::from_string ( const char  Str[],
T &  Obj,
size_t   
)

Conversion with known string length (for strings that may contain nuls)

This is only used for strings, where embedded nul bytes should not determine the end of the string.

For all other types, this just uses the regular, nul-terminated version of from_string().

References pqxx::from_string().

◆ from_string() [3/5]

template<typename T >
void pqxx::from_string ( const std::string &  Str,
T &  Obj 
)

References pqxx::from_string().

◆ from_string() [4/5]

template<typename T >
void pqxx::from_string ( const std::stringstream &  Str,
T &  Obj 
)

References pqxx::from_string().

◆ from_string() [5/5]

template<>
void pqxx::from_string ( const std::string &  Str,
std::string &  Obj 
)

Referenced by pqxx::from_string().

◆ from_string< std::string >()

template<>
void pqxx::from_string< std::string > ( const char  Str[],
std::string &  Obj,
size_t  len 
)

◆ to_string()

template<typename T >
std::string pqxx::to_string ( const T &  Obj)

Convert built-in type to a readable string that PostgreSQL will understand.

No special formatting is done, and any locale settings are ignored. The resulting string will be human-readable and in a format suitable for use in SQL queries.

Referenced by pqxx::internal::throw_null_conversion().