blob: 19dee89818f4e5e22e77af8f05bf5144b7aa12d5 (
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
|
// file : evolution/add-foreign-key/model.hxx
// copyright : Copyright (c) 2009-2013 Code Synthesis Tools CC
// license : GNU GPL v2; see accompanying LICENSE file
#ifndef MODEL_VERSION
# error model.hxx included directly
#endif
#include <string>
#include <odb/core.hxx>
#include <common/config.hxx> // DATABASE_XXX
#pragma db model version(1, MODEL_VERSION)
#define MODEL_NAMESPACE_IMPL(V) v##V
#define MODEL_NAMESPACE(V) MODEL_NAMESPACE_IMPL(V)
namespace MODEL_NAMESPACE(MODEL_VERSION)
{
#if MODEL_VERSION == 3
#pragma db object
struct object1
{
object1 (unsigned long id = 0): id_ (id) {}
#pragma db id
unsigned long id_;
};
#pragma db object
struct object2
{
object2 (unsigned long id = 0): id_ (id) {}
#pragma db id
unsigned long id_;
};
#endif
#pragma db object
struct object
{
#pragma db id
unsigned long id_;
#if MODEL_VERSION == 2
object (unsigned long id = 0): id_ (id) {}
#else
object1* o1;
// There is no support for changing a column to NOT NULL in SQLite.
//
#ifndef ODB_DATABASE_SQLITE
#pragma db not_null
#endif
object2* o2;
object (unsigned long id = 0): id_ (id), o1 (0), o2 (0) {}
~object () {delete o1; delete o2;}
#endif
};
}
#undef MODEL_NAMESPACE
#undef MODEL_NAMESPACE_IMPL
|