]> git.tdb.fi Git - libs/gltk.git/blobdiff - source/style.cpp
Add method to get a Part by name
[libs/gltk.git] / source / style.cpp
index 0bc931188e7e93ee9356cae9e90bf79112d27ecd..8eb5de1e79cb7853a1828dfb12248551204ed787 100644 (file)
@@ -17,6 +17,15 @@ Style::Style(Resources &r):
        font(&r.get_default_font())
 { }
 
+const Part *Style::get_part(const string &name) const
+{
+       for(PartSeq::const_iterator i=parts.begin(); i!=parts.end(); ++i)
+               if(i->get_name()==name)
+                       return &*i;
+
+       return 0;
+}
+
 
 Style::Loader::Loader(Style &s, Resources &r):
        style(s),
@@ -24,8 +33,10 @@ Style::Loader::Loader(Style &s, Resources &r):
 {
        add("font",       &Style::font);
        add("font_color", &Loader::font_color);
-       add("part",       &Loader::part);
-       add("special",    &Loader::special);
+       add("part",       static_cast<void (Loader::*)()>(&Loader::part));
+       add("part",       static_cast<void (Loader::*)(const std::string &)>(&Loader::part));
+       // Deprecated alias
+       add("special",    static_cast<void (Loader::*)(const std::string &)>(&Loader::part));
 }
 
 void Style::Loader::font_color(float r, float g, float b)
@@ -35,12 +46,10 @@ void Style::Loader::font_color(float r, float g, float b)
 
 void Style::Loader::part()
 {
-       Part p((string()));
-       load_sub(p, res);
-       style.parts.push_back(p);
+       part(string());
 }
 
-void Style::Loader::special(const string &n)
+void Style::Loader::part(const string &n)
 {
        Part p(n);
        load_sub(p, res);