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)
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)) {
130 if (!
line.IsWhitespace() && !
line.BeginsWith(
"#")) {
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);
263 subset->
Add(fileInfo);
287 Error(
"Add",
"attempt to add object of class: %s to a %s",
288 o->ClassName(),this->ClassName());
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:");
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");
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)) {
559 while ((url = fileInfo->
NextUrl()))
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;
788 srv.
Form(
"%s://%s%s", scheme.Data(),
TUrl(server).GetHostFQDN(), port.
Data());
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) {
932 fc->SetTitle(title.
Data());
939 Info(
"GetFilesPerServer",
"found server: '%s' (fc: %p)", key.
Data(),
fc);
978 if (excl)
delete excl;
char * Form(const char *fmt,...)
void Printf(const char *fmt,...)
Bool_t R_ISREG(Int_t mode)
R__EXTERN TSystem * gSystem
static struct mg_connection * fc(struct mg_context *ctx)
Collection abstract base class.
virtual void Print(Option_t *option="") const
Default print for collections, calls Print(option, 1).
virtual Int_t GetEntries() const
virtual void SetOwner(Bool_t enable=kTRUE)
Set whether this collection is the owner (enable==true) of its content.
virtual Bool_t IsEmpty() const
virtual Int_t GetSize() const
Return the capacity of the collection, i.e.
Class that contains a list of TFileInfo's and accumulated meta data information about its entries.
Bool_t AddMetaData(TObject *meta)
Add's a meta data object to the file collection object.
TFileCollection * GetStagedSubset()
Creates a subset of the files that have the kStaged & !kCorrupted bit set.
Int_t RemoveDuplicates()
Remove duplicates based on the UUID, typically after a verification.
Int_t Update(Long64_t avgsize=-1)
Update accumulated information about the elements of the collection (e.g.
Long64_t GetTotalEntries(const char *tree) const
Returns the number of entries for the specified tree (retrieved from meta data).
void SetBitAll(UInt_t f)
Set the bit for all TFileInfos.
void Sort(Bool_t useindex=kFALSE)
Sort the collection.
void SetAnchor(const char *anchor)
Calls TUrl::SetAnchor() for all URLs contained in all TFileInfos.
void ResetBitAll(UInt_t f)
Reset the bit for all TFileInfos.
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...
Float_t GetStagedPercentage() const
void FormatSize(Long64_t bytes, TString &um, Double_t &size) const
Format size.
void SetDefaultMetaData(const char *meta)
Moves the indicated meta data in the first position, so that it becomes effectively the default.
virtual ~TFileCollection()
Cleanup.
Long64_t GetNFiles() const
void Print(Option_t *option="") const
Prints the contents of the TFileCollection.
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...
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().
Long64_t GetTotalSize() const
Long64_t Merge(TCollection *list)
Merge all TFileCollection objects in li into this TFileCollection object.
TFileCollection(const TFileCollection &)
Int_t AddFromFile(const char *file, Int_t nfiles=-1, Int_t firstfile=1)
Add file names contained in the specified text file.
TFileInfoMeta * GetMetaData(const char *meta=0) const
Returns the meta data object with the specified meta name.
const char * GetDefaultTreeName() const
Returns the tree set with SetDefaultTreeName if set Returns the name of the first tree in the meta da...
Float_t GetCorruptedPercentage() const
Int_t Add(TFileInfo *info)
Add TFileInfo to the collection.
void PrintDetailed(TString &showOnly) const
Print detailed.
TFileCollection * GetFilesOnServer(const char *server)
Return the subset of files served by 'server'.
Class describing a generic file including meta information.
TUrl * NextUrl()
Iterator function, start iteration by calling ResetUrl().
Bool_t AddMetaData(TObject *meta)
Add's a meta data object to the file info object.
TList * GetMetaDataList() const
Bool_t RemoveMetaData(const char *meta=0)
Remove the metadata object.
Bool_t SetCurrentUrl(const char *url)
Set 'url' as current URL, if in the list Return kFALSE if not in the list.
TUrl * FindByUrl(const char *url, Bool_t withDeflt=kFALSE)
Find an element from a URL. Returns 0 if not found.
TUrl * GetCurrentUrl() const
Return the current url.
TFileInfoMeta * GetMetaData(const char *meta=0) const
Get meta data object with specified name.
THashList implements a hybrid collection class consisting of a hash table and a list to store TObject...
TObject * FindObject(const char *name) const
Find object using its name.
TObject * Remove(TObject *obj)
Remove object from the list.
virtual void Add(TObject *obj)
virtual TObject * Remove(TObject *obj)
Remove object from the list.
virtual void AddFirst(TObject *obj)
Add object at the beginning of the list.
virtual TObject * FindObject(const char *name) const
Find an object in this list using its name.
virtual void Clear(Option_t *option="")
Remove all objects from the list.
virtual void Sort(Bool_t order=kSortAscending)
Sort linked list.
const char * AsString() const
Return message digest as string.
TMap implements an associative array of (key,value) pairs using a THashTable for efficient retrieval ...
void Add(TObject *obj)
This function may not be used (but we need to provide it since it is a pure virtual in TCollection).
TObject * GetValue(const char *keyname) const
Returns a pointer to the value associated with keyname as name of the key.
TObject * FindObject(const char *keyname) const
Check if a (key,value) pair exists with keyname as name of the key.
The TNamed class is the base class for all named ROOT classes.
virtual void SetName(const char *name)
Set the name of the TNamed.
virtual const char * GetTitle() const
Returns title of object.
virtual const char * GetName() const
Returns name of object.
Collectable string class.
Mother of all ROOT objects.
R__ALWAYS_INLINE Bool_t TestBit(UInt_t f) const
virtual void Warning(const char *method, const char *msgfmt,...) const
Issue warning message.
void SetBit(UInt_t f, Bool_t set)
Set or unset the user status bits as specified in f.
virtual void Error(const char *method, const char *msgfmt,...) const
Issue error message.
virtual void Info(const char *method, const char *msgfmt,...) const
Issue info message.
Wrapper for PCRE library (Perl Compatible Regular Expressions).
Int_t Match(const TString &s, UInt_t start=0)
Runs a match on s against the regex 'this' was created with.
Class used by TMap to store (key,value) pairs.
Regular expression class.
TString & Insert(Ssiz_t pos, const char *s)
TString & Replace(Ssiz_t pos, Ssiz_t n, const char *s)
const char * Data() const
TString & ReplaceAll(const TString &s1, const TString &s2)
void Resize(Ssiz_t n)
Resize the string. Truncate or add blanks as necessary.
static TString Format(const char *fmt,...)
Static method which formats a string using a printf style format descriptor and return a TString.
void Form(const char *fmt,...)
Formats a string using a printf style format descriptor.
Bool_t Contains(const char *pat, ECaseCompare cmp=kExact) const
Ssiz_t Index(const char *pat, Ssiz_t i=0, ECaseCompare cmp=kExact) const
virtual Bool_t ExpandPathName(TString &path)
Expand a pathname getting rid of special shell characters like ~.
virtual const char * DirName(const char *pathname)
Return the directory name in pathname.
virtual void FreeDirectory(void *dirp)
Free a directory.
virtual void * OpenDirectory(const char *name)
Open a directory. Returns 0 if directory does not exist.
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.
virtual const char * GetDirEntry(void *dirp)
Get a directory entry. Returns 0 if no more entries.
virtual const char * BaseName(const char *pathname)
Base name of a file name. Base name of /user/root is root.
const char * AsString() const
Return UUID as string. Copy string immediately since it will be reused.
This class represents a RFC 3986 compatible URI.
const TString GetPort() const
Bool_t SetUri(const TString &uri)
Parse URI and set the member variables accordingly, returns kTRUE if URI validates,...
const TString GetScheme() const
This class represents a WWW compatible URL.
const char * GetUrl(Bool_t withDeflt=kFALSE) const
Return full URL.
void SetAnchor(const char *anchor)
const char * GetHostFQDN() const
Return fully qualified domain name of url host.
const char * GetProtocol() const
static constexpr double um
static constexpr double s