2 // Copyright 2010 Mikko Keinänen
4 // This file is part of EmuFront.
7 // EmuFront is free software: you can redistribute it and/or modify
8 // it under the terms of the GNU General Public License as published by
9 // the Free Software Foundation, either version 3 of the License, or
10 // (at your option) any later version.
12 // EmuFront is distributed in the hope that it will be useful,
13 // but WITHOUT ANY WARRANTY; without even the implied warranty of
14 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 // GNU General Public License for more details.
17 // You should have received a copy of the GNU General Public License
18 // along with EmuFront. If not, see <http://www.gnu.org/licenses/>.
20 #ifndef DATABASEMANAGER_H
21 #define DATABASEMANAGER_H
24 #include <QSqlDatabase>
25 #include "../exceptions/emufrontexception.h"
33 class DatabaseManager : public QObject
36 DatabaseManager(QObject *parent = 0);
39 QSqlQueryModel* getDataModel(bool update = false);
40 EmuFrontObject* getDataObjectFromModel(QModelIndex*);
41 EmuFrontObject* getDataObject(int id);
42 EmuFrontObject* getDataObject(QString filter);
43 virtual bool updateDataObjectToModel(const EmuFrontObject*) = 0;
44 virtual int insertDataObjectToModel(const EmuFrontObject*) = 0;
45 virtual bool deleteDataObjectFromModel(QModelIndex*) = 0;
46 virtual int countDataObjectRefs(int id) const = 0;
47 static int getCurrentTimeStamp();
51 Filetype_MediaImageContainer = 0,
52 Filetype_Screenshot = 1,
53 Filetype_PlatformIcon = 2,
54 Filetype_MediaTypeIcon = 3 };
57 QSqlQueryModel* sqlTableModel;
58 virtual EmuFrontObject* recordToDataObject(const QSqlRecord* ) = 0;
59 virtual void filterById(int id) = 0;
60 virtual void filterDataObjects(QList<QString> filter) = 0;
61 virtual void clearFilters() = 0;
62 int countRows(QString tableName, QString columnName, int id) const;
63 static const QString DB_TABLE_NAME_FILE;
64 static const QString DB_TABLE_NAME_FILEPATH;
65 static const QString DB_TABLE_NAME_MEDIATYPE;
66 static const QString DB_TABLE_NAME_PLATFORM;
67 static const QString DB_TABLE_NAME_SETUP;
68 static const QString DB_TABLE_MEDIAIMAGECONTAINER;
69 static const QString DB_TABLE_MEDIAIMAGECONTAINER_MEDIAIMAGE;
70 static const QString DB_TABLE_EXECUTABLE;
74 static const QString DB_FILENAME;
75 static const QString DATABASE;
76 virtual QSqlQueryModel* getData() = 0;
77 static QString getDbPath();
78 EmuFrontObject* getFilteredDataObject();