8 #include <framework/database/DBImportObjPtr.h> 
    9 #include <hlt/softwaretrigger/core/SoftwareTriggerDBHandler.h> 
   11 #include <boost/algorithm/string/predicate.hpp> 
   18   namespace SoftwareTrigger {
 
   30                                                           const std::string& cutIdentifier)
 
   32       assert(baseCutIdentifier.find(
"&") == std::string::npos);
 
   33       assert(cutIdentifier.find(
"&") == std::string::npos);
 
   45       assert(baseIdentifier.find(
"&") == std::string::npos);
 
   52       assert(baseIdentifier.find(
"&") == std::string::npos);
 
   53       assert(std::count(cutName.begin(), cutName.end(), 
'&') == 2);
 
   55       return boost::starts_with(cutName, 
makeFullCutName(baseIdentifier, 
""));
 
   61       B2ASSERT(
"The name " << 
s_totalResultIdentifier << 
" is already used for the total result of each trigger stage. " 
   63       const std::string& fullCutName = 
makeFullCutName(baseCutIdentifier, cutIdentifier);
 
   65       cutToUpload.
construct(cut->getPreScaleFactor(), cut->isRejectCut(), cut->decompile());
 
   70                                                      const std::vector<std::string>& cutIdentifiers,
 
   76       menuToUpload.
construct(cutIdentifiers, acceptMode);
 
   81         const std::string& cutIdentifier)
 
   83       const std::string& fullCutName = 
makeFullCutName(baseCutIdentifier, cutIdentifier);
 
   92     std::unique_ptr<SoftwareTriggerMenu>
 
   98         return std::make_unique<SoftwareTriggerMenu>(*downloadedMenu);
 
  114         if (databaseCutEntry.hasChanged()) {
 
  115           B2ASSERT(
"The name of the database entry changed! This is not handled properly by the module.",
 
  124       B2ASSERT(
"Could not find a valid trigger name with this " 
  133       B2DEBUG(20, 
"Initializing SoftwareTrigger DB with baseIdentifier " << 
m_baseIdentifier << 
" and " << cutIdentifiers.size() <<
 
  136       for (
const std::string& cutIdentifier : cutIdentifiers) {
 
  137         B2DEBUG(20, 
"-> with CutIndentifier " << cutIdentifier);
 
  144           B2FATAL(
"There is no DB object with the name " << fullIdentifier);
 
bool import(const IntervalOfValidity &iov)
Import the object to database.
Class for importing a single object to the database.
void construct(Args &&... params)
Construct an object of type T in this DBImportObjPtr using the provided constructor arguments.
Class for accessing objects in the database.
Class to handle storing SoftwareTriggerCuts in the database.
const std::string & getCutString() const
Return the cut string stored in this db representation.
A class that describes the interval of experiments/runs for which an object in the database is valid.
bool isRejectCut() const
Returns true, if the cut is a reject cut and false otherwise.
unsigned int getPreScaleFactor() const
Return the list of pre scale factors.
static std::unique_ptr< SoftwareTriggerCut > compile(const std::string &cut_string, const unsigned int prescaleFactor, const bool rejectCut=false)
Compile a new SoftwareTriggerCut from a cut string (by using the GeneralCut::compile function) and an...
static std::unique_ptr< SoftwareTriggerMenu > downloadTriggerMenu(const std::string &baseCutIdentifier)
Download a trigger menu from the database.
static std::string makeFullTriggerMenuName(const std::string &baseIdentifier)
Helper function to compile the full menu identifier from the base name.
void initialize()
Download the trigger menu and afterwards the cuts with the given base name and specific names from th...
static std::string makeFullCutName(const std::string &baseCutIdentifier, const std::string &cutIdentifier)
Helper function to compile the full identifier from the base and the specific cut name.
const std::map< std::string, std::unique_ptr< const SoftwareTriggerCut > > & getCutsWithNames() const
Get the already downloaded list of constant cuts with their identifiers.
static const std::string s_totalResultIdentifier
Common suffix to identify all total results in the stored results.
static void uploadTriggerMenu(const std::string &baseCutIdentifier, const std::vector< std::string > &cutIdentifiers, bool acceptMode, const IntervalOfValidity &iov)
Upload a new (or replace an old version) trigger menu with the given base and specific names.
bool getAcceptOverridesReject() const
Return true of the trigger menu is in accept mode.
static std::unique_ptr< SoftwareTriggerCut > createCutFromDB(const DBRepresentationOfSoftwareTriggerCut &dbCut)
Helper factory function to generate a unique cut pointer from its representation in the database.
std::map< std::string, std::unique_ptr< const SoftwareTriggerCut > > m_cutsWithIdentifier
Map of cuts with their identifiers, downloaded from the database.
DBObjPtr< SoftwareTriggerMenu > m_softwareTriggerMenu
Database entry of the software trigger menu.
static bool hasBaseIdentifier(const std::string &cutName, const std::string &baseIdentifier)
Check if a given cut name in the form <package_identifier>&<base_name>&<cut_name> has the given base ...
std::vector< DBObjPtr< DBRepresentationOfSoftwareTriggerCut > > m_databaseObjects
Database entries of the cuts, which where created in the initialize function.
void checkForChangedDBEntries()
Helper function to check for changes in the DB of all cuts registered in the initialize function.
static void upload(const std::unique_ptr< SoftwareTriggerCut > &cut, const std::string &baseCutIdentifier, const std::string &cutIdentifier, const IntervalOfValidity &iov)
Upload a new (or replace an old version) cut with the given base and specific name.
static std::string makeTotalResultName(const std::string &baseIdentifier="all")
Handy function to create the name related to the total result of a specific trigger stage (either fil...
static const std::string s_dbPackageIdentifier
Common prefix to identify all software trigger cuts in the database.
std::string m_baseIdentifier
Base identifier.
static std::unique_ptr< SoftwareTriggerCut > download(const std::string &baseCutIdentifier, const std::string &cutIdentifier)
Download a cut from the database.
Abstract base class for different kinds of events.