From 08a47c70ad517b80b72914d47d547463f576bcd3 Mon Sep 17 00:00:00 2001 From: Boris Kolpackov Date: Mon, 24 Oct 2011 16:32:51 +0200 Subject: Generate database schema from database model instead of C++ model We now first create the so-called database model from C++ model and then use that to generate the database schema. The new approach also adds more general support for primary/foreign keys, including multi- column keys. Finally, for MySQL we now generate out-of-line foreign key definitions. Because MySQL does not support deferred constraints checking, deferred foreign keys are written commented out, for documentation. --- odb/semantics/relational/table.cxx | 52 ++++++++++++++++++++++++++++++++++++++ 1 file changed, 52 insertions(+) create mode 100644 odb/semantics/relational/table.cxx (limited to 'odb/semantics/relational/table.cxx') diff --git a/odb/semantics/relational/table.cxx b/odb/semantics/relational/table.cxx new file mode 100644 index 0000000..a9290c6 --- /dev/null +++ b/odb/semantics/relational/table.cxx @@ -0,0 +1,52 @@ +// file : odb/semantics/relational/table.cxx +// author : Boris Kolpackov +// copyright : Copyright (c) 2009-2011 Code Synthesis Tools CC +// license : GNU GPL v3; see accompanying LICENSE file + +#include + +#include + +namespace semantics +{ + namespace relational + { + // type info + // + namespace + { + struct init + { + init () + { + using compiler::type_info; + + // table + // + { + type_info ti (typeid (table)); + ti.add_base (typeid (nameable)); + ti.add_base (typeid (scope)); + insert (ti); + } + + // object_table + // + { + type_info ti (typeid (object_table)); + ti.add_base (typeid (table)); + insert (ti); + } + + // container_table + // + { + type_info ti (typeid (container_table)); + ti.add_base (typeid (table)); + insert (ti); + } + } + } init_; + } + } +} -- cgit v1.1