Source code of Windows XP (NT5)
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
|
|
///////////////////////////////////////////////////////////////////////////////
//
// Copyright (c) 1998, Microsoft Corp. All rights reserved.
//
// FILE
//
// perflib.h
//
// SYNOPSIS
//
// Declares classes for implementing a PerfMon DLL.
//
// MODIFICATION HISTORY
//
// 09/06/1998 Original version.
//
///////////////////////////////////////////////////////////////////////////////
#ifndef _PERLIB_H_
#define _PERLIB_H_
#if _MSC_VER >= 1000
#pragma once
#endif
#include <winperf.h>
#include <vector>
// nonstandard extension used : zero-sized array in struct/union
#pragma warning(disable:4200)
// Forward declaration.
class PerfObjectType;
//////////
// Callback function that populates a PerfObjectType prior to collection.
//////////
typedef VOID (WINAPI *PerfDataSource)(PerfObjectType& sink);
//////////
// Struct defining a counter.
//////////
struct PerfCounterDef { DWORD nameTitleOffset; DWORD counterType; DWORD defaultScale; DWORD detailLevel; };
//////////
// Struct defining an object type.
//////////
struct PerfObjectTypeDef { DWORD nameTitleOffset; DWORD numCounters; PerfCounterDef* counters; PerfDataSource dataSource; // May be NULL.
BOOL multipleInstances; // TRUE if the type support multiple instances.
DWORD defaultCounter; };
//////////
// Struct defining the data collector for an application.
//////////
struct PerfCollectorDef { PCWSTR name; // Registry key containing the counter offsets.
DWORD numTypes; PerfObjectTypeDef* types; };
///////////////////////////////////////////////////////////////////////////////
//
// CLASS
//
// PerfCounterBlock
//
// DESCRIPTION
//
// Encapsulates a PERF_COUNTER_BLOCK struct.
//
///////////////////////////////////////////////////////////////////////////////
class PerfCounterBlock { public: // Returns a pointer to the internal counter array.
PDWORD getCounters() throw () { return counters; }
// Zero out all the counters.
void zeroCounters() throw () { memset(counters, 0, pcb.ByteLength - sizeof(PERF_COUNTER_BLOCK)); }
// Collects PerfMon data into the buffer bounded by 'first' and 'last'.
// Returns a pointer to the end of the collected data.
PBYTE collect(PBYTE first, PBYTE last);
// Create a new PerfCounterBlock object.
static PerfCounterBlock* create(DWORD numDWORDs);
protected: // Constructor is protected since new objects may only be instantiated
// through the 'create' method.
PerfCounterBlock() throw () { }
PERF_COUNTER_BLOCK pcb; DWORD counters[0];
private: // Not implemented.
PerfCounterBlock(const PerfCounterBlock&); PerfCounterBlock& operator=(const PerfCounterBlock&); };
///////////////////////////////////////////////////////////////////////////////
//
// CLASS
//
// PerfInstanceDefinition
//
// DESCRIPTION
//
// Encapsulates a PERF_INSTANCE_DEFINITION struct.
//
///////////////////////////////////////////////////////////////////////////////
class PerfInstanceDefinition { public: // Returns the name of the instance; may be null.
PCWSTR getName() const throw () { return pid.NameLength ? name : NULL; }
// Returns the Unique ID of the instance.
LONG getUniqueID() const throw () { return pid.UniqueID; }
PBYTE collect(PBYTE first, PBYTE last);
// Create a new PerfInstanceDefinition object.
static PerfInstanceDefinition* create( PCWSTR name, // May be NULL.
LONG uniqueID );
protected: // Constructor is protected since new objects may only be instantiated
// through the 'create' method.
PerfInstanceDefinition() throw () { }
PERF_INSTANCE_DEFINITION pid; WCHAR name[0];
private: // Not implemented.
PerfInstanceDefinition(const PerfInstanceDefinition&); PerfInstanceDefinition& operator=(const PerfInstanceDefinition&); };
///////////////////////////////////////////////////////////////////////////////
//
// CLASS
//
// PerfInstance
//
// DESCRIPTION
//
// Represents an instance of a particular performance object type. Consists
// of an optional PerfInstanceDefinition followed by a mandatory
// PerfCounterBlock
//
///////////////////////////////////////////////////////////////////////////////
class PerfInstance { public: PerfInstance(DWORD numCounters) : pcb(PerfCounterBlock::create(numCounters)) { }
PerfInstance(PCWSTR name, LONG uniqueID, DWORD numCounters) : pid(PerfInstanceDefinition::create(name, uniqueID)), pcb(PerfCounterBlock::create(numCounters)) { }
// Returns a pointer to the internal counter array.
PDWORD getCounters() throw () { return pcb->getCounters(); }
PBYTE collect(PBYTE first, PBYTE last);
protected: std::auto_ptr<PerfInstanceDefinition> pid; std::auto_ptr<PerfCounterBlock> pcb;
private: // Not implemented.
PerfInstance(const PerfInstance&); PerfInstance& operator=(const PerfInstance&); };
///////////////////////////////////////////////////////////////////////////////
//
// CLASS
//
// PerfObjectType
//
// DESCRIPTION
//
// Encapsulates a performance object type containing zero or more
// PerfInstance's.
//
///////////////////////////////////////////////////////////////////////////////
class PerfObjectType { public: typedef std::vector<PerfInstance*> MyVec; typedef MyVec::size_type size_type;
~PerfObjectType() throw ();
// Access a given instance of this type.
PerfInstance& operator[](size_type pos) throw () { return *instances[pos]; } PerfInstance& at(size_type pos) throw () { return *instances[pos]; }
// Returns the index used by PerfMon to identify this object type.
DWORD getIndex() const throw () { return pot.ObjectNameTitleIndex; }
// Clears all instances.
void clear() throw ();
// Reserves space for at least 'N' instances.
void reserve(size_type N) { instances.reserve(N); }
// Returns the number of instances.
size_type size() const throw () { return instances.size(); }
// Add a new instance of this type.
void addInstance( PCWSTR name = NULL, LONG uniqueID = PERF_NO_UNIQUE_ID );
// Collect performance data for this object type.
PBYTE collect(PBYTE first, PBYTE last);
// Create a new PerfObjectType.
static PerfObjectType* create(const PerfObjectTypeDef& def);
protected: // Constructor is protected since new objects may only be instantiated
// through the 'create' method.
PerfObjectType() throw () { }
PerfDataSource dataSource; // Callback for populating objects.
MyVec instances; // Vector of existing instances.
DWORD numDWORDs; // DWORD's of data for each instance.
PERF_OBJECT_TYPE pot; PERF_COUNTER_DEFINITION pcd[0];
private: // Not implemented.
PerfObjectType(const PerfObjectType&); PerfObjectType& operator=(const PerfObjectType&); };
///////////////////////////////////////////////////////////////////////////////
//
// CLASS
//
// PerfCollector
//
// DESCRIPTION
//
// Maintains all the PerfObjectType's for a given application.
//
///////////////////////////////////////////////////////////////////////////////
class PerfCollector { public: typedef size_t size_type;
PerfCollector() throw () : types(NULL) { } ~PerfCollector() throw ();
// Access a given object type.
PerfObjectType& operator[](size_type pos) throw () { return *(types[pos]); }
// Clears all instances (but not all PerfObjectType's).
void clear() throw ();
// Initialize the collector for use.
void open(const PerfCollectorDef& def);
// Collect performance data for the indicated types.
void collect( PCWSTR values, PVOID& data, DWORD& numBytes, DWORD& numTypes );
// Shutdown the collector.
void close() throw ();
protected: PerfObjectType** types;
private: // Not implemented.
PerfCollector(PerfCollector&); PerfCollector& operator=(PerfCollector&); };
#endif // _PERLIB_H_
|