Ignore:
Timestamp:
10/28/03 14:54:20 (21 years ago)
Author:
tbretz
Message:
*** empty log message ***
Location:
trunk/MagicSoft/Mars/mbase
Files:
4 edited

Legend:

Unmodified
Added
Removed
  • trunk/MagicSoft/Mars/mbase/MEvtLoop.cc

    r2416 r2438  
    1616!
    1717!
    18 !   Author(s): Thomas Bretz  12/2000 <mailto:tbretz@uni-sw.gwdg.de>
     18!   Author(s): Thomas Bretz, 12/2000 <mailto:tbretz@astro.uni-wuerzburg.de>
    1919!
    20 !   Copyright: MAGIC Software Development, 2000-2001
     20!   Copyright: MAGIC Software Development, 2000-2003
    2121!
    2222!
     
    7878#include <TSystem.h>        // gSystem
    7979#include <TStopwatch.h>
    80 #include <TGProgressBar.h>
     80#include <TGProgressBar.h> 
    8181
    8282#include "MLog.h"
     
    191191        fProgress=NULL;
    192192    else
     193    {
    193194        d->SetBit(kMustCleanup);
     195
     196        // Get pointer to update Progress bar
     197        fProgress = fDisplay->GetBar();
     198    }
    194199
    195200    if (fParList)
     
    237242        // Lock display to prevent user from deleting it
    238243        fDisplay->Lock();
    239         // Get pointer to update Progress bar
    240         fProgress = fDisplay->GetBar();
    241244        // Don't display context menus
    242245        fDisplay->SetNoContextMenu();
     
    267270}
    268271
    269 Bool_t MEvtLoop::ProcessGuiEvents(Int_t num, Int_t entries)
     272Bool_t MEvtLoop::ProcessGuiEvents(Int_t num)
    270273{
    271274    if (gROOT->IsBatch())
     
    347350            txt += " (";
    348351            txt += speed;
    349             txt += "Evts/s, est: ";
    350             txt += (int)((long int)(t0-t2)*entries/(60000.*(num-start)));
    351             txt += "m";
     352            txt += "Evts/s";
     353            if (fNumEvents>0)
     354            {
     355                txt += ", est: ";
     356                txt += (int)((long int)(t0-t2)*fNumEvents/(60000.*(num-start)));
     357                txt += "m";
     358            }
    352359            //txt += (int)fmod(entries/(1000.*(num-start)/(long int)(t0-t2)), 60);
    353360            //txt += "s";
     
    362369    // Set new progress bar position
    363370    //
    364     if (fProgress)
    365         fProgress->SetPosition(num);
     371    if (fProgress && fNumEvents>0)
     372        fProgress->SetPosition(num/fNumEvents);
    366373
    367374    //
     
    409416
    410417    Int_t entries = INT_MAX;
     418    fNumEvents = 0;
    411419
    412420    if (fProgress && !gROOT->IsBatch())
    413421    {
    414422        fProgress->Reset();
     423        fProgress->SetRange(0, 1);
     424
    415425#ifdef __MARS__
    416426        // limits.h
     
    421431
    422432        if (maxcnt>0)
    423             fProgress->SetRange(0, TMath::Min(maxcnt, entries));
     433            fNumEvents = TMath::Min(maxcnt, entries);
    424434        else
    425435            if (entries!=INT_MAX)
    426                 fProgress->SetRange(0, entries);
     436                fNumEvents = entries;
    427437    }
    428438
     
    454464        {
    455465            numcnts++;
    456             if (!ProcessGuiEvents(++dummy, entries))
     466            if (!ProcessGuiEvents(++dummy))
    457467                break;
    458468        }
     
    462472        {
    463473            numcnts++;
    464             if (!ProcessGuiEvents(maxcnt - dummy, entries))
     474            if (!ProcessGuiEvents(maxcnt - dummy))
    465475                break;
    466476        }
     
    473483    if (fProgress && !gROOT->IsBatch())
    474484    {
    475         fProgress->SetPosition(maxcnt>0 ? TMath::Min(maxcnt, entries) : entries);
     485        //fProgress->SetPosition(maxcnt>0 ? TMath::Min(maxcnt, entries) : entries);
     486        fProgress->SetPosition(1);
    476487        // FIXME: This is a workaround, because TApplication::Run is not thread safe against ProcessEvents
    477488        if (gApplication->InheritsFrom(TRint::Class()))
  • trunk/MagicSoft/Mars/mbase/MEvtLoop.h

    r2299 r2438  
    3030    TGProgressBar *fProgress;  //!
    3131
     32    ULong_t fNumEvents;        //!
     33
    3234    enum { kIsOwner = BIT(14) };
    3335
     
    3739    void StreamPrimitive(ofstream &out) const;
    3840
    39     Bool_t ProcessGuiEvents(Int_t num, Int_t entries);
     41    Bool_t ProcessGuiEvents(Int_t num);
    4042
    4143public:
  • trunk/MagicSoft/Mars/mbase/MReadSocket.cc

    r2386 r2438  
    3030//////////////////////////////////////////////////////////////////////////////
    3131#include "MReadSocket.h"
    32 
    33 /*
    34  #ifdef _REENTRANT
    35  #include <pthread.h>
    36  #endif
    37 */
    3832
    3933#include <unistd.h>          // usleep
     
    155149int MReadSocket::underflow()
    156150{
     151    if (fail())
     152    {
     153        setg(fBuffer, fBuffer, fBuffer+fMtu);
     154        return 0;
     155    }
     156
    157157    //
    158158    // This simple trick should do its job, because the
     
    161161    const TTime timeout = fTimeout+gSystem->Now();
    162162
    163     Int_t l, len=-1;
     163    Int_t len=-1;
    164164    while (len<0 && gSystem->Now()<timeout)
    165165    {
     166        Int_t l;
    166167        fRxSocket->GetOption(kBytesToRead, l);
    167168        if (l==0)
    168169        {
    169             usleep(1);
     170            gSystem->Sleep(1);
    170171            continue;
    171172        }
     
    177178        cout << "MReadSocket: TSocket::RecvRaw - Connection timed out." << endl;
    178179        setstate(ios::failbit);
     180        memset(fBuffer, 0, fMtu);
     181        len = fMtu;
    179182    }
    180183
  • trunk/MagicSoft/Mars/mbase/MTime.h

    r2386 r2438  
    7676    }
    7777
     78    void SetTime(ULong_t t)
     79    {
     80        // t [millisec]
     81        fNanoSec  = (t*1000000)%1000;
     82        t /= 1000;
     83        fSec      = t%60;
     84        t /= 60;
     85        fMin      = t%60;
     86        t /= 60;
     87        fHour     = t%24;
     88    }
     89
     90    void SetTime(Double_t t)
     91    {
     92        // t [s]
     93        fNanoSec  = (UInt_t)(fmod(t, 1)*1e9);
     94        fSec      = (Byte_t)fmod(t, 60);
     95        t /= 60;
     96        fMin      = (Byte_t)fmod(t, 60);
     97        t /= 60;
     98        fHour     = (Byte_t)fmod(t, 24);
     99    }
     100
    78101    void SetTime(Byte_t h, Byte_t m, Byte_t s, UShort_t ns)
    79102    {
     
    112135        return fNanoSec/1e9+(fHour*24*60*60+fMin*60+fSec);
    113136    }
     137    double operator()() const //[s]
     138    {
     139        return operator double();
     140    }
    114141
    115142    ClassDef(MTime, 1)  //A generalized MARS time stamp
     
    118145inline Double_t operator-(MTime &t1, MTime &t2)
    119146{
    120     return (Double_t)t1.GetTimeLo()-(Double_t)t2.GetTimeLo();
     147    return t1()-t2();
    121148}
    122149
    123150inline Bool_t operator<(MTime &t1, MTime &t2)
    124151{
    125     return (t1.GetTimeHi()<=t2.GetTimeHi()) && (t1.GetTimeLo()<t2.GetTimeLo());
     152    return t1()<t2();
    126153}
    127154
    128155inline Bool_t operator>(MTime &t1, MTime &t2)
    129156{
    130     return (t1.GetTimeHi()>=t2.GetTimeHi()) && (t1.GetTimeLo()>t2.GetTimeLo());
     157    return t1()>t2();
    131158}
    132159
    133160inline Bool_t operator<=(MTime &t1, MTime &t2)
    134161{
    135     return (t1.GetTimeHi()<=t2.GetTimeHi()) && (t1.GetTimeLo()<=t2.GetTimeLo());
     162    return t1<=t2();
    136163}
    137164
    138165inline Bool_t operator>=(MTime &t1, MTime &t2)
    139166{
    140     return (t1.GetTimeHi()>=t2.GetTimeHi()) && (t1.GetTimeLo()>=t2.GetTimeLo());
     167    return t1()>=t2();
    141168}
    142169
    143170inline Bool_t operator==(MTime &t1, MTime &t2)
    144171{
    145     return (t1.GetTimeLo()==t2.GetTimeLo()) && (t1.GetTimeHi()==t2.GetTimeHi());
     172    return t1()==t2();
    146173}
    147174
Note: See TracChangeset for help on using the changeset viewer.