menu: some member name changing

This commit is contained in:
Andrzej Rybczak
2012-08-30 07:07:19 +02:00
parent 0447b4e881
commit 798c9b3121
15 changed files with 252 additions and 251 deletions

View File

@@ -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);
} }
} }

View File

@@ -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())

View File

@@ -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;
} }

View File

@@ -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;

View File

@@ -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; }

View File

@@ -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;

View File

@@ -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 "";
} }

View File

@@ -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

View File

@@ -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();

View File

@@ -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));

View File

@@ -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);

View File

@@ -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);

View File

@@ -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");

View File

@@ -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);

View File

@@ -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;
} }