LSSTApplications  16.0-10-g0ee56ad+5,16.0-11-ga33d1f2+5,16.0-12-g3ef5c14+3,16.0-12-g71e5ef5+18,16.0-12-gbdf3636+3,16.0-13-g118c103+3,16.0-13-g8f68b0a+3,16.0-15-gbf5c1cb+4,16.0-16-gfd17674+3,16.0-17-g7c01f5c+3,16.0-18-g0a50484+1,16.0-20-ga20f992+8,16.0-21-g0e05fd4+6,16.0-21-g15e2d33+4,16.0-22-g62d8060+4,16.0-22-g847a80f+4,16.0-25-gf00d9b8+1,16.0-28-g3990c221+4,16.0-3-gf928089+3,16.0-32-g88a4f23+5,16.0-34-gd7987ad+3,16.0-37-gc7333cb+2,16.0-4-g10fc685+2,16.0-4-g18f3627+26,16.0-4-g5f3a788+26,16.0-5-gaf5c3d7+4,16.0-5-gcc1f4bb+1,16.0-6-g3b92700+4,16.0-6-g4412fcd+3,16.0-6-g7235603+4,16.0-69-g2562ce1b+2,16.0-8-g14ebd58+4,16.0-8-g2df868b+1,16.0-8-g4cec79c+6,16.0-8-gadf6c7a+1,16.0-8-gfc7ad86,16.0-82-g59ec2a54a+1,16.0-9-g5400cdc+2,16.0-9-ge6233d7+5,master-g2880f2d8cf+3,v17.0.rc1
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).