]> git.lyx.org Git - lyx.git/blobdiff - src/ToolbarBackend.C
Point fix, earlier forgotten
[lyx.git] / src / ToolbarBackend.C
index 1d379e0ab6004d5654edaa608ca2bdee02cc2820..099d9cafaf7af9dfd885e7432587759d99662571 100644 (file)
@@ -3,9 +3,10 @@
  * This file is part of LyX, the document processor.
  * Licence details can be found in the file COPYING.
  *
- * \author unknown
+ * \author Jean-Marc Lasgouttes
+ * \author John Levon
  *
- * Full author contact details are available in file CREDITS
+ * Full author contact details are available in file CREDITS.
  */
 
 #include <config.h>
 
 #include <vector>
 
+using namespace lyx::support;
+
 using std::endl;
 using std::vector;
+using std::make_pair;
 
 ToolbarBackend toolbarbackend;
 
@@ -68,39 +72,6 @@ void ToolbarBackend::read(LyXLex & lex)
 
        Toolbar tb;
        tb.name = lex.getString();
-       lex.next(true);
-       
-       tb.flags = static_cast<Flags>(0);
-       string flagstr = lex.getString();
-       vector<string> flags = getVectorFromString(flagstr);
-
-       vector<string>::const_iterator cit = flags.begin();
-       vector<string>::const_iterator end = flags.end();
-
-       for (; cit != end; ++cit) {
-               int flag = 0;
-               if (!compare_ascii_no_case(*cit, "off"))
-                       flag = OFF;
-               else if (!compare_ascii_no_case(*cit, "on"))
-                       flag = ON;
-               else if (!compare_ascii_no_case(*cit, "math"))
-                       flag = MATH;
-               else if (!compare_ascii_no_case(*cit, "table"))
-                       flag = TABLE;
-               else if (!compare_ascii_no_case(*cit, "top"))
-                       flag = TOP;
-               else if (!compare_ascii_no_case(*cit, "bottom"))
-                       flag = BOTTOM;
-               else if (!compare_ascii_no_case(*cit, "left"))
-                       flag = LEFT;
-               else if (!compare_ascii_no_case(*cit, "right"))
-                       flag = RIGHT;
-               else {
-                       lyxerr << "ToolbarBackend::read: unrecognised token:`"
-                              << *cit << '\'' << endl;
-               }
-               tb.flags = static_cast<Flags>(tb.flags | flag);
-       }
 
        bool quit = false;
 
@@ -151,6 +122,74 @@ void ToolbarBackend::read(LyXLex & lex)
 }
 
 
+void ToolbarBackend::readToolbars(LyXLex & lex)
+{
+       //consistency check
+       if (compare_ascii_no_case(lex.getString(), "toolbars")) {
+               lyxerr << "ToolbarBackend::read: ERROR wrong token:`"
+                      << lex.getString() << '\'' << endl;
+       }
+
+       lex.next(true);
+
+       while (lex.isOK()) {
+               string name = lex.getString();
+               lex.next(true);
+
+               if (!compare_ascii_no_case(name, "end"))
+                       return;
+
+               Toolbars::iterator tcit = toolbars.begin();
+               Toolbars::iterator tend = toolbars.end();
+               for (; tcit != tend; ++tcit) {
+                       if (tcit->name == name)
+                               break;
+               }
+
+               if (tcit == tend) {
+                       lyxerr << "ToolbarBackend: undefined toolbar "
+                               << name << endl;
+                       return;
+               }
+
+               tcit->flags = static_cast<Flags>(0);
+               string flagstr = lex.getString();
+               lex.next(true);
+               vector<string> flags = getVectorFromString(flagstr);
+
+               vector<string>::const_iterator cit = flags.begin();
+               vector<string>::const_iterator end = flags.end();
+
+               for (; cit != end; ++cit) {
+                       int flag = 0;
+                       if (!compare_ascii_no_case(*cit, "off"))
+                               flag = OFF;
+                       else if (!compare_ascii_no_case(*cit, "on"))
+                               flag = ON;
+                       else if (!compare_ascii_no_case(*cit, "math"))
+                               flag = MATH;
+                       else if (!compare_ascii_no_case(*cit, "table"))
+                               flag = TABLE;
+                       else if (!compare_ascii_no_case(*cit, "top"))
+                               flag = TOP;
+                       else if (!compare_ascii_no_case(*cit, "bottom"))
+                               flag = BOTTOM;
+                       else if (!compare_ascii_no_case(*cit, "left"))
+                               flag = LEFT;
+                       else if (!compare_ascii_no_case(*cit, "right"))
+                               flag = RIGHT;
+                       else {
+                               lyxerr << "ToolbarBackend::read: unrecognised token:`"
+                                      << *cit << '\'' << endl;
+                       }
+                       tcit->flags = static_cast<Flags>(tcit->flags | flag);
+               }
+
+               usedtoolbars.push_back(*tcit);
+       }
+}
+
+
 void ToolbarBackend::add(Toolbar & tb, int action, string const & tooltip)
 {
        tb.items.push_back(make_pair(action, tooltip));
@@ -201,5 +240,8 @@ string const ToolbarBackend::getIcon(int action)
                return fullname;
        }
 
+       lyxerr[Debug::GUI] << "Cannot find icon for command \""
+                          << lyxaction.getActionName(f.action)
+                          << ' ' << f.argument << '"' << endl;
        return LibFileSearch("images", "unknown", "xpm");
 }