* \author André Pönitz
*/
+#include <config.h>
+
#include "funcrequest.h"
+#include "BufferView.h"
+#include "lyxfunc.h" // only for setMessage()
+#include "frontends/LyXView.h"
+#include "debug.h"
+#include "Lsstream.h"
+
+
+using std::vector;
+using std::getline;
+using std::endl;
+
FuncRequest::FuncRequest()
- : view_(0), action(LFUN_UNKNOWN_ACTION)
+ : view_(0), action(LFUN_UNKNOWN_ACTION), button_(mouse_button::none)
{}
FuncRequest::FuncRequest(kb_action act)
- : view_(0), action(act)
+ : view_(0), action(act), button_(mouse_button::none)
{}
FuncRequest::FuncRequest(kb_action act, string const & arg)
- : view_(0), action(act), argument(arg)
+ : view_(0), action(act), argument(arg), button_(mouse_button::none)
+{}
+
+
+FuncRequest::FuncRequest
+ (kb_action act, int ax, int ay, mouse_button::state button)
+ : view_(0), action(act), argument(), x(ax), y(ay), button_(button)
{}
FuncRequest::FuncRequest(BufferView * view, kb_action act)
- : view_(view), action(act)
+ : view_(view), action(act), button_(mouse_button::none)
{}
FuncRequest::FuncRequest(BufferView * view, kb_action act, string const & arg)
- : view_(view), action(act), argument(arg)
+ : view_(view), action(act), argument(arg), button_(mouse_button::none)
{}
FuncRequest::FuncRequest
- (BufferView * view, kb_action act, int ax, int ay, int aextra)
- : view_(view), action(act), argument(), x(ax), y(ay), extra(aextra)
+ (BufferView * view, kb_action act, int ax, int ay, mouse_button::state but)
+ : view_(view), action(act), argument(), x(ax), y(ay), button_(but)
+{}
+
+
+FuncRequest::FuncRequest(FuncRequest const & cmd, string const & arg)
+ : view_(cmd.view_), action(cmd.action), argument(arg),
+ x(cmd.x), y(cmd.y), button_(cmd.button_)
+{}
+
+
+FuncRequest::FuncRequest(FuncRequest const & cmd, BufferView * view)
+ : view_(view), action(cmd.action), argument(cmd.argument),
+ x(cmd.x), y(cmd.y), button_(cmd.button_)
{}
{
view_ = view;
}
+
+
+mouse_button::state FuncRequest::button() const
+{
+ return button_;
+}
+
+
+void FuncRequest::message(string const & msg) const
+{
+ if (view_)
+ view_->owner()->getLyXFunc().setMessage(msg);
+ else
+ lyxerr << "Dropping message '" << msg << "'" << endl;
+}
+
+
+void FuncRequest::errorMessage(string const & msg) const
+{
+ if (view_)
+ view_->owner()->getLyXFunc().setErrorMessage(msg);
+ else
+ lyxerr << "Dropping error message '" << msg << "'" << endl;
+}
+
+
+void split(vector<string> & args, string str)
+{
+ istringstream is(STRCONV(str));
+ while (is) {
+ char c;
+ string s;
+ is >> c;
+ if (c == '"')
+ getline(is, s, '"');
+ else {
+ is.putback(c);
+ is >> s;
+ }
+ args.push_back(s);
+ }
+}
+
+
+string FuncRequest::getArg(int i) const
+{
+ vector<string> args;
+ split(args, argument);
+ return i < args.size() ? args[i] : string();
+}