ROOT logo
ROOT » PROOF » PROOF » TDataSetManagerFile

class TDataSetManagerFile: public TDataSetManager


TDataSetManagerFile

Implementation of TDataSetManager handling datasets from root
files under a specific directory path


Function Members (Methods)

public:
TDataSetManagerFile(const char* group = 0, const char* user = 0, const char* ins = 0)
virtual~TDataSetManagerFile()
voidTObject::AbstractMethod(const char* method) const
virtual voidTObject::AppendPad(Option_t* option = "")
virtual voidTObject::Browse(TBrowser* b)
static TClass*Class()
virtual const char*TObject::ClassName() const
virtual voidTObject::Clear(Option_t* = "")
virtual TObject*TObject::Clone(const char* newname = "") const
virtual Int_tTObject::Compare(const TObject* obj) const
virtual voidTObject::Copy(TObject& object) const
static TStringTDataSetManager::CreateUri(const char* dsGroup = 0, const char* dsUser = 0, const char* dsName = 0, const char* dsTree = 0)
virtual voidTObject::Delete(Option_t* option = "")MENU
virtual Int_tTObject::DistancetoPrimitive(Int_t px, Int_t py)
virtual voidTObject::Draw(Option_t* option = "")
virtual voidTObject::DrawClass() constMENU
virtual TObject*TObject::DrawClone(Option_t* option = "") constMENU
virtual voidTObject::Dump() constMENU
virtual voidTObject::Error(const char* method, const char* msgfmt) const
virtual voidTObject::Execute(const char* method, const char* params, Int_t* error = 0)
virtual voidTObject::Execute(TMethod* method, TObjArray* params, Int_t* error = 0)
virtual voidTObject::ExecuteEvent(Int_t event, Int_t px, Int_t py)
virtual Bool_tExistsDataSet(const char* uri)
virtual voidTObject::Fatal(const char* method, const char* msgfmt) const
virtual TObject*TObject::FindObject(const char* name) const
virtual TObject*TObject::FindObject(const TObject* obj) const
virtual TFileCollection*GetDataSet(const char* uri, const char* srv = 0)
TFileCollection*GetDataSet(const char* group, const char* user, const char* dsName, UInt_t option = 0, TMD5** checksum = 0)
virtual TMap*GetDataSets(const char* uri, UInt_t = 0)
TMap*GetDataSets(const char* group, const char* user, UInt_t option = 0)
virtual Option_t*TObject::GetDrawOption() const
static Long_tTObject::GetDtorOnly()
virtual Long64_tTDataSetManager::GetGroupQuota(const char* group)
virtual TMap*TDataSetManager::GetGroupQuotaMap()
virtual Long64_tTDataSetManager::GetGroupUsed(const char* group)
virtual const char*TObject::GetIconName() const
virtual const char*TObject::GetName() const
virtual char*TObject::GetObjectInfo(Int_t px, Int_t py) const
static Bool_tTObject::GetObjectStat()
virtual Option_t*TObject::GetOption() const
virtual TMap*TDataSetManager::GetSubDataSets(const char* uri, const char* excludeservers)
virtual const char*TObject::GetTitle() const
virtual UInt_tTObject::GetUniqueID() const
virtual Bool_tTObject::HandleTimer(TTimer* timer)
virtual ULong_tTObject::Hash() const
virtual voidTObject::Info(const char* method, const char* msgfmt) const
virtual Bool_tTObject::InheritsFrom(const char* classname) const
virtual Bool_tTObject::InheritsFrom(const TClass* cl) const
virtual voidTObject::Inspect() constMENU
voidTObject::InvertBit(UInt_t f)
virtual TClass*IsA() const
virtual Bool_tTObject::IsEqual(const TObject* obj) const
virtual Bool_tTObject::IsFolder() const
Bool_tTObject::IsOnHeap() const
virtual Bool_tTObject::IsSortable() const
Bool_tTObject::IsZombie() const
virtual voidTObject::ls(Option_t* option = "") const
voidTObject::MayNotUse(const char* method) const
virtual voidTDataSetManager::MonitorUsedSpace(TVirtualMonitoringWriter* monitoring)
virtual Bool_tTObject::Notify()
static voidTObject::operator delete(void* ptr)
static voidTObject::operator delete(void* ptr, void* vp)
static voidTObject::operator delete[](void* ptr)
static voidTObject::operator delete[](void* ptr, void* vp)
void*TObject::operator new(size_t sz)
void*TObject::operator new(size_t sz, void* vp)
void*TObject::operator new[](size_t sz)
void*TObject::operator new[](size_t sz, void* vp)
TObject&TObject::operator=(const TObject& rhs)
virtual voidTObject::Paint(Option_t* option = "")
virtual voidParseInitOpts(const char* opts)
Bool_tTDataSetManager::ParseUri(const char* uri, TString* dsGroup = 0, TString* dsUser = 0, TString* dsName = 0, TString* dsTree = 0, Bool_t onlyCurrent = kFALSE, Bool_t wildcards = kFALSE)
virtual voidTObject::Pop()
virtual voidTObject::Print(Option_t* option = "") const
virtual Int_tTObject::Read(const char* name)
virtual voidTObject::RecursiveRemove(TObject* obj)
virtual Int_tRegisterDataSet(const char* uri, TFileCollection* dataSet, const char* opt)
virtual Bool_tRemoveDataSet(const char* uri)
voidTObject::ResetBit(UInt_t f)
virtual voidTObject::SaveAs(const char* filename = "", Option_t* option = "") constMENU
virtual voidTObject::SavePrimitive(basic_ostream<char,char_traits<char> >& out, Option_t* option = "")
virtual Int_tScanDataSet(const char* uri, UInt_t option = 0)
Int_tScanDataSet(TFileCollection* dataset, UInt_t option, Int_t filesmax = -1)
voidTObject::SetBit(UInt_t f)
voidTObject::SetBit(UInt_t f, Bool_t set)
virtual voidTObject::SetDrawOption(Option_t* option = "")MENU
static voidTObject::SetDtorOnly(void* obj)
static voidTObject::SetObjectStat(Bool_t stat)
virtual voidTObject::SetUniqueID(UInt_t uid)
virtual voidTDataSetManager::ShowDataSets(const char* uri = "*", const char* opt = "")
virtual voidShowMembers(TMemberInspector& insp, char* parent)
virtual voidTDataSetManager::ShowQuota(const char* opt)
virtual voidStreamer(TBuffer& b)
voidStreamerNVirtual(TBuffer& b)
virtual voidTObject::SysError(const char* method, const char* msgfmt) const
Bool_tTObject::TestBit(UInt_t f) const
Int_tTObject::TestBits(UInt_t f) const
virtual voidTObject::UseCurrentStyle()
virtual voidTObject::Warning(const char* method, const char* msgfmt) const
virtual Int_tTObject::Write(const char* name = 0, Int_t option = 0, Int_t bufsize = 0)
virtual Int_tTObject::Write(const char* name = 0, Int_t option = 0, Int_t bufsize = 0) const
Int_tWriteDataSet(const char* group, const char* user, const char* dsName, TFileCollection* dataset, UInt_t option = 0, TMD5* checksum = 0)
protected:
Bool_tBrowseDataSets(const char* group, const char* user, UInt_t option, TObject* target)
virtual voidTObject::DoError(int level, const char* location, const char* fmt, va_list va) const
Bool_tExistsDataSet(const char* group, const char* user, const char* dsName)
const char*GetDataSetPath(const char* group, const char* user, const char* dsName)
virtual TMap*TDataSetManager::GetGroupUsedMap()
Int_tTDataSetManager::GetNDisapparedFiles() const
Int_tTDataSetManager::GetNOpenedFiles() const
Int_tTDataSetManager::GetNTouchedFiles() const
voidTDataSetManager::GetQuota(const char* group, const char* user, const char* dsName, TFileCollection* dataset)
virtual TMap*TDataSetManager::GetUserUsedMap()
voidTObject::MakeZombie()
voidTDataSetManager::PrintDataSet(TFileCollection* fc, Int_t popt = 0)
voidTDataSetManager::PrintUsedSpace()
Bool_tTDataSetManager::ReadGroupConfig(const char* cf = 0)
Bool_tRemoveDataSet(const char* group, const char* user, const char* dsName)
Int_tScanDataSet(const char* group, const char* user, const char* dsName, UInt_t option)
static Long64_tTDataSetManager::ToBytes(const char* size = 0)
virtual voidUpdateUsedSpace()

