// file : odb/oracle/object-result.txx // copyright : Copyright (c) 2009-2012 Code Synthesis Tools CC // license : ODB NCUEL; see accompanying LICENSE file #include #include #include #include namespace odb { namespace oracle { // // object_result_impl // template object_result_impl:: ~object_result_impl () { change_callback_type& cc (statements_.image ().change_callback_); if (cc.context == this) { cc.context = 0; cc.callback = 0; } delete image_copy_; } template object_result_impl:: object_result_impl (const query&, details::shared_ptr statement, object_statements& statements) : base_type (statements.connection ().database ()), statement_ (statement), statements_ (statements), use_copy_ (false), image_copy_ (0) { } template void object_result_impl:: load (object_type& obj, bool) { // This is a top-level call so the statements cannot be locked. // assert (!statements_.locked ()); typename object_statements::auto_lock l (statements_); odb::database& db (this->database ()); object_traits::callback (db, obj, callback_event::pre_load); typename object_traits::image_type& i ( use_copy_ ? *image_copy_ : statements_.image ()); object_traits::init (obj, i, db); // If we are using a copy, make sure the callback information for // LOB data also comes from the copy. // statement_->stream_result ( use_copy_ ? &statements_.image () : 0, use_copy_ ? image_copy_ : 0); // Initialize the id image and binding and load the rest of the object // (containers, etc). // typename object_traits::id_image_type& idi (statements_.id_image ()); object_traits::init (idi, object_traits::id (i)); binding& idb (statements_.id_image_binding ()); if (idi.version != statements_.id_image_version () || idb.version == 0) { object_traits::bind (idb.bind, idi); statements_.id_image_version (idi.version); idb.version++; } object_traits::load_ (statements_, obj); statements_.load_delayed (); l.unlock (); object_traits::callback (db, obj, callback_event::post_load); } template typename object_result_impl::id_type object_result_impl:: load_id () { return object_traits::id ( use_copy_ ? *image_copy_ : statements_.image ()); } template void object_result_impl:: next () { this->current (pointer_type ()); typename object_traits::image_type& im (statements_.image ()); change_callback_type& cc (im.change_callback_); if (cc.context == this) { cc.callback = 0; cc.context = 0; } use_copy_ = false; if (im.version != statements_.select_image_version ()) { binding& b (statements_.select_image_binding ()); object_traits::bind (b.bind, im, statement_select); statements_.select_image_version (im.version); b.version++; } if (statement_->fetch () == select_statement::no_data) this->end_ = true; else { cc.callback = &change_callback; cc.context = this; } } template void object_result_impl:: cache () { } template std::size_t object_result_impl:: size () { throw result_not_cached (); } template void object_result_impl:: change_callback (void* c) { object_result_impl* r (static_cast*> (c)); typename object_traits::image_type& im (r->statements_.image ()); if (r->image_copy_ == 0) r->image_copy_ = new typename object_traits::image_type (im); else *r->image_copy_ = im; // Increment binding version since we may have "stolen" some // descriptors (LOB, date-time) from the image. Re-bind will // reallocate them and update the binding. // r->statements_.select_image_binding ().version++; im.change_callback_.callback = 0; im.change_callback_.context = 0; r->use_copy_ = true; } // // object_result_impl_no_id // template object_result_impl_no_id:: ~object_result_impl_no_id () { change_callback_type& cc (statements_.image ().change_callback_); if (cc.context == this) { cc.context = 0; cc.callback = 0; } delete image_copy_; } template object_result_impl_no_id:: object_result_impl_no_id (const query&, details::shared_ptr statement, object_statements_no_id& statements) : base_type (statements.connection ().database ()), statement_ (statement), statements_ (statements), use_copy_ (false), image_copy_ (0) { } template void object_result_impl_no_id:: load (object_type& obj) { odb::database& db (this->database ()); object_traits::callback (db, obj, callback_event::pre_load); object_traits::init (obj, use_copy_ ? *image_copy_ : statements_.image (), db); // If we are using a copy, make sure the callback information for // LOB data also comes from the copy. // statement_->stream_result ( use_copy_ ? &statements_.image () : 0, use_copy_ ? image_copy_ : 0); object_traits::callback (db, obj, callback_event::post_load); } template void object_result_impl_no_id:: next () { this->current (pointer_type ()); typename object_traits::image_type& im (statements_.image ()); change_callback_type& cc (im.change_callback_); if (cc.context == this) { cc.callback = 0; cc.context = 0; } use_copy_ = false; if (im.version != statements_.select_image_version ()) { binding& b (statements_.select_image_binding ()); object_traits::bind (b.bind, im, statement_select); statements_.select_image_version (im.version); b.version++; } if (statement_->fetch () == select_statement::no_data) this->end_ = true; else { cc.callback = &change_callback; cc.context = this; } } template void object_result_impl_no_id:: cache () { } template std::size_t object_result_impl_no_id:: size () { throw result_not_cached (); } template void object_result_impl_no_id:: change_callback (void* c) { object_result_impl_no_id* r ( static_cast*> (c)); typename object_traits::image_type im (r->statements_.image ()); if (r->image_copy_ == 0) r->image_copy_ = new typename object_traits::image_type (im); else *r->image_copy_ = im; // Increment binding version since we may have "stolen" some // descriptors (LOB, date-time) from the image. Re-bind will // reallocate them and update the binding. // r->statements_.select_image_binding ().version++; im.change_callback_.callback = 0; im.change_callback_.context = 0; r->use_copy_ = true; } } }