menu: some member name changing
This commit is contained in:
@@ -1161,13 +1161,13 @@ void ToggleDisplayMode::Run()
|
|||||||
|
|
||||||
if (Config.columns_in_playlist)
|
if (Config.columns_in_playlist)
|
||||||
{
|
{
|
||||||
myPlaylist->Items->SetItemDisplayer(Display::SongsInColumns);
|
myPlaylist->Items->setItemDisplayer(Display::SongsInColumns);
|
||||||
myPlaylist->Items->SetTitle(Config.titles_visibility ? Display::Columns(myPlaylist->Items->GetWidth()) : "");
|
myPlaylist->Items->SetTitle(Config.titles_visibility ? Display::Columns(myPlaylist->Items->GetWidth()) : "");
|
||||||
myPlaylist->Items->SetGetStringFunction(Playlist::SongInColumnsToString);
|
myPlaylist->Items->SetGetStringFunction(Playlist::SongInColumnsToString);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
myPlaylist->Items->SetItemDisplayer(Display::Songs);
|
myPlaylist->Items->setItemDisplayer(Display::Songs);
|
||||||
myPlaylist->Items->SetTitle("");
|
myPlaylist->Items->SetTitle("");
|
||||||
myPlaylist->Items->SetGetStringFunction(Playlist::SongToString);
|
myPlaylist->Items->SetGetStringFunction(Playlist::SongToString);
|
||||||
}
|
}
|
||||||
@@ -1191,12 +1191,12 @@ void ToggleDisplayMode::Run()
|
|||||||
ShowMessage("Playlist editor display mode: %s", Config.columns_in_playlist_editor ? "Columns" : "Classic");
|
ShowMessage("Playlist editor display mode: %s", Config.columns_in_playlist_editor ? "Columns" : "Classic");
|
||||||
if (Config.columns_in_playlist_editor)
|
if (Config.columns_in_playlist_editor)
|
||||||
{
|
{
|
||||||
myPlaylistEditor->Content->SetItemDisplayer(Display::SongsInColumns);
|
myPlaylistEditor->Content->setItemDisplayer(Display::SongsInColumns);
|
||||||
myPlaylistEditor->Content->SetGetStringFunction(Playlist::SongInColumnsToString);
|
myPlaylistEditor->Content->SetGetStringFunction(Playlist::SongInColumnsToString);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
myPlaylistEditor->Content->SetItemDisplayer(Display::Songs);
|
myPlaylistEditor->Content->setItemDisplayer(Display::Songs);
|
||||||
myPlaylistEditor->Content->SetGetStringFunction(Playlist::SongToString);
|
myPlaylistEditor->Content->SetGetStringFunction(Playlist::SongToString);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -60,8 +60,8 @@ void Browser::Init()
|
|||||||
w->CenteredCursor(Config.centered_cursor);
|
w->CenteredCursor(Config.centered_cursor);
|
||||||
w->SetSelectPrefix(&Config.selected_item_prefix);
|
w->SetSelectPrefix(&Config.selected_item_prefix);
|
||||||
w->SetSelectSuffix(&Config.selected_item_suffix);
|
w->SetSelectSuffix(&Config.selected_item_suffix);
|
||||||
w->SetItemDisplayer(Display::Items);
|
w->setItemDisplayer(Display::Items);
|
||||||
w->SetItemDisplayerUserData(&sf);
|
w->setItemDisplayerData(&sf);
|
||||||
w->SetGetStringFunction(ItemToString);
|
w->SetGetStringFunction(ItemToString);
|
||||||
|
|
||||||
if (SupportedExtensions.empty())
|
if (SupportedExtensions.empty())
|
||||||
|
|||||||
@@ -38,12 +38,12 @@ namespace Display
|
|||||||
|
|
||||||
std::string Columns(size_t);
|
std::string Columns(size_t);
|
||||||
|
|
||||||
template <typename T> void Generic(const T &t, void *, Menu<T> *menu)
|
template <typename T> void Default(const T &t, void *, Menu<T> *menu)
|
||||||
{
|
{
|
||||||
*menu << t;
|
*menu << t;
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename A, typename B> void Pairs(const std::pair<A, B> &pair, void *, Menu< std::pair<A, B> > *menu)
|
template <typename A, typename B> void Pair(const std::pair<A, B> &pair, void *, Menu< std::pair<A, B> > *menu)
|
||||||
{
|
{
|
||||||
*menu << pair.first;
|
*menu << pair.first;
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -39,6 +39,11 @@
|
|||||||
#include "outputs.h"
|
#include "outputs.h"
|
||||||
#include "visualizer.h"
|
#include "visualizer.h"
|
||||||
|
|
||||||
|
std::string StringPairToString(const std::pair<std::string, std::string> &pair, void *)
|
||||||
|
{
|
||||||
|
return pair.first;
|
||||||
|
}
|
||||||
|
|
||||||
void ParseArgv(int argc, char **argv)
|
void ParseArgv(int argc, char **argv)
|
||||||
{
|
{
|
||||||
bool quit = 0;
|
bool quit = 0;
|
||||||
|
|||||||
@@ -28,10 +28,7 @@
|
|||||||
|
|
||||||
void ParseArgv(int, char **);
|
void ParseArgv(int, char **);
|
||||||
|
|
||||||
template <typename A, typename B> std::string StringPairToString(const std::pair<A, B> &pair, void *)
|
std::string StringPairToString(const std::pair<std::string, std::string> &pair, void *);
|
||||||
{
|
|
||||||
return pair.first;
|
|
||||||
}
|
|
||||||
|
|
||||||
template <typename T> struct StringConverter {
|
template <typename T> struct StringConverter {
|
||||||
const char *operator()(const char *s) { return s; }
|
const char *operator()(const char *s) { return s; }
|
||||||
|
|||||||
@@ -67,7 +67,7 @@ void MediaLibrary::Init()
|
|||||||
Artists->CenteredCursor(Config.centered_cursor);
|
Artists->CenteredCursor(Config.centered_cursor);
|
||||||
Artists->SetSelectPrefix(&Config.selected_item_prefix);
|
Artists->SetSelectPrefix(&Config.selected_item_prefix);
|
||||||
Artists->SetSelectSuffix(&Config.selected_item_suffix);
|
Artists->SetSelectSuffix(&Config.selected_item_suffix);
|
||||||
Artists->SetItemDisplayer(DisplayPrimaryTags);
|
Artists->setItemDisplayer(DisplayPrimaryTags);
|
||||||
|
|
||||||
Albums = new Menu<SearchConstraints>(itsMiddleColStartX, MainStartY, itsMiddleColWidth, MainHeight, Config.titles_visibility ? "Albums" : "", Config.main_color, brNone);
|
Albums = new Menu<SearchConstraints>(itsMiddleColStartX, MainStartY, itsMiddleColWidth, MainHeight, Config.titles_visibility ? "Albums" : "", Config.main_color, brNone);
|
||||||
Albums->HighlightColor(Config.main_highlight_color);
|
Albums->HighlightColor(Config.main_highlight_color);
|
||||||
@@ -75,7 +75,7 @@ void MediaLibrary::Init()
|
|||||||
Albums->CenteredCursor(Config.centered_cursor);
|
Albums->CenteredCursor(Config.centered_cursor);
|
||||||
Albums->SetSelectPrefix(&Config.selected_item_prefix);
|
Albums->SetSelectPrefix(&Config.selected_item_prefix);
|
||||||
Albums->SetSelectSuffix(&Config.selected_item_suffix);
|
Albums->SetSelectSuffix(&Config.selected_item_suffix);
|
||||||
Albums->SetItemDisplayer(DisplayAlbums);
|
Albums->setItemDisplayer(DisplayAlbums);
|
||||||
Albums->SetGetStringFunction(AlbumToString);
|
Albums->SetGetStringFunction(AlbumToString);
|
||||||
Albums->SetGetStringFunctionUserData(this);
|
Albums->SetGetStringFunctionUserData(this);
|
||||||
|
|
||||||
@@ -87,8 +87,8 @@ void MediaLibrary::Init()
|
|||||||
Songs->CenteredCursor(Config.centered_cursor);
|
Songs->CenteredCursor(Config.centered_cursor);
|
||||||
Songs->SetSelectPrefix(&Config.selected_item_prefix);
|
Songs->SetSelectPrefix(&Config.selected_item_prefix);
|
||||||
Songs->SetSelectSuffix(&Config.selected_item_suffix);
|
Songs->SetSelectSuffix(&Config.selected_item_suffix);
|
||||||
Songs->SetItemDisplayer(Display::Songs);
|
Songs->setItemDisplayer(Display::Songs);
|
||||||
Songs->SetItemDisplayerUserData(&sf);
|
Songs->setItemDisplayerData(&sf);
|
||||||
Songs->SetGetStringFunction(SongToString);
|
Songs->SetGetStringFunction(SongToString);
|
||||||
|
|
||||||
w = Artists;
|
w = Artists;
|
||||||
|
|||||||
@@ -24,14 +24,13 @@ using namespace NCurses;
|
|||||||
|
|
||||||
template <> std::string Menu<std::string>::GetOption(size_t pos)
|
template <> std::string Menu<std::string>::GetOption(size_t pos)
|
||||||
{
|
{
|
||||||
if (itsOptionsPtr->at(pos))
|
if (m_options_ptr->at(pos))
|
||||||
{
|
{
|
||||||
if (itsGetStringFunction)
|
if (m_get_string_helper)
|
||||||
return itsGetStringFunction((*itsOptionsPtr)[pos]->Item, itsGetStringFunctionUserData);
|
return m_get_string_helper((*m_options_ptr)[pos]->Item, m_get_string_helper_data);
|
||||||
else
|
else
|
||||||
return (*itsOptionsPtr)[pos]->Item;
|
return (*m_options_ptr)[pos]->Item;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
return "";
|
return "";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
422
src/menu.h
422
src/menu.h
@@ -104,17 +104,17 @@ namespace NCurses
|
|||||||
template <typename T> class Menu : public Window, public List
|
template <typename T> class Menu : public Window, public List
|
||||||
{
|
{
|
||||||
/// Function helper prototype used to display each option on the screen.
|
/// Function helper prototype used to display each option on the screen.
|
||||||
/// If not set by SetItemDisplayer(), menu won't display anything.
|
/// If not set by setItemDisplayer(), menu won't display anything.
|
||||||
/// @see SetItemDisplayer()
|
/// @see setItemDisplayer()
|
||||||
///
|
///
|
||||||
typedef void (*ItemDisplayer)(const T &, void *, Menu<T> *);
|
typedef std::function<void(const T &, void *, Menu<T> *)> ItemDisplayer;
|
||||||
|
|
||||||
/// Function helper prototype used for converting items to strings.
|
/// Function helper prototype used for converting items to strings.
|
||||||
/// If not set by SetGetStringFunction(), searching and filtering
|
/// If not set by SetGetStringFunction(), searching and filtering
|
||||||
/// won't work (note that Menu<std::string> doesn't need this)
|
/// won't work (note that Menu<std::string> doesn't need this)
|
||||||
/// @see SetGetStringFunction()
|
/// @see SetGetStringFunction()
|
||||||
///
|
///
|
||||||
typedef std::string (*GetStringFunction)(const T &, void *);
|
typedef std::function<std::string(const T &, void *)> GetStringFunction;
|
||||||
|
|
||||||
/// Struct that holds each item in the list and its attributes
|
/// Struct that holds each item in the list and its attributes
|
||||||
///
|
///
|
||||||
@@ -173,24 +173,24 @@ namespace NCurses
|
|||||||
/// Sets helper function that is responsible for displaying items
|
/// Sets helper function that is responsible for displaying items
|
||||||
/// @param ptr function pointer that matches the ItemDisplayer prototype
|
/// @param ptr function pointer that matches the ItemDisplayer prototype
|
||||||
///
|
///
|
||||||
void SetItemDisplayer(ItemDisplayer ptr) { itsItemDisplayer = ptr; }
|
void setItemDisplayer(ItemDisplayer ptr) { m_item_displayer = ptr; }
|
||||||
|
|
||||||
/// Sets optional user data, that is passed to
|
/// Sets optional user data, that is passed to
|
||||||
/// ItemDisplayer function each time it's invoked
|
/// ItemDisplayer function each time it's invoked
|
||||||
/// @param data void pointer to userdata
|
/// @param data void pointer to userdata
|
||||||
///
|
///
|
||||||
void SetItemDisplayerUserData(void *data) { itsItemDisplayerUserdata = data; }
|
void setItemDisplayerData(void *data) { m_item_displayer_data = data; }
|
||||||
|
|
||||||
/// Sets helper function that is responsible for converting items to strings
|
/// Sets helper function that is responsible for converting items to strings
|
||||||
/// @param f function pointer that matches the GetStringFunction prototype
|
/// @param f function pointer that matches the GetStringFunction prototype
|
||||||
///
|
///
|
||||||
void SetGetStringFunction(GetStringFunction f) { itsGetStringFunction = f; }
|
void SetGetStringFunction(GetStringFunction f) { m_get_string_helper = f; }
|
||||||
|
|
||||||
/// Sets optional user data, that is passed to
|
/// Sets optional user data, that is passed to
|
||||||
/// GetStringFunction function each time it's invoked
|
/// GetStringFunction function each time it's invoked
|
||||||
/// @param data void pointer to user data
|
/// @param data void pointer to user data
|
||||||
///
|
///
|
||||||
void SetGetStringFunctionUserData(void *data) { itsGetStringFunctionUserData = data; }
|
void SetGetStringFunctionUserData(void *data) { m_get_string_helper_data = data; }
|
||||||
|
|
||||||
/// Reserves the size for internal container (this just calls std::vector::reserve())
|
/// Reserves the size for internal container (this just calls std::vector::reserve())
|
||||||
/// @param size requested size
|
/// @param size requested size
|
||||||
@@ -337,7 +337,7 @@ namespace NCurses
|
|||||||
|
|
||||||
/// @return const reference to currently used search constraint
|
/// @return const reference to currently used search constraint
|
||||||
///
|
///
|
||||||
virtual const std::string &GetSearchConstraint() { return itsSearchConstraint; }
|
virtual const std::string &GetSearchConstraint() { return m_search_constraint; }
|
||||||
|
|
||||||
/// Moves current position in the list to the next found one
|
/// Moves current position in the list to the next found one
|
||||||
/// @param wrap if true, this function will go to the first
|
/// @param wrap if true, this function will go to the first
|
||||||
@@ -366,21 +366,21 @@ namespace NCurses
|
|||||||
|
|
||||||
/// @return true if list is currently filtered, false otherwise
|
/// @return true if list is currently filtered, false otherwise
|
||||||
///
|
///
|
||||||
virtual bool isFiltered() { return itsOptionsPtr == &itsFilteredOptions; }
|
virtual bool isFiltered() { return m_options_ptr == &m_filtered_options; }
|
||||||
|
|
||||||
/// Turns off filtering
|
/// Turns off filtering
|
||||||
///
|
///
|
||||||
void ShowAll() { itsOptionsPtr = &itsOptions; }
|
void ShowAll() { m_options_ptr = &m_options; }
|
||||||
|
|
||||||
/// Turns on filtering
|
/// Turns on filtering
|
||||||
///
|
///
|
||||||
void ShowFiltered() { itsOptionsPtr = &itsFilteredOptions; }
|
void ShowFiltered() { m_options_ptr = &m_filtered_options; }
|
||||||
|
|
||||||
/// Converts given position in list to string using GetStringFunction
|
/// Converts given position in list to string using GetStringFunction
|
||||||
/// if specified and an empty string otherwise
|
/// if specified and an empty string otherwise
|
||||||
/// @param pos position to be converted
|
/// @param pos position to be converted
|
||||||
/// @return item converted to string
|
/// @return item converted to string
|
||||||
/// @see SetItemDisplayer()
|
/// @see setItemDisplayer()
|
||||||
///
|
///
|
||||||
std::string GetOption(size_t pos);
|
std::string GetOption(size_t pos);
|
||||||
|
|
||||||
@@ -409,61 +409,61 @@ namespace NCurses
|
|||||||
///
|
///
|
||||||
template <typename Comparison> void Sort(size_t beginning = 0, size_t end = -1)
|
template <typename Comparison> void Sort(size_t beginning = 0, size_t end = -1)
|
||||||
{
|
{
|
||||||
if (itsOptions.empty())
|
if (m_options.empty())
|
||||||
return;
|
return;
|
||||||
sort(itsOptions.begin()+beginning, end == size_t(-1) ? itsOptions.end() : itsOptions.begin()+end, InternalSorting<Comparison>());
|
sort(m_options.begin()+beginning, end == size_t(-1) ? m_options.end() : m_options.begin()+end, InternalSorting<Comparison>());
|
||||||
if (isFiltered())
|
if (isFiltered())
|
||||||
ApplyFilter(itsFilter);
|
ApplyFilter(m_filter);
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Sets prefix, that is put before each selected item to indicate its selection
|
/// Sets prefix, that is put before each selected item to indicate its selection
|
||||||
/// Note that the passed variable is not deleted along with menu object.
|
/// Note that the passed variable is not deleted along with menu object.
|
||||||
/// @param b pointer to buffer that contains the prefix
|
/// @param b pointer to buffer that contains the prefix
|
||||||
///
|
///
|
||||||
void SetSelectPrefix(Buffer *b) { itsSelectedPrefix = b; }
|
void SetSelectPrefix(Buffer *b) { m_selected_prefix = b; }
|
||||||
|
|
||||||
/// Sets suffix, that is put after each selected item to indicate its selection
|
/// Sets suffix, that is put after each selected item to indicate its selection
|
||||||
/// Note that the passed variable is not deleted along with menu object.
|
/// Note that the passed variable is not deleted along with menu object.
|
||||||
/// @param b pointer to buffer that contains the suffix
|
/// @param b pointer to buffer that contains the suffix
|
||||||
///
|
///
|
||||||
void SetSelectSuffix(Buffer *b) { itsSelectedSuffix = b; }
|
void SetSelectSuffix(Buffer *b) { m_selected_suffix = b; }
|
||||||
|
|
||||||
/// Sets custom color of highlighted position
|
/// Sets custom color of highlighted position
|
||||||
/// @param col custom color
|
/// @param col custom color
|
||||||
///
|
///
|
||||||
void HighlightColor(Color color) { itsHighlightColor = color; }
|
void HighlightColor(Color color) { m_highlight_color = color; }
|
||||||
|
|
||||||
/// @return state of highlighting
|
/// @return state of highlighting
|
||||||
///
|
///
|
||||||
bool isHighlighted() { return highlightEnabled; }
|
bool isHighlighted() { return m_highlight_enabled; }
|
||||||
|
|
||||||
/// Turns on/off highlighting
|
/// Turns on/off highlighting
|
||||||
/// @param state state of hihglighting
|
/// @param state state of hihglighting
|
||||||
///
|
///
|
||||||
void Highlighting(bool state) { highlightEnabled = state; }
|
void Highlighting(bool state) { m_highlight_enabled = state; }
|
||||||
|
|
||||||
/// Turns on/off cyclic scrolling
|
/// Turns on/off cyclic scrolling
|
||||||
/// @param state state of cyclic scrolling
|
/// @param state state of cyclic scrolling
|
||||||
///
|
///
|
||||||
void CyclicScrolling(bool state) { useCyclicScrolling = state; }
|
void CyclicScrolling(bool state) { m_cyclic_scroll_enabled = state; }
|
||||||
|
|
||||||
/// Turns on/off centered cursor
|
/// Turns on/off centered cursor
|
||||||
/// @param state state of centered cursor
|
/// @param state state of centered cursor
|
||||||
///
|
///
|
||||||
void CenteredCursor(bool state) { useCenteredCursor = state; }
|
void CenteredCursor(bool state) { m_autocenter_cursor = state; }
|
||||||
|
|
||||||
/// Checks if list is empty
|
/// Checks if list is empty
|
||||||
/// @return true if list is empty, false otherwise
|
/// @return true if list is empty, false otherwise
|
||||||
/// @see ReallyEmpty()
|
/// @see ReallyEmpty()
|
||||||
///
|
///
|
||||||
virtual bool Empty() const { return itsOptionsPtr->empty(); }
|
virtual bool Empty() const { return m_options_ptr->empty(); }
|
||||||
|
|
||||||
/// Checks if list is really empty since Empty() may not
|
/// Checks if list is really empty since Empty() may not
|
||||||
/// be accurate if filter is set)
|
/// be accurate if filter is set)
|
||||||
/// @return true if list is empty, false otherwise
|
/// @return true if list is empty, false otherwise
|
||||||
/// @see Empty()
|
/// @see Empty()
|
||||||
///
|
///
|
||||||
virtual bool ReallyEmpty() const { return itsOptions.empty(); }
|
virtual bool ReallyEmpty() const { return m_options.empty(); }
|
||||||
|
|
||||||
/// @return size of the list
|
/// @return size of the list
|
||||||
///
|
///
|
||||||
@@ -473,7 +473,7 @@ namespace NCurses
|
|||||||
/// defined only within drawing function that is called by Refresh()
|
/// defined only within drawing function that is called by Refresh()
|
||||||
/// @see Refresh()
|
/// @see Refresh()
|
||||||
///
|
///
|
||||||
size_t CurrentlyDrawedPosition() const { return itsCurrentlyDrawedPosition; }
|
size_t CurrentlyDrawedPosition() const { return m_currently_drawn_positions; }
|
||||||
|
|
||||||
/// @return reference to last item on the list
|
/// @return reference to last item on the list
|
||||||
/// @throw List::InvalidItem if requested item is separator
|
/// @throw List::InvalidItem if requested item is separator
|
||||||
@@ -526,33 +526,33 @@ namespace NCurses
|
|||||||
///
|
///
|
||||||
void ClearFiltered();
|
void ClearFiltered();
|
||||||
|
|
||||||
ItemDisplayer itsItemDisplayer;
|
ItemDisplayer m_item_displayer;
|
||||||
void *itsItemDisplayerUserdata;
|
void *m_item_displayer_data;
|
||||||
GetStringFunction itsGetStringFunction;
|
GetStringFunction m_get_string_helper;
|
||||||
void *itsGetStringFunctionUserData;
|
void *m_get_string_helper_data;
|
||||||
|
|
||||||
std::string itsFilter;
|
std::string m_filter;
|
||||||
std::string itsSearchConstraint;
|
std::string m_search_constraint;
|
||||||
|
|
||||||
std::vector<Option *> *itsOptionsPtr;
|
std::vector<Option *> *m_options_ptr;
|
||||||
std::vector<Option *> itsOptions;
|
std::vector<Option *> m_options;
|
||||||
std::vector<Option *> itsFilteredOptions;
|
std::vector<Option *> m_filtered_options;
|
||||||
std::vector<size_t> itsFilteredRealPositions;
|
std::vector<size_t> m_filtered_positions;
|
||||||
std::set<size_t> itsFound;
|
std::set<size_t> m_found_positions;
|
||||||
|
|
||||||
int itsBeginning;
|
int itsBeginning;
|
||||||
int itsHighlight;
|
int itsHighlight;
|
||||||
|
|
||||||
Color itsHighlightColor;
|
Color m_highlight_color;
|
||||||
bool highlightEnabled;
|
bool m_highlight_enabled;
|
||||||
bool useCyclicScrolling;
|
bool m_cyclic_scroll_enabled;
|
||||||
|
|
||||||
bool useCenteredCursor;
|
bool m_autocenter_cursor;
|
||||||
|
|
||||||
size_t itsCurrentlyDrawedPosition;
|
size_t m_currently_drawn_positions;
|
||||||
|
|
||||||
Buffer *itsSelectedPrefix;
|
Buffer *m_selected_prefix;
|
||||||
Buffer *itsSelectedSuffix;
|
Buffer *m_selected_suffix;
|
||||||
};
|
};
|
||||||
|
|
||||||
/// Specialization of Menu<T>::GetOption for T = std::string, it's obvious
|
/// Specialization of Menu<T>::GetOption for T = std::string, it's obvious
|
||||||
@@ -569,129 +569,129 @@ template <typename T> NCurses::Menu<T>::Menu(size_t startx,
|
|||||||
Color color,
|
Color color,
|
||||||
Border border)
|
Border border)
|
||||||
: Window(startx, starty, width, height, title, color, border),
|
: Window(startx, starty, width, height, title, color, border),
|
||||||
itsItemDisplayer(0),
|
m_item_displayer(0),
|
||||||
itsItemDisplayerUserdata(0),
|
m_item_displayer_data(0),
|
||||||
itsGetStringFunction(0),
|
m_get_string_helper(0),
|
||||||
itsGetStringFunctionUserData(0),
|
m_get_string_helper_data(0),
|
||||||
itsOptionsPtr(&itsOptions),
|
m_options_ptr(&m_options),
|
||||||
itsBeginning(0),
|
itsBeginning(0),
|
||||||
itsHighlight(0),
|
itsHighlight(0),
|
||||||
itsHighlightColor(itsBaseColor),
|
m_highlight_color(itsBaseColor),
|
||||||
highlightEnabled(1),
|
m_highlight_enabled(1),
|
||||||
useCyclicScrolling(0),
|
m_cyclic_scroll_enabled(0),
|
||||||
useCenteredCursor(0),
|
m_autocenter_cursor(0),
|
||||||
itsSelectedPrefix(0),
|
m_selected_prefix(0),
|
||||||
itsSelectedSuffix(0)
|
m_selected_suffix(0)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename T> NCurses::Menu<T>::Menu(const Menu &m) : Window(m),
|
template <typename T> NCurses::Menu<T>::Menu(const Menu &m) : Window(m),
|
||||||
itsItemDisplayer(m.itsItemDisplayer),
|
m_item_displayer(m.m_item_displayer),
|
||||||
itsItemDisplayerUserdata(m.itsItemDisplayerUserdata),
|
m_item_displayer_data(m.m_item_displayer_data),
|
||||||
itsGetStringFunction(m.itsGetStringFunction),
|
m_get_string_helper(m.m_get_string_helper),
|
||||||
itsGetStringFunctionUserData(m.itsGetStringFunctionUserData),
|
m_get_string_helper_data(m.m_get_string_helper_data),
|
||||||
itsOptionsPtr(m.itsOptionsPtr),
|
m_options_ptr(m.m_options_ptr),
|
||||||
itsBeginning(m.itsBeginning),
|
itsBeginning(m.itsBeginning),
|
||||||
itsHighlight(m.itsHighlight),
|
itsHighlight(m.itsHighlight),
|
||||||
itsHighlightColor(m.itsHighlightColor),
|
m_highlight_color(m.m_highlight_color),
|
||||||
highlightEnabled(m.highlightEnabled),
|
m_highlight_enabled(m.m_highlight_enabled),
|
||||||
useCyclicScrolling(m.useCyclicScrolling),
|
m_cyclic_scroll_enabled(m.m_cyclic_scroll_enabled),
|
||||||
useCenteredCursor(m.useCenteredCursor),
|
m_autocenter_cursor(m.m_autocenter_cursor),
|
||||||
itsSelectedPrefix(m.itsSelectedPrefix),
|
m_selected_prefix(m.m_selected_prefix),
|
||||||
itsSelectedSuffix(m.itsSelectedSuffix)
|
m_selected_suffix(m.m_selected_suffix)
|
||||||
{
|
{
|
||||||
itsOptions.reserve(m.itsOptions.size());
|
m_options.reserve(m.m_options.size());
|
||||||
for (option_const_iterator it = m.itsOptions.begin(); it != m.itsOptions.end(); ++it)
|
for (option_const_iterator it = m.m_options.begin(); it != m.m_options.end(); ++it)
|
||||||
itsOptions.push_back(new Option(**it));
|
m_options.push_back(new Option(**it));
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename T> NCurses::Menu<T>::~Menu()
|
template <typename T> NCurses::Menu<T>::~Menu()
|
||||||
{
|
{
|
||||||
for (option_iterator it = itsOptions.begin(); it != itsOptions.end(); ++it)
|
for (option_iterator it = m_options.begin(); it != m_options.end(); ++it)
|
||||||
delete *it;
|
delete *it;
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename T> void NCurses::Menu<T>::Reserve(size_t size)
|
template <typename T> void NCurses::Menu<T>::Reserve(size_t size)
|
||||||
{
|
{
|
||||||
itsOptions.reserve(size);
|
m_options.reserve(size);
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename T> void NCurses::Menu<T>::ResizeList(size_t size)
|
template <typename T> void NCurses::Menu<T>::ResizeList(size_t size)
|
||||||
{
|
{
|
||||||
if (size > itsOptions.size())
|
if (size > m_options.size())
|
||||||
{
|
{
|
||||||
itsOptions.resize(size);
|
m_options.resize(size);
|
||||||
for (size_t i = 0; i < size; ++i)
|
for (size_t i = 0; i < size; ++i)
|
||||||
if (!itsOptions[i])
|
if (!m_options[i])
|
||||||
itsOptions[i] = new Option();
|
m_options[i] = new Option();
|
||||||
}
|
}
|
||||||
else if (size < itsOptions.size())
|
else if (size < m_options.size())
|
||||||
{
|
{
|
||||||
for (size_t i = size; i < itsOptions.size(); ++i)
|
for (size_t i = size; i < m_options.size(); ++i)
|
||||||
delete itsOptions[i];
|
delete m_options[i];
|
||||||
itsOptions.resize(size);
|
m_options.resize(size);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename T> void NCurses::Menu<T>::AddOption(const T &item, bool is_bold, bool is_static)
|
template <typename T> void NCurses::Menu<T>::AddOption(const T &item, bool is_bold, bool is_static)
|
||||||
{
|
{
|
||||||
itsOptions.push_back(new Option(item, is_bold, is_static));
|
m_options.push_back(new Option(item, is_bold, is_static));
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename T> void NCurses::Menu<T>::AddSeparator()
|
template <typename T> void NCurses::Menu<T>::AddSeparator()
|
||||||
{
|
{
|
||||||
itsOptions.push_back(static_cast<Option *>(0));
|
m_options.push_back(static_cast<Option *>(0));
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename T> void NCurses::Menu<T>::InsertOption(size_t pos, const T &item, bool is_bold, bool is_static)
|
template <typename T> void NCurses::Menu<T>::InsertOption(size_t pos, const T &item, bool is_bold, bool is_static)
|
||||||
{
|
{
|
||||||
itsOptions.insert(itsOptions.begin()+pos, new Option(item, is_bold, is_static));
|
m_options.insert(m_options.begin()+pos, new Option(item, is_bold, is_static));
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename T> void NCurses::Menu<T>::InsertSeparator(size_t pos)
|
template <typename T> void NCurses::Menu<T>::InsertSeparator(size_t pos)
|
||||||
{
|
{
|
||||||
itsOptions.insert(itsOptions.begin()+pos, 0);
|
m_options.insert(m_options.begin()+pos, 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename T> void NCurses::Menu<T>::DeleteOption(size_t pos)
|
template <typename T> void NCurses::Menu<T>::DeleteOption(size_t pos)
|
||||||
{
|
{
|
||||||
if (itsOptionsPtr->empty())
|
if (m_options_ptr->empty())
|
||||||
return;
|
return;
|
||||||
if (itsOptionsPtr == &itsFilteredOptions)
|
if (m_options_ptr == &m_filtered_options)
|
||||||
{
|
{
|
||||||
delete itsOptions.at(itsFilteredRealPositions[pos]);
|
delete m_options.at(m_filtered_positions[pos]);
|
||||||
itsOptions.erase(itsOptions.begin()+itsFilteredRealPositions[pos]);
|
m_options.erase(m_options.begin()+m_filtered_positions[pos]);
|
||||||
itsFilteredOptions.erase(itsFilteredOptions.begin()+pos);
|
m_filtered_options.erase(m_filtered_options.begin()+pos);
|
||||||
itsFilteredRealPositions.erase(itsFilteredRealPositions.begin()+pos);
|
m_filtered_positions.erase(m_filtered_positions.begin()+pos);
|
||||||
for (size_t i = pos; i < itsFilteredRealPositions.size(); ++i)
|
for (size_t i = pos; i < m_filtered_positions.size(); ++i)
|
||||||
itsFilteredRealPositions[i]--;
|
m_filtered_positions[i]--;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
delete itsOptions.at(pos);
|
delete m_options.at(pos);
|
||||||
itsOptions.erase(itsOptions.begin()+pos);
|
m_options.erase(m_options.begin()+pos);
|
||||||
}
|
}
|
||||||
itsFound.clear();
|
m_found_positions.clear();
|
||||||
if (itsOptionsPtr->empty())
|
if (m_options_ptr->empty())
|
||||||
Window::Clear();
|
Window::Clear();
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename T> void NCurses::Menu<T>::IntoSeparator(size_t pos)
|
template <typename T> void NCurses::Menu<T>::IntoSeparator(size_t pos)
|
||||||
{
|
{
|
||||||
delete itsOptionsPtr->at(pos);
|
delete m_options_ptr->at(pos);
|
||||||
(*itsOptionsPtr)[pos] = 0;
|
(*m_options_ptr)[pos] = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename T> void NCurses::Menu<T>::Bold(int pos, bool state)
|
template <typename T> void NCurses::Menu<T>::Bold(int pos, bool state)
|
||||||
{
|
{
|
||||||
if (!itsOptionsPtr->at(pos))
|
if (!m_options_ptr->at(pos))
|
||||||
return;
|
return;
|
||||||
(*itsOptionsPtr)[pos]->isBold = state;
|
(*m_options_ptr)[pos]->isBold = state;
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename T> void NCurses::Menu<T>::Swap(size_t one, size_t two)
|
template <typename T> void NCurses::Menu<T>::Swap(size_t one, size_t two)
|
||||||
{
|
{
|
||||||
std::swap(itsOptions.at(one), itsOptions.at(two));
|
std::swap(m_options.at(one), m_options.at(two));
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename T> void NCurses::Menu<T>::Move(size_t from, size_t to)
|
template <typename T> void NCurses::Menu<T>::Move(size_t from, size_t to)
|
||||||
@@ -700,18 +700,18 @@ template <typename T> void NCurses::Menu<T>::Move(size_t from, size_t to)
|
|||||||
if (diff > 0)
|
if (diff > 0)
|
||||||
{
|
{
|
||||||
for (size_t i = from; i > to; --i)
|
for (size_t i = from; i > to; --i)
|
||||||
std::swap(itsOptions.at(i), itsOptions.at(i-1));
|
std::swap(m_options.at(i), m_options.at(i-1));
|
||||||
}
|
}
|
||||||
else if (diff < 0)
|
else if (diff < 0)
|
||||||
{
|
{
|
||||||
for (size_t i = from; i < to; ++i)
|
for (size_t i = from; i < to; ++i)
|
||||||
std::swap(itsOptions.at(i), itsOptions.at(i+1));
|
std::swap(m_options.at(i), m_options.at(i+1));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename T> bool NCurses::Menu<T>::Goto(size_t y)
|
template <typename T> bool NCurses::Menu<T>::Goto(size_t y)
|
||||||
{
|
{
|
||||||
if (!itsOptionsPtr->at(itsBeginning+y) || itsOptionsPtr->at(itsBeginning+y)->isStatic)
|
if (!m_options_ptr->at(itsBeginning+y) || m_options_ptr->at(itsBeginning+y)->isStatic)
|
||||||
return false;
|
return false;
|
||||||
itsHighlight = itsBeginning+y;
|
itsHighlight = itsBeginning+y;
|
||||||
return true;
|
return true;
|
||||||
@@ -719,12 +719,12 @@ template <typename T> bool NCurses::Menu<T>::Goto(size_t y)
|
|||||||
|
|
||||||
template <typename T> void NCurses::Menu<T>::Refresh()
|
template <typename T> void NCurses::Menu<T>::Refresh()
|
||||||
{
|
{
|
||||||
if (itsOptionsPtr->empty())
|
if (m_options_ptr->empty())
|
||||||
{
|
{
|
||||||
Window::Refresh();
|
Window::Refresh();
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
int MaxBeginning = itsOptionsPtr->size() < itsHeight ? 0 : itsOptionsPtr->size()-itsHeight;
|
int MaxBeginning = m_options_ptr->size() < itsHeight ? 0 : m_options_ptr->size()-itsHeight;
|
||||||
|
|
||||||
if (itsBeginning < itsHighlight-int(itsHeight)+1) // highlighted position is off the screen
|
if (itsBeginning < itsHighlight-int(itsHeight)+1) // highlighted position is off the screen
|
||||||
itsBeginning = itsHighlight-itsHeight+1;
|
itsBeginning = itsHighlight-itsHeight+1;
|
||||||
@@ -734,51 +734,51 @@ template <typename T> void NCurses::Menu<T>::Refresh()
|
|||||||
else if (itsBeginning > MaxBeginning)
|
else if (itsBeginning > MaxBeginning)
|
||||||
itsBeginning = MaxBeginning;
|
itsBeginning = MaxBeginning;
|
||||||
|
|
||||||
if (!itsOptionsPtr->empty() && itsHighlight > int(itsOptionsPtr->size())-1)
|
if (!m_options_ptr->empty() && itsHighlight > int(m_options_ptr->size())-1)
|
||||||
itsHighlight = itsOptionsPtr->size()-1;
|
itsHighlight = m_options_ptr->size()-1;
|
||||||
|
|
||||||
if (!(*itsOptionsPtr)[itsHighlight] || (*itsOptionsPtr)[itsHighlight]->isStatic) // it shouldn't be here
|
if (!(*m_options_ptr)[itsHighlight] || (*m_options_ptr)[itsHighlight]->isStatic) // it shouldn't be here
|
||||||
{
|
{
|
||||||
Scroll(wUp);
|
Scroll(wUp);
|
||||||
if (!(*itsOptionsPtr)[itsHighlight] || (*itsOptionsPtr)[itsHighlight]->isStatic)
|
if (!(*m_options_ptr)[itsHighlight] || (*m_options_ptr)[itsHighlight]->isStatic)
|
||||||
Scroll(wDown);
|
Scroll(wDown);
|
||||||
}
|
}
|
||||||
|
|
||||||
size_t line = 0;
|
size_t line = 0;
|
||||||
for (size_t &i = (itsCurrentlyDrawedPosition = itsBeginning); i < itsBeginning+itsHeight; ++i)
|
for (size_t &i = (m_currently_drawn_positions = itsBeginning); i < itsBeginning+itsHeight; ++i)
|
||||||
{
|
{
|
||||||
GotoXY(0, line);
|
GotoXY(0, line);
|
||||||
if (i >= itsOptionsPtr->size())
|
if (i >= m_options_ptr->size())
|
||||||
{
|
{
|
||||||
for (; line < itsHeight; ++line)
|
for (; line < itsHeight; ++line)
|
||||||
mvwhline(itsWindow, line, 0, 32, itsWidth);
|
mvwhline(itsWindow, line, 0, 32, itsWidth);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
if (!(*itsOptionsPtr)[i]) // separator
|
if (!(*m_options_ptr)[i]) // separator
|
||||||
{
|
{
|
||||||
mvwhline(itsWindow, line++, 0, 0, itsWidth);
|
mvwhline(itsWindow, line++, 0, 0, itsWidth);
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
if ((*itsOptionsPtr)[i]->isBold)
|
if ((*m_options_ptr)[i]->isBold)
|
||||||
*this << fmtBold;
|
*this << fmtBold;
|
||||||
if (highlightEnabled && int(i) == itsHighlight)
|
if (m_highlight_enabled && int(i) == itsHighlight)
|
||||||
{
|
{
|
||||||
*this << fmtReverse;
|
*this << fmtReverse;
|
||||||
*this << itsHighlightColor;
|
*this << m_highlight_color;
|
||||||
}
|
}
|
||||||
mvwhline(itsWindow, line, 0, 32, itsWidth);
|
mvwhline(itsWindow, line, 0, 32, itsWidth);
|
||||||
if ((*itsOptionsPtr)[i]->isSelected && itsSelectedPrefix)
|
if ((*m_options_ptr)[i]->isSelected && m_selected_prefix)
|
||||||
*this << *itsSelectedPrefix;
|
*this << *m_selected_prefix;
|
||||||
if (itsItemDisplayer)
|
if (m_item_displayer)
|
||||||
itsItemDisplayer((*itsOptionsPtr)[i]->Item, itsItemDisplayerUserdata, this);
|
m_item_displayer((*m_options_ptr)[i]->Item, m_item_displayer_data, this);
|
||||||
if ((*itsOptionsPtr)[i]->isSelected && itsSelectedSuffix)
|
if ((*m_options_ptr)[i]->isSelected && m_selected_suffix)
|
||||||
*this << *itsSelectedSuffix;
|
*this << *m_selected_suffix;
|
||||||
if (highlightEnabled && int(i) == itsHighlight)
|
if (m_highlight_enabled && int(i) == itsHighlight)
|
||||||
{
|
{
|
||||||
*this << clEnd;
|
*this << clEnd;
|
||||||
*this << fmtReverseEnd;
|
*this << fmtReverseEnd;
|
||||||
}
|
}
|
||||||
if ((*itsOptionsPtr)[i]->isBold)
|
if ((*m_options_ptr)[i]->isBold)
|
||||||
*this << fmtBoldEnd;
|
*this << fmtBoldEnd;
|
||||||
line++;
|
line++;
|
||||||
}
|
}
|
||||||
@@ -787,10 +787,10 @@ template <typename T> void NCurses::Menu<T>::Refresh()
|
|||||||
|
|
||||||
template <typename T> void NCurses::Menu<T>::Scroll(Where where)
|
template <typename T> void NCurses::Menu<T>::Scroll(Where where)
|
||||||
{
|
{
|
||||||
if (itsOptionsPtr->empty())
|
if (m_options_ptr->empty())
|
||||||
return;
|
return;
|
||||||
int MaxHighlight = itsOptionsPtr->size()-1;
|
int MaxHighlight = m_options_ptr->size()-1;
|
||||||
int MaxBeginning = itsOptionsPtr->size() < itsHeight ? 0 : itsOptionsPtr->size()-itsHeight;
|
int MaxBeginning = m_options_ptr->size() < itsHeight ? 0 : m_options_ptr->size()-itsHeight;
|
||||||
int MaxCurrentHighlight = itsBeginning+itsHeight-1;
|
int MaxCurrentHighlight = itsBeginning+itsHeight-1;
|
||||||
switch (where)
|
switch (where)
|
||||||
{
|
{
|
||||||
@@ -802,7 +802,7 @@ template <typename T> void NCurses::Menu<T>::Scroll(Where where)
|
|||||||
}
|
}
|
||||||
if (itsHighlight == 0)
|
if (itsHighlight == 0)
|
||||||
{
|
{
|
||||||
if (useCyclicScrolling)
|
if (m_cyclic_scroll_enabled)
|
||||||
return Scroll(wEnd);
|
return Scroll(wEnd);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@@ -810,9 +810,9 @@ template <typename T> void NCurses::Menu<T>::Scroll(Where where)
|
|||||||
{
|
{
|
||||||
itsHighlight--;
|
itsHighlight--;
|
||||||
}
|
}
|
||||||
if (!(*itsOptionsPtr)[itsHighlight] || (*itsOptionsPtr)[itsHighlight]->isStatic)
|
if (!(*m_options_ptr)[itsHighlight] || (*m_options_ptr)[itsHighlight]->isStatic)
|
||||||
{
|
{
|
||||||
Scroll(itsHighlight == 0 && !useCyclicScrolling ? wDown : wUp);
|
Scroll(itsHighlight == 0 && !m_cyclic_scroll_enabled ? wDown : wUp);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@@ -824,7 +824,7 @@ template <typename T> void NCurses::Menu<T>::Scroll(Where where)
|
|||||||
}
|
}
|
||||||
if (itsHighlight == MaxHighlight)
|
if (itsHighlight == MaxHighlight)
|
||||||
{
|
{
|
||||||
if (useCyclicScrolling)
|
if (m_cyclic_scroll_enabled)
|
||||||
return Scroll(wHome);
|
return Scroll(wHome);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@@ -832,15 +832,15 @@ template <typename T> void NCurses::Menu<T>::Scroll(Where where)
|
|||||||
{
|
{
|
||||||
itsHighlight++;
|
itsHighlight++;
|
||||||
}
|
}
|
||||||
if (!(*itsOptionsPtr)[itsHighlight] || (*itsOptionsPtr)[itsHighlight]->isStatic)
|
if (!(*m_options_ptr)[itsHighlight] || (*m_options_ptr)[itsHighlight]->isStatic)
|
||||||
{
|
{
|
||||||
Scroll(itsHighlight == MaxHighlight && !useCyclicScrolling ? wUp : wDown);
|
Scroll(itsHighlight == MaxHighlight && !m_cyclic_scroll_enabled ? wUp : wDown);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case wPageUp:
|
case wPageUp:
|
||||||
{
|
{
|
||||||
if (useCyclicScrolling && itsHighlight == 0)
|
if (m_cyclic_scroll_enabled && itsHighlight == 0)
|
||||||
return Scroll(wEnd);
|
return Scroll(wEnd);
|
||||||
itsHighlight -= itsHeight;
|
itsHighlight -= itsHeight;
|
||||||
itsBeginning -= itsHeight;
|
itsBeginning -= itsHeight;
|
||||||
@@ -850,15 +850,15 @@ template <typename T> void NCurses::Menu<T>::Scroll(Where where)
|
|||||||
if (itsHighlight < 0)
|
if (itsHighlight < 0)
|
||||||
itsHighlight = 0;
|
itsHighlight = 0;
|
||||||
}
|
}
|
||||||
if (!(*itsOptionsPtr)[itsHighlight] || (*itsOptionsPtr)[itsHighlight]->isStatic)
|
if (!(*m_options_ptr)[itsHighlight] || (*m_options_ptr)[itsHighlight]->isStatic)
|
||||||
{
|
{
|
||||||
Scroll(itsHighlight == 0 && !useCyclicScrolling ? wDown : wUp);
|
Scroll(itsHighlight == 0 && !m_cyclic_scroll_enabled ? wDown : wUp);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case wPageDown:
|
case wPageDown:
|
||||||
{
|
{
|
||||||
if (useCyclicScrolling && itsHighlight == MaxHighlight)
|
if (m_cyclic_scroll_enabled && itsHighlight == MaxHighlight)
|
||||||
return Scroll(wHome);
|
return Scroll(wHome);
|
||||||
itsHighlight += itsHeight;
|
itsHighlight += itsHeight;
|
||||||
itsBeginning += itsHeight;
|
itsBeginning += itsHeight;
|
||||||
@@ -868,9 +868,9 @@ template <typename T> void NCurses::Menu<T>::Scroll(Where where)
|
|||||||
if (itsHighlight > MaxHighlight)
|
if (itsHighlight > MaxHighlight)
|
||||||
itsHighlight = MaxHighlight;
|
itsHighlight = MaxHighlight;
|
||||||
}
|
}
|
||||||
if (!(*itsOptionsPtr)[itsHighlight] || (*itsOptionsPtr)[itsHighlight]->isStatic)
|
if (!(*m_options_ptr)[itsHighlight] || (*m_options_ptr)[itsHighlight]->isStatic)
|
||||||
{
|
{
|
||||||
Scroll(itsHighlight == MaxHighlight && !useCyclicScrolling ? wUp : wDown);
|
Scroll(itsHighlight == MaxHighlight && !m_cyclic_scroll_enabled ? wUp : wDown);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@@ -878,7 +878,7 @@ template <typename T> void NCurses::Menu<T>::Scroll(Where where)
|
|||||||
{
|
{
|
||||||
itsHighlight = 0;
|
itsHighlight = 0;
|
||||||
itsBeginning = 0;
|
itsBeginning = 0;
|
||||||
if (!(*itsOptionsPtr)[itsHighlight] || (*itsOptionsPtr)[itsHighlight]->isStatic)
|
if (!(*m_options_ptr)[itsHighlight] || (*m_options_ptr)[itsHighlight]->isStatic)
|
||||||
{
|
{
|
||||||
Scroll(itsHighlight == 0 ? wDown : wUp);
|
Scroll(itsHighlight == 0 ? wDown : wUp);
|
||||||
}
|
}
|
||||||
@@ -888,14 +888,14 @@ template <typename T> void NCurses::Menu<T>::Scroll(Where where)
|
|||||||
{
|
{
|
||||||
itsHighlight = MaxHighlight;
|
itsHighlight = MaxHighlight;
|
||||||
itsBeginning = MaxBeginning;
|
itsBeginning = MaxBeginning;
|
||||||
if (!(*itsOptionsPtr)[itsHighlight] || (*itsOptionsPtr)[itsHighlight]->isStatic)
|
if (!(*m_options_ptr)[itsHighlight] || (*m_options_ptr)[itsHighlight]->isStatic)
|
||||||
{
|
{
|
||||||
Scroll(itsHighlight == MaxHighlight ? wUp : wDown);
|
Scroll(itsHighlight == MaxHighlight ? wUp : wDown);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (useCenteredCursor)
|
if (m_autocenter_cursor)
|
||||||
Highlight(itsHighlight);
|
Highlight(itsHighlight);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -907,70 +907,70 @@ template <typename T> void NCurses::Menu<T>::Reset()
|
|||||||
|
|
||||||
template <typename T> void NCurses::Menu<T>::ClearFiltered()
|
template <typename T> void NCurses::Menu<T>::ClearFiltered()
|
||||||
{
|
{
|
||||||
itsFilteredOptions.clear();
|
m_filtered_options.clear();
|
||||||
itsFilteredRealPositions.clear();
|
m_filtered_positions.clear();
|
||||||
itsOptionsPtr = &itsOptions;
|
m_options_ptr = &m_options;
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename T> void NCurses::Menu<T>::Clear()
|
template <typename T> void NCurses::Menu<T>::Clear()
|
||||||
{
|
{
|
||||||
for (option_iterator it = itsOptions.begin(); it != itsOptions.end(); ++it)
|
for (option_iterator it = m_options.begin(); it != m_options.end(); ++it)
|
||||||
delete *it;
|
delete *it;
|
||||||
itsOptions.clear();
|
m_options.clear();
|
||||||
itsFound.clear();
|
m_found_positions.clear();
|
||||||
itsFilter.clear();
|
m_filter.clear();
|
||||||
ClearFiltered();
|
ClearFiltered();
|
||||||
itsOptionsPtr = &itsOptions;
|
m_options_ptr = &m_options;
|
||||||
Window::Clear();
|
Window::Clear();
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename T> bool NCurses::Menu<T>::isBold(int pos)
|
template <typename T> bool NCurses::Menu<T>::isBold(int pos)
|
||||||
{
|
{
|
||||||
pos = pos == -1 ? itsHighlight : pos;
|
pos = pos == -1 ? itsHighlight : pos;
|
||||||
if (!itsOptionsPtr->at(pos))
|
if (!m_options_ptr->at(pos))
|
||||||
return 0;
|
return 0;
|
||||||
return (*itsOptionsPtr)[pos]->isBold;
|
return (*m_options_ptr)[pos]->isBold;
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename T> void NCurses::Menu<T>::Select(int pos, bool state)
|
template <typename T> void NCurses::Menu<T>::Select(int pos, bool state)
|
||||||
{
|
{
|
||||||
if (!itsOptionsPtr->at(pos))
|
if (!m_options_ptr->at(pos))
|
||||||
return;
|
return;
|
||||||
(*itsOptionsPtr)[pos]->isSelected = state;
|
(*m_options_ptr)[pos]->isSelected = state;
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename T> void NCurses::Menu<T>::Static(int pos, bool state)
|
template <typename T> void NCurses::Menu<T>::Static(int pos, bool state)
|
||||||
{
|
{
|
||||||
if (!itsOptionsPtr->at(pos))
|
if (!m_options_ptr->at(pos))
|
||||||
return;
|
return;
|
||||||
(*itsOptionsPtr)[pos]->isStatic = state;
|
(*m_options_ptr)[pos]->isStatic = state;
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename T> bool NCurses::Menu<T>::isSelected(int pos) const
|
template <typename T> bool NCurses::Menu<T>::isSelected(int pos) const
|
||||||
{
|
{
|
||||||
pos = pos == -1 ? itsHighlight : pos;
|
pos = pos == -1 ? itsHighlight : pos;
|
||||||
if (!itsOptionsPtr->at(pos))
|
if (!m_options_ptr->at(pos))
|
||||||
return 0;
|
return 0;
|
||||||
return (*itsOptionsPtr)[pos]->isSelected;
|
return (*m_options_ptr)[pos]->isSelected;
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename T> bool NCurses::Menu<T>::isStatic(int pos) const
|
template <typename T> bool NCurses::Menu<T>::isStatic(int pos) const
|
||||||
{
|
{
|
||||||
pos = pos == -1 ? itsHighlight : pos;
|
pos = pos == -1 ? itsHighlight : pos;
|
||||||
if (!itsOptionsPtr->at(pos))
|
if (!m_options_ptr->at(pos))
|
||||||
return 1;
|
return 1;
|
||||||
return (*itsOptionsPtr)[pos]->isStatic;
|
return (*m_options_ptr)[pos]->isStatic;
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename T> bool NCurses::Menu<T>::isSeparator(int pos) const
|
template <typename T> bool NCurses::Menu<T>::isSeparator(int pos) const
|
||||||
{
|
{
|
||||||
pos = pos == -1 ? itsHighlight : pos;
|
pos = pos == -1 ? itsHighlight : pos;
|
||||||
return !itsOptionsPtr->at(pos);
|
return !m_options_ptr->at(pos);
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename T> bool NCurses::Menu<T>::hasSelected() const
|
template <typename T> bool NCurses::Menu<T>::hasSelected() const
|
||||||
{
|
{
|
||||||
for (option_const_iterator it = itsOptionsPtr->begin(); it != itsOptionsPtr->end(); ++it)
|
for (option_const_iterator it = m_options_ptr->begin(); it != m_options_ptr->end(); ++it)
|
||||||
if (*it && (*it)->isSelected)
|
if (*it && (*it)->isSelected)
|
||||||
return true;
|
return true;
|
||||||
return false;
|
return false;
|
||||||
@@ -978,8 +978,8 @@ template <typename T> bool NCurses::Menu<T>::hasSelected() const
|
|||||||
|
|
||||||
template <typename T> void NCurses::Menu<T>::GetSelected(std::vector<size_t> &v) const
|
template <typename T> void NCurses::Menu<T>::GetSelected(std::vector<size_t> &v) const
|
||||||
{
|
{
|
||||||
for (size_t i = 0; i < itsOptionsPtr->size(); ++i)
|
for (size_t i = 0; i < m_options_ptr->size(); ++i)
|
||||||
if ((*itsOptionsPtr)[i] && (*itsOptionsPtr)[i]->isSelected)
|
if ((*m_options_ptr)[i] && (*m_options_ptr)[i]->isSelected)
|
||||||
v.push_back(i);
|
v.push_back(i);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -991,7 +991,7 @@ template <typename T> void NCurses::Menu<T>::Highlight(size_t pos)
|
|||||||
|
|
||||||
template <typename T> size_t NCurses::Menu<T>::Size() const
|
template <typename T> size_t NCurses::Menu<T>::Size() const
|
||||||
{
|
{
|
||||||
return itsOptionsPtr->size();
|
return m_options_ptr->size();
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename T> size_t NCurses::Menu<T>::Choice() const
|
template <typename T> size_t NCurses::Menu<T>::Choice() const
|
||||||
@@ -1002,7 +1002,7 @@ template <typename T> size_t NCurses::Menu<T>::Choice() const
|
|||||||
template <typename T> size_t NCurses::Menu<T>::RealChoice() const
|
template <typename T> size_t NCurses::Menu<T>::RealChoice() const
|
||||||
{
|
{
|
||||||
size_t result = 0;
|
size_t result = 0;
|
||||||
for (option_const_iterator it = itsOptionsPtr->begin(); it != itsOptionsPtr->begin()+itsHighlight; ++it)
|
for (option_const_iterator it = m_options_ptr->begin(); it != m_options_ptr->begin()+itsHighlight; ++it)
|
||||||
if (*it && !(*it)->isStatic)
|
if (*it && !(*it)->isStatic)
|
||||||
result++;
|
result++;
|
||||||
return result;
|
return result;
|
||||||
@@ -1010,7 +1010,7 @@ template <typename T> size_t NCurses::Menu<T>::RealChoice() const
|
|||||||
|
|
||||||
template <typename T> void NCurses::Menu<T>::ReverseSelection(size_t beginning)
|
template <typename T> void NCurses::Menu<T>::ReverseSelection(size_t beginning)
|
||||||
{
|
{
|
||||||
option_iterator it = itsOptionsPtr->begin()+beginning;
|
option_iterator it = m_options_ptr->begin()+beginning;
|
||||||
for (size_t i = beginning; i < Size(); ++i, ++it)
|
for (size_t i = beginning; i < Size(); ++i, ++it)
|
||||||
if (*it)
|
if (*it)
|
||||||
(*it)->isSelected = !(*it)->isSelected && !(*it)->isStatic;
|
(*it)->isSelected = !(*it)->isSelected && !(*it)->isStatic;
|
||||||
@@ -1018,143 +1018,143 @@ template <typename T> void NCurses::Menu<T>::ReverseSelection(size_t beginning)
|
|||||||
|
|
||||||
template <typename T> bool NCurses::Menu<T>::Search(const std::string &constraint, size_t beginning, int flags)
|
template <typename T> bool NCurses::Menu<T>::Search(const std::string &constraint, size_t beginning, int flags)
|
||||||
{
|
{
|
||||||
itsFound.clear();
|
m_found_positions.clear();
|
||||||
itsSearchConstraint.clear();
|
m_search_constraint.clear();
|
||||||
if (constraint.empty())
|
if (constraint.empty())
|
||||||
return false;
|
return false;
|
||||||
itsSearchConstraint = constraint;
|
m_search_constraint = constraint;
|
||||||
regex_t rx;
|
regex_t rx;
|
||||||
if (regcomp(&rx, itsSearchConstraint.c_str(), flags) == 0)
|
if (regcomp(&rx, m_search_constraint.c_str(), flags) == 0)
|
||||||
{
|
{
|
||||||
for (size_t i = beginning; i < itsOptionsPtr->size(); ++i)
|
for (size_t i = beginning; i < m_options_ptr->size(); ++i)
|
||||||
{
|
{
|
||||||
if (regexec(&rx, GetOption(i).c_str(), 0, 0, 0) == 0)
|
if (regexec(&rx, GetOption(i).c_str(), 0, 0, 0) == 0)
|
||||||
itsFound.insert(i);
|
m_found_positions.insert(i);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
regfree(&rx);
|
regfree(&rx);
|
||||||
return !itsFound.empty();
|
return !m_found_positions.empty();
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename T> void NCurses::Menu<T>::NextFound(bool wrap)
|
template <typename T> void NCurses::Menu<T>::NextFound(bool wrap)
|
||||||
{
|
{
|
||||||
if (itsFound.empty())
|
if (m_found_positions.empty())
|
||||||
return;
|
return;
|
||||||
std::set<size_t>::iterator next = itsFound.upper_bound(itsHighlight);
|
std::set<size_t>::iterator next = m_found_positions.upper_bound(itsHighlight);
|
||||||
if (next != itsFound.end())
|
if (next != m_found_positions.end())
|
||||||
Highlight(*next);
|
Highlight(*next);
|
||||||
else if (wrap)
|
else if (wrap)
|
||||||
Highlight(*itsFound.begin());
|
Highlight(*m_found_positions.begin());
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename T> void NCurses::Menu<T>::PrevFound(bool wrap)
|
template <typename T> void NCurses::Menu<T>::PrevFound(bool wrap)
|
||||||
{
|
{
|
||||||
if (itsFound.empty())
|
if (m_found_positions.empty())
|
||||||
return;
|
return;
|
||||||
std::set<size_t>::iterator prev = itsFound.lower_bound(itsHighlight);
|
std::set<size_t>::iterator prev = m_found_positions.lower_bound(itsHighlight);
|
||||||
if (prev != itsFound.begin())
|
if (prev != m_found_positions.begin())
|
||||||
Highlight(*--prev);
|
Highlight(*--prev);
|
||||||
else if (wrap)
|
else if (wrap)
|
||||||
Highlight(*itsFound.rbegin());
|
Highlight(*m_found_positions.rbegin());
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename T> void NCurses::Menu<T>::ApplyFilter(const std::string &filter, size_t beginning, int flags)
|
template <typename T> void NCurses::Menu<T>::ApplyFilter(const std::string &filter, size_t beginning, int flags)
|
||||||
{
|
{
|
||||||
itsFound.clear();
|
m_found_positions.clear();
|
||||||
ClearFiltered();
|
ClearFiltered();
|
||||||
itsFilter = filter;
|
m_filter = filter;
|
||||||
if (itsFilter.empty())
|
if (m_filter.empty())
|
||||||
return;
|
return;
|
||||||
for (size_t i = 0; i < beginning; ++i)
|
for (size_t i = 0; i < beginning; ++i)
|
||||||
{
|
{
|
||||||
itsFilteredRealPositions.push_back(i);
|
m_filtered_positions.push_back(i);
|
||||||
itsFilteredOptions.push_back(itsOptions[i]);
|
m_filtered_options.push_back(m_options[i]);
|
||||||
}
|
}
|
||||||
regex_t rx;
|
regex_t rx;
|
||||||
if (regcomp(&rx, itsFilter.c_str(), flags) == 0)
|
if (regcomp(&rx, m_filter.c_str(), flags) == 0)
|
||||||
{
|
{
|
||||||
for (size_t i = beginning; i < itsOptions.size(); ++i)
|
for (size_t i = beginning; i < m_options.size(); ++i)
|
||||||
{
|
{
|
||||||
if (regexec(&rx, GetOption(i).c_str(), 0, 0, 0) == 0)
|
if (regexec(&rx, GetOption(i).c_str(), 0, 0, 0) == 0)
|
||||||
{
|
{
|
||||||
itsFilteredRealPositions.push_back(i);
|
m_filtered_positions.push_back(i);
|
||||||
itsFilteredOptions.push_back(itsOptions[i]);
|
m_filtered_options.push_back(m_options[i]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
regfree(&rx);
|
regfree(&rx);
|
||||||
itsOptionsPtr = &itsFilteredOptions;
|
m_options_ptr = &m_filtered_options;
|
||||||
if (itsOptionsPtr->empty()) // oops, we didn't find anything
|
if (m_options_ptr->empty()) // oops, we didn't find anything
|
||||||
Window::Clear();
|
Window::Clear();
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename T> const std::string &NCurses::Menu<T>::GetFilter()
|
template <typename T> const std::string &NCurses::Menu<T>::GetFilter()
|
||||||
{
|
{
|
||||||
return itsFilter;
|
return m_filter;
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename T> std::string NCurses::Menu<T>::GetOption(size_t pos)
|
template <typename T> std::string NCurses::Menu<T>::GetOption(size_t pos)
|
||||||
{
|
{
|
||||||
if (itsOptionsPtr->at(pos) && itsGetStringFunction)
|
if (m_options_ptr->at(pos) && m_get_string_helper)
|
||||||
return itsGetStringFunction((*itsOptionsPtr)[pos]->Item, itsGetStringFunctionUserData);
|
return m_get_string_helper((*m_options_ptr)[pos]->Item, m_get_string_helper_data);
|
||||||
else
|
else
|
||||||
return "";
|
return "";
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename T> T &NCurses::Menu<T>::Back()
|
template <typename T> T &NCurses::Menu<T>::Back()
|
||||||
{
|
{
|
||||||
if (!itsOptionsPtr->back())
|
if (!m_options_ptr->back())
|
||||||
FatalError("Menu::Back() has requested separator!");
|
FatalError("Menu::Back() has requested separator!");
|
||||||
return itsOptionsPtr->back()->Item;
|
return m_options_ptr->back()->Item;
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename T> const T &NCurses::Menu<T>::Back() const
|
template <typename T> const T &NCurses::Menu<T>::Back() const
|
||||||
{
|
{
|
||||||
if (!itsOptionsPtr->back())
|
if (!m_options_ptr->back())
|
||||||
FatalError("Menu::Back() has requested separator!");
|
FatalError("Menu::Back() has requested separator!");
|
||||||
return itsOptionsPtr->back()->Item;
|
return m_options_ptr->back()->Item;
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename T> T &NCurses::Menu<T>::Current()
|
template <typename T> T &NCurses::Menu<T>::Current()
|
||||||
{
|
{
|
||||||
if (!itsOptionsPtr->at(itsHighlight))
|
if (!m_options_ptr->at(itsHighlight))
|
||||||
FatalError("Menu::Current() has requested separator!");
|
FatalError("Menu::Current() has requested separator!");
|
||||||
return (*itsOptionsPtr)[itsHighlight]->Item;
|
return (*m_options_ptr)[itsHighlight]->Item;
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename T> const T &NCurses::Menu<T>::Current() const
|
template <typename T> const T &NCurses::Menu<T>::Current() const
|
||||||
{
|
{
|
||||||
if (!itsOptionsPtr->at(itsHighlight))
|
if (!m_options_ptr->at(itsHighlight))
|
||||||
FatalError("Menu::Current() const has requested separator!");
|
FatalError("Menu::Current() const has requested separator!");
|
||||||
return (*itsOptionsPtr)[itsHighlight]->Item;
|
return (*m_options_ptr)[itsHighlight]->Item;
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename T> T &NCurses::Menu<T>::at(size_t pos)
|
template <typename T> T &NCurses::Menu<T>::at(size_t pos)
|
||||||
{
|
{
|
||||||
if (!itsOptionsPtr->at(pos))
|
if (!m_options_ptr->at(pos))
|
||||||
FatalError("Menu::at() has requested separator!");
|
FatalError("Menu::at() has requested separator!");
|
||||||
return (*itsOptionsPtr)[pos]->Item;
|
return (*m_options_ptr)[pos]->Item;
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename T> const T &NCurses::Menu<T>::at(size_t pos) const
|
template <typename T> const T &NCurses::Menu<T>::at(size_t pos) const
|
||||||
{
|
{
|
||||||
if (!itsOptions->at(pos))
|
if (!m_options->at(pos))
|
||||||
FatalError("Menu::at() const has requested separator!");
|
FatalError("Menu::at() const has requested separator!");
|
||||||
return (*itsOptionsPtr)[pos]->Item;
|
return (*m_options_ptr)[pos]->Item;
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename T> const T &NCurses::Menu<T>::operator[](size_t pos) const
|
template <typename T> const T &NCurses::Menu<T>::operator[](size_t pos) const
|
||||||
{
|
{
|
||||||
if (!(*itsOptionsPtr)[pos])
|
if (!(*m_options_ptr)[pos])
|
||||||
FatalError("Menu::operator[] const has requested separator!");
|
FatalError("Menu::operator[] const has requested separator!");
|
||||||
return (*itsOptionsPtr)[pos]->Item;
|
return (*m_options_ptr)[pos]->Item;
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename T> T &NCurses::Menu<T>::operator[](size_t pos)
|
template <typename T> T &NCurses::Menu<T>::operator[](size_t pos)
|
||||||
{
|
{
|
||||||
if (!(*itsOptionsPtr)[pos])
|
if (!(*m_options_ptr)[pos])
|
||||||
FatalError("Menu::operator[] has requested separator!");
|
FatalError("Menu::operator[] has requested separator!");
|
||||||
return (*itsOptionsPtr)[pos]->Item;
|
return (*m_options_ptr)[pos]->Item;
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|||||||
@@ -37,7 +37,7 @@ void Outputs::Init()
|
|||||||
w->CyclicScrolling(Config.use_cyclic_scrolling);
|
w->CyclicScrolling(Config.use_cyclic_scrolling);
|
||||||
w->CenteredCursor(Config.centered_cursor);
|
w->CenteredCursor(Config.centered_cursor);
|
||||||
w->HighlightColor(Config.main_highlight_color);
|
w->HighlightColor(Config.main_highlight_color);
|
||||||
w->SetItemDisplayer(Display::Outputs);
|
w->setItemDisplayer(Display::Outputs);
|
||||||
|
|
||||||
isInitialized = 1;
|
isInitialized = 1;
|
||||||
FetchList();
|
FetchList();
|
||||||
|
|||||||
@@ -53,8 +53,8 @@ void Playlist::Init()
|
|||||||
Items->HighlightColor(Config.main_highlight_color);
|
Items->HighlightColor(Config.main_highlight_color);
|
||||||
Items->SetSelectPrefix(&Config.selected_item_prefix);
|
Items->SetSelectPrefix(&Config.selected_item_prefix);
|
||||||
Items->SetSelectSuffix(&Config.selected_item_suffix);
|
Items->SetSelectSuffix(&Config.selected_item_suffix);
|
||||||
Items->SetItemDisplayer(Config.columns_in_playlist ? Display::SongsInColumns : Display::Songs);
|
Items->setItemDisplayer(Config.columns_in_playlist ? Display::SongsInColumns : Display::Songs);
|
||||||
Items->SetItemDisplayerUserData(&sf);
|
Items->setItemDisplayerData(&sf);
|
||||||
Items->SetGetStringFunction(Config.columns_in_playlist ? SongInColumnsToString : SongToString);
|
Items->SetGetStringFunction(Config.columns_in_playlist ? SongInColumnsToString : SongToString);
|
||||||
Items->SetGetStringFunctionUserData(&Config.song_list_format_dollar_free);
|
Items->SetGetStringFunctionUserData(&Config.song_list_format_dollar_free);
|
||||||
|
|
||||||
@@ -65,7 +65,7 @@ void Playlist::Init()
|
|||||||
SortDialog = new Menu< std::pair<std::string, MPD::Song::GetFunction> >((COLS-SortDialogWidth)/2, (MainHeight-SortDialogHeight)/2+MainStartY, SortDialogWidth, SortDialogHeight, "Sort songs by...", Config.main_color, Config.window_border);
|
SortDialog = new Menu< std::pair<std::string, MPD::Song::GetFunction> >((COLS-SortDialogWidth)/2, (MainHeight-SortDialogHeight)/2+MainStartY, SortDialogWidth, SortDialogHeight, "Sort songs by...", Config.main_color, Config.window_border);
|
||||||
SortDialog->CyclicScrolling(Config.use_cyclic_scrolling);
|
SortDialog->CyclicScrolling(Config.use_cyclic_scrolling);
|
||||||
SortDialog->CenteredCursor(Config.centered_cursor);
|
SortDialog->CenteredCursor(Config.centered_cursor);
|
||||||
SortDialog->SetItemDisplayer(Display::Pairs);
|
SortDialog->setItemDisplayer(Display::Pair<std::string, MPD::Song::GetFunction>);
|
||||||
|
|
||||||
SortDialog->AddOption(std::make_pair("Artist", &MPD::Song::getArtist));
|
SortDialog->AddOption(std::make_pair("Artist", &MPD::Song::getArtist));
|
||||||
SortDialog->AddOption(std::make_pair("Album", &MPD::Song::getAlbum));
|
SortDialog->AddOption(std::make_pair("Album", &MPD::Song::getAlbum));
|
||||||
|
|||||||
@@ -52,7 +52,7 @@ void PlaylistEditor::Init()
|
|||||||
Playlists->HighlightColor(Config.active_column_color);
|
Playlists->HighlightColor(Config.active_column_color);
|
||||||
Playlists->CyclicScrolling(Config.use_cyclic_scrolling);
|
Playlists->CyclicScrolling(Config.use_cyclic_scrolling);
|
||||||
Playlists->CenteredCursor(Config.centered_cursor);
|
Playlists->CenteredCursor(Config.centered_cursor);
|
||||||
Playlists->SetItemDisplayer(Display::Generic);
|
Playlists->setItemDisplayer(Display::Default<std::string>);
|
||||||
|
|
||||||
static Display::ScreenFormat sf = { this, &Config.song_list_format };
|
static Display::ScreenFormat sf = { this, &Config.song_list_format };
|
||||||
|
|
||||||
@@ -62,8 +62,8 @@ void PlaylistEditor::Init()
|
|||||||
Content->CenteredCursor(Config.centered_cursor);
|
Content->CenteredCursor(Config.centered_cursor);
|
||||||
Content->SetSelectPrefix(&Config.selected_item_prefix);
|
Content->SetSelectPrefix(&Config.selected_item_prefix);
|
||||||
Content->SetSelectSuffix(&Config.selected_item_suffix);
|
Content->SetSelectSuffix(&Config.selected_item_suffix);
|
||||||
Content->SetItemDisplayer(Config.columns_in_playlist_editor ? Display::SongsInColumns : Display::Songs);
|
Content->setItemDisplayer(Config.columns_in_playlist_editor ? Display::SongsInColumns : Display::Songs);
|
||||||
Content->SetItemDisplayerUserData(&sf);
|
Content->setItemDisplayerData(&sf);
|
||||||
Content->SetGetStringFunction(Config.columns_in_playlist_editor ? Playlist::SongInColumnsToString : Playlist::SongToString);
|
Content->SetGetStringFunction(Config.columns_in_playlist_editor ? Playlist::SongInColumnsToString : Playlist::SongToString);
|
||||||
Content->SetGetStringFunctionUserData(&Config.song_list_format_dollar_free);
|
Content->SetGetStringFunctionUserData(&Config.song_list_format_dollar_free);
|
||||||
|
|
||||||
|
|||||||
@@ -69,8 +69,8 @@ void SearchEngine::Init()
|
|||||||
w->HighlightColor(Config.main_highlight_color);
|
w->HighlightColor(Config.main_highlight_color);
|
||||||
w->CyclicScrolling(Config.use_cyclic_scrolling);
|
w->CyclicScrolling(Config.use_cyclic_scrolling);
|
||||||
w->CenteredCursor(Config.centered_cursor);
|
w->CenteredCursor(Config.centered_cursor);
|
||||||
w->SetItemDisplayer(Display::SearchEngine);
|
w->setItemDisplayer(Display::SearchEngine);
|
||||||
w->SetItemDisplayerUserData(&sf);
|
w->setItemDisplayerData(&sf);
|
||||||
w->SetSelectPrefix(&Config.selected_item_prefix);
|
w->SetSelectPrefix(&Config.selected_item_prefix);
|
||||||
w->SetSelectSuffix(&Config.selected_item_suffix);
|
w->SetSelectSuffix(&Config.selected_item_suffix);
|
||||||
w->SetGetStringFunction(SearchEngineOptionToString);
|
w->SetGetStringFunction(SearchEngineOptionToString);
|
||||||
|
|||||||
@@ -42,13 +42,13 @@ void SelectedItemsAdder::Init()
|
|||||||
itsPlaylistSelector->CyclicScrolling(Config.use_cyclic_scrolling);
|
itsPlaylistSelector->CyclicScrolling(Config.use_cyclic_scrolling);
|
||||||
itsPlaylistSelector->CenteredCursor(Config.centered_cursor);
|
itsPlaylistSelector->CenteredCursor(Config.centered_cursor);
|
||||||
itsPlaylistSelector->HighlightColor(Config.main_highlight_color);
|
itsPlaylistSelector->HighlightColor(Config.main_highlight_color);
|
||||||
itsPlaylistSelector->SetItemDisplayer(Display::Generic);
|
itsPlaylistSelector->setItemDisplayer(Display::Default<std::string>);
|
||||||
|
|
||||||
itsPositionSelector = new Menu<std::string>((COLS-itsPSWidth)/2, (MainHeight-itsPSHeight)/2+MainStartY, itsPSWidth, itsPSHeight, "Where?", Config.main_color, Config.window_border);
|
itsPositionSelector = new Menu<std::string>((COLS-itsPSWidth)/2, (MainHeight-itsPSHeight)/2+MainStartY, itsPSWidth, itsPSHeight, "Where?", Config.main_color, Config.window_border);
|
||||||
itsPositionSelector->CyclicScrolling(Config.use_cyclic_scrolling);
|
itsPositionSelector->CyclicScrolling(Config.use_cyclic_scrolling);
|
||||||
itsPositionSelector->CenteredCursor(Config.centered_cursor);
|
itsPositionSelector->CenteredCursor(Config.centered_cursor);
|
||||||
itsPositionSelector->HighlightColor(Config.main_highlight_color);
|
itsPositionSelector->HighlightColor(Config.main_highlight_color);
|
||||||
itsPositionSelector->SetItemDisplayer(Display::Generic);
|
itsPositionSelector->setItemDisplayer(Display::Default<std::string>);
|
||||||
itsPositionSelector->AddOption("At the end of playlist");
|
itsPositionSelector->AddOption("At the end of playlist");
|
||||||
itsPositionSelector->AddOption("At the beginning of playlist");
|
itsPositionSelector->AddOption("At the beginning of playlist");
|
||||||
itsPositionSelector->AddOption("After current track");
|
itsPositionSelector->AddOption("After current track");
|
||||||
|
|||||||
@@ -72,14 +72,14 @@ void TagEditor::Init()
|
|||||||
Albums->HighlightColor(Config.active_column_color);
|
Albums->HighlightColor(Config.active_column_color);
|
||||||
Albums->CyclicScrolling(Config.use_cyclic_scrolling);
|
Albums->CyclicScrolling(Config.use_cyclic_scrolling);
|
||||||
Albums->CenteredCursor(Config.centered_cursor);
|
Albums->CenteredCursor(Config.centered_cursor);
|
||||||
Albums->SetItemDisplayer(Display::Pairs);
|
Albums->setItemDisplayer(Display::Pair<std::string, std::string>);
|
||||||
Albums->SetGetStringFunction(StringPairToString);
|
Albums->SetGetStringFunction(StringPairToString);
|
||||||
|
|
||||||
Dirs = new Menu<string_pair>(0, MainStartY, LeftColumnWidth, MainHeight, Config.titles_visibility ? "Directories" : "", Config.main_color, brNone);
|
Dirs = new Menu<string_pair>(0, MainStartY, LeftColumnWidth, MainHeight, Config.titles_visibility ? "Directories" : "", Config.main_color, brNone);
|
||||||
Dirs->HighlightColor(Config.active_column_color);
|
Dirs->HighlightColor(Config.active_column_color);
|
||||||
Dirs->CyclicScrolling(Config.use_cyclic_scrolling);
|
Dirs->CyclicScrolling(Config.use_cyclic_scrolling);
|
||||||
Dirs->CenteredCursor(Config.centered_cursor);
|
Dirs->CenteredCursor(Config.centered_cursor);
|
||||||
Dirs->SetItemDisplayer(Display::Pairs);
|
Dirs->setItemDisplayer(Display::Pair<std::string, std::string>);
|
||||||
Dirs->SetGetStringFunction(StringPairToString);
|
Dirs->SetGetStringFunction(StringPairToString);
|
||||||
|
|
||||||
LeftColumn = Config.albums_in_tag_editor ? Albums : Dirs;
|
LeftColumn = Config.albums_in_tag_editor ? Albums : Dirs;
|
||||||
@@ -88,7 +88,7 @@ void TagEditor::Init()
|
|||||||
TagTypes->HighlightColor(Config.main_highlight_color);
|
TagTypes->HighlightColor(Config.main_highlight_color);
|
||||||
TagTypes->CyclicScrolling(Config.use_cyclic_scrolling);
|
TagTypes->CyclicScrolling(Config.use_cyclic_scrolling);
|
||||||
TagTypes->CenteredCursor(Config.centered_cursor);
|
TagTypes->CenteredCursor(Config.centered_cursor);
|
||||||
TagTypes->SetItemDisplayer(Display::Generic);
|
TagTypes->setItemDisplayer(Display::Default<std::string>);
|
||||||
|
|
||||||
for (const SongInfo::Metadata *m = SongInfo::Tags; m->Name; ++m)
|
for (const SongInfo::Metadata *m = SongInfo::Tags; m->Name; ++m)
|
||||||
TagTypes->AddOption(m->Name);
|
TagTypes->AddOption(m->Name);
|
||||||
@@ -110,15 +110,15 @@ void TagEditor::Init()
|
|||||||
Tags->CenteredCursor(Config.centered_cursor);
|
Tags->CenteredCursor(Config.centered_cursor);
|
||||||
Tags->SetSelectPrefix(&Config.selected_item_prefix);
|
Tags->SetSelectPrefix(&Config.selected_item_prefix);
|
||||||
Tags->SetSelectSuffix(&Config.selected_item_suffix);
|
Tags->SetSelectSuffix(&Config.selected_item_suffix);
|
||||||
Tags->SetItemDisplayer(Display::Tags);
|
Tags->setItemDisplayer(Display::Tags);
|
||||||
Tags->SetItemDisplayerUserData(TagTypes);
|
Tags->setItemDisplayerData(TagTypes);
|
||||||
Tags->SetGetStringFunction(TagToString);
|
Tags->SetGetStringFunction(TagToString);
|
||||||
Tags->SetGetStringFunctionUserData(TagTypes);
|
Tags->SetGetStringFunctionUserData(TagTypes);
|
||||||
|
|
||||||
FParserDialog = new Menu<std::string>((COLS-FParserDialogWidth)/2, (MainHeight-FParserDialogHeight)/2+MainStartY, FParserDialogWidth, FParserDialogHeight, "", Config.main_color, Config.window_border);
|
FParserDialog = new Menu<std::string>((COLS-FParserDialogWidth)/2, (MainHeight-FParserDialogHeight)/2+MainStartY, FParserDialogWidth, FParserDialogHeight, "", Config.main_color, Config.window_border);
|
||||||
FParserDialog->CyclicScrolling(Config.use_cyclic_scrolling);
|
FParserDialog->CyclicScrolling(Config.use_cyclic_scrolling);
|
||||||
FParserDialog->CenteredCursor(Config.centered_cursor);
|
FParserDialog->CenteredCursor(Config.centered_cursor);
|
||||||
FParserDialog->SetItemDisplayer(Display::Generic);
|
FParserDialog->setItemDisplayer(Display::Default<std::string>);
|
||||||
FParserDialog->AddOption("Get tags from filename");
|
FParserDialog->AddOption("Get tags from filename");
|
||||||
FParserDialog->AddOption("Rename files");
|
FParserDialog->AddOption("Rename files");
|
||||||
FParserDialog->AddSeparator();
|
FParserDialog->AddSeparator();
|
||||||
@@ -127,7 +127,7 @@ void TagEditor::Init()
|
|||||||
FParser = new Menu<std::string>((COLS-FParserWidth)/2, (MainHeight-FParserHeight)/2+MainStartY, FParserWidthOne, FParserHeight, "_", Config.main_color, Config.active_window_border);
|
FParser = new Menu<std::string>((COLS-FParserWidth)/2, (MainHeight-FParserHeight)/2+MainStartY, FParserWidthOne, FParserHeight, "_", Config.main_color, Config.active_window_border);
|
||||||
FParser->CyclicScrolling(Config.use_cyclic_scrolling);
|
FParser->CyclicScrolling(Config.use_cyclic_scrolling);
|
||||||
FParser->CenteredCursor(Config.centered_cursor);
|
FParser->CenteredCursor(Config.centered_cursor);
|
||||||
FParser->SetItemDisplayer(Display::Generic);
|
FParser->setItemDisplayer(Display::Default<std::string>);
|
||||||
|
|
||||||
FParserLegend = new Scrollpad((COLS-FParserWidth)/2+FParserWidthOne, (MainHeight-FParserHeight)/2+MainStartY, FParserWidthTwo, FParserHeight, "Legend", Config.main_color, Config.window_border);
|
FParserLegend = new Scrollpad((COLS-FParserWidth)/2+FParserWidthOne, (MainHeight-FParserHeight)/2+MainStartY, FParserWidthTwo, FParserHeight, "Legend", Config.main_color, Config.window_border);
|
||||||
|
|
||||||
|
|||||||
@@ -48,7 +48,7 @@ void TinyTagEditor::Init()
|
|||||||
w->HighlightColor(Config.main_highlight_color);
|
w->HighlightColor(Config.main_highlight_color);
|
||||||
w->CyclicScrolling(Config.use_cyclic_scrolling);
|
w->CyclicScrolling(Config.use_cyclic_scrolling);
|
||||||
w->CenteredCursor(Config.centered_cursor);
|
w->CenteredCursor(Config.centered_cursor);
|
||||||
w->SetItemDisplayer(Display::Generic);
|
w->setItemDisplayer(Display::Default<Buffer>);
|
||||||
isInitialized = 1;
|
isInitialized = 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user