#include "lfuns.h"
-#include <boost/utility.hpp>
-
#include <map>
#include <string>
+
+namespace lyx {
+
class FuncRequest;
/**
* dynamically, for encapsulating a real action and an
* argument. They are used for things like the menus.
*/
-class LyXAction : boost::noncopyable {
+class LyXAction {
+public:
+ /// category of an action, used in the Shortcuts dialog
+ enum func_type {
+ Hidden, //< Not listed for configuration
+ Edit, //< Cursor and mouse movement, copy/paste etc
+ Math, //< Mathematics
+ Buffer, //< Buffer and window related
+ Layout, //< Font, Layout and textclass related
+ System, //< Lyx preference, server etc
+ };
+
private:
/// information for an action
struct func_info {
std::string name;
/// the func_attrib values set
unsigned int attrib;
+ /// the category of this func
+ func_type type;
};
public:
+ /// noncopyable
+ LyXAction(LyXAction const &);
+ void operator=(LyXAction const &);
+
/// type for map between a function name and its action
typedef std::map<std::string, kb_action> func_map;
/// type for map between an action and its info
/// Return the name (and argument) associated with the given (pseudo) action
std::string const getActionName(kb_action action) const;
+ func_type const getActionType(kb_action action) const;
+
/// True if the command has `flag' set
bool funcHasFlag(kb_action action, func_attrib flag) const;
/// populate the action container with our actions
void init();
/// add the given action
- void newFunc(kb_action, std::string const & name, unsigned int attrib);
+ void newFunc(kb_action, std::string const & name, unsigned int attrib, func_type type);
/**
* This is a list of all the LyXFunc names with the
/// singleton instance
extern LyXAction lyxaction;
+
+} // namespace lyx
+
#endif // LYXACTION_H