LSSTApplications  10.0-2-g4f67435,11.0.rc2+1,11.0.rc2+12,11.0.rc2+3,11.0.rc2+4,11.0.rc2+5,11.0.rc2+6,11.0.rc2+7,11.0.rc2+8
LSSTDataManagementBasePackage
FormatterRegistry.cc
Go to the documentation of this file.
1 // -*- lsst-c++ -*-
2 
3 /*
4  * LSST Data Management System
5  * Copyright 2008, 2009, 2010 LSST Corporation.
6  *
7  * This product includes software developed by the
8  * LSST Project (http://www.lsst.org/).
9  *
10  * This program is free software: you can redistribute it and/or modify
11  * it under the terms of the GNU General Public License as published by
12  * the Free Software Foundation, either version 3 of the License, or
13  * (at your option) any later version.
14  *
15  * This program is distributed in the hope that it will be useful,
16  * but WITHOUT ANY WARRANTY; without even the implied warranty of
17  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
18  * GNU General Public License for more details.
19  *
20  * You should have received a copy of the LSST License Statement and
21  * the GNU General Public License along with this program. If not,
22  * see <http://www.lsstcorp.org/LegalNotices/>.
23  */
24 
25 
38 #ifndef __GNUC__
39 # define __attribute__(x) /*NOTHING*/
40 #endif
41 static char const* SVNid __attribute__((unused)) = "$Id$";
42 
44 
45 #include "lsst/pex/exceptions.h"
46 
47 namespace lsst {
48 namespace daf {
49 namespace persistence {
50 
58  return *registry;
59 }
60 
68  std::string const& persistableName, std::type_info const& persistableType,
69  Formatter::FactoryPtr factory) {
70  _byName.insert(FactoryMap::value_type(persistableName, factory));
71  _nameForType.insert(StringMap::value_type(persistableType.name(),
72  persistableName));
73 }
74 
82  std::type_info const& persistableType,
84  StringMap::const_iterator it = _nameForType.find(persistableType.name());
85  if (it == _nameForType.end()) {
86  throw LSST_EXCEPT(lsst::pex::exceptions::InvalidParameterError,
87  std::string("No Formatter registered for Persistable type: ") +
88  persistableType.name());
89  }
90  return lookupFormatter(it->second, policy);
91 }
92 
100  std::string const& persistableName,
102  FactoryMap::const_iterator it = _byName.find(persistableName);
103  if (it == _byName.end()) {
104  throw LSST_EXCEPT(lsst::pex::exceptions::InvalidParameterError,
105  "No Formatter registered for Persistable name: " +
106  persistableName);
107  }
108  lsst::pex::policy::Policy::Ptr formatterPolicy;
109  if (policy && policy->exists(persistableName)) {
110  formatterPolicy = policy->getPolicy(persistableName);
111  }
112  return (*(it->second))(formatterPolicy);
113 }
114 
118  lsst::daf::base::Citizen(typeid(*this)) {
119  markPersistent();
120 }
121 
125 }
126 
127 }}} // namespace lsst::daf::persistence
StringMap _nameForType
Registry of Persistable names by std::type_info::name().
boost::shared_ptr< Formatter > Ptr
Definition: Formatter.h:81
Class that registers all Formatter subclasses.
static FormatterRegistry & getInstance(void)
boost::shared_ptr< Policy > Ptr
Definition: Policy.h:172
void markPersistent(void)
Mark a Citizen as persistent and not destroyed until process end.
Definition: Citizen.cc:253
Interface for FormatterRegistry class.
Ptr(* FactoryPtr)(lsst::pex::policy::Policy::Ptr)
Definition: Formatter.h:85
void registerFormatter(std::string const &persistableName, std::type_info const &persistableType, Formatter::FactoryPtr factory)
#define LSST_EXCEPT(type,...)
Definition: Exception.h:46
Formatter::Ptr lookupFormatter(std::type_info const &persistableType, lsst::pex::policy::Policy::Ptr policy)
#define __attribute__(x)
FactoryMap _byName
Registry of Formatter factories by Persistable name.
Include files required for standard LSST Exception handling.