SelectNextObject.cpp
Go to the documentation of this file.
1/*
2 * This file is part of ArmarX.
3 *
4 * ArmarX is free software; you can redistribute it and/or modify
5 * it under the terms of the GNU General Public License version 2 as
6 * published by the Free Software Foundation.
7 *
8 * ArmarX is distributed in the hope that it will be useful, but
9 * WITHOUT ANY WARRANTY; without even the implied warranty of
10 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
11 * GNU General Public License for more details.
12 *
13 * You should have received a copy of the GNU General Public License
14 * along with this program. If not, see <http://www.gnu.org/licenses/>.
15 *
16 * @package RobotSkillTemplates::ObjectLocalization
17 * @author Markus Grotz ( markus dot grotz at kit dot edu )
18 * @date 2018
19 * @copyright http://www.gnu.org/licenses/gpl-2.0.txt
20 * GNU General Public License
21 */
22
23#include "SelectNextObject.h"
24
25//#include <ArmarXCore/core/time/TimeUtil.h>
26//#include <ArmarXCore/observers/variant/DatafieldRef.h>
27
28using namespace armarx;
29using namespace ObjectLocalization;
30
31// DO NOT EDIT NEXT LINE
32SelectNextObject::SubClassRegistry SelectNextObject::Registry(SelectNextObject::GetName(),
34
35void
37{
38 size_t pos = in.isPosSet() ? in.getPos() : 0;
39 if (pos < in.getObjectNames().size())
40 {
41 out.setObjectName(in.getObjectNames().at(pos));
42 out.setPos(++pos);
43 emitSuccess();
44 }
45 else
46 {
47 emitDone();
48 }
49 // put your user code for the enter-point here
50 // execution time should be short (<100ms)
51}
52
53//void SelectNextObject::run()
54//{
55// // put your user code for the execution-phase here
56// // runs in seperate thread, thus can do complex operations
57// // should check constantly whether isRunningTaskStopped() returns true
58//
59//// uncomment this if you need a continous run function. Make sure to use sleep or use blocking wait to reduce cpu load.
60// while (!isRunningTaskStopped()) // stop run function if returning true
61// {
62// // do your calculations
63// }
64//}
65
66//void SelectNextObject::onBreak()
67//{
68// // put your user code for the breaking point here
69// // execution time should be short (<100ms)
70//}
71
72void
74{
75 // put your user code for the exit point here
76 // execution time should be short (<100ms)
77}
78
79// DO NOT EDIT NEXT FUNCTION
SelectNextObject(const XMLStateConstructorParams &stateData)
static XMLStateFactoryBasePtr CreateInstance(XMLStateConstructorParams stateData)
This file offers overloads of toIce() and fromIce() functions for STL container types.
IceInternal::Handle< XMLStateFactoryBase > XMLStateFactoryBasePtr
Definition XMLState.h:64