LSSTApplications  17.0+11,17.0+34,17.0+56,17.0+57,17.0+59,17.0+7,17.0-1-g377950a+33,17.0.1-1-g114240f+2,17.0.1-1-g4d4fbc4+28,17.0.1-1-g55520dc+49,17.0.1-1-g5f4ed7e+52,17.0.1-1-g6dd7d69+17,17.0.1-1-g8de6c91+11,17.0.1-1-gb9095d2+7,17.0.1-1-ge9fec5e+5,17.0.1-1-gf4e0155+55,17.0.1-1-gfc65f5f+50,17.0.1-1-gfc6fb1f+20,17.0.1-10-g87f9f3f+1,17.0.1-11-ge9de802+16,17.0.1-16-ga14f7d5c+4,17.0.1-17-gc79d625+1,17.0.1-17-gdae4c4a+8,17.0.1-2-g26618f5+29,17.0.1-2-g54f2ebc+9,17.0.1-2-gf403422+1,17.0.1-20-g2ca2f74+6,17.0.1-23-gf3eadeb7+1,17.0.1-3-g7e86b59+39,17.0.1-3-gb5ca14a,17.0.1-3-gd08d533+40,17.0.1-30-g596af8797,17.0.1-4-g59d126d+4,17.0.1-4-gc69c472+5,17.0.1-6-g5afd9b9+4,17.0.1-7-g35889ee+1,17.0.1-7-gc7c8782+18,17.0.1-9-gc4bbfb2+3,w.2019.22
LSSTDataManagementBasePackage
prefsImpl.cc
Go to the documentation of this file.
1 // -*- lsst-C++ -*-
2 #include "lsst/meas/extensions/psfex/prefs.hh"
3 #include "lsst/daf/base.h"
4 
5 namespace lsst { namespace meas { namespace extensions { namespace psfex {
6 
7 Prefs::Prefs(std::string const& filename, lsst::daf::base::PropertySet const* values
8  ) : _command_line(0) {
9  char *cfilename = const_cast<char *>(filename.c_str()); // const_cast as PSFEX isn't careful about const
10  int const narg = values->nameCount();
11  if (narg == 0) {
12  readprefs(cfilename, 0x0, 0x0, narg);
13  } else {
14  std::vector<char *> argkey(narg);
15  std::vector<char *> argval(narg);
16  std::vector<std::string> const names = values->paramNames();
17  // Next, decalre a vector to store string values. These strings must
18  // live long enough such that pointers to them (returned by c_str) stay
19  // valid until the readprefs function can read their values. Once this
20  // happens, the srings and pointers are no longer needed, and will be
21  // cleaned up when the vector goes out of scope
22  std::vector<std::string> paramvalues(narg);
23 
24  for (int i = 0; i != narg; ++i) {
25  std::string const& name = names[i];
26  argkey[i] = const_cast<char *>(name.c_str());
27  paramvalues[i] = values->getAsString(name);
28  argval[i] = const_cast<char *>(paramvalues[i].c_str());
29  }
30 
31  readprefs(cfilename, &argkey[0], &argval[0], narg);
32  }
33 
34  for (int i = 0; i != prefs.ncontext_name; ++i) {
35  _context_names.push_back(prefs.context_name[i]);
36  }
37  for (int i = 0; i != prefs.ncontext_group; ++i) {
38  _context_groups.push_back(prefs.context_group[i]);
39  }
40  for (int i = 0; i != prefs.ngroup_deg; ++i) {
41  _group_degs.push_back(prefs.group_deg[i]);
42  }
43 }
44 
45 Prefs::~Prefs()
46 {
47  delete[] _command_line;
48 }
49 
50 void
51 Prefs::setCommandLine(std::vector<std::string> const& argv)
52 {
53  prefs.ncommand_line = argv.size();
54  _command_line = new char const*[prefs.ncommand_line + 1];
55  int i;
56  for (i = 0; i != prefs.ncommand_line; ++i) {
57  _command_line[i] = argv[i].c_str();
58  }
59  _command_line[i] = 0;
60  prefs.command_line = const_cast<char **>(_command_line);
61 }
62 
63 void
64 Prefs::addCatalog(std::string const& filename) {
65  if (prefs.ncat >= MAXFILE) {
66  throw LSST_EXCEPT(lsst::pex::exceptions::LengthError, "Too many input catalogues");
67  }
68  _catalogs.push_back(filename);
69  prefs.incat_name[prefs.ncat++] = const_cast<char *>((_catalogs.end() - 1)->c_str());
70 }
71 
72 }}}}
Reports attempts to exceed implementation-defined length limits for some classes. ...
Definition: Runtime.h:76
std::vector< std::string > paramNames(bool topLevelOnly=true) const
A variant of names that excludes the names of subproperties.
STL class.
A base class for image defects.
size_t nameCount(bool topLevelOnly=true) const
Get the number of names in the PropertySet, optionally including those in subproperties.
T size(T... args)
#define LSST_EXCEPT(type,...)
Create an exception with a given type.
Definition: Exception.h:48
STL class.
Class for storing generic metadata.
Definition: PropertySet.h:68
T c_str(T... args)
std::string getAsString(std::string const &name) const
Get the last value for a string property name (possibly hierarchical).