OPeNDAP Hyrax Back End Server (BES)  Updated for version 3.8.3
NCModule.cc
Go to the documentation of this file.
1 // NCModule.cc
2 
3 // This file is part of bes, A C++ back-end server implementation framework
4 // for the OPeNDAP Data Access Protocol.
5 
6 // Copyright (c) 2004,2005 University Corporation for Atmospheric Research
7 // Author: Patrick West <pwest@ucar.org>
8 //
9 // This library is free software; you can redistribute it and/or
10 // modify it under the terms of the GNU Lesser General Public
11 // License as published by the Free Software Foundation; either
12 // version 2.1 of the License, or (at your option) any later version.
13 //
14 // This library is distributed in the hope that it will be useful,
15 // but WITHOUT ANY WARRANTY; without even the implied warranty of
16 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
17 // Lesser General Public License for more details.
18 //
19 // You should have received a copy of the GNU Lesser General Public
20 // License along with this library; if not, write to the Free Software
21 // Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
22 //
23 // You can contact University Corporation for Atmospheric Research at
24 // 3080 Center Green Drive, Boulder, CO 80301
25 
26 // (c) COPYRIGHT University Corporation for Atmospheric Research 2004-2005
27 // Please read the full copyright statement in the file COPYRIGHT_UCAR.
28 //
29 // Authors:
30 // pwest Patrick West <pwest@ucar.edu>
31 
32 #include <iostream>
33 
34 #include <BESRequestHandlerList.h>
35 #include <BESDapService.h>
38 #include <BESCatalogDirectory.h>
39 #include <BESCatalogList.h>
40 #include <BESDebug.h>
41 
42 #include "NCModule.h"
43 #include "NCRequestHandler.h"
44 
45 using std::endl;
46 
47 #define NC_CATALOG "catalog"
48 
49 void NCModule::initialize(const string & modname)
50 {
51  BESDEBUG("nc", "Initializing NC module " << modname << endl);
52 
53  BESRequestHandler *handler = new NCRequestHandler(modname);
54  BESRequestHandlerList::TheList()->add_handler(modname, handler);
55 
57 
58  if (!BESCatalogList::TheCatalogList()->ref_catalog( NC_CATALOG)) {
60  }
61  else {
62  BESDEBUG("nc", " catalog already exists, skipping" << endl);
63  }
64 
65  if (!BESContainerStorageList::TheList()->ref_persistence( NC_CATALOG)) {
67  }
68  else {
69  BESDEBUG("nc", " storage already exists, skipping" << endl);
70  }
71 
72  BESDebug::Register("nc");
73 
74  BESDEBUG("nc", "Done Initializing NC module " << modname << endl);
75 }
76 
77 void NCModule::terminate(const string & modname)
78 {
79  BESDEBUG("nc", "Cleaning NC module " << modname << endl);
80 
82  if (rh) delete rh;
83 
85 
87 
88  BESDEBUG("nc", "Done Cleaning NC module " << modname << endl);
89 }
90 
97 void NCModule::dump(ostream & strm) const
98 {
99  strm << BESIndent::LMarg << "NCModule::dump - (" << (void *) this << ")" << endl;
100 }
101 
102 extern "C" BESAbstractModule * maker()
103 {
104  return new NCModule;
105 }
106 
virtual bool add_handler(const string &handler_name, BESRequestHandler *handler)
add a request handler to the list of registered handlers for this server
virtual bool add_catalog(BESCatalog *catalog)
adds the speciifed catalog to the list
BESAbstractModule * maker()
Definition: NCModule.cc:102
virtual bool add_persistence(BESContainerStorage *p)
Add a persistent store to the list.
implementation of BESContainerStorage that represents a data within a catalog repository ...
virtual void initialize(const string &modname)
Definition: NCModule.cc:49
virtual bool deref_catalog(const string &catalog_name)
de-reference the specified catalog and remove from list if no longer referenced
builds catalogs from a directory structure
static ostream & LMarg(ostream &strm)
Definition: BESIndent.cc:73
virtual bool deref_persistence(const string &persist_name)
dereference a persistent store in the list.
virtual void dump(ostream &strm) const
dumps information about this object
Definition: NCModule.cc:97
Represents a specific data type request handler.
static BESRequestHandlerList * TheList()
static BESContainerStorageList * TheList()
#define BESDEBUG(x, y)
macro used to send debug information to the debug stream
Definition: BESDebug.h:64
static BESCatalogList * TheCatalogList()
returns the singleton BESCatalogList instance.
static void Register(const string &flagName)
register the specified debug flag
Definition: BESDebug.h:138
static void handle_dap_service(const string &handler)
static function to register a handler to handle the dap services
#define NC_CATALOG
Definition: NCModule.cc:47
virtual BESRequestHandler * remove_handler(const string &handler_name)
remove and return the specified request handler
virtual void terminate(const string &modname)
Definition: NCModule.cc:77