1 /*---------------------------------------------------------------------------*\
5 * Copyright (C) 2000-2006 by the OpenSG Forum *
9 * contact: dirk@opensg.org, gerrit.voss@vossg.org, jbehr@zgdv.de *
11 \*---------------------------------------------------------------------------*/
12 /*---------------------------------------------------------------------------*\
15 * This library is free software; you can redistribute it and/or modify it *
16 * under the terms of the GNU Library General Public License as published *
17 * by the Free Software Foundation, version 2. *
19 * This library is distributed in the hope that it will be useful, but *
20 * WITHOUT ANY WARRANTY; without even the implied warranty of *
21 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU *
22 * Library General Public License for more details. *
24 * You should have received a copy of the GNU Library General Public *
25 * License along with this library; if not, write to the Free Software *
26 * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. *
28 \*---------------------------------------------------------------------------*/
29 /*---------------------------------------------------------------------------*\
37 \*---------------------------------------------------------------------------*/
39 #ifndef _OSG_PERF_MONITOR_GUARD_
40 #define _OSG_PERF_MONITOR_GUARD_
42 #include "OSGPerfMonitor.h"
47 /*! \ingroup GrpBasePerfMon
49 * Helper class that uses the guard idiom to create and monitor performance.
50 * To use, just create a PerfMonitorGuard with the name of the perf sample
51 * point. It will automatically call enter on creation and exit on destruction.
53 class PerfMonitorGuard
56 PerfMonitorGuard(const std::string
& name
, const std::string
& desc
= "")
60 PerfMonitor::the()->sample(OSG::PerfMonitorBase::ENTER
, mName
, 0.0, mDesc
);
64 PerfMonitor::the()->sample(OSG::PerfMonitorBase::EXIT
, mName
, 0.0,
68 std::string mName
; /**< The name of the sample point. */