LSST Applications  21.0.0-147-g0e635eb1+1acddb5be5,22.0.0+052faf71bd,22.0.0+1ea9a8b2b2,22.0.0+6312710a6c,22.0.0+729191ecac,22.0.0+7589c3a021,22.0.0+9f079a9461,22.0.1-1-g7d6de66+b8044ec9de,22.0.1-1-g87000a6+536b1ee016,22.0.1-1-g8e32f31+6312710a6c,22.0.1-10-gd060f87+016f7cdc03,22.0.1-12-g9c3108e+df145f6f68,22.0.1-16-g314fa6d+c825727ab8,22.0.1-19-g93a5c75+d23f2fb6d8,22.0.1-19-gb93eaa13+aab3ef7709,22.0.1-2-g8ef0a89+b8044ec9de,22.0.1-2-g92698f7+9f079a9461,22.0.1-2-ga9b0f51+052faf71bd,22.0.1-2-gac51dbf+052faf71bd,22.0.1-2-gb66926d+6312710a6c,22.0.1-2-gcb770ba+09e3807989,22.0.1-20-g32debb5+b8044ec9de,22.0.1-23-gc2439a9a+fb0756638e,22.0.1-3-g496fd5d+09117f784f,22.0.1-3-g59f966b+1e6ba2c031,22.0.1-3-g849a1b8+f8b568069f,22.0.1-3-gaaec9c0+c5c846a8b1,22.0.1-32-g5ddfab5d3+60ce4897b0,22.0.1-4-g037fbe1+64e601228d,22.0.1-4-g8623105+b8044ec9de,22.0.1-5-g096abc9+d18c45d440,22.0.1-5-g15c806e+57f5c03693,22.0.1-7-gba73697+57f5c03693,master-g6e05de7fdc+c1283a92b8,master-g72cdda8301+729191ecac,w.2021.39
LSST Data Management Base Package
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 }}}}
table::Key< std::string > name
Definition: Amplifier.cc:116
#define LSST_EXCEPT(type,...)
Create an exception with a given type.
Definition: Exception.h:48
T c_str(T... args)
Class for storing generic metadata.
Definition: PropertySet.h:66
std::string getAsString(std::string const &name) const
Get the last value for a string property name (possibly hierarchical).
size_t nameCount(bool topLevelOnly=true) const
Get the number of names in the PropertySet, optionally including those in subproperties.
std::vector< std::string > paramNames(bool topLevelOnly=true) const
A variant of names that excludes the names of subproperties.
Reports attempts to exceed implementation-defined length limits for some classes.
Definition: Runtime.h:76
A base class for image defects.
T size(T... args)