src
sick_mrs1000.cpp
Go to the documentation of this file.
1
/*
2
* Copyright (C) 2017, Osnabrück University
3
* All rights reserved.
4
*
5
* Redistribution and use in source and binary forms, with or without
6
* modification, are permitted provided that the following conditions are met:
7
*
8
* * Redistributions of source code must retain the above copyright
9
* notice, this list of conditions and the following disclaimer.
10
* * Redistributions in binary form must reproduce the above copyright
11
* notice, this list of conditions and the following disclaimer in the
12
* documentation and/or other materials provided with the distribution.
13
* * Neither the name of Osnabrück University nor the names of its
14
* contributors may be used to endorse or promote products derived from
15
* this software without specific prior written permission.
16
*
17
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
18
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
19
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
20
* ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
21
* LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
22
* CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
23
* SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
24
* INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
25
* CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
26
* ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
27
* POSSIBILITY OF SUCH DAMAGE.
28
*
29
* Author:
30
* Sebastian Pütz <spuetz@uos.de>
31
*
32
*/
33
34
#include <
sick_tim/sick_mrs1000_communication.h
>
35
#include <
sick_tim/sick_mrs1000_parser.h
>
36
37
int
main
(
int
argc,
char
**argv)
38
{
39
ros::init
(argc, argv,
"sick_mrs_1000"
);
40
ros::NodeHandle
nhPriv(
"~"
);
41
42
// check for TCP - use if ~hostname is set.
43
bool
useTCP =
false
;
44
std::string hostname;
45
if
(!nhPriv.
getParam
(
"hostname"
, hostname))
46
{
47
ROS_FATAL_STREAM
(
"No hostname given!"
);
48
return
sick_tim::ExitError
;
49
}
50
std::string port;
51
nhPriv.
param
<std::string>(
"port"
, port,
"2112"
);
52
53
sick_tim::SickMRS1000Parser
* parser =
new
sick_tim::SickMRS1000Parser
();
54
55
double
param
;
56
if
(nhPriv.
getParam
(
"range_min"
,
param
))
57
{
58
parser->set_range_min(
param
);
59
}
60
if
(nhPriv.
getParam
(
"range_max"
,
param
))
61
{
62
parser->set_range_max(
param
);
63
}
64
if
(nhPriv.
getParam
(
"time_increment"
,
param
))
65
{
66
parser->set_time_increment(
param
);
67
}
68
69
int
timelimit;
70
nhPriv.
param
(
"timelimit"
, timelimit, 5);
71
72
sick_tim::SickTimCommon
*
s
= NULL;
73
74
int
result =
sick_tim::ExitError
;
75
while
(
ros::ok
())
76
{
77
// Atempt to connect/reconnect
78
s
=
new
sick_tim::SickMrs1000Communication
(hostname, port, timelimit, parser);
79
result =
s
->init();
80
81
while
(
ros::ok
() && (result ==
sick_tim::ExitSuccess
)){
82
ros::spinOnce
();
83
result =
s
->loopOnce();
84
}
85
86
delete
s
;
87
88
if
(result ==
sick_tim::ExitFatal
)
89
return
result;
90
}
91
92
delete
parser;
93
return
result;
94
}
sick_mrs1000_parser.h
sick_tim::SickMrs1000Communication
Definition:
sick_mrs1000_communication.h:48
ros::init
ROSCPP_DECL void init(const M_string &remappings, const std::string &name, uint32_t options=0)
s
XmlRpcServer s
ros::NodeHandle::getParam
bool getParam(const std::string &key, bool &b) const
ROS_FATAL_STREAM
#define ROS_FATAL_STREAM(args)
ros::spinOnce
ROSCPP_DECL void spinOnce()
sick_tim::ExitError
@ ExitError
Definition:
abstract_parser.h:47
ros::ok
ROSCPP_DECL bool ok()
sick_mrs1000_communication.h
sick_tim::ExitFatal
@ ExitFatal
Definition:
abstract_parser.h:48
sick_tim::ExitSuccess
@ ExitSuccess
Definition:
abstract_parser.h:46
sick_tim::SickMRS1000Parser
Definition:
sick_mrs1000_parser.h:44
main
int main(int argc, char **argv)
Definition:
sick_mrs1000.cpp:37
ros::NodeHandle::param
T param(const std::string ¶m_name, const T &default_val) const
param
T param(const std::string ¶m_name, const T &default_val)
sick_tim::SickTimCommon
Definition:
sick_tim_common.h:63
ros::NodeHandle
sick_tim
Author(s): Jochen Sprickerhof
, Martin Günther
, Sebastian Pütz
autogenerated on Thu Nov 28 2024 03:03:33