From 620f9bef290737c3a0655120371329f1ced8285e Mon Sep 17 00:00:00 2001 From: rbock Date: Fri, 27 Jun 2014 17:45:33 +0200 Subject: [PATCH] Fixed dynamic rows for bind_results --- include/sqlpp11/result_row.h | 28 +++++++++++++++++++++++++++- 1 file changed, 27 insertions(+), 1 deletion(-) diff --git a/include/sqlpp11/result_row.h b/include/sqlpp11/result_row.h index ce4d4eb3..e06d1339 100644 --- a/include/sqlpp11/result_row.h +++ b/include/sqlpp11/result_row.h @@ -237,6 +237,10 @@ namespace sqlpp _is_valid(false), _dynamic_columns(dynamic_columns) { + for (auto name : _dynamic_columns) + { + _dynamic_fields.insert({name, _field_type{}}); + } } dynamic_result_row_t(const dynamic_result_row_t&) = delete; @@ -255,13 +259,24 @@ namespace sqlpp dynamic_row.len += _last_static_index; for (const auto& column : _dynamic_columns) { - _dynamic_fields[column].assign(dynamic_row.data[0], dynamic_row.len[0]); + _dynamic_fields.at(column).assign(dynamic_row.data[0], dynamic_row.len[0]); ++dynamic_row.data; ++dynamic_row.len; } return *this; } + void validate() + { + + _impl::validate(); + _is_valid = true; + for (auto& field : _dynamic_fields) + { + field.second.validate(); + } + } + void invalidate() { _impl::invalidate(); @@ -287,6 +302,17 @@ namespace sqlpp return _is_valid; } + template + void _bind(Target& target) + { + _impl::_bind(target); + + std::size_t index = _last_static_index; + for (const auto& name : _dynamic_columns) + { + _dynamic_fields.at(name)._bind(target, ++index); + } + } }; }