Data Members

protected:
Long64_tTDataSetManager::fAvgFileSizeAverage file size to be used to estimate the dataset size (in MB)
TUriTDataSetManager::fBaseBase URI used to parse dataset names
TStringTDataSetManager::fCommonGroupGroup that stores the COMMON datasets
TStringTDataSetManager::fCommonUserUser that stores the COMMON datasets
TStringTDataSetManager::fGroupGroup to which the owner of this session belongs
TStringTDataSetManager::fGroupConfigFilePath to the group config file
TMapTDataSetManager::fGroupQuotaGroup quotas (read from config file)
TMapTDataSetManager::fGroupUsed<group> --> <used bytes> (TParameter)
Long_tTDataSetManager::fMTimeGroupConfigLast modification of the group config file
Int_tTDataSetManager::fNDisappearedFilesNumber of files disappared in the last ScanDataSet operation
Int_tTDataSetManager::fNOpenedFilesNumber of files opened in the last ScanDataSet operation
Int_tTDataSetManager::fNTouchedFilesNumber of files touched in the last ScanDataSet operation
TStringTDataSetManager::fUserOwner of the session
TMapTDataSetManager::fUserUsed<group> --> <map of users> --> <value>
static TStringTDataSetManager::fgCommonDataSetTagName for common datasets, default: COMMON
private:
TStringfDataSetDirLocation of datasets
TStringfDataSetLockFileDataset lock file
Int_tfLockFileTimeLimitLimit in seconds after a lock automatically expires
TStringfMSSUrlURL for the Mass Storage System

