move sigar_get_self_path to sigar_util
This commit is contained in:
		
							parent
							
								
									dc3eceb517
								
							
						
					
					
						commit
						5fc7cc7134
					
				@ -81,6 +81,8 @@ double sigar_file_system_usage_calc_used(sigar_t *sigar,
 | 
			
		||||
 | 
			
		||||
void sigar_cpu_model_adjust(sigar_t *sigar, sigar_cpu_info_t *info);
 | 
			
		||||
 | 
			
		||||
char *sigar_get_self_path(sigar_t *sigar);
 | 
			
		||||
 | 
			
		||||
typedef struct sigar_cache_entry_t sigar_cache_entry_t;
 | 
			
		||||
 | 
			
		||||
struct sigar_cache_entry_t {
 | 
			
		||||
 | 
			
		||||
@ -510,6 +510,52 @@ SIGAR_DECLARE(int) sigar_nfs_ping(char *host)
 | 
			
		||||
#define vsnprintf _vsnprintf
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
static int proc_module_get_self(void *data, char *name, int len)
 | 
			
		||||
{
 | 
			
		||||
    sigar_t *sigar = (sigar_t *)data;
 | 
			
		||||
    char *ptr = rindex(name, '/');
 | 
			
		||||
 | 
			
		||||
    if (!ptr) {
 | 
			
		||||
        return SIGAR_OK;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    if (strnEQ(ptr+1, "libsigar-", 9)) {
 | 
			
		||||
        *ptr = '\0'; /* chop libsigar-powerpc-ibm-aix-4.3.x.so */
 | 
			
		||||
 | 
			
		||||
        sigar->self_path = sigar_strdup(name);
 | 
			
		||||
 | 
			
		||||
        if (SIGAR_LOG_IS_DEBUG(sigar)) {
 | 
			
		||||
            sigar_log_printf(sigar, SIGAR_LOG_DEBUG,
 | 
			
		||||
                             "detected sigar-lib='%s'",
 | 
			
		||||
                             sigar->self_path);
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        return !SIGAR_OK; /* break loop */
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    return SIGAR_OK;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
char *sigar_get_self_path(sigar_t *sigar)
 | 
			
		||||
{
 | 
			
		||||
    if (!sigar->self_path) {
 | 
			
		||||
        sigar_proc_modules_t procmods;
 | 
			
		||||
        procmods.module_getter = proc_module_get_self;
 | 
			
		||||
        procmods.data = sigar;
 | 
			
		||||
 | 
			
		||||
        sigar_proc_modules_get(sigar,
 | 
			
		||||
                               sigar_pid_get(sigar),
 | 
			
		||||
                               &procmods);
 | 
			
		||||
 | 
			
		||||
        if (!sigar->self_path) {
 | 
			
		||||
            /* dont try again */
 | 
			
		||||
            sigar->self_path = sigar_strdup(".");
 | 
			
		||||
        }
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    return sigar->self_path;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
SIGAR_DECLARE(void) sigar_log_printf(sigar_t *sigar, int level,
 | 
			
		||||
                                     const char *format, ...)
 | 
			
		||||
{
 | 
			
		||||
 | 
			
		||||
		Loading…
	
		Reference in New Issue
	
	Block a user