Project: bml_realizer License: BSD Dependencies:
Used by:
None |
bml_realizer/src/edu/wpi/hri/bml/realizer/RealizerNode.javaGo to the documentation of this file.00001 /* 00002 * Software License Agreement (BSD License) 00003 * 00004 * Copyright (c) 2010, Worcester Polytechnic Institute 00005 * All rights reserved. 00006 * 00007 * Redistribution and use in source and binary forms, with or without 00008 * modification, are permitted provided that the following conditions 00009 * are met: 00010 * 00011 * * Redistributions of source code must retain the above copyright 00012 * notice, this list of conditions and the following disclaimer. 00013 * * Redistributions in binary form must reproduce the above 00014 * copyright notice, this list of conditions and the following 00015 * disclaimer in the documentation and/or other materials provided 00016 * with the distribution. 00017 * * Neither the name of Worcester Polytechnic Institute. nor the names 00018 * of its contributors may be used to endorse or promote products 00019 * derived from this software without specific prior written permission. 00020 * 00021 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS 00022 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT 00023 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS 00024 * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE 00025 * COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, 00026 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, 00027 * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; 00028 * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER 00029 * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 00030 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN 00031 * ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 00032 * POSSIBILITY OF SUCH DAMAGE. 00033 */ 00034 package edu.wpi.hri.bml.realizer; 00035 00036 import ros.NodeHandle; 00037 import ros.Ros; 00038 import ros.RosException; 00039 import ros.pkg.bml_srvs.srv.BMLRealization; 00040 import edu.wpi.hri.comm.MasterSpinner; 00041 import edu.wpi.hri.log.Logger; 00042 import edu.wpi.hri.log.Logger.Colors; 00043 import edu.wpi.hri.log.Logger.LoggerLevel; 00044 00052 public class RealizerNode { 00053 00054 private static void setupParameters() { 00055 BMLParams.DEBUG_LEVEL.setString(LoggerLevel.ALL.toString()); 00056 BMLParams.LOGGER_TYPE.setString("SYSTEM"); 00057 } 00058 00066 public static void main(String[] args) { 00067 setupParameters(); 00068 00069 // create the ROS stuff as necessary 00070 Ros.getInstance().init("realizer", false, false, false, args); 00071 final NodeHandle handle = Ros.getInstance().createNodeHandle(); 00072 00073 // create the logger by checking which to create 00074 LoggerLevel maxLevel = LoggerLevel.valueOf(BMLParams.DEBUG_LEVEL 00075 .getString()); 00076 String type = BMLParams.LOGGER_TYPE.getString(); 00077 final Logger logger = Logger.createBase(maxLevel, type, 00078 Colors.REALIZER, "RLZR"); 00079 00080 final MasterSpinner spin = new MasterSpinner(logger, true); 00081 00082 try { 00083 // then create the handles to the other communication stuff 00084 final BMLComm comm = new BMLComm(logger, handle); 00085 final ControlComm control = new ControlComm(logger, handle); 00086 00087 // create the service for the realization of BML 00088 final RealizerService realizer = new RealizerService(logger, comm, 00089 control, spin); 00090 handle.advertiseService("bml/realize", new BMLRealization(), 00091 realizer); 00092 00093 } catch (RosException e) { 00094 logger.printThrowable(LoggerLevel.INIT, e); 00095 logger.fatal("Could not initialize the realization service", -1); 00096 } 00097 00098 // Tell the user that the realizer is now running 00099 logger.info("Realizer started"); 00100 spin.joinOldMasters(); 00101 handle.shutdown(); 00102 } 00103 } |