Manpages

NAME

pmGetInDomArchive - get instance identifiers for a performance metrics instance domain

C SYNOPSIS

#include <pcp/pmapi.h>

int pmGetInDomArchive(pmInDom indom, int **instlist, char ***namelist);

cc ... -lpcp

DESCRIPTION

Provided the current Performance Metrics Application Programming Interface (PMAPI) context is associated with a set of archives, pmGetInDomArchive will scan the union of all the instance domain metadata for the instance domain indom, and return via instlist the internal instance identifiers for all instances, and via namelist the full external identifiers for all instances.

This routine is a specialized version of the more general PMAPI routine pmGetInDom.

The number of instances found is returned as the function value (else less than zero to indicate an error).

The value for the instance domain indom is typically extracted from a pmDesc structure, following a call to pmLookupDesc(3) for a particular performance metric.

The resulting lists of instance identifiers (instlist and namelist), and the names that the elements of namelist point to, will have been allocated by pmGetInDomArchive with two calls to malloc(3), and it is the responsibility of the caller to free(instlist) and free(namelist) to release the space when it is no longer required.

When the result of pmGetInDomArchive is less than one, both instlist and namelist are undefined (no space will have been allocated, and so calling free(3) is a singularly bad idea).

DIAGNOSTICS

PM_ERR_NOTARCHIVE

the current PMAPI context is not associated with a set of archives

PM_ERR_INDOM_LOG

indom is not a defined instance domain identifier for the set of archives

PCP ENVIRONMENT

Environment variables with the prefix PCP_ are used to parameterize the file and directory names used by PCP. On each installation, the file /etc/pcp.conf contains the local values for these variables. The $PCP_CONF variable may be used to specify an alternative configuration file, as described in pcp.conf(5). Values for these variables may be obtained programmatically using the pmGetConfig(3) function.

SEE ALSO

PMAPI(3), pmGetConfig(3), pmGetInDom(3), pmLookupDesc(3), pmLookupInDomArchive(3), pmNameInDomArchive(3), pcp.conf(5) and pcp.env(5).