summaryrefslogtreecommitdiff
path: root/libodb/odb/section.cxx
diff options
context:
space:
mode:
authorKaren Arutyunov <karen@codesynthesis.com>2024-01-24 17:03:38 +0300
committerKaren Arutyunov <karen@codesynthesis.com>2024-01-24 17:03:38 +0300
commit0f1f6841ce5a50d5b315c24d796a2d8e2627d136 (patch)
treee16bbf9e23ca75a88b8af032c4e3ed299ca8db66 /libodb/odb/section.cxx
parent823026b58211a4166de06ac243d978dcb9930271 (diff)
parent26e36b3a9d7b49d46ecfa69b447482251acba8ac (diff)
Merge branch 'libodb' into multi-package
Diffstat (limited to 'libodb/odb/section.cxx')
-rw-r--r--libodb/odb/section.cxx27
1 files changed, 27 insertions, 0 deletions
diff --git a/libodb/odb/section.cxx b/libodb/odb/section.cxx
new file mode 100644
index 0000000..0fe5211
--- /dev/null
+++ b/libodb/odb/section.cxx
@@ -0,0 +1,27 @@
+// file : odb/section.cxx
+// license : GNU GPL v2; see accompanying LICENSE file
+
+#include <odb/section.hxx>
+
+namespace odb
+{
+ void section::
+ disarm ()
+ {
+ transaction& t (transaction::current ());
+ t.callback_unregister (this);
+ state_.armed = 0;
+ }
+
+ void section::
+ transacion_callback (unsigned short event, void* key, unsigned long long)
+ {
+ section& s (*static_cast<section*> (key));
+
+ if (event == transaction::event_rollback && s.state_.restore)
+ s.state_.changed = 1;
+
+ s.state_.armed = 0;
+ s.state_.restore = 0;
+ }
+}