summaryrefslogtreecommitdiffstats
path: root/crawl-ref/source/menu.cc
diff options
context:
space:
mode:
Diffstat (limited to 'crawl-ref/source/menu.cc')
-rw-r--r--crawl-ref/source/menu.cc20
1 files changed, 13 insertions, 7 deletions
diff --git a/crawl-ref/source/menu.cc b/crawl-ref/source/menu.cc
index 6b368433cb..f9afedac4c 100644
--- a/crawl-ref/source/menu.cc
+++ b/crawl-ref/source/menu.cc
@@ -16,12 +16,13 @@
#include "view.h"
#include "initfile.h"
-Menu::Menu( int _flags )
+Menu::Menu( int _flags, const std::string& tagname )
: f_selitem(NULL),
f_drawitem(NULL),
f_keyfilter(NULL),
title(NULL),
flags(_flags),
+ tag(tagname),
first_entry(0),
y_offset(0),
pagesize(0),
@@ -92,6 +93,7 @@ void Menu::set_title( MenuEntry *e )
void Menu::add_entry( MenuEntry *entry )
{
+ entry->tag = tag;
items.push_back( entry );
}
@@ -1028,15 +1030,19 @@ bool slider_menu::line_up()
// Menu colouring
//
-int menu_colour(const std::string &text, const std::string &prefix)
+int menu_colour(const std::string &text, const std::string &prefix,
+ const std::string &tag)
{
- std::string tmp_text = prefix + text;
+ const std::string tmp_text = prefix + text;
- for (int i = 0, size = Options.menu_colour_mappings.size(); i < size; ++i)
+ for (unsigned int i = 0; i < Options.menu_colour_mappings.size(); ++i)
{
- colour_mapping &cm = Options.menu_colour_mappings[i];
- if (cm.pattern.matches(tmp_text))
+ const colour_mapping &cm = Options.menu_colour_mappings[i];
+ if ( (cm.tag.empty() || cm.tag == "any" || cm.tag == tag) &&
+ cm.pattern.matches(tmp_text) )
+ {
return (cm.colour);
+ }
}
return (-1);
}
@@ -1411,7 +1417,7 @@ bool formatted_scroller::page_up()
bool formatted_scroller::line_down()
{
- if (first_entry + pagesize < (int) items.size() &&
+ if (first_entry + pagesize < static_cast<int>(items.size()) &&
items[first_entry + pagesize]->level != MEL_TITLE )
{
++first_entry;