aboutsummaryrefslogtreecommitdiff
path: root/common/wrapper/test.hxx
blob: 75f987beb1033ad727de800416ef2743106bf408 (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
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
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
// file      : common/wrapper/test.hxx
// copyright : Copyright (c) 2009-2017 Code Synthesis Tools CC
// license   : GNU GPL v2; see accompanying LICENSE file

#ifndef TEST_HXX
#define TEST_HXX

#include <common/config.hxx> // HAVE_CXX11, HAVE_TR1_MEMORY

#include <string>
#include <memory> // std::auto_ptr
#include <vector>

#include <odb/core.hxx>
#include <odb/nullable.hxx>

#if !defined(HAVE_CXX11) && defined(HAVE_TR1_MEMORY)
#  include <odb/tr1/memory.hxx>
#endif

using odb::nullable;

// Test 1: simple values.
//
#pragma db namespace table("t1_")
namespace test1
{
  typedef nullable<std::string> nullable_string;

#ifdef HAVE_CXX11
  typedef std::unique_ptr<int> num_uptr;
  typedef std::unique_ptr<std::string> str_uptr;
  typedef std::shared_ptr<std::string> str_sptr;
#else
  typedef std::auto_ptr<int> num_uptr;
  typedef std::auto_ptr<std::string> str_uptr;
#  ifdef HAVE_TR1_MEMORY
  typedef std::tr1::shared_ptr<std::string> str_sptr;
#  endif
#endif

  #pragma db object table("obj1")
  struct object1
  {
    #pragma db id auto
    unsigned long id_;

    num_uptr num;

    #pragma db null
    str_uptr str;

    nullable_string nstr;
    std::vector<nullable_string> nstrs;
  };

  #pragma db object
  struct object2
  {
    #pragma db id auto
    unsigned long id_;

#if defined(HAVE_CXX11) || defined(HAVE_TR1_MEMORY)
    #pragma db null
    str_sptr sstr;

    #pragma db value_null
    std::vector<str_sptr> sstrs;
#endif
  };
}

//
// Composite values.
//

#pragma db value
struct comp1
{
  comp1 () {}
  comp1 (const std::string& s, int n): str (s), num (n) {}

  std::string str;
  int num;
};

inline bool
operator== (const comp1& x, const comp1& y)
{
  return x.str == y.str && x.num == y.num;
}


#pragma db value
struct comp2
{
  comp2 () {}
  comp2 (const std::string& s, int n): str (s), num (n) {}

  std::string str;
  int num;

  std::vector<std::string> strs;
};

inline bool
operator== (const comp2& x, const comp2& y)
{
  return x.str == y.str && x.num == y.num && x.strs == y.strs;
}

struct comp3;

#ifdef HAVE_CXX11
typedef std::unique_ptr<comp1> comp1_uptr;
typedef std::unique_ptr<comp2> comp2_uptr;
typedef std::unique_ptr<comp3> comp3_uptr;
#else
typedef std::auto_ptr<comp1> comp1_uptr;
typedef std::auto_ptr<comp2> comp2_uptr;
typedef std::auto_ptr<comp3> comp3_uptr;
#endif

#pragma db object
struct comp_object
{
  #pragma db id auto
  unsigned long id_;

  comp1_uptr                    c1;  // Wrapped comp value.
  std::vector<nullable<comp1> > vc1; // Container of wrapped comp values.
  comp2_uptr                    c2;  // Container inside wrapped comp value.
};

// This one is just a compilation test to cover more convolute cases.
//
#pragma db value
struct comp3: comp2
{
  comp1_uptr c1;
  std::vector<nullable<comp1> > vc1;
};

#pragma db object
struct comp_object2
{
  #pragma db id auto
  unsigned long id_;

  comp3_uptr c3;
};

//
// Containers.
//

#ifdef HAVE_CXX11
typedef std::unique_ptr<std::vector<int>> nums_uptr;
typedef std::unique_ptr<std::vector<std::string>> strs_uptr;
#else
typedef std::auto_ptr<std::vector<int> > nums_uptr;
typedef std::auto_ptr<std::vector<std::string> > strs_uptr;
#endif

#pragma db value
struct cont_comp
{
  int num;
  strs_uptr strs;
};

inline bool
operator== (const cont_comp& x, const cont_comp& y)
{
  return x.num == y.num && *x.strs == *y.strs;
}

#pragma db object
struct cont_object
{
  #pragma db id auto
  unsigned long id_;

  nums_uptr nums; // Wrapped container.
  cont_comp c;    // Wrapped container in comp value.
};

// Test composite NULL values.
//
#pragma db namespace table("t5_")
namespace test5
{
  #pragma db value
  struct base
  {
    base () {}
    base (int n): num (n) {}

    int num;
  };

  inline bool
  operator== (const base& x, const base& y)
  {
    return x.num == y.num;
  }

  #pragma db value
  struct comp: base
  {
    comp () {}
    comp (int n, const std::string s): base (n), str (s), extra (n + 1) {}

    std::string str;
    base extra;

    odb::nullable<int> always_null;
  };

  inline bool
  operator== (const comp& x, const comp& y)
  {
    return static_cast<const base&> (x) == y &&
      x.str == y.str && x.extra == y.extra;
  }

  #pragma db object
  struct object
  {
    #pragma db id auto
    unsigned long id;

    #pragma db null
#ifdef HAVE_CXX11
    std::unique_ptr<comp> p;
#else
    std::auto_ptr<comp> p;
#endif

    odb::nullable<comp> n;

    std::vector< odb::nullable<comp> > v;
  };
}

#endif // TEST_HXX