summaryrefslogtreecommitdiff
path: root/odb/relational/generate.hxx
diff options
context:
space:
mode:
authorBoris Kolpackov <boris@codesynthesis.com>2011-10-24 16:32:51 +0200
committerBoris Kolpackov <boris@codesynthesis.com>2011-10-24 16:32:51 +0200
commit08a47c70ad517b80b72914d47d547463f576bcd3 (patch)
tree8a6ab07cf05e8668ea3c91735dfe97e2a98f3f05 /odb/relational/generate.hxx
parenta976183dc95a8b7a9bd7a308c3ea94f08982c426 (diff)
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.
Diffstat (limited to 'odb/relational/generate.hxx')
-rw-r--r--odb/relational/generate.hxx10
1 files changed, 10 insertions, 0 deletions
diff --git a/odb/relational/generate.hxx b/odb/relational/generate.hxx
index c7c7837..bf4b4aa 100644
--- a/odb/relational/generate.hxx
+++ b/odb/relational/generate.hxx
@@ -6,6 +6,10 @@
#ifndef ODB_RELATIONAL_GENERATE_HXX
#define ODB_RELATIONAL_GENERATE_HXX
+#include <cutl/shared-ptr.hxx>
+
+#include <odb/semantics/relational/model.hxx>
+
namespace relational
{
namespace header
@@ -26,6 +30,12 @@ namespace relational
generate ();
}
+ namespace model
+ {
+ cutl::shared_ptr<semantics::relational::model>
+ generate ();
+ }
+
namespace schema
{
void