aboutsummaryrefslogtreecommitdiff
path: root/odb/mysql
diff options
context:
space:
mode:
authorBoris Kolpackov <boris@codesynthesis.com>2010-08-19 11:24:43 +0200
committerBoris Kolpackov <boris@codesynthesis.com>2010-08-19 11:24:43 +0200
commit3c5b84f94ac786426591d25edf2f6e19d9506859 (patch)
treec82ae4c78842fe94da68013a74fe3d8834181993 /odb/mysql
parentc39378136e17f556608b3ea649f2ee9c92104670 (diff)
Add support for automatic object ids
Diffstat (limited to 'odb/mysql')
-rw-r--r--odb/mysql/context.cxx14
-rw-r--r--odb/mysql/context.hxx3
-rw-r--r--odb/mysql/schema.cxx170
-rw-r--r--odb/mysql/source.cxx16
4 files changed, 115 insertions, 88 deletions
diff --git a/odb/mysql/context.cxx b/odb/mysql/context.cxx
index b7707cb..1778c93 100644
--- a/odb/mysql/context.cxx
+++ b/odb/mysql/context.cxx
@@ -76,6 +76,20 @@ namespace mysql
{
}
+ string context::
+ column_type (semantics::data_member& m) const
+ {
+ string r (::context::column_type (m));
+
+ if (m.count ("auto"))
+ r += " AUTO_INCREMENT";
+
+ std::cerr << r << std::endl;
+
+
+ return r;
+ }
+
static sql_type
parse_sql_type (semantics::data_member& m, std::string const& sql);
diff --git a/odb/mysql/context.hxx b/odb/mysql/context.hxx
index 4007bda..e91320e 100644
--- a/odb/mysql/context.hxx
+++ b/odb/mysql/context.hxx
@@ -87,6 +87,9 @@ namespace mysql
data* data_;
public:
+ virtual string
+ column_type (semantics::data_member&) const;
+
sql_type const&
db_type (semantics::data_member&);
diff --git a/odb/mysql/schema.cxx b/odb/mysql/schema.cxx
index b405016..866cfcc 100644
--- a/odb/mysql/schema.cxx
+++ b/odb/mysql/schema.cxx
@@ -6,124 +6,124 @@
#include <set>
#include <odb/mysql/schema.hxx>
-namespace
+namespace mysql
{
- struct data_member: traversal::data_member, context
+ namespace
{
- data_member (context& c)
- : context (c), first_ (true)
+ struct data_member: traversal::data_member, context
{
- }
+ data_member (context& c)
+ : context (c), first_ (true)
+ {
+ }
- virtual void
- traverse (type& m)
- {
- if (m.count ("transient"))
- return;
+ virtual void
+ traverse (type& m)
+ {
+ if (m.count ("transient"))
+ return;
- if (first_)
- first_ = false;
- else
- os << "," << endl;
+ if (first_)
+ first_ = false;
+ else
+ os << "," << endl;
- os << " `" << column_name (m) << "` " << column_type (m);
+ os << " `" << column_name (m) << "` " << column_type (m);
- if (m.count ("id"))
- os << " PRIMARY KEY";
- }
+ if (m.count ("id"))
+ os << " PRIMARY KEY";
+ }
- private:
- bool first_;
- };
+ private:
+ bool first_;
+ };
- struct class_create: traversal::class_, context
- {
- class_create (context& c)
- : context (c)
+ struct class_create: traversal::class_, context
{
- }
+ class_create (context& c)
+ : context (c)
+ {
+ }
- virtual void
- traverse (type& c)
- {
- if (c.file () != unit.file ())
- return;
+ virtual void
+ traverse (type& c)
+ {
+ if (c.file () != unit.file ())
+ return;
- if (!c.count ("object"))
- return;
+ if (!c.count ("object"))
+ return;
- string const& name (table_name (c));
+ string const& name (table_name (c));
- // If the table with this name was already created, assume the
- // user knows what they are doing and skip it.
- //
- if (tables_.count (name))
- return;
+ // If the table with this name was already created, assume the
+ // user knows what they are doing and skip it.
+ //
+ if (tables_.count (name))
+ return;
- os << "CREATE TABLE `" << name << "` (" << endl;
+ os << "CREATE TABLE `" << name << "` (" << endl;
- {
- data_member m (*this);
- traversal::names n (m);
- names (c, n);
- }
+ {
+ data_member m (*this);
+ traversal::names n (m);
+ names (c, n);
+ }
- os << ")";
+ os << ")";
- string const& engine (options.mysql_engine ());
+ string const& engine (options.mysql_engine ());
- if (engine != "default")
- os << endl
- << " ENGINE=" << engine;
+ if (engine != "default")
+ os << endl
+ << " ENGINE=" << engine;
- os << ";" << endl
- << endl;
+ os << ";" << endl
+ << endl;
- tables_.insert (name);
- }
+ tables_.insert (name);
+ }
- private:
- std::set<string> tables_;
- };
+ private:
+ std::set<string> tables_;
+ };
- struct class_drop: traversal::class_, context
- {
- class_drop (context& c)
- : context (c)
+ struct class_drop: traversal::class_, context
{
- }
+ class_drop (context& c)
+ : context (c)
+ {
+ }
- virtual void
- traverse (type& c)
- {
- if (c.file () != unit.file ())
- return;
+ virtual void
+ traverse (type& c)
+ {
+ if (c.file () != unit.file ())
+ return;
- if (!c.count ("object"))
- return;
+ if (!c.count ("object"))
+ return;
- string const& name (table_name (c));
+ string const& name (table_name (c));
- if (tables_.count (name))
- return;
+ if (tables_.count (name))
+ return;
- os << "DROP TABLE IF EXISTS `" << name << "`;" << endl;
+ os << "DROP TABLE IF EXISTS `" << name << "`;" << endl;
- tables_.insert (name);
- }
+ tables_.insert (name);
+ }
- private:
- std::set<string> tables_;
- };
-}
+ private:
+ std::set<string> tables_;
+ };
-static char const file_header[] =
- "/* This file was generated by CodeSynthesis ODB object persistence\n"
- " * compiler for C++.\n"
- " */\n\n";
+ static char const file_header[] =
+ "/* This file was generated by CodeSynthesis ODB object persistence\n"
+ " * compiler for C++.\n"
+ " */\n\n";
+ }
-namespace mysql
-{
void
generate_schema (context& ctx)
{
diff --git a/odb/mysql/source.cxx b/odb/mysql/source.cxx
index 1e91344..9d47541 100644
--- a/odb/mysql/source.cxx
+++ b/odb/mysql/source.cxx
@@ -838,12 +838,22 @@ namespace mysql
<< "object_statements<object_type>& sts (" << endl
<< "conn.statement_cache ().find<object_type> ());"
<< "binding& b (sts.image_binding ());"
- << endl
+ << endl;
+
+ if (id.count ("auto"))
+ os << "obj." << id.name () << " = 0;";
+
+ os << endl
<< "if (init (sts.image (), obj) || b.version == 0)" << endl
<< "bind (b, sts.image ());"
<< endl
- << "sts.persist_statement ().execute ();"
- << "}";
+ << "mysql::persist_statement& st (sts.persist_statement ());"
+ << "st.execute ();";
+
+ if (id.count ("auto"))
+ os << "obj." << id.name () << " = static_cast<id_type> (st.id ());";
+
+ os << "}";
// store ()
//