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
Storage.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 Storage::Storage(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 
93 void Storage::verifyPathName(std::string const& name) {
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) {
111  throw LSST_EXCEPT(lsst::pex::exceptions::RuntimeError,
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.
117  throw LSST_EXCEPT(lsst::pex::exceptions::RuntimeError,
118  dirName + ": Error searching for directory = " + std::strerror(errno));
119  }
120  else if (!S_ISDIR(buf.st_mode)) {
121  // It's not a directory.
122  throw LSST_EXCEPT(lsst::pex::exceptions::RuntimeError,
123  dirName + ": Non-directory in path");
124  }
125 }
126 
127 }}} // namespace lsst::daf::persistence
table::Key< std::string > name
Definition: ApCorrMap.cc:71
Class for logical location of a persisted Persistable instance.
Interface for Storage abstract base class.
boost::shared_ptr< Policy > Ptr
Definition: Policy.h:172
static Ptr createInstance(std::string const &name, LogicalLocation const &location, bool persist, lsst::pex::policy::Policy::Ptr policy)
Definition: Storage.cc:75
Interface for StorageRegistry class.
#define LSST_EXCEPT(type,...)
Definition: Exception.h:46
boost::shared_ptr< Storage > Ptr
Definition: Storage.h:62
void verifyPathName(std::string const &pathName)
Definition: Storage.cc:93
static StorageRegistry & getRegistry(void)
Storage::Ptr createInstance(std::string const &name)
#define __attribute__(x)
Definition: Storage.cc:39
Include files required for standard LSST Exception handling.
Storage(std::type_info const &type)
Definition: Storage.cc:60