X-Git-Url: https://git.lyx.org/gitweb/?a=blobdiff_plain;f=src%2FFuncRequest.cpp;h=c8fd2f9ed11cb94b4a6e692e71e995ce5d617688;hb=3a123b90af838b08680471d87170c38e56787df9;hp=7755a86957f06aaba4c8f8c04c8132d2f4231fad;hpb=1ba5857f26ffda97decd3f56aeacb033fd063173;p=lyx.git diff --git a/src/FuncRequest.cpp b/src/FuncRequest.cpp index 7755a86957..c8fd2f9ed1 100644 --- a/src/FuncRequest.cpp +++ b/src/FuncRequest.cpp @@ -13,6 +13,7 @@ #include "FuncRequest.h" #include "LyXAction.h" +#include "support/debug.h" #include "support/lstrings.h" #include @@ -29,59 +30,49 @@ FuncRequest const FuncRequest::unknown(LFUN_UNKNOWN_ACTION); FuncRequest const FuncRequest::noaction(LFUN_NOACTION); FuncRequest::FuncRequest(Origin o) - : action(LFUN_NOACTION), origin(o), x(0), y(0), - button_(mouse_button::none) + : action_(LFUN_NOACTION), origin_(o), x_(0), y_(0), + button_(mouse_button::none), modifier_(NoModifier), allow_async_(true) {} FuncRequest::FuncRequest(FuncCode act, Origin o) - : action(act), origin(o), x(0), y(0), button_(mouse_button::none) + : action_(act), origin_(o), x_(0), y_(0), + button_(mouse_button::none), modifier_(NoModifier), allow_async_(true) {} FuncRequest::FuncRequest(FuncCode act, docstring const & arg, Origin o) - : action(act), argument_(arg), origin(o), x(0), y(0), - button_(mouse_button::none) + : action_(act), argument_(arg), origin_(o), x_(0), y_(0), + button_(mouse_button::none), modifier_(NoModifier), allow_async_(true) {} FuncRequest::FuncRequest(FuncCode act, string const & arg, Origin o) - : action(act), argument_(from_utf8(arg)), origin(o), x(0), y(0), - button_(mouse_button::none) + : action_(act), argument_(from_utf8(arg)), origin_(o), x_(0), y_(0), + button_(mouse_button::none), modifier_(NoModifier), allow_async_(true) {} FuncRequest::FuncRequest(FuncCode act, int ax, int ay, - mouse_button::state but, Origin o) - : action(act), origin(o), x(ax), y(ay), button_(but) + mouse_button::state but, KeyModifier modifier, Origin o) + : action_(act), origin_(o), x_(ax), y_(ay), button_(but), + modifier_(modifier), allow_async_(true) {} 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_) + : action_(cmd.action()), argument_(arg), origin_(o), x_(cmd.x_), y_(cmd.y_), + button_(cmd.button_), modifier_(NoModifier), allow_async_(true) {} -FuncRequest::FuncRequest(FuncRequest const & cmd, string const & arg, Origin o) - : action(cmd.action), argument_(from_utf8(arg)), origin(o), - x(cmd.x), y(cmd.y), button_(cmd.button_) -{} - - -mouse_button::state FuncRequest::button() const -{ - return button_; -} - - namespace { -// Extracts arguments from str into args. Arguments are delimted by +// Extracts arguments from str into args. Arguments are delimited by // whitespace or by double quotes. -// We extract at most max arguments, treating the last argument as +// We extract at most max + 1 arguments, treating args[max] as // continuing to eol. -void splitArg(vector & args, string const & str, +void splitArg(vector & args, string const & str, unsigned int max = UINT_MAX) { istringstream is(str); @@ -91,7 +82,7 @@ void splitArg(vector & args, string const & str, getline(is, s); args.push_back(trim(s)); return; - } + } char c; string s; @@ -110,7 +101,7 @@ void splitArg(vector & args, string const & str, } } -} +} // namespace string FuncRequest::getArg(unsigned int i) const { @@ -130,19 +121,26 @@ string FuncRequest::getLongArg(unsigned int i) const 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(); } ostream & operator<<(ostream & os, FuncRequest const & cmd) { return os - << " action: " << cmd.action - << " [" << lyxaction.getActionName(cmd.action) << "] " + << " action: " << cmd.action() + << " [" << lyxaction.getActionName(cmd.action()) << "] " << " arg: '" << to_utf8(cmd.argument()) << "'" - << " x: " << cmd.x - << " y: " << cmd.y; + << " x: " << cmd.x() + << " y: " << cmd.y(); } +LyXErr & operator<<(LyXErr &l, FuncRequest const &fr) +{ + ostringstream oss; + oss << fr; + return l << oss.str(); +} + } // namespace lyx