Created separate directory for player engine
[someplayer] / src / library.cpp
index bfd8a1d..9a530e8 100644 (file)
@@ -3,9 +3,16 @@
 using namespace SomePlayer::DataObjects;
 using namespace SomePlayer::Storage;
 
-Library::Library(QString databasePath, QString playlistsPath) {
+#include "mediascanner.h"
+#include <QDir>
+
+Library::Library(QString databasePath, QString playlistsPath) : QObject(0) {
        _library_storage = new DbStorage(databasePath);
        _playlist_storage = new FileStorage(playlistsPath);
+       _scanner = new MediaScanner();
+       _resolver = new TagResolver(this);
+       connect(_scanner, SIGNAL(scanFinish(QStringList)), _resolver, SLOT(decode(QStringList)));
+       connect(_resolver, SIGNAL(decoded(Track)), this, SLOT(addTrack(Track)));
 }
 
 Library::~Library() {
@@ -14,11 +21,13 @@ Library::~Library() {
 }
 
 void Library::addDirectory(QString path) {
-       /// TODO: implement this
+       _scanner->init(path);
+       _scanner->start(QThread::LowestPriority);
 }
 
 void Library::addFile(QString path) {
-       /// TODO: implement this
+       QStringList files(path);
+       _resolver->decode(files);
 }
 
 QList<QString> Library::getArtists() {
@@ -57,12 +66,16 @@ void Library::removeTrack(Track track) {
        _library_storage->removeTrack(track);
 }
 
+void Library::addTrack(Track track) {
+       _library_storage->addTrack(track);
+}
+
 void Library::addToFavorites(Track track) {
        _library_storage->addToFavorites(track);
 }
 
-void Library::updateTrack(Track track) {
-       _library_storage->updateTrack(track);
+void Library::updateTrackCount(Track track) {
+       _library_storage->updateTrackCount(track);
 }
 
 
@@ -72,6 +85,14 @@ QList<Playlist> Library::getPlaylists() {
        return _playlist_storage->getPlaylists();
 }
 
+QStringList Library::getPlaylistsNames() {
+       return _playlist_storage->getPlaylistsNames();
+}
+
+Playlist Library::getPlaylist(QString name) {
+       return _playlist_storage->getPlaylist(name);
+}
+
 void Library::savePlaylist(Playlist playlist) {
        _playlist_storage->savePlaylist(playlist);
 }
@@ -80,6 +101,9 @@ void Library::removePlaylist(Playlist playlist) {
        _playlist_storage->removePlaylist(playlist);
 }
 
+void Library::removePlaylist(QString name) {
+       _playlist_storage->removePlaylist(name);
+}
 
 Playlist Library::getCurrentPlaylist() {
        return _playlist_storage->getCurrentPlaylist();