3 * Interface definition for encapsulated commands.
4 * Started Spring 2001 by David Megginson, david@megginson.com
5 * This code is released into the Public Domain.
11 # include <simgear_config.h>
14 #include <boost/foreach.hpp>
15 #include <simgear/compiler.h>
16 #include "SGBinding.hxx"
18 #include <simgear/props/props_io.hxx>
19 #include <simgear/structure/exception.hxx>
21 SGBinding::SGBinding()
23 _arg(new SGPropertyNode),
28 SGBinding::SGBinding(const std::string& commandName)
33 _command_name = commandName;
36 SGBinding::SGBinding(const SGPropertyNode* node, SGPropertyNode* root)
44 SGBinding::~SGBinding()
46 if(_arg && _arg->getParent())
47 _arg->getParent()->removeChild(_arg->getName(), _arg->getIndex(), false);
51 SGBinding::read(const SGPropertyNode* node, SGPropertyNode* root)
53 const SGPropertyNode * conditionNode = node->getChild("condition");
54 if (conditionNode != 0)
55 setCondition(sgReadCondition(root, conditionNode));
57 _command_name = node->getStringValue("command", "");
58 if (_command_name.empty()) {
59 SG_LOG(SG_INPUT, SG_WARN, "No command supplied for binding.");
63 _arg = const_cast<SGPropertyNode*>(node);
68 SGBinding::fire() const
76 SGBinding::innerFire () const
79 _command = SGCommandMgr::instance()->getCommand(_command_name);
81 SG_LOG(SG_INPUT, SG_WARN, "No command attached to binding:" << _command_name);
84 if (!(*_command)(_arg)) {
85 SG_LOG(SG_INPUT, SG_ALERT, "Failed to execute command "
88 } catch (sg_exception& e) {
89 SG_LOG(SG_GENERAL, SG_ALERT, "command '" << _command_name << "' failed with exception\n"
90 << "\tmessage:" << e.getMessage() << " (from " << e.getOrigin() << ")");
96 SGBinding::fire (SGPropertyNode* params) const
100 copyProperties(params, _arg);
108 SGBinding::fire (double offset, double max) const
111 _arg->setDoubleValue("offset", offset/max);
117 SGBinding::fire (double setting) const
120 // A value is automatically added to
122 if (_setting == 0) // save the setting node for efficiency
123 _setting = _arg->getChild("setting", 0, true);
124 _setting->setDoubleValue(setting);
129 void fireBindingList(const SGBindingList& aBindings, SGPropertyNode* params)
131 BOOST_FOREACH(SGBinding_ptr b, aBindings) {
136 void fireBindingListWithOffset(const SGBindingList& aBindings, double offset, double max)
138 BOOST_FOREACH(SGBinding_ptr b, aBindings) {
139 b->fire(offset, max);
143 SGBindingList readBindingList(const simgear::PropertyList& aNodes, SGPropertyNode* aRoot)
145 SGBindingList result;
146 BOOST_FOREACH(SGPropertyNode* node, aNodes) {
147 result.push_back(new SGBinding(node, aRoot));