X-Git-Url: https://git.lyx.org/gitweb/?a=blobdiff_plain;f=src%2FFuncRequest.cpp;h=c912b3a0ae14094b8a425da79722a19dfd9af27d;hb=c7ad447f98758c1797f4dc3d7371326bcfa842a0;hp=296728aca2b87d9068bde04be149eb3db8d137a2;hpb=3e3955c4f3ee3302d2e1aae643be37ee3b758512;p=lyx.git diff --git a/src/FuncRequest.cpp b/src/FuncRequest.cpp index 296728aca2..c912b3a0ae 100644 --- a/src/FuncRequest.cpp +++ b/src/FuncRequest.cpp @@ -3,7 +3,7 @@ * This file is part of LyX, the document processor. * Licence details can be found in the file COPYING. * - * \author André Pönitz + * \author André Pönitz * * Full author contact details are available in file CREDITS. */ @@ -11,78 +11,93 @@ #include #include "FuncRequest.h" +#include "LyXAction.h" +#include "support/debug.h" +#include "support/lstrings.h" + +#include #include #include #include -using std::getline; -using std::istringstream; -using std::vector; -using std::string; - +using namespace std; +using namespace lyx::support; namespace lyx { +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), + : action_(LFUN_NOACTION), origin_(o), x_(0), y_(0), button_(mouse_button::none) {} -FuncRequest::FuncRequest(kb_action act, Origin o) - : action(act), origin(o), x(0), y(0), button_(mouse_button::none) +FuncRequest::FuncRequest(FuncCode act, Origin o) + : action_(act), origin_(o), x_(0), y_(0), + button_(mouse_button::none) {} -FuncRequest::FuncRequest(kb_action act, docstring const & arg, Origin o) - : action(act), argument_(arg), origin(o), x(0), y(0), +FuncRequest::FuncRequest(FuncCode 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_(from_utf8(arg)), origin(o), x(0), y(0), +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) {} -FuncRequest::FuncRequest(kb_action act, int ax, int ay, +FuncRequest::FuncRequest(FuncCode act, int ax, int ay, mouse_button::state but, Origin o) - : action(act), origin(o), x(ax), y(ay), button_(but) + : action_(act), origin_(o), x_(ax), y_(ay), button_(but) {} 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_) {} 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_) + : 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 { -void split(vector & args, string const & str) +// Extracts arguments from str into args. Arguments are delimted by +// whitespace or by double quotes. +// We extract at most max + 1 arguments, treating args[max] as +// continuing to eol. +void splitArg(vector & args, string const & str, + unsigned int max = UINT_MAX) { istringstream is(str); while (is) { + if (args.size() == max) { + string s; + getline(is, s); + args.push_back(trim(s)); + return; + } + char c; string s; is >> c; if (is) { if (c == '"') + // get quote delimited argument getline(is, s, '"'); else { + // get whitespace delimited argument is.putback(c); is >> s; } @@ -91,29 +106,46 @@ void split(vector & args, string const & str) } } +} string FuncRequest::getArg(unsigned int i) const { vector args; - split(args, to_utf8(argument_)); + splitArg(args, to_utf8(argument_)); + return i < args.size() ? args[i] : string(); +} + + +string FuncRequest::getLongArg(unsigned int i) const +{ + vector args; + splitArg(args, to_utf8(argument_), i); 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(); } -std::ostream & operator<<(std::ostream & os, FuncRequest const & cmd) +ostream & operator<<(ostream & os, FuncRequest const & cmd) { return os - << " action: " << 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