aboutsummaryrefslogtreecommitdiff
path: root/odb/mssql/object-result.txx
diff options
context:
space:
mode:
authorBoris Kolpackov <boris@codesynthesis.com>2012-01-12 10:46:55 +0200
committerBoris Kolpackov <boris@codesynthesis.com>2012-01-12 10:46:55 +0200
commitdf1fdb4f500308adf2fff1a08b2ef62bf5a88de7 (patch)
tree1a014a6207bba19a58a8b574c6bb00b881585d13 /odb/mssql/object-result.txx
parentbbb153b9e576cdfdb59711f68d7f26a427a55041 (diff)
Detect and throw when object/view with long data is re-loaded from query result
Diffstat (limited to 'odb/mssql/object-result.txx')
-rw-r--r--odb/mssql/object-result.txx15
1 files changed, 12 insertions, 3 deletions
diff --git a/odb/mssql/object-result.txx b/odb/mssql/object-result.txx
index 338f78a..161978e 100644
--- a/odb/mssql/object-result.txx
+++ b/odb/mssql/object-result.txx
@@ -6,8 +6,9 @@
#include <cassert>
#include <odb/callback.hxx>
-#include <odb/exceptions.hxx>
+#include <odb/exceptions.hxx> // result_not_cached
+#include <odb/mssql/exceptions.hxx> // long_data_reload
#include <odb/mssql/object-statements.hxx>
namespace odb
@@ -50,6 +51,9 @@ namespace odb
void object_result_impl<T>::
load (object_type& obj, bool)
{
+ if (!can_load_)
+ throw long_data_reload ();
+
// This is a top-level call so the statements cannot be locked.
//
assert (!statements_.locked ());
@@ -66,7 +70,7 @@ namespace odb
// If we are using a copy, make sure the callback information for
// long data also comes from the copy.
//
- statement_->stream_result (
+ can_load_ = !statement_->stream_result (
use_copy_ ? &statements_.image () : 0,
use_copy_ ? image_copy_ : 0);
@@ -103,6 +107,7 @@ namespace odb
void object_result_impl<T>::
next ()
{
+ can_load_ = true;
this->current (pointer_type ());
typename object_traits::image_type& im (statements_.image ());
@@ -200,6 +205,9 @@ namespace odb
void object_result_impl_no_id<T>::
load (object_type& obj)
{
+ if (!can_load_)
+ throw long_data_reload ();
+
odb::database& db (this->database ());
object_traits::callback (db, obj, callback_event::pre_load);
@@ -211,7 +219,7 @@ namespace odb
// If we are using a copy, make sure the callback information for
// long data also comes from the copy.
//
- statement_->stream_result (
+ can_load_ = !statement_->stream_result (
use_copy_ ? &statements_.image () : 0,
use_copy_ ? image_copy_ : 0);
@@ -222,6 +230,7 @@ namespace odb
void object_result_impl_no_id<T>::
next ()
{
+ can_load_ = true;
this->current (pointer_type ());
typename object_traits::image_type& im (statements_.image ());