converter.hpp
Go to the documentation of this file.
1 /*
2  * Copyright 2015 Aldebaran
3  *
4  * Licensed under the Apache License, Version 2.0 (the "License");
5  * you may not use this file except in compliance with the License.
6  * You may obtain a copy of the License at
7  *
8  * http://www.apache.org/licenses/LICENSE-2.0
9  *
10  * Unless required by applicable law or agreed to in writing, software
11  * distributed under the License is distributed on an "AS IS" BASIS,
12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13  * See the License for the specific language governing permissions and
14  * limitations under the License.
15  *
16 */
17 
18 #ifndef CONVERTER_HPP
19 #define CONVERTER_HPP
20 
21 #include <string>
22 
23 #include <boost/make_shared.hpp>
24 #include <boost/shared_ptr.hpp>
25 
26 #include <ros/ros.h>
28 
29 namespace naoqi
30 {
31 namespace converter
32 {
33 
34 
42 class Converter
43 {
44 
45 public:
46 
50  template<typename T>
51  Converter( T conv ):
52  convPtr_( boost::make_shared<ConverterModel<T> >(conv) )
53  {}
54 
59  std::string name() const
60  {
61  return convPtr_->name();
62  }
63 
68  float frequency() const
69  {
70  return convPtr_->frequency();
71  }
72 
73  void reset()
74  {
75  convPtr_->reset();
76  }
77 
78  void callAll( const std::vector<message_actions::MessageAction>& actions )
79  {
80  if ( actions.size() > 0 )
81  {
82  convPtr_->callAll(actions);
83  }
84 
85  ros::Time after = ros::Time::now();
86  lapse_time = after - before;
87  before = after;
88  }
89 
91  {
92  return lapse_time;
93  }
94 
95  friend bool operator==( const Converter& lhs, const Converter& rhs )
96  {
97  // decision made for OR-comparison since we want to be more restrictive
98  if ( lhs.name() == rhs.name() )
99  return true;
100  return false;
101  }
102 
103 private:
104 
107 
112  {
113  virtual ~ConverterConcept(){}
114  virtual std::string name() const = 0;
115  virtual float frequency() const = 0;
116  virtual void reset() = 0;
117  virtual void callAll( const std::vector<message_actions::MessageAction>& actions ) = 0;
118  };
119 
120 
124  template<typename T>
126  {
127  ConverterModel( const T& other ):
128  converter_( other )
129  {}
130 
131  std::string name() const
132  {
133  return converter_->name();
134  }
135 
136  float frequency() const
137  {
138  return converter_->frequency();
139  }
140 
141  void reset()
142  {
143  converter_->reset();
144  }
145 
146  void callAll( const std::vector<message_actions::MessageAction>& actions )
147  {
148  converter_->callAll( actions );
149  }
150 
152  };
153 
155 
156 }; // class converter
157 
158 } //converter
159 } //naoqi
160 
161 #endif
naoqi::converter::Converter::ConverterModel
Definition: converter.hpp:125
naoqi::converter::Converter::ConverterModel::name
std::string name() const
Definition: converter.hpp:131
naoqi::converter::Converter::ConverterConcept::reset
virtual void reset()=0
naoqi::converter::Converter
Converter concept interface.
Definition: converter.hpp:42
naoqi::converter::Converter::ConverterModel::reset
void reset()
Definition: converter.hpp:141
boost::shared_ptr
converter
naoqi::converter::Converter::ConverterModel::frequency
float frequency() const
Definition: converter.hpp:136
ros.h
naoqi::converter::Converter::convPtr_
boost::shared_ptr< ConverterConcept > convPtr_
Definition: converter.hpp:154
boost
naoqi
Definition: converter.hpp:29
naoqi::converter::Converter::reset
void reset()
Definition: converter.hpp:73
naoqi::converter::Converter::ConverterConcept::~ConverterConcept
virtual ~ConverterConcept()
Definition: converter.hpp:113
naoqi::converter::Converter::frequency
float frequency() const
getting the assigned frequency of this converter instance
Definition: converter.hpp:68
naoqi::converter::Converter::ConverterConcept::frequency
virtual float frequency() const =0
naoqi::converter::Converter::ConverterConcept::callAll
virtual void callAll(const std::vector< message_actions::MessageAction > &actions)=0
naoqi::converter::Converter::lapse_time
ros::Duration lapse_time
Definition: converter.hpp:106
naoqi::converter::Converter::ConverterConcept
Definition: converter.hpp:111
naoqi::converter::Converter::operator==
friend bool operator==(const Converter &lhs, const Converter &rhs)
Definition: converter.hpp:95
naoqi::converter::Converter::ConverterModel::callAll
void callAll(const std::vector< message_actions::MessageAction > &actions)
Definition: converter.hpp:146
naoqi::converter::Converter::before
ros::Time before
Definition: converter.hpp:105
ros::Time
naoqi::converter::Converter::Converter
Converter(T conv)
Constructor for converter interface.
Definition: converter.hpp:51
naoqi::converter::Converter::ConverterConcept::name
virtual std::string name() const =0
message_actions.h
naoqi::converter::Converter::callAll
void callAll(const std::vector< message_actions::MessageAction > &actions)
Definition: converter.hpp:78
naoqi::converter::Converter::ConverterModel::ConverterModel
ConverterModel(const T &other)
Definition: converter.hpp:127
naoqi::converter::Converter::lapseTime
ros::Duration lapseTime() const
Definition: converter.hpp:90
naoqi::converter::Converter::ConverterModel::converter_
T converter_
Definition: converter.hpp:151
ros::Duration
naoqi::converter::Converter::name
std::string name() const
getting the descriptive name for this converter instance
Definition: converter.hpp:59
ros::Time::now
static Time now()


naoqi_driver
Author(s): Karsten Knese
autogenerated on Sat Feb 3 2024 03:50:06