Files
cantata/db/librarydb.h
Craig Drummond b6bd94c236 Update (c) year
2022-01-08 21:24:07 +00:00

174 lines
5.2 KiB
C++

/*
* Cantata
*
* Copyright (c) 2017-2022 Craig Drummond <craig.p.drummond@gmail.com>
*
* ----
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; see the file COPYING. If not, write to
* the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
* Boston, MA 02110-1301, USA.
*/
#ifndef LIBRARY_DB_H
#define LIBRARY_DB_H
#include <QObject>
#include <QList>
#include <QMap>
#include <QElapsedTimer>
#include "mpd-interface/song.h"
#include "support/utils.h"
#include <time.h>
class QSqlDatabase;
class QSqlQuery;
class LibraryDb : public QObject
{
Q_OBJECT
public:
static void enableDebug() { dbgEnabled=true; }
static bool debugEnabled() { return dbgEnabled; }
static const QLatin1String constFileExt;
static const QLatin1String constNullGenre;
enum AlbumSort {
AS_AlArYr,
AS_AlYrAr,
AS_ArAlYr,
AS_ArYrAl,
AS_YrAlAr,
AS_YrArAl,
AS_Modified,
AS_Count
};
static AlbumSort toAlbumSort(const QString &str);
static QString albumSortStr(AlbumSort m);
struct Genre
{
Genre(const QString &n=QString(), int ac=0)
: name(n), artistCount(ac) { }
QString name;
int artistCount;
bool operator<(const Genre &o) const
{
if (constNullGenre==name) {
return constNullGenre!=o.name;
}
return Utils::compare(name, o.name)<0;
}
};
struct Artist
{
Artist(const QString &n=QString(), const QString &s=QString(), int ac=0)
: name(n), sort(s), albumCount(ac) { }
QString name;
QString sort;
int albumCount;
bool operator<(const Artist &o) const
{
const QString &field=sort.isEmpty() ? name : sort;
const QString &ofield=o.sort.isEmpty() ? o.name : o.sort;
return Utils::compare(field, ofield)<0;
}
};
struct Album
{
Album(const QString &n=QString(), const QString &i=QString(), const QString &s=QString(),
const QString &a=QString(), const QString &as=QString(),
int y=0, int tc=0, int d=0, int lm=0, bool onlyUseId=false)
: name(n), id(i), sort(s), artist(a), artistSort(as), year(y), trackCount(tc), duration(d), lastModified(lm), identifyById(onlyUseId) { }
QString name;
QString id;
QString sort;
QString artist;
QString artistSort;
int year;
int trackCount;
int duration;
int lastModified;
bool identifyById; // Should we jsut use albumId to locate tracks - Issue #1025
};
LibraryDb(QObject *p, const QString &name);
~LibraryDb() override;
void clear();
void erase();
virtual bool init(const QString &dbFile);
void insertSong(const Song &s);
QList<Genre> getGenres();
QList<Artist> getArtists(const QString &genre=QString());
QList<Album> getAlbums(const QString &artistId=QString(), const QString &genre=QString(), AlbumSort sort=AS_YrAlAr);
QList<Song> getTracks(const QString &artistId, const QString &albumId, const QString &genre=QString(), AlbumSort sort=AS_YrAlAr, bool useFilter=true, int maxTracks=-1);
QList<Song> getTracks(int rowFrom, int count);
int trackCount();
QList<Song> songs(const QStringList &files, bool allowPlaylists=false) const;
QList<Album> getAlbumsWithArtistOrComposer(const QString &artist);
Album getRandomAlbum(const QString &genre, const QString &artist);
Album getRandomAlbum(const QStringList &genres, const QStringList &artists);
QSet<QString> get(const QString &type);
void getDetails(QSet<QString> &artists, QSet<QString> &albumArtists, QSet<QString> &composers, QSet<QString> &albums, QSet<QString> &genres);
bool songExists(const Song &song);
bool setFilter(const QString &f, const QString &genre=QString());
const QString & getFilter() const { return filter; }
int getCurrentVersion() const { return currentVersion; }
Q_SIGNALS:
void libraryUpdated();
void error(const QString &str);
public Q_SLOTS:
void updateStarted(time_t ver);
void insertSongs(QList<Song> *songs);
virtual void updateFinished();
void abortUpdate();
protected:
bool createTable(const QString &q);
static Song getSong(const QSqlQuery &query);
protected:
virtual void reset();
void clearSongs(bool startTransaction=true);
protected:
static bool dbgEnabled;
QString dbName;
QString dbFileName;
time_t currentVersion;
time_t newVersion;
QSqlDatabase *db;
QSqlQuery *insertSongQuery;
QElapsedTimer timer;
QString filter;
QString genreFilter;
QString yearFilter;
QMap<QString, QSet<QString> > detailsCache;
};
#endif