Sayonara Player
Connector.h
1 /* Connector.h */
2 
3 /* Copyright (C) 2011-2019 Lucio Carreras
4  *
5  * This file is part of sayonara player
6  *
7  * This program 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  * This program 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 this program. If not, see <http://www.gnu.org/licenses/>.
19  */
20 
21 #ifndef DatabaseConnector_H
22 #define DatabaseConnector_H
23 
24 #include "Database/Base.h"
25 
26 #include "Utils/Singleton.h"
27 #include "Utils/Pimpl.h"
28 
29 #define INDEX_SIZE 3
30 
31 namespace DB
32 {
33  class LibraryDatabase;
34  class Bookmarks;
35  class Playlist;
36  class LibraryDatabase;
37  class Podcasts;
38  class Streams;
39  class VisualStyles;
40  class Settings;
41  class Library;
42  class Shortcuts;
43  class Covers;
44  class Session;
45 
46  using LibraryDatabases=QList<LibraryDatabase*>;
47 
48  class Connector :
49  public Base
50  {
51  SINGLETON(Connector)
52  PIMPL(Connector)
53 
54  protected:
55  bool updateAlbumCissearchFix();
56  bool updateArtistCissearchFix();
57  bool updateTrackCissearchFix();
58  bool updateLostArtists();
59  bool updateLostAlbums();
60 
61  virtual bool apply_fixes();
62 
63  public:
64  Connector(const QString& dir, const QString& db_filename);
65  virtual void clean_up();
66 
67  static Connector* instance(const QString& dir, const QString& db_filename);
68 
69  LibraryDatabases library_dbs() const;
70  DB::LibraryDatabase* library_db(LibraryId library_id, DbId db_id);
71  DB::LibraryDatabase* register_library_db(LibraryId library_id);
72  void delete_library_db(LibraryId library_id);
73 
74  DB::Bookmarks* bookmark_connector();
75  DB::Playlist* playlist_connector();
76  DB::Podcasts* podcast_connector();
77  DB::Streams* stream_connector();
78  DB::VisualStyles* visual_style_connector();
79  DB::Settings* settings_connector();
80  DB::Shortcuts* shortcut_connector();
81  DB::Covers* cover_connector();
82  DB::Library* library_connector();
83  DB::Session* session_connector();
84  };
85 }
86 #endif // DatabaseConnector_H
Definition: Streams.h:29
Definition: Playlist.h:43
Definition: Shortcuts.h:31
Definition: CoverConnector.h:35
Definition: LibraryDatabase.h:33
Definition: Settings.h:30
Definition: Base.h:32
Definition: Podcasts.h:29
Definition: Connector.h:48
The Settings class.
Definition: Settings.h:42
Definition: Albums.h:30
Definition: Bookmarks.h:29
Definition: VisualStyles.h:31
Definition: Session.h:33
An interface class needed when implementing a library plugin.
Definition: CachingThread.h:29
Definition: Library.h:38
The Bookmarks logic class.
Definition: Bookmarks.h:36
Definition: Session.h:35
Definition: AbstractPlaylist.h:32
Definition: org_mpris_media_player2_adaptor.h:20