Changeset 9019 for trunk


Ignore:
Timestamp:
07/20/08 15:53:17 (16 years ago)
Author:
tbretz
Message:
*** empty log message ***
Location:
trunk/MagicSoft/Mars
Files:
5 edited

Legend:

Unmodified
Added
Removed
  • trunk/MagicSoft/Mars/Changelog

    r9018 r9019  
    5353   * mjobs/Makefile, mjobs/JobsLinkDef.h:
    5454     - added MJMerpp
     55
     56   * datacenter/macros/checkfileavail.C, datacenter/macros/checkstardone.C:
     57     - reduced queries to a single query
     58     - take sequence number as argumenet instead of filename
     59
     60   * datacenter/scripts/checkstardone:
     61     - adapted to changes in checkstardone.C
     62
     63   * mjobs/MSequence.[h,cc]:
     64     - a lot of rework to the file-interface
     65     - included subsystem (cc) files
     66     - some renaming to some functions
     67     - improved the interface to the database
     68     - unified the Setup*Runs into GetRuns
     69     - when inflating a sequence name allow to use [tel:]squence now
     70
     71   * mjobs/MSequenceSQL.[h,cc]:
     72     - adapted to changes in MSequence
    5573
    5674
  • trunk/MagicSoft/Mars/mjobs/MSequence.cc

    r9015 r9019  
    141141//    seq.SetNight("2004-07-06");
    142142//    seq.AddFiles(31753, 0, 120);
    143 //    seq.SetupRuns(iter);
     143//    seq.GetRuns(iter);
    144144//    seq.SetupPedRuns(iter, "/mypath", "[DPC]");
    145145//
     
    386386}
    387387
    388 TString MSequence::InflateRunPath(const MTime &night, Bool_t mc)
     388TString MSequence::InflateFilePath(const MTime &night, Bool_t mc)
    389389{
    390390    TString rc = GetStandardPath(mc);
     
    394394}
    395395
    396 TString MSequence::InflateRunPath(const MTime &night, UShort_t tel, Int_t run, Int_t file, Int_t type)
    397 {
    398     return InflateRunPath(night)+InflateRunName(night, tel, run, file, type);
     396TString MSequence::InflateFilePath(const MTime &night, UShort_t tel, Int_t run, Int_t file, Int_t type)
     397{
     398    return InflateFilePath(night)+InflateFileName(night, tel, run, file, type);
    399399}
    400400
     
    411411    {
    412412        d = GetStandardPath();
    413         switch (type)
     413        switch (type&kFileType)
    414414        {
    415         case kRawDat:  // rawdata
    416         case kRawPed:
    417         case kRawCal:
    418         case kRawAll:
    419         case kRootDat: // mcdata
    420         case kRootPed:
    421         case kRootCal:
    422         case kRootAll:
     415        case kRaw:  // rawdata
     416        case kRoot: // mcdata
    423417            d += "rawfiles/";
     418            d += fNight.GetStringFmt("%Y/%m/%d");
     419            break;
     420        case kReport:
     421            d += "../subsystemdata/cc/";
    424422            d += fNight.GetStringFmt("%Y/%m/%d");
    425423            break;
     
    441439}
    442440
    443 TString MSequence::InflateRunName(const MTime &night, UShort_t tel, Int_t run, Int_t file, Int_t type)
     441// --------------------------------------------------------------------------
     442//
     443// Compile FileName according to night, tel, run, file and type.
     444//
     445TString MSequence::InflateFileName(const MTime &night, UShort_t tel, Int_t run, Int_t file, Int_t type)
    444446{
    445447    const char *id="_";
    446     switch (type)
    447     {
    448     case kRawDat:
    449     case kRootDat:
     448    switch ((RunType_t)(type&kRunType))
     449    {
     450    case kDat:
    450451        id = "D";
    451452        break;
    452     case kRawPed:
    453     case kRootPed:
     453    case kPed:
    454454        id = "P";
    455455        break;
    456     case kRawCal:
    457     case kRootCal:
     456    case kCal:
    458457        id = "C";
    459458        break;
    460     case kRawAll:
    461     case kRootAll:
     459    case kAll:
    462460        id = "[PCD]";
    463461        break;
    464     case kCalibrated:
     462    case kCalib:
    465463        id = "Y";
    466464        break;
    467     case kImages:
     465    case kImage:
    468466        id = "I";
    469467        break;
    470     }
     468    case kExcl:
     469        break;
     470    }
     471
     472    // Is report file?
     473    const Bool_t isrep = type&kReport;
     474
     475    // Calculate limit for transition from 5-digit to 8-digit numbers
     476    const Int_t limit = isrep ? 39373 : 35487;
    471477
    472478    // ------------- Create file name --------------
     
    484490        // Changes to read the DAQ numbering format. Changes takes place
    485491        // between runs 35487 and 00035488 (2004_08_30)
    486         n += Form(run>35487 ? "%08d" : "%05d", run);
     492        n += Form(run>limit ? "%08d" : "%05d", run);
    487493
    488494        if (tel>0)
     
    494500    n += "_*";
    495501
    496     if (tel==0)
    497         n += "_E";
    498 
    499     switch (type)
    500     {
    501     case kRawDat:
    502     case kRawPed:
    503     case kRawCal:
    504     case kRawAll:
    505         n += ".raw.?g?z?";  // TPRegexp: (\.gz)?
     502    if (tel==0 && run>=0)
     503        n += isrep ? "_S" : "_E";
     504
     505    switch (type&kFileType)
     506    {
     507    case kRaw:       // MC     // DATA
     508        n += run<0 ? ".root" : ".raw.?g?z?";  // TPRegexp: (\.gz)?
     509        break;
     510    case kReport:
     511        n += ".rep";  // TPRegexp: (\.gz)?
    506512        break;
    507513    default:
    508514        n += ".root";
     515        break;
    509516    }
    510517
     
    519526// the extension is defined by the type as well.
    520527//
    521 TString MSequence::GetFileName(UInt_t i, const TArrayI &arr, const TArrayI &sub, FileType_t type) const
    522 {
    523     return InflateRunName(fNight, arr[i]>999999?fTelescope:0, fMonteCarlo?-arr[i]:arr[i], sub.GetSize()>0?sub[i]:0, type);
     528TString MSequence::GetFileRegexp(UInt_t i, const TArrayI &arr, const TArrayI &sub, FileType_t type) const
     529{
     530    if (i>=(UInt_t)arr.GetSize())
     531        return "";
     532
     533    return InflateFileName(fNight, arr[i]>999999?fTelescope:0, fMonteCarlo?-arr[i]:arr[i], sub.GetSize()>0?sub[i]:0, type);
     534}
     535
     536// --------------------------------------------------------------------------
     537//
     538// Get the filename from the dirctory and the file-regexp.
     539// return "" if file is not accessible or the regular expression is not
     540// unambiguous.
     541//
     542TString MSequence::FindFile(const TString &d, const TString &f) const
     543{
     544    // Check existance and accessibility of file
     545    MDirIter file(d, f, 0);
     546
     547    TString name = file();
     548    gSystem->ExpandPathName(name);
     549    if (gSystem->AccessPathName(name, kFileExists))
     550    {
     551        *fLog << err;
     552        *fLog << "ERROR - File " << d << f << " not accessible!" << endl;
     553        return "";
     554    }
     555    if (!file().IsNull())
     556    {
     557        *fLog << err;
     558        *fLog << "ERROR - Searching for file " << d << f << " gave more than one result!" << endl;
     559        return "";
     560    }
     561
     562    return name;
     563}
     564
     565// --------------------------------------------------------------------------
     566//
     567// Set the path accoring to type (if fDataPath=path=0), fDataPath
     568// (if path=0) or path.
     569// Returns accessability of the path.
     570//
     571Bool_t MSequence::FindPath(TString &path, FileType_t type) const
     572{
     573    if (path.IsNull())
     574        path = fDataPath;
     575
     576    const Bool_t def = path.IsNull();
     577
     578    path = GetPathName(path, type);
     579
     580    return def;
    524581}
    525582
     
    528585// Add the entries from the arrays to the MDirIter
    529586//
    530 UInt_t MSequence::SetupRuns(MDirIter &iter, const TArrayI &arr, const TArrayI &sub, FileType_t type, const char *path) const
    531 {
    532     TString d(path);
    533     if (d.IsNull())
    534         d = fDataPath;
    535 
    536     const Bool_t def = d.IsNull();
    537 
    538     d = GetPathName(d, type);
     587UInt_t MSequence::GetRuns(MDirIter &iter, const TArrayI &arr, const TArrayI &sub, FileType_t type, TString path) const
     588{
     589    const Bool_t def = FindPath(path, type);
    539590
    540591    // For this particular case we assume that the files are added one by
     
    551602        }
    552603
    553         const TString n = GetFileName(i, arr, sub, type);
    554 
    555         // Check existance and accessibility of file
    556         MDirIter file(d, n, 0);
    557         TString name = file();
    558         gSystem->ExpandPathName(name);
    559         if (gSystem->AccessPathName(name, kFileExists))
    560         {
    561             *fLog << err;
    562             *fLog << "ERROR - File " << d << n << " not accessible!" << endl;
    563             return 0;
    564         }
    565         if (!file().IsNull())
    566         {
    567             *fLog << err;
    568             *fLog << "ERROR - Searching for file " << d << n << " gave more than one result!" << endl;
    569             return 0;
    570         }
     604        const TString n = GetFileRegexp(i, arr, sub, type);
     605
     606        if (FindFile(path, n).IsNull())
     607            continue;
    571608
    572609        // Add Path/File to TIter
    573         iter.AddDirectory(d, n, 0);
     610        iter.AddDirectory(path, n, 0);
    574611    }
    575612
     
    584621        *fLog << "ERROR - No input files for sequence #" << GetSequence() << endl;
    585622        *fLog << "        read from " << GetBaseName() << endl;
    586         *fLog << "        found in" << (def?" default-path ":" ") << d << endl;
     623        *fLog << "        found in" << (def?" default-path ":" ") << path << endl;
    587624        return 0;
    588625    }
     
    593630    *fLog << err;
    594631    *fLog << "ERROR - " << n1 << " input files for sequence #" << GetSequence() << " found in" << endl;
    595     *fLog << "        " << (def?" default-path ":" ") << d << endl;
     632    *fLog << "        " << (def?" default-path ":" ") << path << endl;
    596633    *fLog << "        but " << n2 << " files were defined in sequence file" << endl;
    597634    *fLog << "        " << GetBaseName() << endl;
     
    602639    iter.Print();
    603640    return 0;
     641}
     642
     643// --------------------------------------------------------------------------
     644//
     645// Returns "0" if file at i-th index is excluded. Get the access-path
     646// defined by the default or data-path (if path=0) or path.
     647// Get the full file-name by accessing the file.
     648//
     649TString MSequence::GetFileName(UInt_t i, const TArrayI &arr, const TArrayI &sub, FileType_t type, const char *path) const
     650{
     651    if (IsExcluded(arr[i], sub[i]))
     652        return "0";
     653
     654    const TString d = FindPath(type, path);
     655    const TString n = GetFileRegexp(i, arr, sub, type);
     656
     657    return FindFile(d, n);
     658}
     659
     660// --------------------------------------------------------------------------
     661//
     662// Return the pointers to the arrays with the runs/files depending on the
     663// given type.
     664//
     665void MSequence::GetArrays(const TArrayI* &r, const TArrayI* &f, Int_t type) const
     666{
     667    switch ((RunType_t)(type&kRunType))
     668    {
     669    case kPed:
     670        r = &fPedRuns;
     671        f = &fPedRunsSub;
     672        break;
     673    case kDat:
     674    case kImage:
     675    case kCalib:
     676        r = &fDatRuns;
     677        f = &fDatRunsSub;
     678        break;
     679    case kCal:
     680        r = &fCalRuns;
     681        f = &fCalRunsSub;
     682        break;
     683    case kExcl:
     684        r = &fExclRuns;
     685        f = &fExclRunsSub;
     686        break;
     687    case kAll:
     688        r = &fRuns;
     689        f = &fRunsSub;
     690        break;
     691    }
     692}
     693
     694// --------------------------------------------------------------------------
     695//
     696// Add runs from the sequence to MDirIter. If path==0 fDataPath is
     697// used instead. If it is also empty the standard path of the
     698// data-center is assumed. If you have the runs locally use path="."
     699//
     700// Returns the number of files added.
     701//
     702// Runs which are in fExlRuns are ignored.
     703//
     704UInt_t MSequence::GetRuns(MDirIter &iter, FileType_t type, const char *path) const
     705{
     706    const TArrayI *r=0, *f=0;
     707    GetArrays(r, f, type);
     708    return GetRuns(iter, *r, *f, type, path);
     709}
     710
     711// --------------------------------------------------------------------------
     712//
     713// Returns the num-th entry of FileType_t as regular expression.
     714// If the file is excluded return "".
     715// To get the number of valid entries use GetNumEntries(FileType_t)
     716//
     717//  e.g.
     718//        if (GetNumEntries(MSequence::kDat))<5)
     719//            GetFileRegexp(3, MSequence::kRawDat);
     720//
     721TString MSequence::GetFileRegexp(UInt_t num, FileType_t type) const
     722{
     723    const TArrayI *r=0, *f=0;
     724    GetArrays(r, f, type);
     725
     726    TString rc = GetFileRegexp(num, *r, *f, type);
     727    rc.ReplaceAll(".", "\\.");
     728    rc.ReplaceAll("*", ".*");
     729    return rc;
     730}
     731
     732// --------------------------------------------------------------------------
     733//
     734// Returns the num-th entry of FileType_t as filename. To access the
     735// path the default is used if path IsNull, path otherwise.
     736// If the file could not be accessed "" is returned, if it is
     737// excluded "0".
     738// To get the number of valid entries use GetNumEntries(FileType_t)
     739//
     740//  e.g.
     741//        if (GetNumEntries(MSequence::kDat))<5)
     742//            GetFileName(3, MSequence::kRawDat);
     743//
     744TString MSequence::GetFileName(UInt_t num, FileType_t type, const char *path) const
     745{
     746    const TArrayI *r=0, *f=0;
     747    GetArrays(r, f, type);
     748    return GetFileName(num, *r, *f, type, path);
     749}
     750
     751// --------------------------------------------------------------------------
     752//
     753// Returns the num-th entry of FileType_t as filename.
     754// If the file could not be accessed or excluded return "".
     755// To get the number of valid entries use GetNumEntries(RunType_t)
     756//
     757UInt_t MSequence::GetNumEntries(RunType_t type) const
     758{
     759    const TArrayI *r=0, *f=0;
     760    GetArrays(r, f, type);
     761    return r->GetSize();
     762}
     763
     764// --------------------------------------------------------------------------
     765//
     766// Returns the num-th entry of RunType_t as run- and file-number.
     767// Returns -1 if index is out of range, 0 if file is excluded and
     768// 1 in case of success.
     769//
     770//  e.g.
     771//        UInt_t run, file;
     772//        GetFile(3, MSequence::kDat, run, file);
     773//
     774Int_t MSequence::GetFile(UInt_t i, RunType_t type, UInt_t &run, UInt_t &file) const
     775{
     776    const TArrayI *r=0, *f=0;
     777    GetArrays(r, f, type);
     778
     779    if (i>=(UInt_t)r->GetSize())
     780        return -1;
     781
     782    run  = (*r)[i];
     783    file = i<(UInt_t)f->GetSize() ? (*f)[i] : 0;
     784
     785    if (IsExcluded(run, file))
     786        return 0;
     787
     788    return 1;
     789}
     790
     791// --------------------------------------------------------------------------
     792//
     793// Add a file (run/file) to the arrays defined by RunType_t
     794//
     795void MSequence::AddFile(UInt_t run, UInt_t file, RunType_t type)
     796{
     797    const TArrayI *rconst=0, *fconst=0;
     798
     799    GetArrays(rconst, fconst, type);
     800
     801    TArrayI &r=*const_cast<TArrayI*>(rconst);
     802    TArrayI &f=*const_cast<TArrayI*>(fconst);
     803
     804    AddEntry(run, file, r, f);
     805
     806    SortArrays(r, f);
    604807}
    605808
     
    631834// --------------------------------------------------------------------------
    632835//
    633 // Read the file fname as setup file for the sequence.
    634 //
    635 MSequence::MSequence(const char *fname, const char *path, UInt_t seq)
    636 {
    637     fName  = "MSequence";
    638     fTitle = "Sequence file";
    639 
    640     fFileName = fname;
     836// Set the path to the data. If no path is given the data-center default
     837// path is used to access the files.
     838//
     839// kTRUE is returned if the path is acessible, kFALSE otherwise.
     840// (In case of the default path kTRUE is returned in any case)
     841//
     842Bool_t MSequence::SetDataPath(const char *path)
     843{
    641844    fDataPath = path;
    642845
     846    gSystem->ExpandPathName(fDataPath);
     847
     848    const Bool_t rc = !fDataPath.IsNull() && gSystem->AccessPathName(fDataPath, kFileExists);
     849    if (rc)
     850        gLog << err << "ERROR - Directory '" << path << "' doesn't exist." << endl;
     851
     852    return !rc;
     853}
     854
     855// --------------------------------------------------------------------------
     856//
     857// Read a sequence from a file. To set the location of the data (datapath)
     858// use SetDataPath. The sequence number given is used if no sequence
     859// number is found in the sequence file.
     860//
     861// If the file could not be found or accesed kFALSE is returned, kTRUE
     862// otherwise.
     863//
     864Bool_t MSequence::ReadFile(const char *filename, UInt_t seq)
     865{
     866    fFileName = filename;
     867
    643868    gSystem->ExpandPathName(fFileName);
    644     gSystem->ExpandPathName(fDataPath);
    645 
    646     const Bool_t rc1 = gSystem->AccessPathName(fFileName, kFileExists);
    647     const Bool_t rc2 = !fDataPath.IsNull() && gSystem->AccessPathName(fDataPath, kFileExists);
    648 
    649     if (rc1)
    650         gLog << err << "ERROR - Sequence file '" << fname << "' doesn't exist." << endl;
    651     if (rc2)
    652         gLog << err << "ERROR - Directory '" << path << "' doesn't exist." << endl;
     869
     870    const Bool_t rc = gSystem->AccessPathName(fFileName, kFileExists);
     871    if (rc)
     872        gLog << err << "ERROR - Sequence file '" << filename << "' doesn't exist." << endl;
    653873
    654874    MEnv env(fFileName);
    655875
    656876    fSequence = (UInt_t)env.GetValue("Sequence", (Int_t)seq);
    657     if (rc1 || rc2)
    658         fSequence = (UInt_t)-1;
    659 
    660877
    661878    const TString prefix = Form("Sequence%08d", fSequence);
     
    703920        env.PrintUntouched();
    704921    }
     922
     923    return !rc;
     924}
     925
     926// --------------------------------------------------------------------------
     927//
     928// Instantiate a file from either a file or the database.
     929//
     930// If not valid sequence could be created the sequence is invalidated,
     931// which can be queried with IsValid.
     932//
     933//  see ReadFile, ReadDatabase and SetDataPath for more details.
     934//
     935MSequence::MSequence(const char *fname, const char *path, UInt_t seq)
     936{
     937    // regular expression to distinguish beween a mysql-path and
     938    // a filename from where the sequence should be retrieved
     939    TPRegexp regexp("mysql://[a-zA-Z0-9]+:.+@[a-zA-Z0-9]+/[a-zA-Z0-9]+/([0-9]+:)?[0-9]+");
     940
     941    const TString db = TString(fname)(regexp);
     942
     943    const Bool_t rc1 = db.IsNull() ? ReadFile(fname, seq) : ReadDatabase(fname, seq);
     944    const Bool_t rc2 = SetDataPath(path);
     945
     946    fName  = "MSequence";
     947    fTitle = "Sequence file";
     948
     949    if (!rc1 || !rc2)
     950        fSequence = (UInt_t)-1;
     951}
     952
     953// --------------------------------------------------------------------------
     954//
     955// Read a sequence from the database. Give the path to the database as:
     956//    mysql://user:password@name/database
     957// In this case you MUST give a sequence number.
     958//
     959// You can code the telescope and sequence number into the path and
     960// omit the arguments:
     961//    mysql://user:password@name/database/[tel:]sequence
     962//
     963// The third option is to give just the sql.rc as string in the argument.
     964// In this case you MUST give a sequence number.
     965//
     966// If the telecope number is omitted as argument, i.e. ==0, or in the
     967// database path, a sequence is read from the database if the sequence
     968// number is unambiguous.
     969//
     970// kFALSE is returned if the final sequence is invalid, kTRUE in case of
     971// success.
     972//
     973Bool_t MSequence::ReadDatabase(TString name, UInt_t seq, UShort_t tel)
     974{
     975    TPRegexp regexp("([0-9]+:)?[0-9]+$");
     976
     977    const TString telseq = name(regexp);
     978
     979    if (!telseq.IsNull())
     980    {
     981        const Ssiz_t p = telseq.First(':');
     982
     983        const TString strtel = p<0 ? TString("") : telseq(0, p);
     984        const TString strseq = telseq(p+1, telseq.Length());
     985
     986        tel = strtel.Atoi();
     987        seq = strseq.Atoi();
     988
     989        name = gSystem->DirName(name);
     990    }
     991
     992    *this = MSequenceSQL(name, seq, tel);
     993
     994    return IsValid();
    705995}
    706996
     
    7151005//    MSequence seq(mysql, sequence, telescope);
    7161006//
    717 // For more details see MSequenceSQL.
     1007// Is the telescope number is omitted (==0) the database is checked for
     1008// an unambiguous sequence.
     1009//
     1010// For more details see ReadDatabase and MSequenceSQL.
    7181011//
    7191012MSequence::MSequence(const char *fname, UInt_t seq, UShort_t tel)
    7201013{
    721     *this = MSequenceSQL(fname, seq, tel);
     1014    const Bool_t rc = ReadDatabase(fname, seq, tel);
     1015
     1016    fName  = "MSequence";
     1017    fTitle = "Sequence file";
     1018
     1019    if (!rc)
     1020        fSequence = (UInt_t)-1;
    7221021}
    7231022
     
    10841383    {
    10851384        // FIXME: This needs more check!
     1385        // FORBID the + syntax in "Runs"
    10861386        // Could we make "Runs" an automatic summary of all runs?
    10871387        // Should we add a check forbidding the same run in
    10881388        // Cal/Ped/Data? What about the Exclude?
    1089         str += PrintRuns(out, pre, "Runs:     ", fRuns,     fRunsSub);
    1090         /*str +=*/ PrintRuns(out, pre, "CalRuns:  ", fCalRuns,  fCalRunsSub);
    1091         /*str +=*/ PrintRuns(out, pre, "PedRuns:  ", fPedRuns,  fPedRunsSub);
    1092         /*str +=*/ PrintRuns(out, pre, "DataRuns: ", fDatRuns,  fDatRunsSub);
    1093         /*str +=*/ PrintRuns(out, pre, "Exclude:  ", fExclRuns, fExclRunsSub);
     1389        /*str +=*/ PrintRuns(out, pre, "Runs:     ", fRuns,     fRunsSub);
     1390        str += PrintRuns(out, pre, "CalRuns:  ", fCalRuns,  fCalRunsSub);
     1391        str += PrintRuns(out, pre, "PedRuns:  ", fPedRuns,  fPedRunsSub);
     1392        str += PrintRuns(out, pre, "DataRuns: ", fDatRuns,  fDatRunsSub);
     1393        str += PrintRuns(out, pre, "Exclude:  ", fExclRuns, fExclRunsSub);
    10941394    }
    10951395
     
    11441444// --------------------------------------------------------------------------
    11451445//
    1146 // Add all ped runs from the sequence to MDirIter.
    1147 // If path==0 fDataPath is used instead. If it is also empty
    1148 // the standard path of the data-center is assumed.
    1149 // If you have the runs locally use path="."
    1150 // Using raw=kTRUE you get correspodning raw-files setup.
    1151 // Return the number of files added.
    1152 //
    1153 // Runs which are in fExlRuns are ignored.
    1154 //
    1155 UInt_t MSequence::SetupPedRuns(MDirIter &iter, const char *path, Bool_t raw) const
    1156 {
    1157     return SetupRuns(iter, fPedRuns, fPedRunsSub, raw?kRawPed:kRootPed, path);
    1158 }
    1159 
    1160 // --------------------------------------------------------------------------
    1161 //
    1162 // Add all data runs from the sequence to MDirIter.
    1163 // If path==0 fDataPath is used instead. If it is also empty
    1164 // the standard path of the data-center is assumed.
    1165 // If you have the runs locally use path="."
    1166 // Using raw=kTRUE you get correspodning raw-files setup.
    1167 // Return the number of files added.
    1168 //
    1169 // Runs which are in fExlRuns are ignored.
    1170 //
    1171 UInt_t MSequence::SetupDatRuns(MDirIter &iter, const char *path, Bool_t raw) const
    1172 {
    1173     return SetupRuns(iter, fDatRuns, fDatRunsSub, raw?kRawDat:kRootDat, path);
    1174 }
    1175 
    1176 // --------------------------------------------------------------------------
    1177 //
    1178 // Add all runs from the sequence to MDirIter.
    1179 // If path==0 fDataPath is used instead. If it is also empty
    1180 // the standard path of the data-center is assumed.
    1181 // If you have the runs locally use path="."
    1182 // Using raw=kTRUE you get correspodning raw-files setup.
    1183 // Return the number of files added.
    1184 //
    1185 // Runs which are in fExlRuns are ignored.
    1186 //
    1187 UInt_t MSequence::SetupAllRuns(MDirIter &iter, const char *path, Bool_t raw) const
    1188 {
    1189     return SetupRuns(iter, fRuns, fRunsSub, raw?kRawAll:kRootAll, path);
    1190 }
    1191 
    1192 // --------------------------------------------------------------------------
    1193 //
    1194 // Add all calibration runs from the sequence to MDirIter.
    1195 // If path==0 fDataPath is used instead. If it is also empty
    1196 // the standard path of the data-center is assumed.
    1197 // If you have the runs locally use path="."
    1198 // Using raw=kTRUE you get correspodning raw-files setup.
    1199 // Return the number of files added.
    1200 //
    1201 // Runs which are in fExlRuns are ignored.
    1202 //
    1203 UInt_t MSequence::SetupCalRuns(MDirIter &iter, const char *path, Bool_t raw) const
    1204 {
    1205     return SetupRuns(iter, fCalRuns, fCalRunsSub, raw?kRawCal:kRootCal, path);
    1206 }
    1207 
    1208 // --------------------------------------------------------------------------
    1209 //
    1210 // Add all data runs from the sequence to MDirIter.
    1211 // If path==0 fDataPath is used instead. If it is also empty
    1212 // the standard path of the data-center is assumed.
    1213 // If you have the runs locally use path="."
    1214 // Using raw=kTRUE you get correspodning raw-files setup.
    1215 // Return the number of files added.
    1216 //
    1217 // Runs which are in fExlRuns are ignored.
    1218 //
    1219 UInt_t MSequence::SetupDatRuns(MDirIter &iter, FileType_t type, const char *path) const
    1220 {
    1221     return SetupRuns(iter, fDatRuns, fDatRunsSub, type, path);
    1222 }
    1223 
    1224 // --------------------------------------------------------------------------
    1225 //
    12261446// check if the run/file is contained in the arrays.
    12271447//
     
    12421462    }
    12431463    return kFALSE;
    1244 }
    1245 
    1246 // --------------------------------------------------------------------------
    1247 //
    1248 // Add a file (run/file) to the arrays defined by type (P, C, D, X)
    1249 //
    1250 void MSequence::AddFile(UInt_t run, UInt_t file, char type)
    1251 {
    1252     TArrayI *r=0, *f=0;
    1253     switch (type)
    1254     {
    1255     case 'P':
    1256         r = &fPedRuns;
    1257         f = &fPedRunsSub;
    1258         break;
    1259     case 'D':
    1260         r = &fDatRuns;
    1261         f = &fDatRunsSub;
    1262         break;
    1263     case 'C':
    1264         r = &fCalRuns;
    1265         f = &fCalRunsSub;
    1266         break;
    1267     case 'X':
    1268         r = &fExclRuns;
    1269         f = &fExclRunsSub;
    1270         break;
    1271     default:
    1272         r = &fRuns;
    1273         f = &fRunsSub;
    1274         break;
    1275     }
    1276 
    1277     AddEntry(run, file, *r, *f);
    1278 
    1279     SortArrays(*r, *f);
    12801464}
    12811465
     
    13391523Bool_t MSequence::InflateSeq(TString &seq, Bool_t ismc)
    13401524{
    1341     if (seq.IsDigit())
    1342     {
    1343         const Int_t numseq = seq.Atoi();
    1344         seq = "/magic/";
    1345         if (ismc)
     1525    TObjArray *arr = seq.Tokenize(':');
     1526    if (arr->GetEntries()<3)
     1527    {
     1528        TString num1 = (*arr)[0]->GetName();
     1529        TString num2 = arr->GetEntries()==2 ? (*arr)[1]->GetName() : "";
     1530
     1531        if (num1.IsDigit() && num2.IsDigit())
     1532        {
     1533            gLog << err << "ERROR - InflateSeq 'telescope:sequence' not yet implemented." << endl;
     1534            delete arr;
     1535            return kFALSE;
     1536        }
     1537
     1538        if (num1.IsDigit() && num2.IsNull())
     1539        {
     1540            const Int_t numseq = seq.Atoi();
     1541            seq = "/magic/";
     1542            if (ismc)
    13461543            seq += "montecarlo/";
    1347         seq += Form("sequences/%04d/sequence%08d.txt", numseq/10000, numseq);
    1348         gLog << inf << "Inflated sequence file: " << seq << endl;
    1349     }
     1544            seq += Form("sequences/%04d/sequence%08d.txt", numseq/10000, numseq);
     1545            gLog << inf << "Inflated sequence file: " << seq << endl;
     1546        }
     1547    }
     1548    delete arr;
    13501549
    13511550    if (!gSystem->AccessPathName(seq, kFileExists))
  • trunk/MagicSoft/Mars/mjobs/MSequence.h

    r9015 r9019  
    1515{
    1616    friend class MSequenceSQL;
     17
    1718public:
    1819    enum LightCondition_t { kNA, kNoMoon, kTwilight, kMoon, kDay };
     20
     21    enum FileExt_t {
     22        kRaw   =BIT(0),
     23        kRoot  =BIT(1),
     24        kReport=BIT(2),
     25    };
     26    enum RunType_t {
     27        kPed   =BIT(3),
     28        kCal   =BIT(4),
     29        kDat   =BIT(5),
     30        kExcl  =BIT(6),
     31        kAll   =kPed|kDat|kCal,
     32        kImage =BIT(7),
     33        kCalib =BIT(8)
     34    };
     35
     36    enum { kRunType  = kPed|kCal|kDat|kImage|kCalib };
     37    enum { kFileType = kRaw|kRoot|kReport  };
     38
    1939    enum FileType_t {
    20         kRawDat, kRawPed, kRawCal, kRawAll,
    21         kRootDat, kRootPed, kRootCal, kRootAll,
    22         kCalibrated, kImages
     40        kRawDat     = kRaw   |kDat,
     41        kRawPed     = kRaw   |kPed,
     42        kRawCal     = kRaw   |kCal,
     43        kRawAll     = kRaw   |kAll,
     44        kRootDat    = kRoot  |kDat,
     45        kRootPed    = kRoot  |kPed,
     46        kRootCal    = kRoot  |kCal,
     47        kRootAll    = kRoot  |kAll,
     48        kReportPed  = kReport|kPed,
     49        kReportCal  = kReport|kCal,
     50        kReportDat  = kReport|kDat,
     51        kReportAll  = kReport|kAll,
     52        kCalibrated = kRoot  |kCalib,
     53        kImages     = kRoot  |kImage,
    2354    };
    2455
     
    73104
    74105    // Helper for file setup
     106    void    GetArrays(const TArrayI* &r, const TArrayI* &f, Int_t type) const;
     107    Bool_t  FindPath(TString &path, FileType_t type) const;
     108    TString FindPath(FileType_t type, TString path="") const { FindPath(path, type); return path; }
     109    TString FindFile(const TString &d, const TString &f) const;
    75110    TString GetPathName(TString d, FileType_t type) const;
    76     TString GetFileName(UInt_t num, const TArrayI &arr, const TArrayI &sub, FileType_t type) const;
    77     UInt_t  SetupRuns(MDirIter &iter, const TArrayI &arr, const TArrayI &file, FileType_t type, const char *path=0) const;
     111    TString GetFileRegexp(UInt_t num, const TArrayI &arr, const TArrayI &sub, FileType_t type) const;
     112    TString GetFileName(UInt_t i, const TArrayI &arr, const TArrayI &sub, FileType_t type, const char *path) const;
     113    UInt_t  GetRuns(MDirIter &iter, const TArrayI &arr, const TArrayI &file, FileType_t type, TString path="") const;
    78114
    79115    // Helper for Print()
     
    121157
    122158    // I/O
     159    Bool_t ReadDatabase(TString sql, UInt_t seq=0, UShort_t tel=0);
     160    Bool_t ReadFile(const char *filename, UInt_t id=(UInt_t)-1);
    123161    Bool_t WriteFile(const char *filename, const Option_t *o) const;
    124162    Bool_t WriteFile(const char *filename) const { return WriteFile(filename,""); } //*MENU *ARGS={filename=>fBaseName}
     163    Bool_t SetDataPath(const char *path="");
    125164
    126165    // TObject
     
    138177    void SetNight(const char*night);
    139178
    140     void AddRun(UInt_t run, char type='*') { AddFile(run, 0, type); }
    141     void AddRuns(UInt_t run1, UInt_t run2, char type='*') { for (UInt_t i=run1; i<=run2; i++) AddFile(i, 0, type); }
    142     void AddFile(UInt_t run, UInt_t file, char type='*');
    143     void AddFiles(UInt_t run, UInt_t f1, UInt_t f2, char type='*') { for (UInt_t i=f1; i<=f2; i++) AddFile(run, i, type); }
    144 
    145     void ExcludeFile(UInt_t run, UInt_t file=0) { /*if (!force || !IsExcluded(run, file))*/ AddFile(run, file, 'X'); }
     179    void AddRun(UInt_t run, RunType_t type=kAll) { AddFile(run, 0, type); }
     180    void AddRuns(UInt_t run1, UInt_t run2, RunType_t type=kAll) { for (UInt_t i=run1; i<=run2; i++) AddFile(i, 0, type); }
     181    void AddFile(UInt_t run, UInt_t file, RunType_t type=kAll);
     182    void AddFiles(UInt_t run, UInt_t f1, UInt_t f2, RunType_t type=kAll) { for (UInt_t i=f1; i<=f2; i++) AddFile(run, i, type); }
     183
     184    void ExcludeFile(UInt_t run, UInt_t file=0) { /*if (!force || !IsExcluded(run, file))*/ AddFile(run, file, kExcl); }
    146185    void ExcludeRuns(TString runs);
    147186
     
    157196    Bool_t HasMoon() const { return fLightCondition==kMoon; }
    158197
     198    Int_t  GetFile(UInt_t i, RunType_t type, UInt_t &run, UInt_t &file) const;
     199
    159200    LightCondition_t GetLightCondition() const { return fLightCondition; }
    160201
     
    166207
    167208    // Filesystem interface
    168     UInt_t SetupPedRuns(MDirIter &iter, const char *path=0, Bool_t raw=kFALSE) const;
    169     UInt_t SetupDatRuns(MDirIter &iter, const char *path=0, Bool_t raw=kFALSE) const;
    170     UInt_t SetupAllRuns(MDirIter &iter, const char *path=0, Bool_t raw=kFALSE) const;
    171     UInt_t SetupCalRuns(MDirIter &iter, const char *path=0, Bool_t raw=kFALSE) const;
    172     UInt_t SetupDatRuns(MDirIter &iter, FileType_t type, const char *path=0) const;
     209    UInt_t  GetRuns(MDirIter &iter, FileType_t type, const char *path=0) const;
     210    TString GetFileRegexp(UInt_t num, FileType_t type) const;
     211    TString GetFileName(UInt_t i, FileType_t type, const char *path=0) const;
     212    UInt_t  GetNumEntries(RunType_t type=kAll) const;
    173213
    174214    // Filesystem getter
     
    184224    static Bool_t  InflateSeq(TString &seq, /*FIXME: TELNUM*/ Bool_t ismc=kFALSE);
    185225
    186     static TString InflateRunName(const MTime &night, UShort_t tel, Int_t run, Int_t file, Int_t type=kRawAll);
    187     static TString InflateRunName(const MTime &night, Int_t run, Int_t type=kRawAll) { return InflateRunName(night, 1, run, 0, type); }
    188 
    189     static TString InflateRunPath(const MTime &night, UShort_t tel, Int_t run, Int_t file=0, Int_t type=kRawAll);
    190     static TString InflateRunPath(const MTime &night, Int_t run, Int_t type=kRawAll) { return InflateRunPath(night, 1, run, 0, type); }
    191 
    192     static TString InflateRunPath(const MTime &night, Bool_t mc=kFALSE);
     226    static TString InflateFileName(const MTime &night, UShort_t tel, Int_t run, Int_t file, Int_t type=kRawAll);
     227    static TString InflateFileName(const MTime &night, Int_t run, Int_t type=kRawAll) { return InflateFileName(night, 1, run, 0, type); }
     228
     229    static TString InflateFilePath(const MTime &night, UShort_t tel, Int_t run, Int_t file=0, Int_t type=kRawAll);
     230    static TString InflateFilePath(const MTime &night, Int_t run, Int_t type=kRawAll) { return InflateFilePath(night, 1, run, 0, type); }
     231
     232    static TString InflateFilePath(const MTime &night, Bool_t mc=kFALSE);
    193233
    194234    ClassDef(MSequence, 6) // Describes a sequences, reads and writes sequence files
  • trunk/MagicSoft/Mars/mjobs/MSequenceSQL.cc

    r9015 r9019  
    8686// return kFALSE in case of error or if no events are in the files.
    8787//
    88 Bool_t MSequenceSQL::GetRuns(MSQLMagic &serv, TString query, char type, UInt_t nevts)
     88Bool_t MSequenceSQL::GetRuns(MSQLMagic &serv, TString query, RunType_t type, UInt_t nevts)
    8989{
    9090    TSQLResult *res = serv.Query(query);
     
    211211
    212212    // get and setup runs
    213     if (!GetRuns(serv, queryA))
    214         return kFALSE;
    215     if (!GetRuns(serv, queryC, 'C'))
    216         return kFALSE;
    217     if (!GetRuns(serv, queryP, 'P', 1000))
    218         return kFALSE;
    219     if (!GetRuns(serv, queryD, 'D'))
     213    if (!GetRuns(serv, queryA, kAll))
     214        return kFALSE;
     215    if (!GetRuns(serv, queryC, kCal))
     216        return kFALSE;
     217    if (!GetRuns(serv, queryP, kPed, 1000))
     218        return kFALSE;
     219    if (!GetRuns(serv, queryD, kDat))
    220220        return kFALSE;
    221221
  • trunk/MagicSoft/Mars/mjobs/MSequenceSQL.h

    r9015 r9019  
    1414{
    1515private:
    16     Bool_t  GetRuns(MSQLMagic &serv, TString query, char type='*', UInt_t nevts=(UInt_t)-1);
     16    Bool_t  GetRuns(MSQLMagic &serv, TString query, RunType_t type, UInt_t nevts=(UInt_t)-1);
    1717    TString GetTimeFromDatabase(MSQLMagic &serv, const TString &query);
    1818    Bool_t  GetFromDatabase(MSQLMagic &serv, TSQLResult &res);
Note: See TracChangeset for help on using the changeset viewer.