X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fcore%2Fabstractsqlstorage.h;h=2894291383fba787df362b492acfbbfd266cd57b;hp=e14abd929e100c05db181e4a81eef22f51a5abf1;hb=5e5714fb2abf8feaf9cc4a27a26e86f2f9c45b30;hpb=aca3263f8f94e0d6640bdf857e71115151b85037 diff --git a/src/core/abstractsqlstorage.h b/src/core/abstractsqlstorage.h index e14abd92..28942913 100644 --- a/src/core/abstractsqlstorage.h +++ b/src/core/abstractsqlstorage.h @@ -27,6 +27,9 @@ #include #include +class AbstractSqlMigrationReader; +class AbstractSqlMigrationWriter; + class AbstractSqlStorage : public Storage { Q_OBJECT @@ -34,7 +37,12 @@ public: AbstractSqlStorage(QObject *parent = 0); virtual ~AbstractSqlStorage(); + virtual inline AbstractSqlMigrationReader *createMigrationReader() { return 0; } + virtual inline AbstractSqlMigrationWriter *createMigrationWriter() { return 0; } + +public slots: virtual State init(const QVariantMap &settings = QVariantMap()); + virtual bool setup(const QVariantMap &settings = QVariantMap()); protected: inline virtual void sync() {}; @@ -45,7 +53,6 @@ protected: inline QString queryString(const QString &queryName) { return queryString(queryName, 0); } QStringList setupQueries(); - bool setup(const QVariantMap &settings = QVariantMap()); QStringList upgradeQueries(int ver); bool upgradeDb(); @@ -257,7 +264,6 @@ private: QSqlQuery *_query; }; -class AbstractSqlMigrationWriter; class AbstractSqlMigrationReader : public AbstractSqlMigrator { public: AbstractSqlMigrationReader(); @@ -297,6 +303,8 @@ public: inline bool migrateFrom(AbstractSqlMigrationReader *reader) { return reader->migrateTo(this); } + // called after migration process + virtual inline bool postProcess() { return true; } friend class AbstractSqlMigrationReader; };