LSSTApplications  11.0-24-g0a022a1,14.0+77,15.0,15.0+1
LSSTDataManagementBasePackage
FormatterStorage.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 <cerrno>
46 #include <cstring>
47 #include <sys/stat.h>
48 #include <unistd.h>
49 
50 #include "lsst/pex/exceptions.h"
52 
53 namespace lsst {
54 namespace daf {
55 namespace persistence {
56 
60 FormatterStorage::FormatterStorage(std::type_info const& type) : lsst::daf::base::Citizen(type) {
61 }
62 
66 }
67 
76  std::string const& name, LogicalLocation const& location, bool persist,
79  storage->setPolicy(policy);
80  if (persist) {
81  storage->setPersistLocation(location);
82  }
83  else {
84  storage->setRetrieveLocation(location);
85  }
86  return storage;
87 }
88 
94  // Get the directory by stripping off anything after the last slash.
95  std::string::size_type pos = name.find_last_of('/');
96  if (pos == std::string::npos) return;
97  std::string dirName = name.substr(0, pos);
98 
99  // Check to see if the directory exists.
100  struct stat buf;
101  int ret = ::stat(dirName.c_str(), &buf);
102 
103  if (ret == -1 && errno == ENOENT) {
104  // It doesn't; check its parent and then create it.
105  verifyPathName(dirName);
106 
107  ret = ::mkdir(dirName.c_str(), 0777);
108 
109  // If it already exists, we're OK; otherwise, throw an exception.
110  if (ret == -1 && errno != EEXIST) {
112  dirName + ": Error creating directory = " + std::strerror(errno));
113  }
114  }
115  else if (ret == -1) {
116  // We couldn't read the (existing) directory for some reason.
118  dirName + ": Error searching for directory = " + std::strerror(errno));
119  }
120  else if (!S_ISDIR(buf.st_mode)) {
121  // It's not a directory.
123  dirName + ": Non-directory in path");
124  }
125 }
126 
127 }}} // namespace lsst::daf::persistence
table::Key< std::string > name
Definition: ApCorrMap.cc:71
#define __attribute__(x)
T strerror(T... args)
Interface for FormatterStorage abstract base class.
Class for logical location of a persisted Persistable instance.
Interface for StorageRegistry class.
virtual ~FormatterStorage(void)
Minimal destructor.
STL class.
Include files required for standard LSST Exception handling.
T find_last_of(T... args)
A base class for image defects.
Definition: cameraGeom.dox:3
static Ptr createInstance(std::string const &name, LogicalLocation const &location, bool persist, lsst::pex::policy::Policy::Ptr policy)
Create and configure a FormatterStorage subclass instance.
#define LSST_EXCEPT(type,...)
Create an exception with a given type and message and optionally other arguments (dependent on the ty...
Definition: Exception.h:46
T c_str(T... args)
void verifyPathName(std::string const &pathName)
Ensure that all directories along a path exist, creating them if necessary.
T substr(T... args)
static StorageRegistry & getRegistry(void)
Return a reference to a subclass registry.
FormatterStorage(std::type_info const &type)
Constructor.
FormatterStorage::Ptr createInstance(std::string const &name)
Create a FormatterStorage subclass instance by name.