diff options
author | Boris Kolpackov <boris@codesynthesis.com> | 2011-10-11 16:52:45 +0200 |
---|---|---|
committer | Boris Kolpackov <boris@codesynthesis.com> | 2011-10-21 19:06:55 +0200 |
commit | e514a43339bbce7c8d15fb1350674ecfc5649e14 (patch) | |
tree | 3dc9d152ead52740fd0dc470fc62eb85108b8ebe /odb/sqlite/object-statements.txx | |
parent | 0cd9d3b8bbe0e243c37336b3b8ffb3d40e968034 (diff) |
Split 'in' binding into insert/update pair; rename 'out' to select
Also add the initial infrastructure for the readonly members support.
Right now the split insert/update bindings allows us to avoid sending
object id in UPDATE statements. It will also allows us to support
readonly members.
Diffstat (limited to 'odb/sqlite/object-statements.txx')
-rw-r--r-- | odb/sqlite/object-statements.txx | 25 |
1 files changed, 15 insertions, 10 deletions
diff --git a/odb/sqlite/object-statements.txx b/odb/sqlite/object-statements.txx index 04d57c8..fd596e7 100644 --- a/odb/sqlite/object-statements.txx +++ b/odb/sqlite/object-statements.txx @@ -27,23 +27,28 @@ namespace odb object_statements (connection_type& conn) : object_statements_base (conn), container_statement_cache_ (conn), - in_image_binding_ (in_image_bind_, object_traits::in_column_count), - out_image_binding_ (out_image_bind_, object_traits::out_column_count), - id_image_binding_ (in_image_bind_ + object_traits::in_column_count, 1) + select_image_binding_ (select_image_bind_, select_column_count), + insert_image_binding_ (insert_image_bind_, insert_column_count), + update_image_binding_ (update_image_bind_, update_column_count), + id_image_binding_ (update_image_bind_ + update_column_count, + id_column_count) { image_.version = 0; - in_image_version_ = 0; - out_image_version_ = 0; + select_image_version_ = 0; + insert_image_version_ = 0; + update_image_version_ = 0; id_image_.version = 0; id_image_version_ = 0; - std::memset (in_image_bind_, 0, sizeof (in_image_bind_)); - std::memset (out_image_bind_, 0, sizeof (out_image_bind_)); - std::memset (out_image_truncated_, 0, sizeof (out_image_truncated_)); + std::memset (insert_image_bind_, 0, sizeof (insert_image_bind_)); + std::memset (update_image_bind_, 0, sizeof (update_image_bind_)); + std::memset (select_image_bind_, 0, sizeof (select_image_bind_)); + std::memset ( + select_image_truncated_, 0, sizeof (select_image_truncated_)); - for (std::size_t i (0); i < object_traits::out_column_count; ++i) - out_image_bind_[i].truncated = out_image_truncated_ + i; + for (std::size_t i (0); i < select_column_count; ++i) + select_image_bind_[i].truncated = select_image_truncated_ + i; } template <typename T> |