KaliVeda
Toolkit for HIC analysis
KVTarArchive Class Reference

Detailed Description

Handles directories stored in .tgz archive files.

Created by KVClassFactory on Wed Jun 3 08:40:52 2009 Author: John Frankland,,,

Definition at line 22 of file KVTarArchive.h.

#include <KVTarArchive.h>

Inheritance diagram for KVTarArchive:

Public Member Functions

 KVTarArchive ()
 Default constructor. More...
 
 KVTarArchive (const Char_t *dirname, const Char_t *path)
 Open directory/archive with name 'dirname'[.tgz] in directory 'path'. More...
 
virtual ~KVTarArchive ()
 
const Char_t * GetFullPath () const
 
Bool_t IsArchive () const
 
Bool_t IsOK () const
 
- Public Member Functions inherited from KVBase
 KVBase ()
 Default constructor. More...
 
 KVBase (const Char_t *name, const Char_t *title="")
 Ctor for object with given name and type. More...
 
 KVBase (const KVBase &)
 copy ctor More...
 
virtual ~ KVBase ()
 
virtual void Clear (Option_t *opt="")
 Clear object properties : name, type/title, number, label. More...
 
virtual void Copy (TObject &) const
 Make a copy of this object. More...
 
const Char_t * GetLabel () const
 
UInt_t GetNumber () const
 
UInt_t GetNumberOfObjects () const
 
virtual TObject * GetObject () const
 
virtual const Char_t * GetType () const
 
Bool_t HasLabel () const
 
virtual Bool_t IsCalled (const Char_t *name) const
 
Bool_t IsLabelled (const Char_t *l) const
 
virtual Bool_t IsType (const Char_t *typ) const
 
virtual void List ()
 
KVBaseoperator= (const KVBase &)
 copy assignment operator More...
 
virtual void Print (Option_t *option="") const
 
Double_t ProtectedGetX (const TF1 *func, Double_t val, int &status, Double_t xmin=0.0, Double_t xmax=0.0) const
 
void SetLabel (const Char_t *lab)
 
virtual void SetNumber (UInt_t num)
 
virtual void SetType (const Char_t *str)
 

Private Member Functions

void CheckDirectory (const Char_t *dirname, const Char_t *path)
 
void DeleteDirectory (const Char_t *dirpath)
 
void init ()
 Default initialisations for ctors. More...
 

Private Attributes

KVString fFullpath
 full path to directory if found/extracted More...
 
Bool_t fOK
 set to kTRUE if directory/archive is found More...
 
Bool_t fTGZ
 set to kTRUE if directory is extracted from '.tgz' archive More...
 

Additional Inherited Members

- Public Types inherited from KVBase
enum  EKaliVedaBits { kIsKaliVedaObject = BIT(23) }
 
- Static Public Member Functions inherited from KVBase
static Bool_t AreEqual (Double_t x, Double_t y, Long64_t maxdif=1)
 Comparison between two 64-bit floating-point values. More...
 
static void BackupFileWithDate (const Char_t *path)
 
static void CombineFiles (const Char_t *file1, const Char_t *file2, const Char_t *newfilename, Bool_t keep=kTRUE)
 
static void Deprecated (const char *method, const char *advice)
 
static Bool_t FindClassSourceFiles (const Char_t *class_name, KVString &imp_file, KVString &dec_file, const Char_t *dir_name=".")
 
static Bool_t FindExecutable (TString &exec, const Char_t *path="$(PATH)")
 
static const Char_t * FindFile (const Char_t *search, TString &wfil)
 
static const Char_t * GetBINDIRFilePath (const Char_t *namefile="")
 
static const Char_t * GetDATABASEFilePath ()
 
static const Char_t * GetDATADIRFilePath (const Char_t *namefile="")
 
static Bool_t GetDataSetEnv (const Char_t *dataset, const Char_t *type, Bool_t defval)
 
static const Char_t * GetDataSetEnv (const Char_t *dataset, const Char_t *type, const Char_t *defval)
 
static Double_t GetDataSetEnv (const Char_t *dataset, const Char_t *type, Double_t defval)
 
static const Char_t * GetETCDIRFilePath (const Char_t *namefile="")
 
static const Char_t * GetExampleFilePath (const Char_t *library, const Char_t *namefile)
 Return full path to example file for given library (="KVMultiDet", "BackTrack", etc.) More...
 
static const Char_t * GetINCDIRFilePath (const Char_t *namefile="")
 
static const Char_t * GetKVBuildDate ()
 Returns KaliVeda build date. More...
 
static const Char_t * GetKVBuildDir ()
 Returns top-level directory used for build. More...
 
static const Char_t * GetKVBuildTime ()
 Returns KaliVeda build time. More...
 
static const Char_t * GetKVBuildType ()
 Returns KaliVeda build type (cmake build: Release, Debug, RelWithDebInfo, ...) More...
 
static const Char_t * GetKVBuildUser ()
 Returns username of person who performed build. More...
 
