Fawkes API Fawkes Development Version
talkerpub_thread.h
1
2/***************************************************************************
3 * talkerpub_thread.h - Publish talker messages via ROS
4 *
5 * Created: Thu May 05 18:48:40 2011
6 * Copyright 2006-2011 Tim Niemueller [www.niemueller.de]
7 *
8 ****************************************************************************/
9
10/* This program is free software; you can redistribute it and/or modify
11 * it under the terms of the GNU General Public License as published by
12 * the Free Software Foundation; either version 2 of the License, or
13 * (at your option) any later version.
14 *
15 * This program is distributed in the hope that it will be useful,
16 * but WITHOUT ANY WARRANTY; without even the implied warranty of
17 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
18 * GNU Library General Public License for more details.
19 *
20 * Read the full text in the LICENSE.GPL file in the doc directory.
21 */
22
23#ifndef _PLUGINS_ROS_TALKERPUB_THREAD_H_
24#define _PLUGINS_ROS_TALKERPUB_THREAD_H_
25
26#include <aspect/blocked_timing.h>
27#include <aspect/clock.h>
28#include <aspect/configurable.h>
29#include <aspect/logging.h>
30#include <core/threading/thread.h>
31#include <core/utils/lockptr.h>
32#include <plugins/ros/aspect/ros.h>
33#include <ros/publisher.h>
34
41{
42public:
44 virtual ~ROSTalkerPubThread();
45
46 virtual void init();
47 virtual void loop();
48 virtual void finalize();
49
50 /** Stub to see name in backtrace for easier debugging. @see Thread::run() */
51protected:
52 virtual void
54 {
55 Thread::run();
56 }
57
58private:
59 ros::Publisher pub_;
60};
61
62#endif
Thread to publish messages via ROS.
virtual void loop()
Code to execute in the thread.
virtual ~ROSTalkerPubThread()
Destructor.
virtual void run()
Stub to see name in backtrace for easier debugging.
ROSTalkerPubThread()
Constructor.
virtual void finalize()
Finalize the thread.
virtual void init()
Initialize the thread.
Thread aspect to use blocked timing.
Thread aspect that allows to obtain the current time from the clock.
Definition: clock.h:34
Thread aspect to access configuration data.
Definition: configurable.h:33
Thread aspect to log output.
Definition: logging.h:33
Thread aspect to get access to a ROS node handle.
Definition: ros.h:39
Thread class encapsulation of pthreads.
Definition: thread.h:46