separate 'song info' functionality from Info class
This commit is contained in:
@@ -3,8 +3,8 @@ ncmpcpp_SOURCES = browser.cpp charset.cpp clock.cpp conv.cpp curl_handle.cpp \
|
|||||||
display.cpp error.cpp help.cpp helpers.cpp info.cpp lyrics.cpp lyrics_fetcher.cpp \
|
display.cpp error.cpp help.cpp helpers.cpp info.cpp lyrics.cpp lyrics_fetcher.cpp \
|
||||||
media_library.cpp menu.cpp mpdpp.cpp ncmpcpp.cpp outputs.cpp playlist.cpp \
|
media_library.cpp menu.cpp mpdpp.cpp ncmpcpp.cpp outputs.cpp playlist.cpp \
|
||||||
playlist_editor.cpp scrollpad.cpp search_engine.cpp sel_items_adder.cpp server_info.cpp \
|
playlist_editor.cpp scrollpad.cpp search_engine.cpp sel_items_adder.cpp server_info.cpp \
|
||||||
settings.cpp song.cpp status.cpp tag_editor.cpp tiny_tag_editor.cpp tolower.cpp \
|
settings.cpp song.cpp song_info.cpp status.cpp tag_editor.cpp tiny_tag_editor.cpp \
|
||||||
visualizer.cpp window.cpp
|
tolower.cpp visualizer.cpp window.cpp
|
||||||
|
|
||||||
# set the include path found by configure
|
# set the include path found by configure
|
||||||
INCLUDES= $(all_includes)
|
INCLUDES= $(all_includes)
|
||||||
@@ -14,5 +14,5 @@ ncmpcpp_LDFLAGS = $(all_libraries)
|
|||||||
noinst_HEADERS = browser.h charset.h clock.h conv.h curl_handle.h display.h \
|
noinst_HEADERS = browser.h charset.h clock.h conv.h curl_handle.h display.h \
|
||||||
error.h global.h help.h helpers.h home.h info.h lyrics.h lyrics_fetcher.h \
|
error.h global.h help.h helpers.h home.h info.h lyrics.h lyrics_fetcher.h \
|
||||||
media_library.h menu.h mpdpp.h outputs.h playlist_editor.h screen.h scrollpad.h \
|
media_library.h menu.h mpdpp.h outputs.h playlist_editor.h screen.h scrollpad.h \
|
||||||
search_engine.h sel_items_adder.h server_info.h settings.h song.h tag_editor.h \
|
search_engine.h sel_items_adder.h server_info.h settings.h song.h song_info.h \
|
||||||
tiny_tag_editor.h tolower.h visualizer.h window.h
|
tag_editor.h tiny_tag_editor.h tolower.h visualizer.h window.h
|
||||||
|
|||||||
@@ -22,7 +22,7 @@
|
|||||||
|
|
||||||
#include "display.h"
|
#include "display.h"
|
||||||
#include "helpers.h"
|
#include "helpers.h"
|
||||||
#include "info.h"
|
#include "song_info.h"
|
||||||
#include "playlist.h"
|
#include "playlist.h"
|
||||||
#include "global.h"
|
#include "global.h"
|
||||||
|
|
||||||
@@ -375,7 +375,7 @@ void Display::Tags(const MPD::Song &s, void *data, Menu<MPD::Song> *menu)
|
|||||||
size_t i = static_cast<Menu<std::string> *>(data)->Choice();
|
size_t i = static_cast<Menu<std::string> *>(data)->Choice();
|
||||||
if (i < 11)
|
if (i < 11)
|
||||||
{
|
{
|
||||||
ShowTag(*menu, s.GetTags(Info::Tags[i].Get));
|
ShowTag(*menu, s.GetTags(SongInfo::Tags[i].Get));
|
||||||
}
|
}
|
||||||
else if (i == 12)
|
else if (i == 12)
|
||||||
{
|
{
|
||||||
|
|||||||
84
src/info.cpp
84
src/info.cpp
@@ -55,22 +55,6 @@ pthread_t *Info::Downloader = 0;
|
|||||||
|
|
||||||
Info *myInfo = new Info;
|
Info *myInfo = new Info;
|
||||||
|
|
||||||
const Info::Metadata Info::Tags[] =
|
|
||||||
{
|
|
||||||
{ "Title", &MPD::Song::GetTitle, &MPD::Song::SetTitle },
|
|
||||||
{ "Artist", &MPD::Song::GetArtist, &MPD::Song::SetArtist },
|
|
||||||
{ "Album Artist", &MPD::Song::GetAlbumArtist, &MPD::Song::SetAlbumArtist },
|
|
||||||
{ "Album", &MPD::Song::GetAlbum, &MPD::Song::SetAlbum },
|
|
||||||
{ "Year", &MPD::Song::GetDate, &MPD::Song::SetDate },
|
|
||||||
{ "Track", &MPD::Song::GetTrack, &MPD::Song::SetTrack },
|
|
||||||
{ "Genre", &MPD::Song::GetGenre, &MPD::Song::SetGenre },
|
|
||||||
{ "Composer", &MPD::Song::GetComposer, &MPD::Song::SetComposer },
|
|
||||||
{ "Performer", &MPD::Song::GetPerformer, &MPD::Song::SetPerformer },
|
|
||||||
{ "Disc", &MPD::Song::GetDisc, &MPD::Song::SetDisc },
|
|
||||||
{ "Comment", &MPD::Song::GetComment, &MPD::Song::SetComment },
|
|
||||||
{ 0, 0, 0 }
|
|
||||||
};
|
|
||||||
|
|
||||||
void Info::Init()
|
void Info::Init()
|
||||||
{
|
{
|
||||||
w = new Scrollpad(0, MainStartY, COLS, MainHeight, "", Config.main_color, brNone);
|
w = new Scrollpad(0, MainStartY, COLS, MainHeight, "", Config.main_color, brNone);
|
||||||
@@ -101,40 +85,6 @@ void Info::Update()
|
|||||||
Downloader = 0;
|
Downloader = 0;
|
||||||
ArtistReady = 0;
|
ArtistReady = 0;
|
||||||
}
|
}
|
||||||
#endif // HAVE_CURL_CURL_H
|
|
||||||
|
|
||||||
void Info::GetSong()
|
|
||||||
{
|
|
||||||
if (myScreen == this)
|
|
||||||
{
|
|
||||||
myOldScreen->SwitchTo();
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
if (!isInitialized)
|
|
||||||
Init();
|
|
||||||
|
|
||||||
MPD::Song *s = myScreen->CurrentSong();
|
|
||||||
|
|
||||||
if (!s)
|
|
||||||
return;
|
|
||||||
|
|
||||||
if (hasToBeResized)
|
|
||||||
Resize();
|
|
||||||
|
|
||||||
myOldScreen = myScreen;
|
|
||||||
myScreen = this;
|
|
||||||
Global::RedrawHeader = 1;
|
|
||||||
itsTitle = "Song info";
|
|
||||||
w->Clear();
|
|
||||||
w->Reset();
|
|
||||||
PrepareSong(*s);
|
|
||||||
w->Window::Clear();
|
|
||||||
w->Flush();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
#ifdef HAVE_CURL_CURL_H
|
|
||||||
|
|
||||||
void Info::GetArtist()
|
void Info::GetArtist()
|
||||||
{
|
{
|
||||||
@@ -339,37 +289,3 @@ void *Info::PrepareArtist(void *screen_void_ptr)
|
|||||||
}
|
}
|
||||||
#endif // HVAE_CURL_CURL_H
|
#endif // HVAE_CURL_CURL_H
|
||||||
|
|
||||||
void Info::PrepareSong(MPD::Song &s)
|
|
||||||
{
|
|
||||||
# ifdef HAVE_TAGLIB_H
|
|
||||||
std::string path_to_file;
|
|
||||||
if (s.isFromDB())
|
|
||||||
path_to_file += Config.mpd_music_dir;
|
|
||||||
path_to_file += s.GetFile();
|
|
||||||
TagLib::FileRef f(path_to_file.c_str());
|
|
||||||
if (!f.isNull())
|
|
||||||
s.SetComment(f.tag()->comment().to8Bit(1));
|
|
||||||
# endif // HAVE_TAGLIB_H
|
|
||||||
|
|
||||||
*w << fmtBold << Config.color1 << "Filename: " << fmtBoldEnd << Config.color2 << s.GetName() << "\n" << clEnd;
|
|
||||||
*w << fmtBold << "Directory: " << fmtBoldEnd << Config.color2;
|
|
||||||
ShowTag(*w, s.GetDirectory());
|
|
||||||
*w << "\n\n" << clEnd;
|
|
||||||
*w << fmtBold << "Length: " << fmtBoldEnd << Config.color2 << s.GetLength() << "\n" << clEnd;
|
|
||||||
# ifdef HAVE_TAGLIB_H
|
|
||||||
if (!f.isNull())
|
|
||||||
{
|
|
||||||
*w << fmtBold << "Bitrate: " << fmtBoldEnd << Config.color2 << f.audioProperties()->bitrate() << " kbps\n" << clEnd;
|
|
||||||
*w << fmtBold << "Sample rate: " << fmtBoldEnd << Config.color2 << f.audioProperties()->sampleRate() << " Hz\n" << clEnd;
|
|
||||||
*w << fmtBold << "Channels: " << fmtBoldEnd << Config.color2 << (f.audioProperties()->channels() == 1 ? "Mono" : "Stereo") << "\n" << clDefault;
|
|
||||||
}
|
|
||||||
# endif // HAVE_TAGLIB_H
|
|
||||||
*w << clDefault;
|
|
||||||
|
|
||||||
for (const Metadata *m = Tags; m->Name; ++m)
|
|
||||||
{
|
|
||||||
*w << fmtBold << "\n" << m->Name << ": " << fmtBoldEnd;
|
|
||||||
ShowTag(*w, s.GetTags(m->Get));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|||||||
12
src/info.h
12
src/info.h
@@ -28,13 +28,6 @@
|
|||||||
class Info : public Screen<Scrollpad>
|
class Info : public Screen<Scrollpad>
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
struct Metadata
|
|
||||||
{
|
|
||||||
const char *Name;
|
|
||||||
MPD::Song::GetFunction Get;
|
|
||||||
MPD::Song::SetFunction Set;
|
|
||||||
};
|
|
||||||
|
|
||||||
virtual void SwitchTo() { }
|
virtual void SwitchTo() { }
|
||||||
virtual void Resize();
|
virtual void Resize();
|
||||||
|
|
||||||
@@ -51,13 +44,10 @@ class Info : public Screen<Scrollpad>
|
|||||||
|
|
||||||
virtual List *GetList() { return 0; }
|
virtual List *GetList() { return 0; }
|
||||||
|
|
||||||
void GetSong();
|
|
||||||
# ifdef HAVE_CURL_CURL_H
|
# ifdef HAVE_CURL_CURL_H
|
||||||
void GetArtist();
|
void GetArtist();
|
||||||
# endif // HAVE_CURL_CURL_H
|
# endif // HAVE_CURL_CURL_H
|
||||||
|
|
||||||
static const Metadata Tags[];
|
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
virtual void Init();
|
virtual void Init();
|
||||||
|
|
||||||
@@ -66,8 +56,6 @@ class Info : public Screen<Scrollpad>
|
|||||||
std::string itsTitle;
|
std::string itsTitle;
|
||||||
std::string itsFilenamePath;
|
std::string itsFilenamePath;
|
||||||
|
|
||||||
void PrepareSong(MPD::Song &);
|
|
||||||
|
|
||||||
# ifdef HAVE_CURL_CURL_H
|
# ifdef HAVE_CURL_CURL_H
|
||||||
static void *PrepareArtist(void *);
|
static void *PrepareArtist(void *);
|
||||||
|
|
||||||
|
|||||||
@@ -47,6 +47,7 @@
|
|||||||
#include "search_engine.h"
|
#include "search_engine.h"
|
||||||
#include "settings.h"
|
#include "settings.h"
|
||||||
#include "song.h"
|
#include "song.h"
|
||||||
|
#include "song_info.h"
|
||||||
#include "info.h"
|
#include "info.h"
|
||||||
#include "outputs.h"
|
#include "outputs.h"
|
||||||
#include "status.h"
|
#include "status.h"
|
||||||
@@ -2044,7 +2045,7 @@ int main(int argc, char *argv[])
|
|||||||
}
|
}
|
||||||
else if (Keypressed(input, Key.SongInfo))
|
else if (Keypressed(input, Key.SongInfo))
|
||||||
{
|
{
|
||||||
myInfo->GetSong();
|
mySongInfo->SwitchTo();
|
||||||
}
|
}
|
||||||
# ifdef HAVE_CURL_CURL_H
|
# ifdef HAVE_CURL_CURL_H
|
||||||
else if (Keypressed(input, Key.ArtistInfo))
|
else if (Keypressed(input, Key.ArtistInfo))
|
||||||
|
|||||||
126
src/song_info.cpp
Normal file
126
src/song_info.cpp
Normal file
@@ -0,0 +1,126 @@
|
|||||||
|
/***************************************************************************
|
||||||
|
* Copyright (C) 2008-2010 by Andrzej Rybczak *
|
||||||
|
* electricityispower@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; if not, write to the *
|
||||||
|
* Free Software Foundation, Inc., *
|
||||||
|
* 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA. *
|
||||||
|
***************************************************************************/
|
||||||
|
|
||||||
|
#include "global.h"
|
||||||
|
#include "song_info.h"
|
||||||
|
#include "tag_editor.h"
|
||||||
|
|
||||||
|
using Global::MainHeight;
|
||||||
|
using Global::MainStartY;
|
||||||
|
using Global::myScreen;
|
||||||
|
using Global::myOldScreen;
|
||||||
|
|
||||||
|
SongInfo *mySongInfo = new SongInfo;
|
||||||
|
|
||||||
|
const SongInfo::Metadata SongInfo::Tags[] =
|
||||||
|
{
|
||||||
|
{ "Title", &MPD::Song::GetTitle, &MPD::Song::SetTitle },
|
||||||
|
{ "Artist", &MPD::Song::GetArtist, &MPD::Song::SetArtist },
|
||||||
|
{ "Album Artist", &MPD::Song::GetAlbumArtist, &MPD::Song::SetAlbumArtist },
|
||||||
|
{ "Album", &MPD::Song::GetAlbum, &MPD::Song::SetAlbum },
|
||||||
|
{ "Year", &MPD::Song::GetDate, &MPD::Song::SetDate },
|
||||||
|
{ "Track", &MPD::Song::GetTrack, &MPD::Song::SetTrack },
|
||||||
|
{ "Genre", &MPD::Song::GetGenre, &MPD::Song::SetGenre },
|
||||||
|
{ "Composer", &MPD::Song::GetComposer, &MPD::Song::SetComposer },
|
||||||
|
{ "Performer", &MPD::Song::GetPerformer, &MPD::Song::SetPerformer },
|
||||||
|
{ "Disc", &MPD::Song::GetDisc, &MPD::Song::SetDisc },
|
||||||
|
{ "Comment", &MPD::Song::GetComment, &MPD::Song::SetComment },
|
||||||
|
{ 0, 0, 0 }
|
||||||
|
};
|
||||||
|
|
||||||
|
void SongInfo::Init()
|
||||||
|
{
|
||||||
|
w = new Scrollpad(0, MainStartY, COLS, MainHeight, "", Config.main_color, brNone);
|
||||||
|
isInitialized = 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
void SongInfo::Resize()
|
||||||
|
{
|
||||||
|
w->Resize(COLS, MainHeight);
|
||||||
|
w->MoveTo(0, MainStartY);
|
||||||
|
hasToBeResized = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
std::basic_string<my_char_t> SongInfo::Title()
|
||||||
|
{
|
||||||
|
return U("Song info");
|
||||||
|
}
|
||||||
|
|
||||||
|
void SongInfo::SwitchTo()
|
||||||
|
{
|
||||||
|
if (myScreen == this)
|
||||||
|
return myOldScreen->SwitchTo();
|
||||||
|
|
||||||
|
if (!isInitialized)
|
||||||
|
Init();
|
||||||
|
|
||||||
|
MPD::Song *s = myScreen->CurrentSong();
|
||||||
|
|
||||||
|
if (!s)
|
||||||
|
return;
|
||||||
|
|
||||||
|
if (hasToBeResized)
|
||||||
|
Resize();
|
||||||
|
|
||||||
|
myOldScreen = myScreen;
|
||||||
|
myScreen = this;
|
||||||
|
|
||||||
|
Global::RedrawHeader = 1;
|
||||||
|
|
||||||
|
w->Clear();
|
||||||
|
w->Reset();
|
||||||
|
PrepareSong(*s);
|
||||||
|
w->Flush();
|
||||||
|
}
|
||||||
|
|
||||||
|
void SongInfo::PrepareSong(MPD::Song &s)
|
||||||
|
{
|
||||||
|
# ifdef HAVE_TAGLIB_H
|
||||||
|
std::string path_to_file;
|
||||||
|
if (s.isFromDB())
|
||||||
|
path_to_file += Config.mpd_music_dir;
|
||||||
|
path_to_file += s.GetFile();
|
||||||
|
TagLib::FileRef f(path_to_file.c_str());
|
||||||
|
if (!f.isNull())
|
||||||
|
s.SetComment(f.tag()->comment().to8Bit(1));
|
||||||
|
# endif // HAVE_TAGLIB_H
|
||||||
|
|
||||||
|
*w << fmtBold << Config.color1 << "Filename: " << fmtBoldEnd << Config.color2 << s.GetName() << "\n" << clEnd;
|
||||||
|
*w << fmtBold << "Directory: " << fmtBoldEnd << Config.color2;
|
||||||
|
ShowTag(*w, s.GetDirectory());
|
||||||
|
*w << "\n\n" << clEnd;
|
||||||
|
*w << fmtBold << "Length: " << fmtBoldEnd << Config.color2 << s.GetLength() << "\n" << clEnd;
|
||||||
|
# ifdef HAVE_TAGLIB_H
|
||||||
|
if (!f.isNull())
|
||||||
|
{
|
||||||
|
*w << fmtBold << "Bitrate: " << fmtBoldEnd << Config.color2 << f.audioProperties()->bitrate() << " kbps\n" << clEnd;
|
||||||
|
*w << fmtBold << "Sample rate: " << fmtBoldEnd << Config.color2 << f.audioProperties()->sampleRate() << " Hz\n" << clEnd;
|
||||||
|
*w << fmtBold << "Channels: " << fmtBoldEnd << Config.color2 << (f.audioProperties()->channels() == 1 ? "Mono" : "Stereo") << "\n" << clDefault;
|
||||||
|
}
|
||||||
|
# endif // HAVE_TAGLIB_H
|
||||||
|
*w << clDefault;
|
||||||
|
|
||||||
|
for (const Metadata *m = Tags; m->Name; ++m)
|
||||||
|
{
|
||||||
|
*w << fmtBold << "\n" << m->Name << ": " << fmtBoldEnd;
|
||||||
|
ShowTag(*w, s.GetTags(m->Get));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
61
src/song_info.h
Normal file
61
src/song_info.h
Normal file
@@ -0,0 +1,61 @@
|
|||||||
|
/***************************************************************************
|
||||||
|
* Copyright (C) 2008-2010 by Andrzej Rybczak *
|
||||||
|
* electricityispower@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; if not, write to the *
|
||||||
|
* Free Software Foundation, Inc., *
|
||||||
|
* 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA. *
|
||||||
|
***************************************************************************/
|
||||||
|
|
||||||
|
#ifndef _SONG_INFO_H
|
||||||
|
#define _SONG_INFO_H
|
||||||
|
|
||||||
|
#include "screen.h"
|
||||||
|
#include "song.h"
|
||||||
|
|
||||||
|
class SongInfo : public Screen<Scrollpad>
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
struct Metadata
|
||||||
|
{
|
||||||
|
const char *Name;
|
||||||
|
MPD::Song::GetFunction Get;
|
||||||
|
MPD::Song::SetFunction Set;
|
||||||
|
};
|
||||||
|
|
||||||
|
virtual void SwitchTo();
|
||||||
|
virtual void Resize();
|
||||||
|
|
||||||
|
virtual std::basic_string<my_char_t> Title();
|
||||||
|
|
||||||
|
virtual void EnterPressed() { }
|
||||||
|
virtual void SpacePressed() { }
|
||||||
|
|
||||||
|
virtual bool allowsSelection() { return false; }
|
||||||
|
|
||||||
|
virtual List *GetList() { return 0; }
|
||||||
|
|
||||||
|
static const Metadata Tags[];
|
||||||
|
|
||||||
|
protected:
|
||||||
|
virtual void Init();
|
||||||
|
|
||||||
|
private:
|
||||||
|
void PrepareSong(MPD::Song &);
|
||||||
|
};
|
||||||
|
|
||||||
|
extern SongInfo *mySongInfo;
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
@@ -36,7 +36,7 @@
|
|||||||
#include "charset.h"
|
#include "charset.h"
|
||||||
#include "display.h"
|
#include "display.h"
|
||||||
#include "global.h"
|
#include "global.h"
|
||||||
#include "info.h"
|
#include "song_info.h"
|
||||||
#include "playlist.h"
|
#include "playlist.h"
|
||||||
|
|
||||||
using Global::MainHeight;
|
using Global::MainHeight;
|
||||||
@@ -86,7 +86,7 @@ void TagEditor::Init()
|
|||||||
TagTypes->CenteredCursor(Config.centered_cursor);
|
TagTypes->CenteredCursor(Config.centered_cursor);
|
||||||
TagTypes->SetItemDisplayer(Display::Generic);
|
TagTypes->SetItemDisplayer(Display::Generic);
|
||||||
|
|
||||||
for (const Info::Metadata *m = Info::Tags; m->Name; ++m)
|
for (const SongInfo::Metadata *m = SongInfo::Tags; m->Name; ++m)
|
||||||
TagTypes->AddOption(m->Name);
|
TagTypes->AddOption(m->Name);
|
||||||
TagTypes->AddSeparator();
|
TagTypes->AddSeparator();
|
||||||
TagTypes->AddOption("Filename");
|
TagTypes->AddOption("Filename");
|
||||||
@@ -550,8 +550,8 @@ void TagEditor::EnterPressed()
|
|||||||
|
|
||||||
if (id < 11)
|
if (id < 11)
|
||||||
{
|
{
|
||||||
MPD::Song::GetFunction get = Info::Tags[id].Get;
|
MPD::Song::GetFunction get = SongInfo::Tags[id].Get;
|
||||||
MPD::Song::SetFunction set = Info::Tags[id].Set;
|
MPD::Song::SetFunction set = SongInfo::Tags[id].Set;
|
||||||
if (id > 0 && w == TagTypes)
|
if (id > 0 && w == TagTypes)
|
||||||
{
|
{
|
||||||
LockStatusbar();
|
LockStatusbar();
|
||||||
@@ -1069,7 +1069,7 @@ std::string TagEditor::CapitalizeFirstLetters(const std::string &s)
|
|||||||
|
|
||||||
void TagEditor::CapitalizeFirstLetters(MPD::Song &s)
|
void TagEditor::CapitalizeFirstLetters(MPD::Song &s)
|
||||||
{
|
{
|
||||||
for (const Info::Metadata *m = Info::Tags; m->Name; ++m)
|
for (const SongInfo::Metadata *m = SongInfo::Tags; m->Name; ++m)
|
||||||
{
|
{
|
||||||
unsigned i = 0;
|
unsigned i = 0;
|
||||||
for (std::string tag; !(tag = (s.*m->Get)(i)).empty(); ++i)
|
for (std::string tag; !(tag = (s.*m->Get)(i)).empty(); ++i)
|
||||||
@@ -1079,7 +1079,7 @@ void TagEditor::CapitalizeFirstLetters(MPD::Song &s)
|
|||||||
|
|
||||||
void TagEditor::LowerAllLetters(MPD::Song &s)
|
void TagEditor::LowerAllLetters(MPD::Song &s)
|
||||||
{
|
{
|
||||||
for (const Info::Metadata *m = Info::Tags; m->Name; ++m)
|
for (const SongInfo::Metadata *m = SongInfo::Tags; m->Name; ++m)
|
||||||
{
|
{
|
||||||
unsigned i = 0;
|
unsigned i = 0;
|
||||||
for (std::string tag; !(tag = (s.*m->Get)(i)).empty(); ++i)
|
for (std::string tag; !(tag = (s.*m->Get)(i)).empty(); ++i)
|
||||||
@@ -1103,7 +1103,7 @@ std::string TagEditor::TagToString(const MPD::Song &s, void *data)
|
|||||||
std::string result;
|
std::string result;
|
||||||
size_t i = static_cast<Menu<std::string> *>(data)->Choice();
|
size_t i = static_cast<Menu<std::string> *>(data)->Choice();
|
||||||
if (i < 11)
|
if (i < 11)
|
||||||
result = (s.*Info::Tags[i].Get)(0);
|
result = (s.*SongInfo::Tags[i].Get)(0);
|
||||||
else if (i == 12)
|
else if (i == 12)
|
||||||
result = s.GetNewName().empty() ? s.GetName() : s.GetName() + " -> " + s.GetNewName();
|
result = s.GetNewName().empty() ? s.GetName() : s.GetName() + " -> " + s.GetNewName();
|
||||||
return result.empty() ? Config.empty_tag : result;
|
return result.empty() ? Config.empty_tag : result;
|
||||||
|
|||||||
@@ -31,7 +31,7 @@
|
|||||||
#include "charset.h"
|
#include "charset.h"
|
||||||
#include "display.h"
|
#include "display.h"
|
||||||
#include "global.h"
|
#include "global.h"
|
||||||
#include "info.h"
|
#include "song_info.h"
|
||||||
#include "playlist.h"
|
#include "playlist.h"
|
||||||
#include "search_engine.h"
|
#include "search_engine.h"
|
||||||
#include "tag_editor.h"
|
#include "tag_editor.h"
|
||||||
@@ -101,11 +101,11 @@ void TinyTagEditor::EnterPressed()
|
|||||||
if (option < 19) // separator after comment
|
if (option < 19) // separator after comment
|
||||||
{
|
{
|
||||||
size_t pos = option-8;
|
size_t pos = option-8;
|
||||||
Statusbar() << fmtBold << Info::Tags[pos].Name << ": " << fmtBoldEnd;
|
Statusbar() << fmtBold << SongInfo::Tags[pos].Name << ": " << fmtBoldEnd;
|
||||||
s.SetTags(Info::Tags[pos].Set, Global::wFooter->GetString(s.GetTags(Info::Tags[pos].Get)));
|
s.SetTags(SongInfo::Tags[pos].Set, Global::wFooter->GetString(s.GetTags(SongInfo::Tags[pos].Get)));
|
||||||
w->at(option).Clear();
|
w->at(option).Clear();
|
||||||
w->at(option) << fmtBold << Info::Tags[pos].Name << ':' << fmtBoldEnd << ' ';
|
w->at(option) << fmtBold << SongInfo::Tags[pos].Name << ':' << fmtBoldEnd << ' ';
|
||||||
ShowTag(w->at(option), s.GetTags(Info::Tags[pos].Get));
|
ShowTag(w->at(option), s.GetTags(SongInfo::Tags[pos].Get));
|
||||||
}
|
}
|
||||||
else if (option == 20)
|
else if (option == 20)
|
||||||
{
|
{
|
||||||
@@ -227,7 +227,7 @@ bool TinyTagEditor::GetTags()
|
|||||||
w->at(6) << fmtBold << Config.color1 << "Channels: " << fmtBoldEnd << Config.color2 << (f.audioProperties()->channels() == 1 ? "Mono" : "Stereo") << clDefault;
|
w->at(6) << fmtBold << Config.color1 << "Channels: " << fmtBoldEnd << Config.color2 << (f.audioProperties()->channels() == 1 ? "Mono" : "Stereo") << clDefault;
|
||||||
|
|
||||||
unsigned pos = 8;
|
unsigned pos = 8;
|
||||||
for (const Info::Metadata *m = Info::Tags; m->Name; ++m, ++pos)
|
for (const SongInfo::Metadata *m = SongInfo::Tags; m->Name; ++m, ++pos)
|
||||||
{
|
{
|
||||||
w->at(pos) << fmtBold << m->Name << ":" << fmtBoldEnd << ' ';
|
w->at(pos) << fmtBold << m->Name << ":" << fmtBoldEnd << ' ';
|
||||||
ShowTag(w->at(pos), s.GetTags(m->Get));
|
ShowTag(w->at(pos), s.GetTags(m->Get));
|
||||||
|
|||||||
Reference in New Issue
Block a user