9 #include "KVDataSetManager.h"
10 #include "KVDataRepositoryManager.h"
22 #define CHMODE(u,g,o) ((u << 6) + (g << 3) + o)
48 KVDataSetManager::~KVDataSetManager()
81 if (!ReadDataSetList())
92 if (dr) fCacheFileName.Form(
"%s.available.datasets", dr->
GetName());
102 if (GetNavailable()) {
103 for (
Int_t i = 1; i <= GetNavailable(); i++)
104 GetAvailableDataSet(i)->SetAnalysisTasks(&fTasks);
108 if (!dr) gDataSetManager =
this;
134 TIter next_name(toks);
136 while ((group_name = (
TObjString*) next_name())) {
142 fUserGroups.SetValue(group_name->
String().
Data(), users);
197 task_list.
Begin(
" ");
198 while (!task_list.
End()) {
235 cout <<
" *** No available datasets ***" <<
240 for (
int i = 1; i <= fNavailable; i++) {
242 cout <<
"\t" << i <<
". " << ds->
GetTitle() << endl;
247 if (fDataSets.GetSize()) {
248 TIter next(&fDataSets);
302 if (fCacheAvailable) {
304 if (CheckCacheStatus()) {
306 if (ReadAvailableDatasetsFile())
return;
311 if (fRepository) fRepository->PrintAvailableDatasetsUpdateWarning();
315 TString tmp_file_path = fCacheFileName;
319 if (fDataSets.GetSize()) {
320 TIter next(&fDataSets);
329 tmp_file << ds->
GetName() <<
" : ";
342 if (fNavailable && fRepository) {
355 ReadAvailableDatasetsFile();
381 if (fDataSets.GetSize() &&
index < fDataSets.GetSize())
409 if (fNavailable &&
index &&
index <= fNavailable)
437 TString Username = strcmp(username,
441 if (fUserGroups.HasParameter(groupname)) {
442 if (fUserGroups.GetTStringValue(groupname).Contains(Username.
Data()))
477 if (GetNavailable()) {
478 for (
Int_t i = 1; i <= GetNavailable(); i++)
479 GetAvailableDataSet(i)->SetAnalysisTasks(&fTasks);
517 if (OpenAvailableDatasetsFile()) {
518 Info(
"ReadAvailableDataSetsFile",
519 "Reading cached information in file %s", fCacheFileName.Data());
522 line.ReadLine(fDatasets);
523 while (fDatasets.good()) {
537 for (
int i = 1; i < toks->
GetEntries(); i++) {
550 line.ReadLine(fDatasets);
558 TIter next(&fDataSets);
592 Info(
"KVDataSetManager::CheckCacheStatus",
"Checking for available datasets cache file...");
601 Info(
"KVDataSetManager::CheckCacheStatus",
"...file found. It is %u seconds old", file_age);
602 if (file_age < fMaxCacheTime) {
603 Info(
"KVDataSetManager::CheckCacheStatus",
"Using cached file");
607 Info(
"KVDataSetManager::CheckCacheStatus",
"File is too old (max time=%u). Update will be performed.", fMaxCacheTime);
610 Info(
"KVDataSetManager::CheckCacheStatus",
"...no file found");
Option_t Option_t TPoint TPoint const char GetTextMagnitude GetFillStyle GetLineColor GetLineWidth GetMarkerStyle GetTextAlign GetTextColor GetTextSize void char Point_t Rectangle_t WindowAttributes_t index
char * Form(const char *fmt,...)
R__EXTERN TSystem * gSystem
static void OpenTempFile(TString &base, std::ofstream &fp)
static const Char_t * GetWORKDIRFilePath(const Char_t *namefile="")
static Bool_t SearchKVFile(const Char_t *name, TString &fullpath, const Char_t *kvsubdir="")
static Bool_t SearchAndOpenKVFile(const Char_t *name, KVSQLite::database &dbfile, const Char_t *kvsubdir="")
Define and manage data analysis tasks.
virtual void SetDataAnalyser(const Char_t *d)
virtual void SetPrereq(const Char_t *p)
virtual void SetStatusUpdateInterval(Long64_t n)
virtual void SetUserBaseClass(const Char_t *d)
virtual void SetWithUserClass(Bool_t w=kTRUE)
Base class for managing repositories of experimental data.
virtual Bool_t IsRemote() const
Returns kTRUE for remote repositories, kFALSE for local repositories.
Manage all datasets contained in a given data repository.
virtual void Print(Option_t *opt="") const
virtual void ReadUserGroups()
virtual Bool_t ReadDataSetList()
virtual Bool_t Init(KVDataRepository *=0)
KVDataAnalysisTask * GetAnalysisTaskAny(const Char_t *keywords) const
virtual Bool_t OpenAvailableDatasetsFile()
virtual Bool_t CheckCacheStatus()
virtual Bool_t ReadAvailableDatasetsFile()
virtual Bool_t CheckUser(const Char_t *groupname, const Char_t *username="")
virtual KVDataAnalysisTask * GetTask(const Char_t *name)
Return pointer to named data analysis task.
KVDataSet * GetDataSet(Int_t) const
Return pointer to DataSet using index in list of all datasets, index>=0.
virtual KVDataSet * NewDataSet()
Creates and returns pointer to new data set object.
virtual Bool_t ReadTaskList()
virtual void CheckAvailability()
virtual KVDataSet * GetAvailableDataSet(Int_t) const
Manage an experimental dataset corresponding to a given experiment or campaign.
virtual void SetUserGroups(const Char_t *groups)
virtual void SetDataPathSubdir(const Char_t *s)
virtual const Char_t * GetAvailableDataTypes() const
virtual void ls(Option_t *opt="") const
Print dataset information.
virtual void AddAvailableDataType(const Char_t *)
void SetName(const char *name)
virtual void CheckAvailable()
virtual Bool_t IsAvailable() const
Returns kTRUE if this dataset is available for analysis, i.e. if any associated data files are stored...
virtual void SetAvailable(Bool_t yes=kTRUE)
virtual Bool_t CheckUserCanAccess()
void SetRepository(KVDataRepository *)
Set pointer to data repository in which dataset is stored.
Extension of ROOT TString class which allows backwards compatibility with ROOT v3....
void Begin(TString delim) const
KVString Next(Bool_t strip_whitespace=kFALSE) const
UInt_t Convert(Bool_t toGMT=kFALSE) const
virtual const char * GetValue(const char *name, const char *dflt) const
virtual void SetTitle(const char *title="")
const char * GetName() const override
const char * GetTitle() const override
virtual void SetName(const char *name)
Int_t GetEntries() const override
TObject * At(Int_t idx) const override
const TString & GetString() const
const char * Data() const
TObjArray * Tokenize(const TString &delim) const
Bool_t BeginsWith(const char *s, ECaseCompare cmp=kExact) const
virtual int Chmod(const char *file, UInt_t mode)
virtual int CopyFile(const char *from, const char *to, Bool_t overwrite=kFALSE)
virtual int GetPathInfo(const char *path, FileStat_t &buf)
virtual UserGroup_t * GetUserInfo(const char *user=nullptr)
virtual int Unlink(const char *name)