Expanded implementation for saving media image containers to database
[emufront] / src / db / dbmediaimagecontainer.h
1 // EmuFront
2 // Copyright 2010 Mikko Keinänen
3 //
4 // This file is part of EmuFront.
5 //
6 //
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.
11 //
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.
16 //
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/>.
19
20 #ifndef DBMEDIAIMAGECONTAINER_H
21 #define DBMEDIAIMAGECONTAINER_H
22
23 #include "dbquerymodelmanager.h"
24 #include "dbmediaimage.h"
25 #include "dbfile.h"
26 #include "../dataobjects/mediaimagecontainer.h"
27 #include "../dataobjects/filepathobject.h"
28
29 class DbMediaImageContainer : public DbQueryModelManager
30 {
31 public:
32     DbMediaImageContainer(QObject *parent);
33     virtual bool updateDataObjectToModel(const EmuFrontObject *);
34     virtual int insertDataObjectToModel(const EmuFrontObject *);
35     virtual bool deleteDataObjectFromModel(QModelIndex *);
36     virtual int countDataObjectRefs(int id) const;
37     void storeContainers(QList<MediaImageContainer*>, FilePathObject*);
38     int getMediaImageContainer(QString checksum) const;
39 protected:
40     virtual QString constructSelect(QString whereClause) const;
41     virtual QString constructSelectById(int id) const;
42     virtual QString constructFilterById(int id) const;
43     virtual EmuFrontObject* recordToDataObject(const QSqlRecord *);
44 private:
45     virtual QSqlQueryModel* getData();
46     void linkMediaImagesWithContainer(int, QList<int>);
47     DbMediaImage *dbMediaImage;
48     DbFile *dbFile;
49  };
50
51 #endif // DBMEDIAIMAGECONTAINER_H