class LyXErr;
+namespace frontend {
+ class GuiView;
+}
+
/**
* This class encapsulates a LyX action and its argument
* in order to pass it around easily.
MENU, // A menu entry
TOOLBAR, // A toolbar icon
KEYBOARD, // a keyboard binding
- COMMANDBUFFER,
+ COMMANDBUFFER,
LYXSERVER,
TOC
};
/// for changing requests a bit
FuncRequest(FuncRequest const & cmd, docstring const & arg,
Origin o = INTERNAL);
-
+
/// access the whole argument
docstring const & argument() const { return argument_; }
///
///
void setOrigin(Origin o) { origin_ = o; }
///
+ frontend::GuiView* view_origin() const { return view_origin_; }
+ ///
+ void setViewOrigin(frontend::GuiView* o) { view_origin_ = o; }
+ ///
int x() const { return x_; }
///
int y() const { return y_; }
///
void set_y(int y) { y_ = y; }
- ///
+ ///
mouse_button::state button() const { return button_; }
///
KeyModifier modifier() { return modifier_; }
/// eating all characters up to the end of the command line
std::string getLongArg(unsigned int i) const;
- ///
+ ///
static FuncRequest const unknown;
- ///
+ ///
static FuncRequest const noaction;
+ ///
+ bool allowAsync() const { return allow_async_; }
+ ///
+ void allowAsync(bool allow_async) { allow_async_ = allow_async; }
+
private:
/// the action
FuncCode action_;
docstring argument_;
/// who initiated the action
Origin origin_;
+ /// to which view should be this command sent (see bug #11004)
+ /// NULL=current view
+ frontend::GuiView* view_origin_;
/// the x coordinate of a mouse press
int x_;
/// the y coordinate of a mouse press
mouse_button::state button_;
///
KeyModifier modifier_;
+ /// Commands should be run synchronously when they
+ /// are launched via "command-sequence" or "repeat" or "buffer-forall"
+ bool allow_async_;
};