Browsing Counters
To display a dialog box that lists the performance objects and counters defined on the computer, call the PdhBrowseCounters function. The dialog box lets the user browse and select performance counters. You use the PDH_BROWSE_DLG_CONFIG structure to specify the configuration of the dialog box. For example, you can configure the dialog to return one selection or multiple selections.
On input, the szReturnPathBuffer member contains the default performance object and counter that is selected in the dialog box. On output, the buffer contains the performance object and counter that the user selected. You can also use the pCallBack member to specify a callback function to process the counter names returned by the dialog box.
Note that this dialog box can return PDH_DIALOG_CANCELLED if bSingleCounterPerDialog is FALSE and the user clicks the Close button, so your error handling would have to account for this.
For an example that uses the PdhBrowseCounters function, see Browsing Performance Counters.
To retrieve a list of performance objects on the computer, you can also call the PdhEnumObjects function. To retrieve a list of counters and instances for a performance object, call the PdhEnumObjectItems function. You can also use these functions to identify the performance objects and counters contained in a log file. Repeated calls to PdhEnumObjectItems will return the same list of counters and instances until you call PdhEnumObjects to refresh the list of performance objects first. For an example that enumerates objects and counters, see Enumerating Process Objects.
Selecting the data source
You can use PdhSelectDataSource in conjunction with PdhBrowseCounters to prompt the user to select whether the data source is in real-time or from a log file, and, if it is a log file, its name. If you do not want the data source dialog to be displayed, you can call PdhSelectDataSource to display only the file browser catalog. To do this, specify PDH_FLAGS_FILE_BROWSER_ONLY as the second parameter of the call to PdhSelectDataSource.