Orocos Real-Time Toolkit  2.5.0
OperationInterface.cpp
00001 /***************************************************************************
00002   tag: The SourceWorks  Tue Sep 7 00:55:18 CEST 2010  OperationInterface.cpp
00003 
00004                         OperationInterface.cpp -  description
00005                            -------------------
00006     begin                : Tue September 07 2010
00007     copyright            : (C) 2010 The SourceWorks
00008     email                : peter@thesourceworks.com
00009 
00010  ***************************************************************************
00011  *   This library is free software; you can redistribute it and/or         *
00012  *   modify it under the terms of the GNU General Public                   *
00013  *   License as published by the Free Software Foundation;                 *
00014  *   version 2 of the License.                                             *
00015  *                                                                         *
00016  *   As a special exception, you may use this file as part of a free       *
00017  *   software library without restriction.  Specifically, if other files   *
00018  *   instantiate templates or use macros or inline functions from this     *
00019  *   file, or you compile this file and link it with other files to        *
00020  *   produce an executable, this file does not by itself cause the         *
00021  *   resulting executable to be covered by the GNU General Public          *
00022  *   License.  This exception does not however invalidate any other        *
00023  *   reasons why the executable file might be covered by the GNU General   *
00024  *   Public License.                                                       *
00025  *                                                                         *
00026  *   This library is distributed in the hope that it will be useful,       *
00027  *   but WITHOUT ANY WARRANTY; without even the implied warranty of        *
00028  *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU     *
00029  *   Lesser General Public License for more details.                       *
00030  *                                                                         *
00031  *   You should have received a copy of the GNU General Public             *
00032  *   License along with this library; if not, write to the Free Software   *
00033  *   Foundation, Inc., 59 Temple Place,                                    *
00034  *   Suite 330, Boston, MA  02111-1307  USA                                *
00035  *                                                                         *
00036  ***************************************************************************/
00037 
00038 
00039 #include "OperationInterface.hpp"
00040 #include "FactoryExceptions.hpp"
00041 #include <algorithm>
00042 #include "internal/mystd.hpp"
00043 #include "internal/Exceptions.hpp"
00044 #include "Handle.hpp"
00045 
00046 using namespace RTT;
00047 using namespace RTT::detail;
00048 
00049 OperationInterfacePart::~OperationInterfacePart()
00050 {
00051 }
00052 
00053 boost::shared_ptr<base::DisposableInterface> OperationInterfacePart::getLocalOperation() const
00054 {
00055     return boost::shared_ptr<base::DisposableInterface>();
00056 }
00057 
00058 void OperationInterface::clear()
00059 {
00060     for (map_t::iterator i = data.begin(); i != data.end(); ++i)
00061         delete i->second;
00062     data.clear();
00063 }
00064 
00065 std::vector<std::string> OperationInterface::getNames() const
00066 {
00067     std::vector<std::string> ret;
00068     std::transform(data.begin(), data.end(), std::back_inserter(ret), select1st<map_t::value_type> ());
00069     return ret;
00070 }
00071 
00072 bool OperationInterface::hasMember(const std::string& name) const
00073 {
00074     return data.find(name) != data.end();
00075 }
00076 
00077 int OperationInterface::getArity(const std::string& name) const
00078 {
00079     map_t::const_iterator i = data.find(name);
00080     if (i == data.end() || i->second == 0)
00081         return -1;
00082     return i->second->arity();
00083 }
00084 
00085 int OperationInterface::getCollectArity(const std::string& name) const
00086 {
00087     map_t::const_iterator i = data.find(name);
00088     if (i == data.end() || i->second == 0)
00089         return -1;
00090     return i->second->collectArity();
00091 }
00092 
00093 bool OperationInterface::isSynchronous(const std::string& name) const
00094 {
00095     if (!hasMember(name))
00096         return false;
00097     try {
00098         produceHandle(name);
00099     } catch(...) {
00100         return true;
00101     }
00102     return false;
00103 }
00104 
00105 base::DataSourceBase::shared_ptr OperationInterface::produce(const std::string& name, const Arguments& args, ExecutionEngine* caller) const
00106 {
00107     map_t::const_iterator i = data.find(name);
00108     if (i == data.end() || i->second == 0)
00109         ORO_THROW_OR_RETURN(name_not_found_exception(), 0);
00110     return i->second->produce(args, caller);
00111 }
00112 
00113 base::DataSourceBase::shared_ptr OperationInterface::produceSend(const std::string& name, const Arguments& args, ExecutionEngine* caller) const
00114 {
00115     map_t::const_iterator i = data.find(name);
00116     if (i == data.end() || i->second == 0)
00117         ORO_THROW_OR_RETURN(name_not_found_exception(), 0);
00118     return i->second->produceSend(args, caller);
00119 }
00120 
00121 base::DataSourceBase::shared_ptr OperationInterface::produceHandle(const std::string& name) const
00122 {
00123     map_t::const_iterator i = data.find(name);
00124     if (i == data.end() || i->second == 0)
00125         ORO_THROW_OR_RETURN(name_not_found_exception(), 0);
00126     return i->second->produceHandle();
00127 }
00128 
00129 base::DataSourceBase::shared_ptr OperationInterface::produceCollect(const std::string& name, const Arguments& args, DataSource<bool>::shared_ptr blocking) const
00130 {
00131     map_t::const_iterator i = data.find(name);
00132     if (i == data.end() || i->second == 0)
00133         ORO_THROW_OR_RETURN(name_not_found_exception(), 0);
00134     return i->second->produceCollect(args, blocking);
00135 }
00136 
00137 #ifdef ORO_SIGNALLING_OPERATIONS
00138 Handle OperationInterface::produceSignal(const std::string& name, base::ActionInterface* act, const Arguments& args) const
00139 {
00140     map_t::const_iterator i = data.find(name);
00141     if (i == data.end() || i->second == 0)
00142         ORO_THROW_OR_RETURN(name_not_found_exception(), 0);
00143     return i->second->produceSignal(act, args);
00144 }
00145 #endif
00146 OperationInterface::Descriptions OperationInterface::getArgumentList(const std::string& name) const
00147 {
00148     map_t::const_iterator i = data.find(name);
00149     if (i == data.end() || i->second == 0)
00150         ORO_THROW_OR_RETURN(name_not_found_exception(), Descriptions());
00151     return i->second->getArgumentList();
00152 }
00153 
00154 std::string OperationInterface::getResultType(const std::string& name) const
00155 {
00156     map_t::const_iterator i = data.find(name);
00157     if (i == data.end() || i->second == 0)
00158         ORO_THROW_OR_RETURN(name_not_found_exception(), std::string());
00159     return i->second->resultType();
00160 }
00161 
00162 std::string OperationInterface::getDescription(const std::string& name) const
00163 {
00164     map_t::const_iterator i = data.find(name);
00165     if (i == data.end() || i->second == 0)
00166         ORO_THROW_OR_RETURN(name_not_found_exception(), std::string());
00167     return i->second->description();
00168 }
00169 
00170 void OperationInterface::add(const std::string& name, OperationInterfacePart* part)
00171 {
00172     map_t::iterator i = data.find(name);
00173     if (i != data.end())
00174         delete i->second;
00175     data[name] = part;
00176 }
00177 
00178 void OperationInterface::remove(const std::string& name)
00179 {
00180     map_t::iterator i = data.find(name);
00181     if (i != data.end())
00182     {
00183         delete i->second;
00184         data.erase(i);
00185     }
00186 }
00187 
00188 OperationInterfacePart* OperationInterface::getPart(const std::string& name)
00189 {
00190     map_t::iterator i = data.find(name);
00191     if (i != data.end())
00192     {
00193         return i->second;
00194     }
00195     return 0;
00196 }
00197