LSST Applications g063fba187b+cac8b7c890,g0f08755f38+6aee506743,g1653933729+a8ce1bb630,g168dd56ebc+a8ce1bb630,g1a2382251a+b4475c5878,g1dcb35cd9c+8f9bc1652e,g20f6ffc8e0+6aee506743,g217e2c1bcf+73dee94bd0,g28da252d5a+1f19c529b9,g2bbee38e9b+3f2625acfc,g2bc492864f+3f2625acfc,g3156d2b45e+6e55a43351,g32e5bea42b+1bb94961c2,g347aa1857d+3f2625acfc,g35bb328faa+a8ce1bb630,g3a166c0a6a+3f2625acfc,g3e281a1b8c+c5dd892a6c,g3e8969e208+a8ce1bb630,g414038480c+5927e1bc1e,g41af890bb2+8a9e676b2a,g7af13505b9+809c143d88,g80478fca09+6ef8b1810f,g82479be7b0+f568feb641,g858d7b2824+6aee506743,g89c8672015+f4add4ffd5,g9125e01d80+a8ce1bb630,ga5288a1d22+2903d499ea,gb58c049af0+d64f4d3760,gc28159a63d+3f2625acfc,gcab2d0539d+b12535109e,gcf0d15dbbd+46a3f46ba9,gda6a2b7d83+46a3f46ba9,gdaeeff99f8+1711a396fd,ge79ae78c31+3f2625acfc,gef2f8181fd+0a71e47438,gf0baf85859+c1f95f4921,gfa517265be+6aee506743,gfa999e8aa5+17cd334064,w.2024.51
LSST Data Management Base Package
|
A polymorphic functor base class for generating record IDs for a table. More...
#include <IdFactory.h>
Public Member Functions | |
virtual RecordId | operator() ()=0 |
Return a new unique RecordId. | |
virtual void | notify (RecordId id)=0 |
Notify the IdFactory that the given ID has been used and must not be returned by operator(). | |
virtual std::shared_ptr< IdFactory > | clone () const =0 |
Deep-copy the IdFactory. | |
IdFactory ()=default | |
IdFactory (IdFactory const &)=default | |
IdFactory (IdFactory &&)=default | |
IdFactory & | operator= (IdFactory const &other)=delete |
IdFactory & | operator= (IdFactory &&other)=delete |
virtual | ~IdFactory ()=default |
Static Public Member Functions | |
static std::shared_ptr< IdFactory > | makeSimple () |
Return a simple IdFactory that simply counts from 1. | |
static std::shared_ptr< IdFactory > | makeSource (RecordId expId, int reserved) |
Return an IdFactory that includes another, fixed ID in the higher-order bits. | |
static int | computeReservedFromMaxBits (int maxBits) |
Return the number to pass as the 'reserved' argument to makeSource for an exposure ID with the given maximum number of bits. | |
A polymorphic functor base class for generating record IDs for a table.
The IDs produced by an IdFactory need not be sequential, but they must be unique, both with respect to the IDs it generates itself and those passed to it via the notify() member function. Valid IDs must be nonzero, as zero is used to indicate null in some contexts.
Definition at line 21 of file IdFactory.h.
|
default |
|
default |
|
virtualdefault |
|
pure virtual |
Deep-copy the IdFactory.
|
inlinestatic |
Return the number to pass as the 'reserved' argument to makeSource for an exposure ID with the given maximum number of bits.
[in] | maxBits | The maximum number of bits an exposure ID can have. |
Definition at line 57 of file IdFactory.h.
|
static |
Return a simple IdFactory that simply counts from 1.
This is used when an empty pointer is passed to the BaseTable constructor.
Definition at line 70 of file IdFactory.cc.
|
static |
Return an IdFactory that includes another, fixed ID in the higher-order bits.
[in] | expId | ID to include in the upper bits via a bitwise OR. |
[in] | reserved | How many bits to reserve for the part of the ID that is unique. |
The final record ID will be:
(upper << reserved) | sequence
Definition at line 72 of file IdFactory.cc.
Notify the IdFactory that the given ID has been used and must not be returned by operator().
Return a new unique RecordId.