1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
|
// file : common/inheritance/polymorphism/test8.hxx
// copyright : Copyright (c) 2009-2013 Code Synthesis Tools CC
// license : GNU GPL v2; see accompanying LICENSE file
#ifndef TEST8_HXX
#define TEST8_HXX
#include <string>
#include <vector>
#include <typeinfo>
#include <odb/core.hxx>
// Test polymorphism and abstract bases.
//
#pragma db namespace table("t8_")
namespace test8
{
#pragma db object polymorphic
struct root
{
virtual ~root () = 0; // Auto-abstract.
root () {}
root (unsigned long i, unsigned long n): id (i), num (n) {}
#pragma db id
unsigned long id;
unsigned long num;
std::vector<std::string> strs;
virtual bool
compare (const root& r, bool tc = true) const
{
if (tc && typeid (r) != typeid (root))
return false;
return id == r.id && num == r.num && strs == r.strs;
}
};
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 i, unsigned long n, const std::string& s)
: root (i, n), str (s) {}
std::string str;
std::vector<unsigned long> nums;
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) && str == b.str && nums == b.nums;
}
};
#pragma db object abstract
struct interm: base
{
interm () {}
interm (unsigned long i, unsigned long n, const std::string& s, bool b)
: base (i, n, s), bln (b) {}
bool bln;
virtual bool
compare (const root& r, bool tc = true) const
{
if (tc && typeid (r) != typeid (interm))
return false;
const interm& i (static_cast<const interm&> (r));
return base::compare (r, false) && bln == i.bln;
}
};
#pragma db object
struct derived1: interm
{
derived1 () {}
derived1 (unsigned long i, unsigned long n, const std::string& s, bool b)
: interm (i, n, s, b), dnum (n + 1) {}
unsigned long dnum;
virtual bool
compare (const root& r, bool tc = true) const
{
if (tc && typeid (r) != typeid (derived1))
return false;
const derived1& d (static_cast<const derived1&> (r));
return interm::compare (r, false) && dnum == d.dnum;
}
};
#pragma db object
struct derived2: interm
{
derived2 () {}
derived2 (unsigned long i, unsigned long n, const std::string& s, bool b)
: interm (i, n, s, b), dstr (s + 'd') {}
std::string dstr;
virtual bool
compare (const root& r, bool tc = true) const
{
if (tc && typeid (r) != typeid (derived2))
return false;
const derived2& d (static_cast<const derived2&> (r));
return interm::compare (r, false) && dstr == d.dstr;
}
};
}
#endif // TEST8_HXX
|