/usr/include/oce/OSD_PerfMeter.hxx is in liboce-foundation-dev 0.15-4.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 | // Created on: 2002-04-03
// Created by: Michael SAZONOV
// Copyright (c) 2002-2014 OPEN CASCADE SAS
//
// This file is part of Open CASCADE Technology software library.
//
// This library is free software; you can redistribute it and / or modify it
// under the terms of the GNU Lesser General Public version 2.1 as published
// by the Free Software Foundation, with special exception defined in the file
// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT
// distribution for complete text of the license and disclaimer of any warranty.
//
// Alternatively, this file may be used under the terms of Open CASCADE
// commercial license or contractual agreement.
#ifndef OSD_PerfMeter_HeaderFile
#define OSD_PerfMeter_HeaderFile
#include <OSD_PerfMeter.h>
// This class enables measuring the CPU time between two points of code
// execution, regardless of the scope of these points of code. A meter is
// identified by its name (string of chars). So multiple objects in various
// places of user code may point to the same meter. The results will be
// printed on stdout upon finish of the program. For details see
// OSD_PerfMeter.h
class OSD_PerfMeter {
public:
// ---------- PUBLIC METHODS ----------
OSD_PerfMeter () : myIMeter(-1) {}
// constructs a void meter (to further call Init and Start)
OSD_PerfMeter (const char* meter, const unsigned autoStart = 1)
: myIMeter(perf_get_meter(meter,0,0)) {
if (myIMeter < 0) myIMeter = perf_init_meter(meter);
if (autoStart) Start();
}
// constructs and starts (if autoStart is true) the named meter
void Init (const char* meter) {
myIMeter = perf_get_meter(meter,0,0);
if (myIMeter < 0) myIMeter = perf_init_meter(meter);
}
// prepares the named meter
void Start () const { perf_start_imeter(myIMeter); }
// starts the meter
void Stop () const { perf_stop_imeter(myIMeter); }
// stops the meter
void Tick () const { perf_tick_imeter(myIMeter); }
// increments the counter w/o time measurement
void Flush () const { perf_close_imeter(myIMeter); }
// outputs the meter data and resets it to initial state
virtual ~OSD_PerfMeter () { if (myIMeter >= 0) Stop(); }
// assures stopping upon destruction
protected:
// ---------- PROTECTED FIELDS ----------
int myIMeter;
};
#endif
|