Go to the documentation of this file.00001
00002 """
00003 Description:
00004
00005 Usage:
00006 $> roslaunch turtle_nodes.launch
00007 $> ./executive_step_02.py
00008
00009 Output:
00010 [INFO] : State machine starting in initial state 'RESET' with userdata:
00011 []
00012 [INFO] : State machine transitioning 'RESET':'succeeded'-->'SPAWN'
00013 [INFO] : State machine terminating 'SPAWN':'succeeded':'succeeded'
00014
00015 """
00016
00017 import roslib; roslib.load_manifest('smach_tutorials')
00018 import rospy
00019
00020 import threading
00021
00022 import smach
00023 from smach import StateMachine, ServiceState, SimpleActionState
00024
00025 import std_srvs.srv
00026 import turtlesim.srv
00027
00028 def main():
00029 rospy.init_node('smach_usecase_step_02')
00030
00031
00032 sm0 = StateMachine(outcomes=['succeeded','aborted','preempted'])
00033
00034
00035 with sm0:
00036
00037 StateMachine.add('RESET',
00038 ServiceState('reset', std_srvs.srv.Empty),
00039 {'succeeded':'SPAWN'})
00040
00041
00042 StateMachine.add('SPAWN',
00043 ServiceState('spawn', turtlesim.srv.Spawn,
00044 request = turtlesim.srv.SpawnRequest(0.0,0.0,0.0,'turtle2')))
00045
00046
00047 outcome = sm0.execute()
00048
00049
00050 rospy.signal_shutdown('All done.')
00051
00052 if __name__ == '__main__':
00053 main()