diff --git a/crm/common/utils.c b/crm/common/utils.c index 70ec55b354..939ea18bec 100644 --- a/crm/common/utils.c +++ b/crm/common/utils.c @@ -1,260 +1,264 @@ -/* $Id: utils.c,v 1.3 2004/06/03 07:52:16 andrew Exp $ */ +/* $Id: utils.c,v 1.4 2004/06/21 08:43:23 andrew Exp $ */ /* * Copyright (C) 2004 Andrew Beekhof * * This program is free software; you can redistribute it and/or * modify it under the terms of the GNU General Public * License as published by the Free Software Foundation; either * version 2.1 of the License, or (at your option) any later version. * * This software is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * General Public License for more details. * * You should have received a copy of the GNU General Public * License along with this library; if not, write to the Free Software * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA */ #include #include #include #include #include #include #include #include #include #include #include #include #include #include #define MAXLINE 512 static uint ref_counter = 0; const char * generateReference(const char *custom1, const char *custom2) { const char *local_cust1 = custom1; const char *local_cust2 = custom2; int reference_len = 4; char *since_epoch = NULL; reference_len += 20; // too big reference_len += 40; // too big if(local_cust1 == NULL) local_cust1 = "_empty_"; reference_len += strlen(local_cust1); if(local_cust2 == NULL) local_cust2 = "_empty_"; reference_len += strlen(local_cust2); since_epoch = (char*)crm_malloc(reference_len*(sizeof(char))); sprintf(since_epoch, "%s-%s-%ld-%u", local_cust1, local_cust2, (unsigned long)time(NULL), ref_counter++); return since_epoch; } gboolean decodeNVpair(const char *srcstring, char separator, char **name, char **value) { int lpc = 0; int len = 0; const char *temp = NULL; - - crm_verbose("Attempting to decode: [%s]", srcstring); if (srcstring != NULL) { len = strlen(srcstring); while(lpc < len) { - if (srcstring[lpc++] == separator) { - *name = (char*)crm_malloc(sizeof(char)*lpc); - strncpy(*name, srcstring, lpc-1); - (*name)[lpc-1] = '\0'; - - // this sucks but as the strtok *is* a bug - len = len-lpc+1; - *value = (char*)crm_malloc(sizeof(char)*len); - temp = srcstring+lpc; - strncpy(*value, temp, len-1); - (*value)[len-1] = '\0'; + if (srcstring[lpc] == separator + || srcstring[lpc] == '\0') { + *name = (char*)crm_malloc(sizeof(char)*lpc+1); + strncpy(*name, srcstring, lpc); + (*name)[lpc] = '\0'; + +// this sucks but as the strtok manpage says.. it *is* a bug + len = len-lpc; + len--; + if(len > 0) { + *value = (char*)crm_malloc( + sizeof(char)*len+1); + temp = srcstring+lpc+1; + strncpy(*value, temp, len); + (*value)[len] = '\0'; + } else { + *value = NULL; + } return TRUE; } + lpc++; } } *name = NULL; *value = NULL; return FALSE; } char * generate_hash_key(const char *crm_msg_reference, const char *sys) { int ref_len = strlen(sys?sys:"none") + strlen(crm_msg_reference) + 2; char *hash_key = (char*)crm_malloc(sizeof(char)*(ref_len)); sprintf(hash_key, "%s_%s", sys?sys:"none", crm_msg_reference); hash_key[ref_len-1] = '\0'; crm_info("created hash key: (%s)", hash_key); return hash_key; } char * generate_hash_value(const char *src_node, const char *src_subsys) { int ref_len; char *hash_value; if (src_node == NULL || src_subsys == NULL) { return NULL; } if (strcmp(CRM_SYSTEM_DC, src_subsys) == 0) { hash_value = crm_strdup(src_subsys); if (!hash_value) { crm_err("memory allocation failed in " "generate_hash_value()\n"); return NULL; } return hash_value; } ref_len = strlen(src_subsys) + strlen(src_node) + 2; hash_value = (char*)crm_malloc(sizeof(char)*(ref_len)); if (!hash_value) { crm_err("memory allocation failed in " "generate_hash_value()\n"); return NULL; } snprintf(hash_value, ref_len-1, "%s_%s", src_node, src_subsys); hash_value[ref_len-1] = '\0';// make sure it is null terminated crm_info("created hash value: (%s)", hash_value); return hash_value; } gboolean decode_hash_value(gpointer value, char **node, char **subsys) { char *char_value = (char*)value; int value_len = strlen(char_value); - - crm_info("Decoding hash value: (%s:%d)", char_value, value_len); if (strcmp(CRM_SYSTEM_DC, (char*)value) == 0) { *node = NULL; *subsys = (char*)crm_strdup(char_value); if (!*subsys) { crm_err("memory allocation failed in " "decode_hash_value()\n"); return FALSE; } crm_info("Decoded value: (%s:%d)", *subsys, (int)strlen(*subsys)); return TRUE; } else if (char_value != NULL) { if (decodeNVpair(char_value, '_', node, subsys)) { return TRUE; } else { *node = NULL; *subsys = NULL; return FALSE; } } return FALSE; } char * crm_itoa(int an_int) { int len = 32; char *buffer = crm_malloc(sizeof(char)*(len+1)); snprintf(buffer, len, "%d", an_int); return buffer; } unsigned int crm_log_level = LOG_VERBOSE; /* returns the old value */ unsigned int set_crm_log_level(unsigned int level) { unsigned int old = crm_log_level; crm_log_level = level; return old; } unsigned int get_crm_log_level(unsigned int level) { int old = crm_log_level; crm_log_level = level; return old; } void do_crm_log(int log_level, const char *function, const char *fmt, ...) { gboolean do_log = FALSE; switch(log_level) { case LOG_NOTICE: case LOG_WARNING: case LOG_ERR: do_log = TRUE; break; default: - if(log_level >= crm_log_level) { + if(log_level <= crm_log_level) { do_log = TRUE; if(log_level != LOG_INFO) { log_level = LOG_DEBUG; } } break; } if(do_log) { va_list ap; char buf[MAXLINE]; int nbytes; buf[MAXLINE-1] = EOS; va_start(ap, fmt); nbytes=vsnprintf(buf, sizeof(buf)-1, fmt, ap); va_end(ap); if(function == NULL) { cl_log(log_level, "%s", buf); } else { cl_log(log_level, "(%s) %s", function, buf); } } }