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
IdFactory.cc
Go to the documentation of this file.
1 #include <memory>
2 #include "boost/format.hpp"
3 
4 #include "lsst/pex/exceptions.h"
6 
7 namespace lsst {
8 namespace afw {
9 namespace table {
10 
11 namespace {
12 
13 class SimpleIdFactory : public IdFactory {
14 public:
15  RecordId operator()() override { return ++_current; }
16 
17  void notify(RecordId id) override { _current = id; }
18 
19  std::shared_ptr<IdFactory> clone() const override { return std::make_shared<SimpleIdFactory>(*this); }
20 
21  SimpleIdFactory() : _current(0) {}
22 
23 private:
24  RecordId _current;
25 };
26 
27 class SourceIdFactory : public IdFactory {
28 public:
29  RecordId operator()() override {
30  if (++_lower & _upperMask) {
31  --_lower;
32  throw LSST_EXCEPT(pex::exceptions::LengthError,
33  (boost::format("Next ID '%s' is too large for the number of reserved bits") %
34  (_lower + 1))
35  .str());
36  }
37  return _upper | _lower;
38  }
39 
40  void notify(RecordId id) override {
41  RecordId newLower = id & (~_upper); // chop off the exact exposure ID
42  if (newLower & _upperMask) {
43  throw LSST_EXCEPT(
44  pex::exceptions::InvalidParameterError,
45  (boost::format("Explicit ID '%s' does not have the correct form.") % newLower).str());
46  }
47  _lower = newLower;
48  }
49 
50  std::shared_ptr<IdFactory> clone() const override { return std::make_shared<SourceIdFactory>(*this); }
51 
52  SourceIdFactory(RecordId expId, int reserved)
53  : _upper(expId << reserved),
54  _upperMask(std::numeric_limits<RecordId>::max() << reserved),
55  _lower(0) {
56  if (_upper >> reserved != expId) {
57  throw LSST_EXCEPT(pex::exceptions::InvalidParameterError,
58  (boost::format("Exposure ID '%s' is too large.") % expId).str());
59  }
60  }
61 
62 private:
63  RecordId const _upper;
64  RecordId const _upperMask;
65  RecordId _lower;
66 };
67 
68 } // namespace
69 
70 std::shared_ptr<IdFactory> IdFactory::makeSimple() { return std::make_shared<SimpleIdFactory>(); }
71 
73  return std::make_shared<SourceIdFactory>(expId, reserved);
74 }
75 } // namespace table
76 } // namespace afw
77 } // namespace lsst
lsst::afw::table::IdFactory::makeSource
static std::shared_ptr< IdFactory > makeSource(RecordId expId, int reserved)
Return an IdFactory that includes another, fixed ID in the higher-order bits.
Definition: IdFactory.cc:72
std::shared_ptr
STL class.
lsst::afw::table::RecordId
std::int64_t RecordId
Type used for unique IDs for records.
Definition: misc.h:22
lsst::afw::table::IdFactory::makeSimple
static std::shared_ptr< IdFactory > makeSimple()
Return a simple IdFactory that simply counts from 1.
Definition: IdFactory.cc:70
lsst::afw
Definition: imageAlgorithm.dox:1
lsst.pex.config.history.format
def format(config, name=None, writeSourceLine=True, prefix="", verbose=False)
Definition: history.py:174
id
table::Key< int > id
Definition: Detector.cc:162
IdFactory.h
max
int max
Definition: BoundedField.cc:104
std::int64_t
lsst
A base class for image defects.
Definition: imageAlgorithm.dox:1
LSST_EXCEPT
#define LSST_EXCEPT(type,...)
Create an exception with a given type.
Definition: Exception.h:48
std
STL namespace.
lsst::afw::image.slicing.clone
clone
Definition: slicing.py:257
exceptions.h