Class Charts

Inheritance Inherited Members Includes Libraries
Class Charts

Function documentation

TDataSetManagerFile(const char* group = 0, const char* user = 0, const char* ins = 0)
 Main constructor
void ParseInitOpts(const char* opts)
 Parse the input string and set the init bits accordingly
 Format is
    dir:<datasetdir> [mss:<mss-url>] [opt:<base-options>]
 The <datasetdir> is mandatory.
 See TDataSetManager::ParseInitOpts for the available
 base options.
 The base options are laready initialized by the base constructor
const char * GetDataSetPath(const char* group, const char* user, const char* dsName)
 Returns path of the indicated dataset
 Contains a static TString for result. Copy result before using twice.
Bool_t BrowseDataSets(const char* group, const char* user, UInt_t option, TObject* target)
 Adds the dataset in the folder of group, user to the list in target

 The unsigned int 'option' is forwarded to GetDataSet and BrowseDataSet.
 Available options (to be .or.ed):
    kPrint          print the dataset content
    kQuotaUpdate    update quotas
    kExport         use export naming

 NB1: options "kPrint", "kQuoatUpdate" and "kExport" are mutually exclusive
 NB2: for options "kPrint" and "kQuotaUpdate" return is null.
TMap * GetDataSets(const char* group, const char* user, UInt_t option = 0)
 General purpose call to go through the existing datasets.
 If <user> is 0 or "*", act on all datasets for the given <group>.
 If <group> is 0 or "*", act on all datasets.
 Action depends on option; available options:

    kExport         Return a TMap object containing all the information about
                    datasets in the form:
                    { <group>, <map of users> }
                                     |
                             { <map of datasets>, <dataset>}
                    (<dataset> are TFileCollection objects)
    kShowDefault    as kExport with in addition a default selection including
                    the datasets from the current user, the ones from the group
                    and the common ones

    kPrint          print the dataset content; no output is returned
    kQuotaUpdate    update {group, user} quotas; no output is returned

 NB1: options "kPrint", "kQuoatUpdate" and "kExport" are mutually exclusive
 NB2: for options "kPrint" and "kQuoatUpdate" return is null.
