-#include <Main/fgfs.hxx>
-#include <Main/globals.hxx>
-
-#include <map>
-#include <vector>
-
-SG_USING_STD(map);
-SG_USING_STD(vector);
-
-/**
- * An input binding of some sort.
- *
- * <p>This class represents a binding that can be assigned to a
- * keyboard key, a joystick button or axis, or even a panel
- * instrument.</p>
- */
-class FGBinding
-{
-public:
-
- /**
- * Default constructor.
- */
- FGBinding ();
-
-
- /**
- * Convenience constructor.
- *
- * @param node The binding will be built from this node.
- */
- FGBinding (const SGPropertyNode * node);
-
-
- /**
- * Destructor.
- */
- virtual ~FGBinding ();
-
-
- /**
- * Get the command name.
- *
- * @return The string name of the command for this binding.
- */
- virtual const string &getCommandName () const { return _command_name; }
-
-
- /**
- * Get the command itself.
- *
- * @return The command associated with this binding, or 0 if none
- * is present.
- */
- virtual SGCommandMgr::command_t getCommand () const { return _command; }
-
-
- /**
- * Get the argument that will be passed to the command.
- *
- * @return A property node that will be passed to the command as its
- * argument, or 0 if none was supplied.
- */
- virtual const SGPropertyNode * getArg () { return _arg; }
-
-
- /**
- * Read a binding from a property node.
- *
- * @param node The property node containing the binding.
- */
- virtual void read (const SGPropertyNode * node);
-
-
- /**
- * Fire a binding.
- */
- virtual void fire () const;
-
-
- /**
- * Fire a binding with a setting (i.e. joystick axis).
- *
- * A double 'setting' property will be added to the arguments.
- *
- * @param setting The input setting, usually between -1.0 and 1.0.
- */
- virtual void fire (double setting) const;
-
-
-private:
- void _fire (const SGPropertyNode *arg) const;
- string _command_name;
- SGCommandMgr::command_t _command;
- const SGPropertyNode * _arg;
-};