X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=simgear%2Fstructure%2Fcommands.cxx;h=6f6db1c661bad0544adb28150c0e946b22684a0c;hb=200df49d6e2d8896e1deaa6da7af5b4a91058a4f;hp=49a9c63cde0d605c94d73f537a7cc5b95f515126;hpb=2ea2f1b4f29afe7d74e0474ca02874387526e804;p=simgear.git diff --git a/simgear/structure/commands.cxx b/simgear/structure/commands.cxx index 49a9c63c..6f6db1c6 100644 --- a/simgear/structure/commands.cxx +++ b/simgear/structure/commands.cxx @@ -4,13 +4,21 @@ // // $Id$ +#ifdef HAVE_CONFIG_H +# include +#endif + #include #include -#include -#include + +#include +#include #include "commands.hxx" +#include +#include +#include //////////////////////////////////////////////////////////////////////// @@ -28,6 +36,8 @@ SGCommandMgr::~SGCommandMgr () // no-op } +OpenThreads::Mutex SGCommandMgr::_instanceMutex; + SGCommandMgr* SGCommandMgr::instance() { @@ -35,8 +45,7 @@ SGCommandMgr::instance() if (mgr.get()) return mgr.get(); - static SGMutex lock; - SGGuard guard(lock); + OpenThreads::ScopedLock lock(_instanceMutex); if (mgr.get()) return mgr.get(); @@ -45,22 +54,22 @@ SGCommandMgr::instance() } void -SGCommandMgr::addCommand (const string &name, command_t command) +SGCommandMgr::addCommand (const std::string &name, command_t command) { _commands[name] = command; } SGCommandMgr::command_t -SGCommandMgr::getCommand (const string &name) const +SGCommandMgr::getCommand (const std::string &name) const { const command_map::const_iterator it = _commands.find(name); return (it != _commands.end() ? it->second : 0); } -vector +string_list SGCommandMgr::getCommandNames () const { - vector names; + string_list names; command_map::const_iterator it = _commands.begin(); command_map::const_iterator last = _commands.end(); while (it != last) { @@ -71,13 +80,20 @@ SGCommandMgr::getCommandNames () const } bool -SGCommandMgr::execute (const string &name, const SGPropertyNode * arg) const +SGCommandMgr::execute (const std::string &name, const SGPropertyNode * arg) const { command_t command = getCommand(name); if (command == 0) return false; - else + + + try { return (*command)(arg); + } catch (sg_exception& e) { + SG_LOG(SG_GENERAL, SG_ALERT, "command '" << name << "' failed with exception\n" + << "\tmessage:" << e.getMessage() << " (from " << e.getOrigin() << ")"); + return false; + } } // end of commands.cxx