TFileCollection * GetDataSet(const char* group, const char* user, const char* dsName, UInt_t option = 0, TMD5** checksum = 0)
 Returns the dataset <dsName> of user <user> in group <group> .
 If checksum is non-zero, it will contain the pointer to a TMD5 sum object
 with the checksum of the file, has to be deleted by the user.
 If option has the bi kReadShort set, the shortobject is read, that does not
 contain the list of files. This is much faster.
Int_t WriteDataSet(const char* group, const char* user, const char* dsName, TFileCollection* dataset, UInt_t option = 0, TMD5* checksum = 0)
 Writes indicated dataset.
 If option has the bit kFileMustExist set, the file must still exist,
 otherwise the new dataset is not written (returns 3 in this case).
 If checksum is non-zero the files current checksum is checked against it,
 if it does not match the file is not written (the function returns 2 in this
 case, if the file has disappeared it is also not written (i.e. checksum
 implies the bit kFileMustExist set in option).
 Returns != 0 for success, 0 for error
Bool_t RemoveDataSet(const char* group, const char* user, const char* dsName)
 Removes the indicated dataset
Bool_t ExistsDataSet(const char* group, const char* user, const char* dsName)
 Checks if the indicated dataset exits
Int_t RegisterDataSet(const char* uri, TFileCollection* dataSet, const char* opt)
 Register a dataset, perfoming quota checkings and verification, if required.
 Fails if a dataset with the same name already exists, unless 'opts'
 contains 'O', in which case the old dataset is overwritten.
 If 'opts' contains 'V' the dataset files are also verified (if the dataset manager
 is configured to allow so).
 If 'opts' contains 'T' the in the dataset object (status bits, meta,...)
 is trusted, i.e. not reset (if the dataset manager is configured to allow so).
 By default the dataset is not verified.
 Returns 0 on success, -1 on failure
Int_t ScanDataSet(const char* uri, UInt_t option = 0)
 Scans the dataset indicated by <uri> and returns the number of missing files.
 Returns -1 if any failure occurs, >= 0 on success.
 For more details, see documentation of
 ScanDataSet(TFileCollection *dataset, const char *option)
Int_t ScanDataSet(const char* group, const char* user, const char* dsName, UInt_t option)
 See documentation of ScanDataSet(TFileCollection *dataset, UInt_t option)
Int_t ScanDataSet(TFileCollection* dataset, UInt_t option, Int_t filesmax = -1)
 Updates the information in a dataset by opening all files that are not yet
 marked staged creates metadata for each tree in the opened file

 Available options (to be .or.ed)
   kMaxFiles      process a maximum of 'filesmax' files
   kReopen        opens also files that are marked staged
   kTouch         opens and touches files that are marked staged; implies kReopen

 Return code
   negative in case of error
     -1 dataset not found
     -2 could not write dataset after verification

   positive in case of success
     1 dataset was not changed
     2 dataset was changed

 The number of opened, touched, disappeared files can be retrieved by
 GetNTouchedFiles(), GetNOpenedFiles(), GetNDisapparedFiles()
TMap * GetDataSets(const char* uri, UInt_t = 0)
 Returns all datasets for the <group> and <user> specified by <uri>.
 If <user> is 0, it returns all datasets for the given <group>.
 If <group> is 0, it returns all datasets.
 The returned TMap contains:
    <group> --> <map of users> --> <map of datasets> --> <dataset> (TFileCollection)

 The unsigned int 'option' is forwarded to GetDataSet and BrowseDataSet.
 Available options (to be .or.ed):
    kShowDefault    a default selection is shown that include the ones from
                    the current user, the ones from the group and the common ones
    kPrint          print the dataset content
    kQuotaUpdate    update quotas
    kExport         use export naming

 NB1: options "kPrint", "kQuoatUpdate" and "kExport" are mutually exclusive
 NB2: for options "kPrint" and "kQuoatUpdate" return is null.
TFileCollection * GetDataSet(const char* uri, const char* srv = 0)
 Utility function used in various methods for user dataset upload.
Bool_t RemoveDataSet(const char* uri)
 Removes the indicated dataset
Bool_t ExistsDataSet(const char* uri)
 Checks if the indicated dataset exits
void UpdateUsedSpace()
 updates the used space maps
virtual ~TDataSetManagerFile()
{ }