add Port support
This commit is contained in:
parent
b871d2fc3d
commit
8f837228b3
|
@ -721,6 +721,45 @@ static int ptql_env_match(sigar_t *sigar,
|
||||||
return matched ? SIGAR_OK : !SIGAR_OK;
|
return matched ? SIGAR_OK : !SIGAR_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static int ptql_branch_init_port(ptql_parse_branch_t *parsed,
|
||||||
|
ptql_branch_t *branch)
|
||||||
|
{
|
||||||
|
if (strEQ(parsed->attr, "tcp")) {
|
||||||
|
branch->flags = SIGAR_NETCONN_TCP;
|
||||||
|
}
|
||||||
|
else if (strEQ(parsed->attr, "udp")) {
|
||||||
|
branch->flags = SIGAR_NETCONN_UDP;
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
return SIGAR_PTQL_MALFORMED_QUERY;
|
||||||
|
}
|
||||||
|
|
||||||
|
branch->data = (void*)atoi(parsed->value); /*XXX*/
|
||||||
|
|
||||||
|
return SIGAR_OK;
|
||||||
|
}
|
||||||
|
|
||||||
|
static int ptql_port_match(sigar_t *sigar,
|
||||||
|
sigar_pid_t pid,
|
||||||
|
void *data)
|
||||||
|
{
|
||||||
|
ptql_branch_t *branch =
|
||||||
|
(ptql_branch_t *)data;
|
||||||
|
unsigned long port =
|
||||||
|
(unsigned long)branch->data;
|
||||||
|
int status;
|
||||||
|
sigar_pid_t match_pid=0;
|
||||||
|
|
||||||
|
status =
|
||||||
|
sigar_proc_port_get(sigar, branch->flags, port, &match_pid);
|
||||||
|
|
||||||
|
if (status != SIGAR_OK) {
|
||||||
|
return status;
|
||||||
|
}
|
||||||
|
|
||||||
|
return (pid == match_pid) ? SIGAR_OK : !SIGAR_OK;
|
||||||
|
}
|
||||||
|
|
||||||
#define PTQL_LOOKUP_ENTRY(cname, member, type) \
|
#define PTQL_LOOKUP_ENTRY(cname, member, type) \
|
||||||
(ptql_get_t)sigar_##cname##_get, \
|
(ptql_get_t)sigar_##cname##_get, \
|
||||||
sigar_offsetof(sigar_##cname##_t, member), \
|
sigar_offsetof(sigar_##cname##_t, member), \
|
||||||
|
@ -795,6 +834,10 @@ static ptql_lookup_t PTQL_Env[] = {
|
||||||
{ NULL, ptql_env_match, 0, 0, PTQL_VALUE_TYPE_ANY, ptql_branch_init_any }
|
{ NULL, ptql_env_match, 0, 0, PTQL_VALUE_TYPE_ANY, ptql_branch_init_any }
|
||||||
};
|
};
|
||||||
|
|
||||||
|
static ptql_lookup_t PTQL_Port[] = {
|
||||||
|
{ NULL, ptql_port_match, 0, 0, PTQL_VALUE_TYPE_ANY, ptql_branch_init_port }
|
||||||
|
};
|
||||||
|
|
||||||
static ptql_lookup_t PTQL_Pid[] = {
|
static ptql_lookup_t PTQL_Pid[] = {
|
||||||
{ NULL, ptql_pid_match, 0, 0, PTQL_VALUE_TYPE_ANY, ptql_branch_init_pid }
|
{ NULL, ptql_pid_match, 0, 0, PTQL_VALUE_TYPE_ANY, ptql_branch_init_pid }
|
||||||
};
|
};
|
||||||
|
@ -809,6 +852,7 @@ static ptql_entry_t ptql_map[] = {
|
||||||
{ "Fd", PTQL_Fd },
|
{ "Fd", PTQL_Fd },
|
||||||
{ "Args", PTQL_Args },
|
{ "Args", PTQL_Args },
|
||||||
{ "Env", PTQL_Env },
|
{ "Env", PTQL_Env },
|
||||||
|
{ "Port", PTQL_Port },
|
||||||
{ "Pid", PTQL_Pid },
|
{ "Pid", PTQL_Pid },
|
||||||
{ NULL }
|
{ NULL }
|
||||||
};
|
};
|
||||||
|
|
Loading…
Reference in New Issue