aboutsummaryrefslogtreecommitdiff
path: root/schema/embedded/database.hxx
diff options
context:
space:
mode:
Diffstat (limited to 'schema/embedded/database.hxx')
-rw-r--r--schema/embedded/database.hxx20
1 files changed, 19 insertions, 1 deletions
diff --git a/schema/embedded/database.hxx b/schema/embedded/database.hxx
index 7483f52..ab733e2 100644
--- a/schema/embedded/database.hxx
+++ b/schema/embedded/database.hxx
@@ -18,6 +18,8 @@
#if defined(DATABASE_MYSQL)
# include <odb/mysql/database.hxx>
+#elif defined(DATABASE_SQLITE)
+# include <odb/sqlite/database.hxx>
#endif
inline std::auto_ptr<odb::database>
@@ -33,14 +35,30 @@ create_database (int& argc, char* argv[])
#if defined(DATABASE_MYSQL)
odb::mysql::database::print_usage (cerr);
+#elif defined(DATABASE_SQLITE)
+ odb::sqlite::database::print_usage (cerr);
#endif
exit (0);
}
#if defined(DATABASE_MYSQL)
- return auto_ptr<database> (new odb::mysql::database (argc, argv));
+ auto_ptr<database> db (new odb::mysql::database (argc, argv));
+#elif defined(DATABASE_SQLITE)
+ auto_ptr<database> db (
+ new odb::sqlite::database (
+ argc, argv, false, SQLITE_OPEN_READWRITE | SQLITE_OPEN_CREATE));
+
+ // Create the database schema.
+ //
+ {
+ transaction t (db->begin ());
+ schema_catalog::create_schema (*db);
+ t.commit ();
+ }
#endif
+
+ return db;
}
#endif // DATABASE_HXX