summaryrefslogtreecommitdiffstats
path: root/SQLiteStudio3/coreSQLiteStudio/plugins/populatesequence.h
diff options
context:
space:
mode:
Diffstat (limited to 'SQLiteStudio3/coreSQLiteStudio/plugins/populatesequence.h')
-rw-r--r--SQLiteStudio3/coreSQLiteStudio/plugins/populatesequence.h47
1 files changed, 47 insertions, 0 deletions
diff --git a/SQLiteStudio3/coreSQLiteStudio/plugins/populatesequence.h b/SQLiteStudio3/coreSQLiteStudio/plugins/populatesequence.h
new file mode 100644
index 0000000..5435477
--- /dev/null
+++ b/SQLiteStudio3/coreSQLiteStudio/plugins/populatesequence.h
@@ -0,0 +1,47 @@
+#ifndef POPULATESEQUENCE_H
+#define POPULATESEQUENCE_H
+
+#include "builtinplugin.h"
+#include "populateplugin.h"
+#include "config_builder.h"
+
+CFG_CATEGORIES(PopulateSequenceConfig,
+ CFG_CATEGORY(PopulateSequence,
+ CFG_ENTRY(int, StartValue, 0)
+ CFG_ENTRY(int, Step, 1)
+ )
+)
+
+class PopulateSequence : public BuiltInPlugin, public PopulatePlugin
+{
+ Q_OBJECT
+
+ SQLITESTUDIO_PLUGIN_TITLE("Sequence")
+ SQLITESTUDIO_PLUGIN_DESC("Support for populating tables with sequenced values.")
+ SQLITESTUDIO_PLUGIN_VERSION(10001)
+ SQLITESTUDIO_PLUGIN_AUTHOR("sqlitestudio.pl")
+
+ public:
+ PopulateSequence();
+
+ QString getTitle() const;
+ PopulateEngine* createEngine();
+};
+
+class PopulateSequenceEngine : public PopulateEngine
+{
+ public:
+ bool beforePopulating(Db* db, const QString& table);
+ QVariant nextValue(bool& nextValueError);
+ void afterPopulating();
+ CfgMain* getConfig();
+ QString getPopulateConfigFormName() const;
+ bool validateOptions();
+
+ private:
+ CFG_LOCAL(PopulateSequenceConfig, cfg)
+ qint64 seq = 0;
+ qint64 step = 1;
+};
+
+#endif // POPULATESEQUENCE_H