aboutsummaryrefslogtreecommitdiff
path: root/odb/mysql/traits.hxx
diff options
context:
space:
mode:
authorBoris Kolpackov <boris@codesynthesis.com>2010-08-10 11:17:52 +0200
committerBoris Kolpackov <boris@codesynthesis.com>2010-08-10 11:17:52 +0200
commit0a589394a09ce5b3f16d902d657710a2886cc2fc (patch)
tree08f5bfa47a0d07b0dc20352706342e17f277759f /odb/mysql/traits.hxx
parentc67f076c75a36877ce142dc43a1ed2292ab8117a (diff)
Add query support
Diffstat (limited to 'odb/mysql/traits.hxx')
-rw-r--r--odb/mysql/traits.hxx169
1 files changed, 168 insertions, 1 deletions
diff --git a/odb/mysql/traits.hxx b/odb/mysql/traits.hxx
index a8c6c09..7d1caca 100644
--- a/odb/mysql/traits.hxx
+++ b/odb/mysql/traits.hxx
@@ -10,7 +10,7 @@
#include <string>
#include <cstddef> // std::size_t
-#include <cstring> // std::memcpy
+#include <cstring> // std::memcpy, std::strlen
#include <odb/traits.hxx>
@@ -20,16 +20,138 @@ namespace odb
{
namespace mysql
{
+ enum image_id_type
+ {
+ id_tiny,
+ id_utiny,
+ id_short,
+ id_ushort,
+ id_long,
+ id_ulong,
+ id_longlong,
+ id_ulonglong,
+
+ id_float,
+ id_double,
+
+ id_date,
+ id_time,
+ id_datetime,
+ id_timestamp,
+ id_year,
+
+ id_string,
+ id_blob
+ };
+
template <typename T>
class value_traits: public odb::value_traits<T>
{
};
+ // Integral types.
+ //
+ template <>
+ class value_traits<bool>: public odb::value_traits<bool>
+ {
+ public:
+ static const image_id_type image_id = id_tiny;
+ };
+
+ template <>
+ class value_traits<signed char>: public odb::value_traits<signed char>
+ {
+ public:
+ static const image_id_type image_id = id_tiny;
+ };
+
+ template <>
+ class value_traits<unsigned char>: public odb::value_traits<unsigned char>
+ {
+ public:
+ static const image_id_type image_id = id_utiny;
+ };
+
+ template <>
+ class value_traits<short>: public odb::value_traits<short>
+ {
+ public:
+ static const image_id_type image_id = id_short;
+ };
+
+ template <>
+ class value_traits<unsigned short>: public odb::value_traits<unsigned short>
+ {
+ public:
+ static const image_id_type image_id = id_ushort;
+ };
+
+ template <>
+ class value_traits<int>: public odb::value_traits<int>
+ {
+ public:
+ static const image_id_type image_id = id_long;
+ };
+
+ template <>
+ class value_traits<unsigned int>: public odb::value_traits<unsigned int>
+ {
+ public:
+ static const image_id_type image_id = id_ulong;
+ };
+
+ template <>
+ class value_traits<long>: public odb::value_traits<long>
+ {
+ public:
+ static const image_id_type image_id = id_longlong;
+ };
+
+ template <>
+ class value_traits<unsigned long>: public odb::value_traits<unsigned long>
+ {
+ public:
+ static const image_id_type image_id = id_ulonglong;
+ };
+
+ template <>
+ class value_traits<long long>: public odb::value_traits<long long>
+ {
+ public:
+ static const image_id_type image_id = id_longlong;
+ };
+
+ template <>
+ class value_traits<unsigned long long>: public odb::value_traits<unsigned long long>
+ {
+ public:
+ static const image_id_type image_id = id_ulonglong;
+ };
+
+ // Float types.
+ //
+ template <>
+ class value_traits<float>: public odb::value_traits<float>
+ {
+ public:
+ static const image_id_type image_id = id_float;
+ };
+
+ template <>
+ class value_traits<double>: public odb::value_traits<double>
+ {
+ public:
+ static const image_id_type image_id = id_double;
+ };
+
+ // String type.
+ //
template <>
class value_traits<std::string>
{
public:
typedef std::string value_type;
+ static const image_id_type image_id = id_string;
static void
set_value (value_type& v, const char* s, std::size_t n, bool is_null)
@@ -73,6 +195,51 @@ namespace odb
std::memcpy (b.data (), v.c_str (), n);
}
};
+
+ // Specialization for const char* which only supports initialization
+ // of an image from the value but not the other way around. This way
+ // we can pass such values to the queries.
+ //
+ template <>
+ class value_traits<const char*>
+ {
+ public:
+ typedef const char* value_type;
+ static const image_id_type image_id = id_string;
+
+ static void
+ set_image (char* s,
+ std::size_t c,
+ std::size_t& n,
+ bool& is_null,
+ value_type v)
+ {
+ is_null = false;
+ n = std::strlen (v);
+
+ if (n > c)
+ n = c;
+
+ if (n != 0)
+ std::memcpy (s, v, n);
+ }
+
+ static void
+ set_image (buffer& b,
+ std::size_t& n,
+ bool& is_null,
+ const value_type& v)
+ {
+ is_null = false;
+ n = std::strlen (v);
+
+ if (n > b.capacity ())
+ b.capacity (n);
+
+ if (n != 0)
+ std::memcpy (b.data (), v, n);
+ }
+ };
}
}