TestModule.cc

Go to the documentation of this file.
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 

Generated on Wed Jan 2 06:01:19 2008 for OPeNDAP Back End Server (BES) by  doxygen 1.5.4