aboutsummaryrefslogtreecommitdiff
path: root/common/polymorphism/test12.hxx
diff options
context:
space:
mode:
authorBoris Kolpackov <boris@codesynthesis.com>2012-10-08 14:47:57 +0200
committerBoris Kolpackov <boris@codesynthesis.com>2012-10-08 14:47:57 +0200
commit6b76715e63d2c265a4c51c73f9019bc578f874cb (patch)
treec0b5f6a944abf6fe015742bbc08e5a393249cf6d /common/polymorphism/test12.hxx
parentdcee8530bb5c58710a22f50bb92ac7c3b19ddf84 (diff)
Fix bug in transient inheritance handling
Also test that we can handle it for objects, composite values, and views.
Diffstat (limited to 'common/polymorphism/test12.hxx')
-rw-r--r--common/polymorphism/test12.hxx80
1 files changed, 0 insertions, 80 deletions
diff --git a/common/polymorphism/test12.hxx b/common/polymorphism/test12.hxx
deleted file mode 100644
index 5feb2bb..0000000
--- a/common/polymorphism/test12.hxx
+++ /dev/null
@@ -1,80 +0,0 @@
-// file : common/polymorphism/test12.hxx
-// copyright : Copyright (c) 2009-2012 Code Synthesis Tools CC
-// license : GNU GPL v2; see accompanying LICENSE file
-
-#ifndef TEST12_HXX
-#define TEST12_HXX
-
-#include <typeinfo>
-
-#include <odb/core.hxx>
-
-// Test polymorphic classes with private auto id.
-//
-#pragma db namespace table("t12_")
-namespace test12
-{
- #pragma db object polymorphic
- struct root
- {
- virtual ~root () = 0; // Auto-abstract.
-
- virtual bool
- compare (const root& r, bool tc = true) const
- {
- if (tc && typeid (r) != typeid (root))
- return false;
-
- return id_ == r.id_;
- }
-
- unsigned long id () const {return id_;}
- void id (unsigned long id) {id_ = id;}
- private:
- #pragma db id auto access(id)
- unsigned long id_;
- };
-
- inline root::
- ~root () {}
-
- inline bool
- operator== (const root& x, const root& y) {return x.compare (y);}
-
- #pragma db object
- struct base: root
- {
- base () {}
- base (unsigned long n): num (n) {}
-
- unsigned long num;
-
- virtual bool
- compare (const root& r, bool tc = true) const
- {
- if (tc && typeid (r) != typeid (base))
- return false;
-
- const base& b (static_cast<const base&> (r));
- return root::compare (r, false) && num == b.num;
- }
- };
-
- #pragma db object
- struct derived: base
- {
- derived () {}
- derived (unsigned long n): base (n) {}
-
- virtual bool
- compare (const root& r, bool tc = true) const
- {
- if (tc && typeid (r) != typeid (derived))
- return false;
-
- return base::compare (r, false);
- }
- };
-}
-
-#endif // TEST12_HXX