aboutsummaryrefslogtreecommitdiff
path: root/odb/relational
diff options
context:
space:
mode:
Diffstat (limited to 'odb/relational')
-rw-r--r--odb/relational/model.hxx14
-rw-r--r--odb/relational/sqlite/model.cxx6
2 files changed, 15 insertions, 5 deletions
diff --git a/odb/relational/model.hxx b/odb/relational/model.hxx
index c50b6b5..5936ed1 100644
--- a/odb/relational/model.hxx
+++ b/odb/relational/model.hxx
@@ -102,20 +102,18 @@ namespace relational
virtual bool
traverse_column (semantics::data_member& m, string const& name, bool)
{
- bool id (object_columns_base::id ()); // Id or part of.
- bool null (!id && object_columns_base::null ());
-
string col_id (id_prefix_ +
(key_prefix_.empty () ? m.name () : key_prefix_));
sema_rel::column& c (
- model_.new_node<sema_rel::column> (col_id, column_type (), null));
+ model_.new_node<sema_rel::column> (
+ col_id, column_type (), null (m)));
c.set ("cxx-location", m.location ());
model_.new_edge<sema_rel::unames> (table_, c, name);
// An id member cannot have a default value.
//
- if (!id)
+ if (!object_columns_base::id ())
{
string const& d (default_ (m));
@@ -134,6 +132,12 @@ namespace relational
return true;
}
+ virtual bool
+ null (semantics::data_member&)
+ {
+ return !object_columns_base::id () && object_columns_base::null ();
+ }
+
virtual string
default_null (semantics::data_member&)
{
diff --git a/odb/relational/sqlite/model.cxx b/odb/relational/sqlite/model.cxx
index 78977cc..63a5302 100644
--- a/odb/relational/sqlite/model.cxx
+++ b/odb/relational/sqlite/model.cxx
@@ -23,6 +23,12 @@ namespace relational
{
object_columns (base const& x): base (x) {}
+ virtual bool
+ null (semantics::data_member& m)
+ {
+ return options.sqlite_override_null () || base::null (m);
+ }
+
virtual string
default_enum (semantics::data_member& m, tree en, string const&)
{