use sigar_t.pids

This commit is contained in:
Doug MacEachern 2007-12-21 22:45:59 +00:00
parent bb3b9dd280
commit 3c35d5fb78

View File

@ -164,21 +164,22 @@ SIGAR_DECLARE(int) sigar_proc_stat_get(sigar_t *sigar,
sigar_proc_stat_t *procstat) sigar_proc_stat_t *procstat)
{ {
int status, i; int status, i;
sigar_proc_list_t proclist; sigar_proc_list_t *pids;
SIGAR_ZERO(procstat); SIGAR_ZERO(procstat);
procstat->threads = SIGAR_FIELD_NOTIMPL; procstat->threads = SIGAR_FIELD_NOTIMPL;
if ((status = sigar_proc_list_get(sigar, &proclist)) != SIGAR_OK) { if ((status = sigar_proc_list_get(sigar, NULL)) != SIGAR_OK) {
return status; return status;
} }
procstat->total = proclist.number; pids = sigar->pids;
procstat->total = pids->number;
for (i=0; i<proclist.number; i++) { for (i=0; i<pids->number; i++) {
sigar_proc_state_t state; sigar_proc_state_t state;
status = sigar_proc_state_get(sigar, proclist.data[i], &state); status = sigar_proc_state_get(sigar, pids->data[i], &state);
if (status != SIGAR_OK) { if (status != SIGAR_OK) {
continue; continue;
} }
@ -208,8 +209,6 @@ SIGAR_DECLARE(int) sigar_proc_stat_get(sigar_t *sigar,
} }
} }
sigar_proc_list_destroy(sigar, &proclist);
return SIGAR_OK; return SIGAR_OK;
} }