LSSTApplications  19.0.0-14-gb0260a2+72efe9b372,20.0.0+7927753e06,20.0.0+8829bf0056,20.0.0+995114c5d2,20.0.0+b6f4b2abd1,20.0.0+bddc4f4cbe,20.0.0-1-g253301a+8829bf0056,20.0.0-1-g2b7511a+0d71a2d77f,20.0.0-1-g5b95a8c+7461dd0434,20.0.0-12-g321c96ea+23efe4bbff,20.0.0-16-gfab17e72e+fdf35455f6,20.0.0-2-g0070d88+ba3ffc8f0b,20.0.0-2-g4dae9ad+ee58a624b3,20.0.0-2-g61b8584+5d3db074ba,20.0.0-2-gb780d76+d529cf1a41,20.0.0-2-ged6426c+226a441f5f,20.0.0-2-gf072044+8829bf0056,20.0.0-2-gf1f7952+ee58a624b3,20.0.0-20-geae50cf+e37fec0aee,20.0.0-25-g3dcad98+544a109665,20.0.0-25-g5eafb0f+ee58a624b3,20.0.0-27-g64178ef+f1f297b00a,20.0.0-3-g4cc78c6+e0676b0dc8,20.0.0-3-g8f21e14+4fd2c12c9a,20.0.0-3-gbd60e8c+187b78b4b8,20.0.0-3-gbecbe05+48431fa087,20.0.0-38-ge4adf513+a12e1f8e37,20.0.0-4-g97dc21a+544a109665,20.0.0-4-gb4befbc+087873070b,20.0.0-4-gf910f65+5d3db074ba,20.0.0-5-gdfe0fee+199202a608,20.0.0-5-gfbfe500+d529cf1a41,20.0.0-6-g64f541c+d529cf1a41,20.0.0-6-g9a5b7a1+a1cd37312e,20.0.0-68-ga3f3dda+5fca18c6a4,20.0.0-9-g4aef684+e18322736b,w.2020.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 }}}}
std::string
STL class.
std::vector
STL class.
std::vector::size
T size(T... args)
lsst::afw::geom.transform.transformContinued.name
string name
Definition: transformContinued.py:32
base.h
lsst.pex::exceptions::LengthError
Reports attempts to exceed implementation-defined length limits for some classes.
Definition: Runtime.h:76
lsst::daf::base::PropertySet::getAsString
std::string getAsString(std::string const &name) const
Get the last value for a string property name (possibly hierarchical).
std::string::c_str
T c_str(T... args)
lsst::daf::base::PropertySet::nameCount
size_t nameCount(bool topLevelOnly=true) const
Get the number of names in the PropertySet, optionally including those in subproperties.
lsst
A base class for image defects.
Definition: imageAlgorithm.dox:1
lsst::daf::base::PropertySet::paramNames
std::vector< std::string > paramNames(bool topLevelOnly=true) const
A variant of names that excludes the names of subproperties.
LSST_EXCEPT
#define LSST_EXCEPT(type,...)
Create an exception with a given type.
Definition: Exception.h:48
lsst::daf::base::PropertySet
Class for storing generic metadata.
Definition: PropertySet.h:67