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  PIMPL(Connector)
52 
53  protected:
54  bool updateAlbumCissearchFix();
55  bool updateArtistCissearchFix();
56  bool updateTrackCissearchFix();
57  bool updateLostArtists();
58  bool updateLostAlbums();
59 
60  virtual bool apply_fixes() override;
61 
62  public:
63  Connector(const QString& source_dir, const QString& target_dir, const QString& db_filename);
64  ~Connector() override;
65 
66  virtual void clean_up();
67 
68  static Connector* instance(QString source_dir=QString(), QString target_dir=QString(), QString db_filename=QString());
69 
70  LibraryDatabases library_dbs() const;
71  DB::LibraryDatabase* library_db(LibraryId library_id, DbId db_id);
72  DB::LibraryDatabase* register_library_db(LibraryId library_id);
73  void delete_library_db(LibraryId library_id);
74 
75  DB::Bookmarks* bookmark_connector();
76  DB::Playlist* playlist_connector();
77  DB::Podcasts* podcast_connector();
78  DB::Streams* stream_connector();
79  DB::VisualStyles* visual_style_connector();
80  DB::Settings* settings_connector();
81  DB::Shortcuts* shortcut_connector();
82  DB::Covers* cover_connector();
83  DB::Library* library_connector();
84  DB::Session* session_connector();
85 
86  static int get_max_db_version();
87  int old_db_version() const;
88  };
89 }
90 #endif // DatabaseConnector_H
Settings
The Settings class.
Definition: Settings.h:42
QList
Definition: EngineUtils.h:33
Session
Definition: Session.h:33
DB::Shortcuts
Definition: Shortcuts.h:31
Library
An interface class needed when implementing a library plugin.
Definition: LocalLibraryWatcher.h:32
DB::LibraryDatabase
Definition: LibraryDatabase.h:33
DB::Connector
Definition: Connector.h:48
DB::Session
Definition: Session.h:35
Bookmarks
The Bookmarks logic class.
Definition: Bookmarks.h:36
DB::Playlist
Definition: Playlist.h:45
DB::Base
Definition: Base.h:32
DB::Library
Definition: Library.h:38
DB::Bookmarks
Definition: Bookmarks.h:29
DB::VisualStyles
Definition: VisualStyles.h:31
DB::Settings
Definition: Settings.h:31
DB::Covers
Definition: CoverConnector.h:35
DB::Streams
Definition: Streams.h:29
DB::Podcasts
Definition: Podcasts.h:29