LSSTApplications  17.0+124,17.0+14,17.0+73,18.0.0+37,18.0.0+80,18.0.0-4-g68ffd23+4,18.1.0-1-g0001055+12,18.1.0-1-g03d53ef+5,18.1.0-1-g1349e88+55,18.1.0-1-g2505f39+44,18.1.0-1-g5315e5e+4,18.1.0-1-g5e4b7ea+14,18.1.0-1-g7e8fceb+4,18.1.0-1-g85f8cd4+48,18.1.0-1-g8ff0b9f+4,18.1.0-1-ga2c679d+1,18.1.0-1-gd55f500+35,18.1.0-10-gb58edde+2,18.1.0-11-g0997b02+4,18.1.0-13-gfe4edf0b+12,18.1.0-14-g259bd21+21,18.1.0-19-gdb69f3f+2,18.1.0-2-g5f9922c+24,18.1.0-2-gd3b74e5+11,18.1.0-2-gfbf3545+32,18.1.0-26-g728bddb4+5,18.1.0-27-g6ff7ca9+2,18.1.0-3-g52aa583+25,18.1.0-3-g8ea57af+9,18.1.0-3-gb69f684+42,18.1.0-3-gfcaddf3+6,18.1.0-32-gd8786685a,18.1.0-4-gf3f9b77+6,18.1.0-5-g1dd662b+2,18.1.0-5-g6dbcb01+41,18.1.0-6-gae77429+3,18.1.0-7-g9d75d83+9,18.1.0-7-gae09a6d+30,18.1.0-9-gc381ef5+4,w.2019.45
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:67
T c_str(T... args)
std::string getAsString(std::string const &name) const
Get the last value for a string property name (possibly hierarchical).