1PMGETCHILDRENSTATUS(3) Library Functions Manual PMGETCHILDRENSTATUS(3)
2
3
4
6 pmGetChildrenStatus - return the descendent nodes of a PMNS node and
7 their respective status
8
10 #include <pcp/pmapi.h>
11
12 int pmGetChildrenStatus(const char *name, char ***offspring,
13 int **status);
14
15 cc ... -lpcp
16
18 Given a fully qualified pathname to a node in the current Performance
19 Metrics Name Space (PMNS), as identified by name, pmGetChildrenStatus
20 returns via offspring a list of the relative names of all of the imme‐
21 diate descendent nodes of name in the current PMNS.
22
23 As a special case, if name is an empty string (i.e.""), the immediate
24 descendants of the root node in the PMNS will be returned.
25
26 If status is not NULL, then pmGetChildrenStatus will also return the
27 status of each child via status. The status will refer to either a
28 leaf node (with value PMNS_LEAF_STATUS ) or a non-leaf node (with value
29 PMNS_NONLEAF_STATUS ).
30
31 Normally, pmGetChildrenStatus will return the number of descendent
32 names discovered, else a value less than zero for an error. The value
33 zero indicates that name is a valid metric name, i.e. is associated
34 with a leaf node in the PMNS.
35
36 The resulting list of pointers offspring and the values (the relative
37 names) that the pointers reference will have been allocated by
38 pmGetChildrenStatus with a single call to malloc(3), and it is the re‐
39 sponsibility of the pmGetChildrenStatus caller to free(offspring) to
40 release the space when it is no longer required. The same holds true
41 for the status array.
42
43 When an error occurs, or name is a leaf node (i.e. the result of
44 pmGetChildrenStatus is less than one), both offspring and status are
45 undefined (no space will have been allocated, and so calling free(3) is
46 a singularly bad idea).
47
49 Environment variables with the prefix PCP_ are used to parameterize the
50 file and directory names used by PCP. On each installation, the file
51 /etc/pcp.conf contains the local values for these variables. The
52 $PCP_CONF variable may be used to specify an alternative configuration
53 file, as described in pcp.conf(5). Values for these variables may be
54 obtained programmatically using the pmGetConfig(3) function.
55
57 PMAPI(3), pmGetChildren(3), pmGetConfig(3), pmLoadASCIINameSpace(3),
58 pmLoadNameSpace(3), pmLookupName(3), pmNameID(3), pcp.conf(5),
59 pcp.env(5) and pmns(5).
60
62 PM_ERR_NOPMNS
63 Failed to access a PMNS for operation. Note that if the appli‐
64 cation hasn't a priori called pmLoadNameSpace(3) and wants to
65 use the distributed PMNS, then a call to pmGetChildrenStatus
66 must be made inside a current context.
67
68 PM_ERR_NAME
69 The pathname name is not valid in the current PMNS
70
71 PM_ERR_*
72 Other diagnostics are for protocol failures when accessing the
73 distributed PMNS.
74
75
76
77Performance Co-Pilot PCP PMGETCHILDRENSTATUS(3)