00001 // TestModule.cc 00002 00003 // This file is part of bes, A C++ back-end server implementation framework 00004 // for the OPeNDAP Data Access Protocol. 00005 00006 // Copyright (c) 2004,2005 University Corporation for Atmospheric Research 00007 // Author: Patrick West <pwest@ucar.edu> and Jose Garcia <jgarcia@ucar.edu> 00008 // 00009 // This library is free software; you can redistribute it and/or 00010 // modify it under the terms of the GNU Lesser General Public 00011 // License as published by the Free Software Foundation; either 00012 // version 2.1 of the License, or (at your option) any later version. 00013 // 00014 // This library is distributed in the hope that it will be useful, 00015 // but WITHOUT ANY WARRANTY; without even the implied warranty of 00016 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU 00017 // Lesser General Public License for more details. 00018 // 00019 // You should have received a copy of the GNU Lesser General Public 00020 // License along with this library; if not, write to the Free Software 00021 // Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA 00022 // 00023 // You can contact University Corporation for Atmospheric Research at 00024 // 3080 Center Green Drive, Boulder, CO 80301 00025 00026 // (c) COPYRIGHT University Corporation for Atmostpheric Research 2004-2005 00027 // Please read the full copyright statement in the file COPYRIGHT_UCAR. 00028 // 00029 // Authors: 00030 // pwest Patrick West <pwest@ucar.edu> 00031 // jgarcia Jose Garcia <jgarcia@ucar.edu> 00032 00033 #include <iostream> 00034 00035 using std::endl ; 00036 00037 #include "TestModule.h" 00038 #include "TestNames.h" 00039 #include "BESResponseHandlerList.h" 00040 #include "TestSigResponseHandler.h" 00041 #include "TestEhmResponseHandler.h" 00042 #include "TestCommand.h" 00043 #include "BESRequestHandlerList.h" 00044 #include "TestRequestHandler.h" 00045 #include "TestException.h" 00046 #include "BESExceptionManager.h" 00047 00048 #include "BESLog.h" 00049 00050 void 00051 TestModule::initialize( const string &modname ) 00052 { 00053 if( BESLog::TheLog()->is_verbose() ) 00054 (*BESLog::TheLog()) << "Initializing Test Module" << endl; 00055 00056 if( BESLog::TheLog()->is_verbose() ) 00057 (*BESLog::TheLog()) << " adding " << modname << " request handler" << endl ; 00058 BESRequestHandlerList::TheList()->add_handler( modname, new TestRequestHandler( modname ) ) ; 00059 00060 if( BESLog::TheLog()->is_verbose() ) 00061 (*BESLog::TheLog()) << " adding " << TEST_SIG << " response handler" << endl; 00062 BESResponseHandlerList::TheList()->add_handler( TEST_SIG, TestSigResponseHandler::TestSigResponseBuilder ) ; 00063 00064 if( BESLog::TheLog()->is_verbose() ) 00065 (*BESLog::TheLog()) << " adding " << TEST_EHM << " response handler" << endl; 00066 BESResponseHandlerList::TheList()->add_handler( TEST_EHM, TestEhmResponseHandler::TestEhmResponseBuilder ) ; 00067 00068 if( BESLog::TheLog()->is_verbose() ) 00069 (*BESLog::TheLog()) << " adding " << TEST_RESPONSE << " command" << endl; 00070 BESCommand *cmd = new TestCommand( TEST_RESPONSE ) ; 00071 BESCommand::add_command( TEST_RESPONSE, cmd ) ; 00072 00073 string cmd_name = string( TEST_RESPONSE ) + "." + TEST_SIG ; 00074 if( BESLog::TheLog()->is_verbose() ) 00075 (*BESLog::TheLog()) << " adding " << cmd_name << " command" << endl; 00076 BESCommand::add_command( cmd_name, BESCommand::TermCommand ) ; 00077 00078 cmd_name = string( TEST_RESPONSE ) + "." + TEST_EHM ; 00079 if( BESLog::TheLog()->is_verbose() ) 00080 (*BESLog::TheLog()) << " adding " << cmd_name << " command" << endl; 00081 BESCommand::add_command( cmd_name, BESCommand::TermCommand ) ; 00082 00083 if( BESLog::TheLog()->is_verbose() ) 00084 (*BESLog::TheLog()) << " adding Test exception callback" << endl ; 00085 BESExceptionManager::TheEHM()->add_ehm_callback( TestException::handleException ) ; 00086 } 00087 00088 void 00089 TestModule::terminate( const string &modname ) 00090 { 00091 if( BESLog::TheLog()->is_verbose() ) 00092 (*BESLog::TheLog()) << "Cleaing up Test Module" << endl; 00093 00094 BESRequestHandler *rh = 00095 BESRequestHandlerList::TheList()->remove_handler( modname ) ; 00096 if( rh ) delete rh ; 00097 00098 BESCommand::del_command( TEST_RESPONSE ) ; 00099 00100 BESResponseHandlerList::TheList()->remove_handler( TEST_SIG ) ; 00101 BESResponseHandlerList::TheList()->remove_handler( TEST_EHM ) ; 00102 } 00103 00104 extern "C" 00105 { 00106 BESAbstractModule *maker() 00107 { 00108 return new TestModule ; 00109 } 00110 } 00111