LSSTApplications  16.0+42,16.0-1-gce273f5+8,16.0-10-g230e10e+1,16.0-11-g9fe0e56+17,16.0-11-gce733cf+17,16.0-12-g5ad1ebf+9,16.0-12-gc85596e+2,16.0-13-gde155d7+2,16.0-14-g9428de4d,16.0-14-gc1cf4a94+2,16.0-15-g8e16a51+14,16.0-2-g0febb12+7,16.0-2-g839ba83+32,16.0-2-g9d5294e+22,16.0-2-gab3db49+7,16.0-2-gf41ba6b+6,16.0-2-gf4e7cdd+5,16.0-3-g6923fb6+15,16.0-3-g8e51203+2,16.0-3-g9645794+6,16.0-3-gcfd6c53+20,16.0-35-g34c7dfe62+1,16.0-4-g03cf288+11,16.0-4-g32d12de,16.0-4-g5f3a788+7,16.0-4-g7690030+30,16.0-4-g8a0f11a+16,16.0-4-ga5d8928+16,16.0-5-g0da18be+7,16.0-5-g4940a70,16.0-5-g563880a+2,16.0-5-g7742071+2,16.0-5-gb3f8a4b+26,16.0-6-g3610b4f+5,16.0-6-gf0acd13+14,16.0-8-g4dec96c+7,16.0-8-gc315727+16,16.0-9-g1de645c+7,16.0-9-gcc4efb7+6,w.2018.36
LSSTDataManagementBasePackage
PropertyListFormatter.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 /*
26  * Implementation of PropertyListFormatter class
27  */
28 #include <cstdint>
29 #include <memory>
30 #include <string>
31 
32 #include "lsst/daf/base.h"
34 #include "lsst/daf/persistence.h"
35 #include "lsst/log/Log.h"
37 #include "lsst/afw/fits.h"
38 
39 namespace {
40 LOG_LOGGER _log = LOG_GET("afw.PropertyListFormatter");
41 }
42 
44 
45 namespace lsst {
46 namespace afw {
47 namespace formatters {
48 
49 lsst::daf::persistence::FormatterRegistration PropertyListFormatter::registration(
50  "PropertyList", typeid(lsst::daf::base::PropertyList), createInstance);
51 
52 PropertyListFormatter::PropertyListFormatter(PropertyListFormatter const&) = default;
53 PropertyListFormatter::PropertyListFormatter(PropertyListFormatter&&) = default;
54 PropertyListFormatter& PropertyListFormatter::operator=(PropertyListFormatter const&) = default;
55 PropertyListFormatter& PropertyListFormatter::operator=(PropertyListFormatter&&) = default;
56 
58  : lsst::daf::persistence::Formatter(typeid(this)) {}
59 
63  LOGL_DEBUG(_log, "PropertyListFormatter write start");
64  auto ip = dynamic_cast<lsst::daf::base::PropertyList const*>(persistable);
65  if (ip == 0) {
66  throw LSST_EXCEPT(lsst::pex::exceptions::RuntimeError, "Persisting non-PropertyList");
67  }
68  // TODO: Replace this with something better in DM-10776
69  auto& actualStorage = *storage;
70  if (typeid(actualStorage) == typeid(lsst::daf::persistence::FitsStorage)) {
72  "FitsStorage for PropertyList read-only (writing is not supported)");
73  }
74  throw LSST_EXCEPT(lsst::pex::exceptions::RuntimeError, "Unrecognized FormatterStorage for PropertyList");
75 }
76 
77 namespace {
78 std::unique_ptr<daf::base::PropertyList> readMetadataAsUniquePtr(std::string const& fileName, int hdu,
79  bool strip) {
81 
82  auto inheritedMetadata = fits::readMetadata(fileName, hdu, strip);
83  metadata->combine(inheritedMetadata);
84 
85  return metadata;
86 }
87 } // namespace
88 
92  LOGL_DEBUG(_log, "PropertyListFormatter read start");
93  // TODO: Replace this with something better in DM-10776
95  if (fits) {
96  LOGL_DEBUG(_log, "PropertyListFormatter read FitsStorage");
97 
98  auto ip = readMetadataAsUniquePtr(fits->getPath(), fits->getHdu(), false);
99 
100  LOGL_DEBUG(_log, "PropertyListFormatter read end");
101  return ip.release();
102  }
103  throw LSST_EXCEPT(lsst::pex::exceptions::RuntimeError, "Unrecognized FormatterStorage for PropertyList");
104 }
105 
109  throw LSST_EXCEPT(lsst::pex::exceptions::RuntimeError, "Unexpected call to update for PropertyList");
110 }
111 
112 template <class Archive>
115  LOGL_DEBUG(_log, "PropertyListFormatter delegateSerialize start");
116  auto ip = dynamic_cast<lsst::daf::base::PropertyList*>(persistable);
117  if (ip == 0) {
118  throw LSST_EXCEPT(lsst::pex::exceptions::RuntimeError, "Serializing non-PropertyList");
119  }
120  throw LSST_EXCEPT(lsst::pex::exceptions::RuntimeError, "PropertyList serialization not yet implemented");
121 }
122 
126 }
127 } // namespace formatters
128 } // namespace afw
129 } // namespace lsst
Abstract base class for FormatterStorage implementations.
daf::base::Persistable * read(std::shared_ptr< daf::persistence::FormatterStorage > storage, std::shared_ptr< daf::base::PropertySet > additionalData) override
PropertyListFormatter(PropertyListFormatter const &)
#define LOG_LOGGER
Definition: Log.h:712
Class for storing ordered metadata with comments.
Definition: PropertyList.h:72
Construct a static instance of this helper class to register a Formatter subclass in the FormatterReg...
Definition: Formatter.h:138
Class for FITS file storage.
Definition: FitsStorage.h:52
Class implementing persistence and retrieval for PropertyLists.
daf_persistence package header file
#define LOGL_DEBUG(logger, message...)
Log a debug-level message using a varargs/printf style interface.
Definition: Log.h:513
Fits * fits
Definition: FitsWriter.cc:90
STL class.
LSST DM logging module built on log4cxx.
PropertyListFormatter & operator=(PropertyListFormatter const &)
static std::shared_ptr< daf::persistence::Formatter > createInstance(std::shared_ptr< pex::policy::Policy > policy)
A base class for image defects.
Definition: cameraGeom.dox:3
T dynamic_pointer_cast(T... args)
#define LSST_EXCEPT(type,...)
Create an exception with a given type.
Definition: Exception.h:47
STL class.
static void delegateSerialize(Archive &ar, int const version, daf::base::Persistable *persistable)
Base class for all persistable classes.
Definition: Persistable.h:73
void write(daf::base::Persistable const *persistable, std::shared_ptr< daf::persistence::FormatterStorage > storage, std::shared_ptr< daf::base::PropertySet > additionalData) override
#define LOG_GET(logger)
Returns a Log object associated with logger.
Definition: Log.h:83
void update(daf::base::Persistable *persistable, std::shared_ptr< daf::persistence::FormatterStorage > storage, std::shared_ptr< daf::base::PropertySet > additionalData) override
bool strip
Definition: fits.cc:817
Reports errors that are due to events beyond the control of the program.
Definition: Runtime.h:104
std::shared_ptr< daf::base::PropertyList > readMetadata(std::string const &fileName, int hdu=DEFAULT_HDU, bool strip=false)
Read FITS header.
Definition: fits.cc:1496