]> git.lyx.org Git - lyx.git/blobdiff - src/funcrequest.C
* GuiView.C (updateTab): do not update early if current tab has
[lyx.git] / src / funcrequest.C
index 6a9b3fd9a1605e1866b5d756b191265326fcb5c4..156da5c8f3e9a809d9996118f9dd713bd7370643 100644 (file)
 #include <sstream>
 #include <vector>
 
-using std::getline;
 
+namespace lyx {
+
+using std::getline;
 using std::istringstream;
 using std::vector;
 using std::string;
@@ -34,8 +36,14 @@ FuncRequest::FuncRequest(kb_action act, Origin o)
 {}
 
 
+FuncRequest::FuncRequest(kb_action act, docstring const & arg, Origin o)
+       : action(act), argument_(arg), origin(o), x(0), y(0),
+         button_(mouse_button::none)
+{}
+
+
 FuncRequest::FuncRequest(kb_action act, string const & arg, Origin o)
-       : action(act), argument(arg), origin(o), x(0), y(0),
+       : action(act), argument_(from_utf8(arg)), origin(o), x(0), y(0),
          button_(mouse_button::none)
 {}
 
@@ -46,8 +54,14 @@ FuncRequest::FuncRequest(kb_action act, int ax, int ay,
 {}
 
 
+FuncRequest::FuncRequest(FuncRequest const & cmd, docstring const & arg, Origin o)
+       : action(cmd.action), argument_(arg), origin(o),
+         x(cmd.x), y(cmd.y), button_(cmd.button_)
+{}
+
+
 FuncRequest::FuncRequest(FuncRequest const & cmd, string const & arg, Origin o)
-       : action(cmd.action), argument(arg), origin(o),
+       : action(cmd.action), argument_(from_utf8(arg)), origin(o),
          x(cmd.x), y(cmd.y), button_(cmd.button_)
 {}
 
@@ -58,20 +72,22 @@ mouse_button::state FuncRequest::button() const
 }
 
 
-void split(vector<string> & args, string str)
+void split(vector<string> & args, string const & str)
 {
        istringstream is(str);
        while (is) {
                char c;
                string s;
                is >> c;
-               if (c == '"')
-                       getline(is, s, '"');
-               else {
-                       is.putback(c);
-                       is >> s;
+               if (is) {
+                       if (c == '"')
+                               getline(is, s, '"');
+                       else {
+                               is.putback(c);
+                               is >> s;
+                       }
+                       args.push_back(s);
                }
-               args.push_back(s);
        }
 }
 
@@ -79,14 +95,14 @@ void split(vector<string> & args, string str)
 string FuncRequest::getArg(unsigned int i) const
 {
        vector<string> args;
-       split(args, argument);
+       split(args, to_utf8(argument_));
        return i < args.size() ? args[i] : string();
 }
 
 
 bool operator==(FuncRequest const & lhs, FuncRequest const & rhs)
 {
-       return lhs.action == rhs.action && lhs.argument == rhs.argument;
+       return lhs.action == rhs.action && lhs.argument() == rhs.argument();
 }
 
 
@@ -94,7 +110,10 @@ std::ostream & operator<<(std::ostream & os, FuncRequest const & cmd)
 {
        return os
                << " action: " << cmd.action
-               << " arg: '" << cmd.argument << "'"
+               << " arg: '" << to_utf8(cmd.argument()) << "'"
                << " x: " << cmd.x
                << " y: " << cmd.y;
 }
+
+
+} // namespace lyx