From b1817a0bc9d4828fe6f6edbdfb14a14da1e25d44 Mon Sep 17 00:00:00 2001 From: Andrzej Rybczak Date: Mon, 2 Feb 2009 23:43:12 +0100 Subject: [PATCH] support for switching between supported lyrics databases at runtime --- doc/keys | 2 ++ src/help.cpp | 1 + src/lyrics.cpp | 16 ++++++++++++++-- src/lyrics.h | 2 ++ src/ncmpcpp.cpp | 11 +++++++++++ src/settings.cpp | 8 ++++++-- src/settings.h | 1 + 7 files changed, 37 insertions(+), 4 deletions(-) diff --git a/doc/keys b/doc/keys index 61afff42..0cdf9958 100644 --- a/doc/keys +++ b/doc/keys @@ -126,6 +126,8 @@ # #key_toggle_display_mode = 'p' # +#key_toggle_lyrics_db = 'L' +# #key_go_to_containing_directory = 'G' # #key_start_searching = 'y' diff --git a/src/help.cpp b/src/help.cpp index 65c64f0a..70199133 100644 --- a/src/help.cpp +++ b/src/help.cpp @@ -151,6 +151,7 @@ void GetKeybindings(Scrollpad &help) help << DisplayKeys(Key.SongInfo) << "Show song's info\n"; # ifdef HAVE_CURL_CURL_H help << DisplayKeys(Key.ArtistInfo) << "Show artist's info\n"; + help << DisplayKeys(Key.ToggleLyricsDB) << "Toggle lyrics database\n"; # endif // HAVE_CURL_CURL_H help << DisplayKeys(Key.Lyrics) << "Show/hide song's lyrics\n\n"; diff --git a/src/lyrics.cpp b/src/lyrics.cpp index 67be5644..1f6cbb83 100644 --- a/src/lyrics.cpp +++ b/src/lyrics.cpp @@ -285,13 +285,20 @@ namespace lyricsplugin_not_found }; + const char *lyricsplugins_list[] = + { + "lyricwiki.org", + "lyricsplugin.com", + 0 + }; + const LyricsPlugin *ChooseLyricsPlugin(int i) { switch (i) { - case 1: + case 0: return &lyricwiki; - case 2: + case 1: return &lyricsplugin; default: return &lyricwiki; @@ -299,6 +306,11 @@ namespace } } +const char *GetLyricsPluginName(int offset) +{ + return lyricsplugins_list[offset]; +} + #endif // HAVE_CURL_CURL_H void *GetLyrics(void *song) diff --git a/src/lyrics.h b/src/lyrics.h index 1834f8a3..2202f3a7 100644 --- a/src/lyrics.h +++ b/src/lyrics.h @@ -36,6 +36,8 @@ struct LyricsPlugin bool (*not_found)(const string &); }; +const char *GetLyricsPluginName(int); + #endif void * GetLyrics(void *); diff --git a/src/ncmpcpp.cpp b/src/ncmpcpp.cpp index 706b8f65..238d5f73 100644 --- a/src/ncmpcpp.cpp +++ b/src/ncmpcpp.cpp @@ -2562,6 +2562,17 @@ int main(int argc, char *argv[]) } // redraw_screen = 1; } +# ifdef HAVE_CURL_CURL_H + else if (Keypressed(input, Key.ToggleLyricsDB)) + { + const char *current_lyrics_plugin = GetLyricsPluginName(++Config.lyrics_db); + if (!current_lyrics_plugin) + { + current_lyrics_plugin = GetLyricsPluginName(Config.lyrics_db = 0); + } + ShowMessage("Using lyrics database: %s", current_lyrics_plugin); + } +# endif // HAVE_CURL_CURL_H else if (Keypressed(input, Key.ToggleAutoCenter)) { Config.autocenter_mode = !Config.autocenter_mode; diff --git a/src/settings.cpp b/src/settings.cpp index a0efb58d..7f19dfb7 100644 --- a/src/settings.cpp +++ b/src/settings.cpp @@ -160,6 +160,7 @@ void DefaultKeys(ncmpcpp_keys &keys) keys.StartSearching[0] = 'y'; keys.ToggleAutoCenter[0] = 'U'; keys.ToggleDisplayMode[0] = 'p'; + keys.ToggleLyricsDB[0] = 'L'; keys.GoToParentDir[0] = 263; keys.SwitchTagTypeList[0] = '`'; keys.Quit[0] = 'q'; @@ -223,6 +224,7 @@ void DefaultKeys(ncmpcpp_keys &keys) keys.StartSearching[1] = null_key; keys.ToggleAutoCenter[1] = null_key; keys.ToggleDisplayMode[1] = null_key; + keys.ToggleLyricsDB[1] = null_key; keys.GoToParentDir[1] = 127; keys.SwitchTagTypeList[1] = null_key; keys.Quit[1] = 'Q'; @@ -284,7 +286,7 @@ void DefaultConfiguration(ncmpcpp_config &conf) conf.seek_time = 1; conf.playlist_disable_highlight_delay = 5; conf.message_delay_time = 4; - conf.lyrics_db = 1; + conf.lyrics_db = 0; } string GetLineValue(string &line, char a, char b, bool once) @@ -481,6 +483,8 @@ void ReadKeys(ncmpcpp_keys &keys) GetKeys(key, keys.ToggleAutoCenter); else if (key.find("key_toggle_display_mode ") != string::npos) GetKeys(key, keys.ToggleDisplayMode); + else if (key.find("key_toggle_lyrics_db ") != string::npos) + GetKeys(key, keys.ToggleLyricsDB); else if (key.find("key_go_to_containing_directory ") != string::npos) GetKeys(key, keys.GoToContainingDir); else if (key.find("key_start_searching ") != string::npos) @@ -703,7 +707,7 @@ void ReadConfiguration(ncmpcpp_config &conf) else if (cl.find("lyrics_database") != string::npos) { if (!v.empty()) - conf.lyrics_db = StrToInt(v); + conf.lyrics_db = StrToInt(v)-1; } else if (cl.find("song_window_title_format") != string::npos) { diff --git a/src/settings.h b/src/settings.h index 1d6d7e17..b5bb2c1e 100644 --- a/src/settings.h +++ b/src/settings.h @@ -88,6 +88,7 @@ struct ncmpcpp_keys int StartSearching[2]; int ToggleAutoCenter[2]; int ToggleDisplayMode[2]; + int ToggleLyricsDB[2]; int GoToParentDir[2]; int SwitchTagTypeList[2]; int Quit[2];