blob: 996fc1981e0be7b6a1d1be8f9a5df5f0855c1fb2 (
plain)
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
|
// file : section/person.hxx
// copyright : not copyrighted - public domain
#ifndef PERSON_HXX
#define PERSON_HXX
#include <string>
#include <odb/core.hxx>
#include <odb/vector.hxx>
#include <odb/section.hxx>
#pragma db object
class person
{
public:
person (const std::string& first, const std::string& last)
: first_ (first), last_ (last)
{
}
const std::string&
first () const
{
return first_;
}
const std::string&
last () const
{
return last_;
}
// Biography.
//
const std::string&
bio () const
{
return bio_;
}
void
bio (const std::string& bio)
{
bio_ = bio;
extras_.change (); // Mark the section as changed.
}
// Nicknames.
//
typedef odb::vector<std::string> names;
const names&
nicknames () const
{
return nicknames_;
}
names&
nicknames ()
{
// Because we are using a change-tracking container (odb::vector),
// ODB will automatically mark the section as changed if we update
// the nicknames.
//
return nicknames_;
}
// The extras section accessor and modifier. Notice that they are
// by-reference.
//
const odb::section&
extras_section () const
{
return extras_;
}
odb::section&
extras_section ()
{
return extras_;
}
private:
friend class odb::access;
person () {}
#pragma db id auto
unsigned long id_;
std::string first_;
std::string last_;
#pragma db section(extras_)
std::string bio_;
#pragma db section(extras_)
names nicknames_;
#pragma db load(lazy) update(change)
odb::section extras_;
};
#endif // PERSON_HXX
|