44 const
char *textfile,
Int_t nfiles,
Int_t firstfile)
45 :
TNamed(name, title), fList(0), fMetaDataList(0), fDefaultTree(),
46 fTotalSize(0), fNFiles(0), fNStagedFiles(0), fNCorruptFiles(0)
51 fMetaDataList =
new TList;
54 AddFromFile(textfile, nfiles, firstfile);
78 Warning(
"Add",
"file: '%s' already in the list - ignoring",
124 Int_t ff = (!all && (firstfile < 1)) ? 1 : firstfile;
126 while (f.good() && (all || nf < nfiles)) {
132 if (all || nn >= ff) {
143 Error(
"AddFromFile",
"unable to open file %s (%s)", textfile, fn.
Data());
163 Error(
"Add",
"input dir undefined");
186 Error(
"Add",
"directory %s cannot be opened",
244 Info(
"RemoveDuplicates",
"%d duplicates found and removed", nr);
261 while ((fileInfo = dynamic_cast<TFileInfo*>(iter.
Next()))) {
263 subset->
Add(fileInfo);
287 Error(
"Add",
"attempt to add object of class: %s to a %s",
334 while ((fileInfo = dynamic_cast<TFileInfo*> (iter.
Next()))) {
353 while ((obj = metaDataIter.Next())) {
403 TPMERegexp re(
"(^|;| )filter:([SsCc]+)( |;|$)", 4);
404 if (re.
Match(option) == 4) {
410 Printf(
"TFileCollection %s - %s contains: %lld files with a size of" 411 " %lld bytes, %.1f %% staged - default tree name: '%s'",
416 Printf(
"The files contain the following trees:");
420 while ((metaData = dynamic_cast<TFileInfoMeta*>(metaDataIter.
Next()))) {
429 Printf(
"The collection contains the following files:");
442 bS = bs = bC = bc =
kFALSE;
450 if (!bc && !bC) bc = bC =
kTRUE;
451 if (!bs && !bS) bs = bS =
kTRUE;
458 Printf(
"\033[1m #. SC | Entries | Size | URL\033[m");
463 while ((info = dynamic_cast<TFileInfo *>(it.
Next()))) {
472 if ( ((s && bS) || (!s && bs)) && ((c && bC) || (!c && bc)) ) {
484 const char *curUrlStr = curUrl ? curUrl->
GetUrl() :
"n.a.";
485 Printf(
"\033[1m%4u.\033[m %c%c | %-7s | %6.1lf %s | %s",
487 (s ?
'S' :
's'), (c ?
'C' :
'c'),
488 ((entries > 0) ?
Form(
"% 7d", entries) :
"n.a."),
489 sz, um.
Data(), curUrlStr);
493 while ((url = info->
NextUrl())) {
504 Printf(
">> There are \033[1m%u\033[m file(s) in dataset: " 505 "\033[1m%u (%5.1f%%)\033[m matched your criteria (%s)",
506 countAll, countMatch,
510 Printf(
">> Total size : \033[1m%.1f %s\033[m", sz, um.
Data());
512 Printf(
">> Corrupted (C) : \033[1m%5.1f %%\033[m",
517 Printf(
">> No files in dataset");
521 Printf(
">> Default tree : \033[1m%s\033[m",
522 (treeName ? treeName :
"(no default tree)"));
532 static const char *ums[] = {
"byt",
"KiB",
"MiB",
"GiB",
"TiB" };
533 Int_t maxDiv =
sizeof(ums)/
sizeof(
const char *);
537 while ((b >= 1024.) && (nDiv+1 < maxDiv)) {
556 while ((fileInfo = dynamic_cast<TFileInfo*>(iter.
Next()))) {
559 while ((url = fileInfo->
NextUrl()))
575 while ((fileInfo = dynamic_cast<TFileInfo*>(iter.
Next())))
589 while ((fileInfo = dynamic_cast<TFileInfo*>(iter.
Next())))
605 while ((metaData = dynamic_cast<TFileInfoMeta*>(metaDataIter.
Next()))) {
620 if (!tree || !*tree) {
667 while ((fileInfo = dynamic_cast<TFileInfo*>(iter.
Next())))
715 treeInfo +=
TString::Format(
", %3.1f %% of total", frac->GetEntries() / 10.);
731 if (popt == 0) treeInfo.
Resize(25);
734 const char *unit[4] = {
"kB",
"MB",
"GB",
"TB"};
738 while (xsz > 1024 && k < 3) {
751 outs =
new TObjString(
Form(
"%s %lld files, %lld %s, staged %d %%, tree: %s", dsname.
Data(),
772 if (!server || strlen(server) <= 0) {
773 Info(
"GetFilesOnServer",
"server undefined - do nothing");
779 Info(
"GetFilesOnServer",
"the list is empty - do nothing");
785 TString srv, scheme(
"root"), port;
790 Info(
"GetFilesOnServer",
"searching for files on server: '%s' (input: '%s')",
801 fc->SetTitle(title.
Data());
828 Info(
"GetFilesOnServer",
"adding: %s", xu->
GetUrl());
834 if (fc->GetList()->GetSize() <= 0) {
837 Info(
"GetFilesOnServer",
"dataset '%s' has no files on server: '%s' (searched for: '%s')",
867 Info(
"GetFilesPerServer",
"the list is empty - do nothing");
873 if (exclude && strlen(exclude) > 0) {
877 TString srvs(exclude), s, srv, scheme, port;
879 while (srvs.Tokenize(s, from,
",")) {
906 while ((xurl = (curronly) ? curl : fi->
NextUrl())) {
913 }
else if (excl && xurl->
GetPort() > 0) {
939 Info(
"GetFilesPerServer",
"found server: '%s' (fc: %p)", key.
Data(),
fc);
978 if (excl)
delete excl;
virtual const char * BaseName(const char *pathname)
Base name of a file name. Base name of /user/root is root.
virtual const char * GetName() const
Returns name of object.
TFileInfoMeta * GetMetaData(const char *meta=0) const
Returns the meta data object with the specified meta name.
virtual void Info(const char *method, const char *msgfmt,...) const
Issue info message.
TFileCollection * GetFilesOnServer(const char *server)
Return the subset of files served by 'server'.
const char * GetDefaultTreeName() const
Returns the tree set with SetDefaultTreeName if set Returns the name of the first tree in the meta da...
void SetAnchor(const char *anchor)
Calls TUrl::SetAnchor() for all URLs contained in all TFileInfos.
Collectable string class.
Long64_t GetTotalSize() const
This class represents a WWW compatible URL.
TString & ReplaceAll(const TString &s1, const TString &s2)
int GetPathInfo(const char *path, Long_t *id, Long_t *size, Long_t *flags, Long_t *modtime)
Get info about a file: id, size, flags, modification time.
TUrl * GetCurrentUrl() const
Return the current url.
Bool_t TestBit(UInt_t f) const
const char * GetProtocol() const
virtual void SetName(const char *name)
Set the name of the TNamed.
Float_t GetStagedPercentage() const
virtual void SetOwner(Bool_t enable=kTRUE)
Set whether this collection is the owner (enable==true) of its content.
TUrl * NextUrl()
Iterator function, start iteration by calling ResetUrl().
Long64_t GetTotalEntries(const char *tree) const
Returns the number of entries for the specified tree (retrieved from meta data).
virtual Int_t GetEntries() const
const TString GetPort() const
virtual void AddFirst(TObject *obj)
Add object at the beginning of the list.
Regular expression class.
void Add(TObject *obj)
This function may not be used (but we need to provide it since it is a pure virtual in TCollection)...
Ssiz_t Index(const char *pat, Ssiz_t i=0, ECaseCompare cmp=kExact) const
const char * AsString() const
Return message digest as string.
virtual const char * DirName(const char *pathname)
Return the directory name in pathname.
This class represents a RFC 3986 compatible URI.
TObject * FindObject(const char *name) const
Find object using its name.
TString & Insert(Ssiz_t pos, const char *s)
const char * GetHostFQDN() const
Return fully qualified domain name of url host.
Bool_t R_ISREG(Int_t mode)
void SetBit(UInt_t f, Bool_t set)
Set or unset the user status bits as specified in f.
const char * GetUrl(Bool_t withDeflt=kFALSE) const
Return full URL.
virtual TObject * FindObject(const char *name) const
Find an object in this list using its name.
TString & Replace(Ssiz_t pos, Ssiz_t n, const char *s)
virtual void Sort(Bool_t order=kSortAscending)
Sort linked list.
static struct mg_connection * fc(struct mg_context *ctx)
Int_t Update(Long64_t avgsize=-1)
Update accumulated information about the elements of the collection (e.g.
Bool_t SetUri(const TString &uri)
Parse URI and set the member variables accordingly, returns kTRUE if URI validates, and kFALSE otherwise: URI = scheme ":" hier-part [ "?" query ] [ "#" fragment ] hier-part = "//" authority path-abempty / path-absolute / path-rootless / path-empty.
virtual const char * GetDirEntry(void *dirp)
Get a directory entry. Returns 0 if no more entries.
virtual const char * ClassName() const
Returns name of class to which the object belongs.
static TString Format(const char *fmt,...)
Static method which formats a string using a printf style format descriptor and return a TString...
Bool_t AddMetaData(TObject *meta)
Add's a meta data object to the file info object.
THashList implements a hybrid collection class consisting of a hash table and a list to store TObject...
The TNamed class is the base class for all named ROOT classes.
TFileCollection * GetStagedSubset()
Creates a subset of the files that have the kStaged & !kCorrupted bit set.
Bool_t SetCurrentUrl(const char *url)
Set 'url' as current URL, if in the list Return kFALSE if not in the list.
void RemoveMetaData(const char *meta=0)
Removes the indicated meta data object in all TFileInfos and this object If no name is given all meta...
TUrl * FindByUrl(const char *url, Bool_t withDeflt=kFALSE)
Find an element from a URL. Returns 0 if not found.
Long64_t Merge(TCollection *list)
Merge all TFileCollection objects in li into this TFileCollection object.
TFileInfoMeta * GetMetaData(const char *meta=0) const
Get meta data object with specified name.
void Sort(Bool_t useindex=kFALSE)
Sort the collection.
Bool_t AddMetaData(TObject *meta)
Add's a meta data object to the file collection object.
TObjString * ExportInfo(const char *name=0, Int_t popt=0)
Export the relevant info as a string; use 'name' as collection name, if defined, else use GetName()...
R__EXTERN TSystem * gSystem
Int_t RemoveDuplicates()
Remove duplicates based on the UUID, typically after a verification.
Int_t Add(TFileInfo *info)
Add TFileInfo to the collection.
Long64_t GetNFiles() const
void Print(Option_t *option="") const
Prints the contents of the TFileCollection.
virtual TObject * Remove(TObject *obj)
Remove object from the list.
Bool_t BeginsWith(const char *s, ECaseCompare cmp=kExact) const
TObject * Remove(TObject *obj)
Remove object from the list.
Collection abstract base class.
void Form(const char *fmt,...)
Formats a string using a printf style format descriptor.
virtual void Error(const char *method, const char *msgfmt,...) const
Issue error message.
char * Form(const char *fmt,...)
void FormatSize(Long64_t bytes, TString &um, Double_t &size) const
Format size.
virtual void FreeDirectory(void *dirp)
Free a directory.
TFileCollection(const TFileCollection &)
Class used by TMap to store (key,value) pairs.
void SetAnchor(const char *anchor)
virtual Bool_t IsEmpty() const
void SetDefaultTreeName(const char *treeName)
TMap implements an associative array of (key,value) pairs using a THashTable for efficient retrieval ...
Bool_t Contains(const char *pat, ECaseCompare cmp=kExact) const
virtual void Clear(Option_t *option="")
Remove all objects from the list.
const char * AsString() const
Return UUID as string. Copy string immediately since it will be reused.
Int_t Match(const TString &s, UInt_t start=0)
Runs a match on s against the regex 'this' was created with.
Mother of all ROOT objects.
std::istream & ReadToDelim(std::istream &str, char delim='\n')
Read up to an EOF, or a delimiting character, whichever comes first.
Int_t AddFromFile(const char *file, Int_t nfiles=-1, Int_t firstfile=1)
Add file names contained in the specified text file.
void SetDefaultMetaData(const char *meta)
Moves the indicated meta data in the first position, so that it becomes effectively the default...
TObject * FindObject(const char *keyname) const
Check if a (key,value) pair exists with keyname as name of the key.
void PrintDetailed(TString &showOnly) const
Print detailed.
Bool_t RemoveMetaData(const char *meta=0)
Remove the metadata object.
virtual void Add(TObject *obj)
virtual ~TFileCollection()
Cleanup.
Wrapper for PCRE library (Perl Compatible Regular Expressions).
Class that contains a list of TFileInfo's and accumulated meta data information about its entries...
void ResetBitAll(UInt_t f)
Reset the bit for all TFileInfos.
you should not use this method at all Int_t Int_t Double_t Double_t Double_t Int_t Double_t Double_t Double_t Double_t b
Float_t GetCorruptedPercentage() const
virtual void * OpenDirectory(const char *name)
Open a directory. Returns 0 if directory does not exist.
TObject * GetValue(const char *keyname) const
Returns a pointer to the value associated with keyname as name of the key.
Class describing a generic file including meta information.
virtual Bool_t ExpandPathName(TString &path)
Expand a pathname getting rid of special shell characters like ~.
virtual void Print(Option_t *option="") const
Default print for collections, calls Print(option, 1).
virtual Int_t GetSize() const
virtual void SetTitle(const char *title="")
Set the title of the TNamed.
Bool_t IsWhitespace() const
TMap * GetFilesPerServer(const char *exclude=0, Bool_t curronly=kFALSE)
Return a map of TFileCollections with the files on each data server, excluding servers in the comma-s...
void SetBitAll(UInt_t f)
Set the bit for all TFileInfos.
TList * GetMetaDataList() const
virtual void Warning(const char *method, const char *msgfmt,...) const
Issue warning message.
void Resize(Ssiz_t n)
Resize the string. Truncate or add blanks as necessary.
virtual const char * GetTitle() const
Returns title of object.
const TString GetScheme() const
const char * Data() const