abs_hand_command.py
Go to the documentation of this file.
00001 #!/usr/bin/env python
00002 
00003 # Software License Agreement (BSD License)
00004 #
00005 # Copyright (c) 2013, Tokyo Opensource Robotics Kyokai Association
00006 # All rights reserved.
00007 #
00008 # Redistribution and use in source and binary forms, with or without
00009 # modification, are permitted provided that the following conditions
00010 # are met:
00011 #
00012 #  * Redistributions of source code must retain the above copyright
00013 #    notice, this list of conditions and the following disclaimer.
00014 #  * Redistributions in binary form must reproduce the above
00015 #    copyright notice, this list of conditions and the following
00016 #    disclaimer in the documentation and/or other materials provided
00017 #    with the distribution.
00018 #  * Neither the name of Tokyo Opensource Robotics Kyokai Association. nor the
00019 #    names of its contributors may be used to endorse or promote products
00020 #    derived from this software without specific prior written permission.
00021 #
00022 # THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
00023 # "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
00024 # LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
00025 # FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
00026 # COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
00027 # INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
00028 # BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
00029 # LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
00030 # CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
00031 # LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
00032 # ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
00033 # POSSIBILITY OF SUCH DAMAGE.
00034 #
00035 # Author: Isaac Isao Saito
00036 
00037 import rospy
00038 
00039 
00040 class AbsractHandCommand(object):
00041     '''
00042     Following Command design pattern, this class represents an abstract
00043     command for hand classes of NEXTAGE OPEN.
00044     '''
00045     # TODO: Unittest is needed!!DIO_V
00046 
00047     def __init__(self, hands, hand, dio_pins):
00048         '''
00049         @type hands: nextage_ros_bridge.base_hands.BaseHands
00050         @type hand: str
00051         @param hand: Side of hand. Variables that are defined in
00052                      nextage_ros_bridge.base_hands.BaseHands can be used
00053                      { HAND_L, HAND_R }.
00054         @type dio_pins: [int]
00055         @param dio_pins: List of DIO pins that are used in each HandCommand
00056                          class. The order is important; it needs be defined
00057                          in subclasses.
00058         '''
00059         self._hands = hands
00060         self._hand = hand
00061         self._assign_dio_names(dio_pins)
00062 
00063     def execute(self, operation):
00064         '''
00065         Needs overriddedn, otherwise expcetion occurs.
00066 
00067         @type operation: str
00068         @param operation: name of the operation.
00069         @rtype: bool
00070         @return: True if dout was writtable to the register. False otherwise.
00071 
00072         @raise exception: RuntimeError
00073         '''
00074         msg = 'AbsractHandCommand.execute() not extended.'
00075         rospy.logerr(msg)
00076         raise NotImplementedError(msg)
00077 
00078     def _assign_dio_names(self, dio_pins):
00079         '''
00080         It's recommended in the derived classes to re-assign DIO names to
00081         better represent the specific purposes of each DIO pin in there.
00082         Since doing so isn' mandatory, this method doesn't emit error even when
00083         it's not implemented.
00084         @type dio_pins: [int]
00085         @param dio_pins: List of DIO pins that are used in each HandCommand
00086                          class. The order is important; it needs be defined
00087                          in subclasses.
00088         '''
00089         pass


nextage_ros_bridge
Author(s): Isaac Isao Saito , Akio Ochiai
autogenerated on Fri Aug 28 2015 12:55:59