lazhen
2024-07-22 52e314fa22dd8904a8c3ab8a68392b1b4e9cf514
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
Quintiq file version 2.0
#parent: #root
StaticMethod Read (Algorithm algorithm, String id) const as Duration
{
  Description: 'Get the current duration from the stopwatch with the given id.'
  TextBody:
  [*
    value := Duration::Zero();
    
    if( LibOpt_AlgorithmStopwatch::HasValue( algorithm, id ) )
    {
    
      time := guard( algorithm.RetrieveReal( LibOpt_AlgorithmStopwatch::StrTimeStored( id ) ), 0.0 );
      if( LibOpt_AlgorithmStopwatch::IsRunning( algorithm, id ) )
      {
        time := time + guard( OS::PrecisionCounter() - algorithm.RetrieveReal( LibOpt_AlgorithmStopwatch::StrTimeStart( id ) ), 0.0 );
      }
      
      value := Duration::Seconds( time / OS::PrecisionCounterFrequency() );
    }
    
    return value;
  *]
}