CommandExecFunction.hpp

00001 /***************************************************************************
00002   tag: Peter Soetens  Tue Dec 21 22:43:07 CET 2004  CommandExecFunction.hpp
00003 
00004                         CommandExecFunction.hpp -  description
00005                            -------------------
00006     begin                : Tue December 21 2004
00007     copyright            : (C) 2004 Peter Soetens
00008     email                : peter.soetens@mech.kuleuven.ac.be
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 #ifndef COMMAND_EXEC_FUNCTION_HPP
00040 #define COMMAND_EXEC_FUNCTION_HPP
00041 
00042 #include "ConditionInterface.hpp"
00043 #include "CommandInterface.hpp"
00044 #include "DataSources.hpp"
00045 #include "ProgramInterface.hpp"
00046 #include "ProgramProcessor.hpp"
00047 #include "DispatchInterface.hpp"
00048 #include "DataSource.hpp"
00049 #include <boost/shared_ptr.hpp>
00050 
00051 namespace RTT
00052 {
00053     using namespace detail;
00057     class RTT_API ConditionExecFunction
00058         : public ConditionInterface
00059     {
00060         DataSource<ProgramInterface*>::shared_ptr _v;
00061     public:
00062         ConditionExecFunction( DataSource<ProgramInterface*>* v)
00063             : _v( v )
00064         {}
00065 
00066         bool evaluate()
00067         {
00068             return _v->get()->isStopped();
00069         }
00070 
00071         ConditionInterface* clone() const
00072         {
00073             return new ConditionExecFunction( _v.get() );
00074         }
00075 
00076         ConditionInterface* copy( std::map<const DataSourceBase*, DataSourceBase*>& alreadyCloned ) const
00077         {
00078             // after *all* the copying is done, _v will be set to the correct function
00079             // by the Command's copy.
00080             return new ConditionExecFunction( _v->copy( alreadyCloned ) );
00081         }
00082 
00083     };
00084 
00090     class RTT_API CommandExecFunction
00091         : public DispatchInterface
00092     {
00093         CommandInterface* minit;
00094         ProgramProcessor* _proc;
00095         AssignableDataSource<ProgramInterface*>::shared_ptr _v;
00096         boost::shared_ptr<ProgramInterface> _foo;
00097         bool isqueued;
00098         AssignableDataSource<bool>::shared_ptr maccept;
00099     public:
00108         CommandExecFunction( CommandInterface* init_com, boost::shared_ptr<ProgramInterface> foo, ProgramProcessor* p, AssignableDataSource<ProgramInterface*>* v = 0 , AssignableDataSource<bool>* a = 0 );
00109 
00110         ~CommandExecFunction();
00111 
00112         void readArguments()
00113         {
00114             minit->readArguments();
00115         }
00116 
00117         bool ready() const {
00118             return !isqueued;
00119         }
00120 
00121         bool dispatch()
00122         {
00123             return execute();
00124         }
00125 
00126         bool execute()
00127         {
00128             // this is asyn behaviour :
00129             if (isqueued == false ) {
00130                 isqueued = true;
00131                 maccept->set( minit->execute() && _proc->runFunction( _foo.get() ) );
00132                 return maccept->get();
00133             }
00134             // if it was queued already return if it is
00135             // in error or not.
00136             return maccept->get() && ! _foo->inError();
00137         }
00138 
00139         void reset()
00140         {
00141             // reset the program, so that it is valid to be re-queued again
00142             _foo->reset();
00143             minit->reset();
00144             isqueued = false;
00145             //remove any old left-overs.
00146             _foo->stop();
00147         }
00148 
00149         virtual bool sent() const {
00150             return isqueued;
00151         }
00152 
00153         virtual bool accepted() const {
00154             return maccept->get();
00155         }
00156 
00157         virtual bool executed() const {
00158             return isqueued;
00159         }
00160 
00161         virtual bool valid() const {
00162             return maccept->get() && ! _foo->inError();
00163         }
00164 
00165         virtual bool done() const {
00166             return maccept->get() && _v->get()->isStopped();
00167         }
00168 
00172         ConditionInterface* createCondition() const
00173         {
00174             return new ConditionExecFunction( _v.get() );
00175         }
00176 
00177         DispatchInterface* clone() const
00178         {
00179             // _v is shared_ptr, so don't clone.
00180             return new CommandExecFunction( minit->clone(), _foo, _proc, _v.get(), maccept.get() );
00181         }
00182 
00183         DispatchInterface* copy( std::map<const DataSourceBase*, DataSourceBase*>& alreadyCloned ) const
00184         {
00185             // this may seem strange, but :
00186             // make a copy of foo (a function), make a copy of _v (a datasource), store pointer to new foo in _v !
00187             boost::shared_ptr<ProgramInterface> fcpy( _foo->copy(alreadyCloned) );
00188             AssignableDataSource<ProgramInterface*>* vcpy = _v->copy(alreadyCloned);
00189             vcpy->set( fcpy.get() ); // since we own _foo, we may manipulate the copy of _v
00190             AssignableDataSource<bool>* acpy = maccept->copy(alreadyCloned);
00191             return new CommandExecFunction( minit->copy(alreadyCloned), fcpy , _proc, vcpy, acpy );
00192         }
00193 
00194     };
00195 
00196 }
00197 
00198 #endif
Generated on Thu Dec 23 13:22:36 2010 for Orocos Real-Time Toolkit by  doxygen 1.6.3