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;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
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) \
 | 
			
		||||
    (ptql_get_t)sigar_##cname##_get, \
 | 
			
		||||
    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 }
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
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[] = {
 | 
			
		||||
    { 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 },
 | 
			
		||||
    { "Args",     PTQL_Args },
 | 
			
		||||
    { "Env",      PTQL_Env },
 | 
			
		||||
    { "Port",     PTQL_Port },
 | 
			
		||||
    { "Pid",      PTQL_Pid },
 | 
			
		||||
    { NULL }
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
		Loading…
	
		Reference in New Issue
	
	Block a user