static const Char_t * GetKVSourceDir ()
 Returns top-level directory of source tree used for build. More...
 
static const Char_t * GetKVVersion ()
 Returns KaliVeda version string. More...
 
static const Char_t * GetLIBDIRFilePath (const Char_t *namefile="")
 
static const Char_t * GetListOfPlugins (const Char_t *base)
 
static const Char_t * GetListOfPluginURIs (const Char_t *base)
 
static const Char_t * GetPluginURI (const Char_t *base, const Char_t *plugin)
 
static void GetTempFileName (TString &base)
 
static const Char_t * GetTEMPLATEDIRFilePath (const Char_t *namefile="")
 
static const Char_t * GetWORKDIRFilePath (const Char_t *namefile="")
 
static const Char_t * gitBranch ()
 Returns git branch of sources. More...
 
static const Char_t * gitCommit ()
 Returns last git commit of sources. More...
 
static void InitEnvironment ()
 
static bool is_gnuinstall ()
 
static Bool_t IsThisAPlugin (const TString &uri, TString &base)
 
static TPluginHandler * LoadPlugin (const Char_t *base, const Char_t *uri="0")
 
static Bool_t OpenContextMenu (const char *method, TObject *obj, const char *alt_method_name="")
 
static void OpenTempFile (TString &base, std::ofstream &fp)
 
static void PrintSplashScreen ()
 Prints welcome message and infos on version etc. More...
 
static Bool_t SearchAndOpenKVFile (const Char_t *name, KVSQLite::database &dbfile, const Char_t *kvsubdir="")
 
static Bool_t SearchAndOpenKVFile (const Char_t *name, std::ifstream &file, const Char_t *kvsubdir="", KVLockfile *locks=0)
 
static Bool_t SearchAndOpenKVFile (const Char_t *name, std::ofstream &file, const Char_t *kvsubdir="", KVLockfile *locks=0)
 
static Bool_t SearchKVFile (const Char_t *name, TString &fullpath, const Char_t *kvsubdir="")
 
static const Char_t * WorkingDirectory ()
 

Constructor & Destructor Documentation

◆ KVTarArchive() [1/2]

KVTarArchive::KVTarArchive ( )

Default constructor.

Definition at line 23 of file KVTarArchive.cpp.

◆ KVTarArchive() [2/2]

KVTarArchive::KVTarArchive ( const Char_t *  dirname,
const Char_t *  path 
)

Open directory/archive with name 'dirname'[.tgz] in directory 'path'.

Definition at line 34 of file KVTarArchive.cpp.

◆ ~KVTarArchive()

KVTarArchive::~KVTarArchive ( )
virtual

Destructor If the directory was extracted from an archive file, we delete the extracted directory and all files in it. This is so that the next time we need files from the archive, we reopen the archive (in case the archive has been updated).

Definition at line 50 of file KVTarArchive.cpp.

Member Function Documentation

◆ CheckDirectory()

void KVTarArchive::CheckDirectory ( const Char_t *  dirname,
const Char_t *  path 
)
private

We look for the directory 'dirname' in the directory 'path', i.e. we look for path/dirname

If not found, we look for the following compressed archive:

path/dirname.tgz

and if found, uncompress it (with 'tar -zxf').

Sets fOK to kTRUE if directory/archive file exists.Full path to directory returned in 'fullpath'.

Sets fOK to kFALSE if directory does not exist and no archive file found.

Definition at line 89 of file KVTarArchive.cpp.

◆ DeleteDirectory()

void KVTarArchive::DeleteDirectory ( const Char_t *  dirpath)
private

Delete all files in directory 'dirpath' (give full path) then delete the directory itself. This is to get round the fact that gSystem->Unlink(dirname) does not work if the directory contains any files.

Definition at line 143 of file KVTarArchive.cpp.

◆ GetFullPath()

const Char_t* KVTarArchive::GetFullPath ( ) const
inline

Returns full path to extracted directory if found (IsOK()==kTRUE)

Definition at line 47 of file KVTarArchive.h.

◆ init()

void KVTarArchive::init ( void  )
private

Default initialisations for ctors.

Definition at line 65 of file KVTarArchive.cpp.

◆ IsArchive()

Bool_t KVTarArchive::IsArchive ( ) const
inline

Returns kTRUE if directory extracted from archive file

Definition at line 42 of file KVTarArchive.h.

◆ IsOK()

Bool_t KVTarArchive::IsOK ( ) const
inline

Returns kTRUE if directory/archive found

Definition at line 37 of file KVTarArchive.h.

Member Data Documentation

◆ fFullpath

KVString KVTarArchive::fFullpath
private

full path to directory if found/extracted

Definition at line 28 of file KVTarArchive.h.

◆ fOK

Bool_t KVTarArchive::fOK
private

set to kTRUE if directory/archive is found

Definition at line 26 of file KVTarArchive.h.

◆ fTGZ

Bool_t KVTarArchive::fTGZ
private

set to kTRUE if directory is extracted from '.tgz' archive

Definition at line 27 of file KVTarArchive.h.