[svn-commits] trunk r9310 - in /trunk: cli.c config.c db.c
devicestate.c dnsmgr.c
svn-commits at lists.digium.com
svn-commits at lists.digium.com
Thu Feb 9 09:59:54 MST 2006
Author: russell
Date: Thu Feb 9 10:59:50 2006
New Revision: 9310
URL: http://svn.digium.com/view/asterisk?rev=9310&view=rev
Log:
conversions to memory allocation wrappers, remove duplicated error messages,
remove unnecessary casts, malloc+memset to calloc (issue #6395)
Modified:
trunk/cli.c
trunk/config.c
trunk/db.c
trunk/devicestate.c
trunk/dnsmgr.c
Modified: trunk/cli.c
URL: http://svn.digium.com/view/asterisk/trunk/cli.c?rev=9310&r1=9309&r2=9310&view=diff
==============================================================================
--- trunk/cli.c (original)
+++ trunk/cli.c Thu Feb 9 10:59:50 2006
@@ -63,14 +63,14 @@
void ast_cli(int fd, char *fmt, ...)
{
char *stuff;
- int res = 0;
+ int res;
va_list ap;
va_start(ap, fmt);
res = vasprintf(&stuff, fmt, ap);
va_end(ap);
if (res == -1) {
- ast_log(LOG_ERROR, "Out of memory\n");
+ ast_log(LOG_ERROR, "Memory allocation failure\n");
} else {
ast_carefulwrite(fd, stuff, strlen(stuff), 100);
free(stuff);
@@ -520,8 +520,7 @@
if (argc != 4)
return RESULT_SHOWUSAGE;
- buf = malloc(buflen);
- if (!buf)
+ if (!(buf = ast_malloc(buflen)))
return RESULT_FAILURE;
buf[len] = '\0';
matches = ast_cli_completion_matches(argv[2], argv[3]);
@@ -534,9 +533,8 @@
if (len + matchlen >= buflen) {
buflen += matchlen * 3;
obuf = buf;
- buf = realloc(obuf, buflen);
- if (!buf)
- /* Out of memory... Just free old buffer and be done */
+ if (!(buf = ast_realloc(obuf, buflen)))
+ /* Memory allocation failure... Just free old buffer and be done */
free(obuf);
}
if (buf)
@@ -1274,13 +1272,14 @@
while ((retstr = ast_cli_generator(text, word, matches)) != NULL) {
if (matches + 1 >= match_list_len) {
match_list_len <<= 1;
- match_list = realloc(match_list, match_list_len * sizeof(char *));
+ if (!(match_list = ast_realloc(match_list, match_list_len * sizeof(*match_list))))
+ return NULL;
}
match_list[++matches] = retstr;
}
if (!match_list)
- return (char **) NULL;
+ return NULL;
which = 2;
prevstr = match_list[1];
@@ -1291,14 +1290,18 @@
max_equal = i;
}
- retstr = malloc(max_equal + 1);
+ if (!(retstr = ast_malloc(max_equal + 1)))
+ return NULL;
+
strncpy(retstr, match_list[1], max_equal);
retstr[max_equal] = '\0';
match_list[0] = retstr;
- if (matches + 1 >= match_list_len)
- match_list = realloc(match_list, (match_list_len + 1) * sizeof(char *));
- match_list[matches + 1] = (char *) NULL;
+ if (matches + 1 >= match_list_len) {
+ if (!(match_list = ast_realloc(match_list, (match_list_len + 1) * sizeof(*match_list))))
+ return NULL;
+ }
+ match_list[matches + 1] = NULL;
return match_list;
}
@@ -1391,10 +1394,9 @@
int x;
char *dup;
int tws;
-
- dup = parse_args(s, &x, argv, sizeof(argv) / sizeof(argv[0]), &tws);
- if (!dup) {
- ast_log(LOG_ERROR, "Out of Memory!\n");
+
+ if (!(dup = parse_args(s, &x, argv, sizeof(argv) / sizeof(argv[0]), &tws))) {
+ ast_log(LOG_ERROR, "Memory allocation failure\n");
return -1;
}
Modified: trunk/config.c
URL: http://svn.digium.com/view/asterisk/trunk/config.c?rev=9310&r1=9309&r2=9310&view=diff
==============================================================================
--- trunk/config.c (original)
+++ trunk/config.c Thu Feb 9 10:59:50 2006
@@ -101,13 +101,11 @@
struct ast_variable *ast_variable_new(const char *name, const char *value)
{
struct ast_variable *variable;
-
- int length = strlen(name) + strlen(value) + 2 + sizeof(struct ast_variable);
- variable = malloc(length);
- if (variable) {
- memset(variable, 0, length);
+ int name_len = strlen(name) + 1;
+
+ if ((variable = ast_calloc(1, name_len + strlen(value) + 1 + sizeof(*variable)))) {
variable->name = variable->stuff;
- variable->value = variable->stuff + strlen(name) + 1;
+ variable->value = variable->stuff + name_len;
strcpy(variable->name,name);
strcpy(variable->value,value);
}
@@ -203,9 +201,7 @@
{
struct ast_category *category;
- category = malloc(sizeof(struct ast_category));
- if (category) {
- memset(category, 0, sizeof(struct ast_category));
+ if ((category = ast_calloc(1, sizeof(*category)))) {
ast_copy_string(category->name, name, sizeof(category->name));
}
@@ -329,9 +325,7 @@
{
struct ast_config *config;
- config = malloc(sizeof(*config));
- if (config) {
- memset(config, 0, sizeof(*config));
+ if ((config = ast_calloc(1, sizeof(*config)))) {
config->max_include_level = MAX_INCLUDE_LEVEL;
}
@@ -390,9 +384,7 @@
if (*c++ != '(')
c = NULL;
catname = cur;
- *cat = newcat = ast_category_new(catname);
- if (!newcat) {
- ast_log(LOG_WARNING, "Out of memory, line %d of %s\n", lineno, configfile);
+ if (!(*cat = newcat = ast_category_new(catname))) {
return -1;
}
/* If there are options or categories to inherit from, process them now */
@@ -511,15 +503,13 @@
c++;
} else
object = 0;
- v = ast_variable_new(ast_strip(cur), ast_strip(c));
- if (v) {
+ if ((v = ast_variable_new(ast_strip(cur), ast_strip(c)))) {
v->lineno = lineno;
v->object = object;
/* Put and reset comments */
v->blanklines = 0;
ast_variable_append(*cat, v);
} else {
- ast_log(LOG_WARNING, "Out of memory, line %d\n", lineno);
return -1;
}
} else {
@@ -767,12 +757,10 @@
length += strlen(database) + 1;
if (table)
length += strlen(table) + 1;
- map = malloc(length);
-
- if (!map)
+
+ if (!(map = ast_calloc(1, length)))
return -1;
- memset(map, 0, length);
map->name = map->stuff;
strcpy(map->name, name);
map->driver = map->name + strlen(map->name) + 1;
Modified: trunk/db.c
URL: http://svn.digium.com/view/asterisk/trunk/db.c?rev=9310&r1=9309&r2=9310&view=diff
==============================================================================
--- trunk/db.c (original)
+++ trunk/db.c Thu Feb 9 10:59:50 2006
@@ -63,14 +63,11 @@
static int dbinit(void)
{
- if (!astdb) {
- if (!(astdb = dbopen((char *)ast_config_AST_DB, O_CREAT | O_RDWR, 0664, DB_BTREE, NULL))) {
- ast_log(LOG_WARNING, "Unable to open Asterisk database\n");
- }
- }
- if (astdb)
- return 0;
- return -1;
+ if (!astdb && !(astdb = dbopen((char *)ast_config_AST_DB, O_CREAT | O_RDWR, 0664, DB_BTREE, NULL))) {
+ ast_log(LOG_WARNING, "Unable to open Asterisk database\n");
+ return -1;
+ }
+ return 0;
}
@@ -402,6 +399,7 @@
char prefix[256];
DBT key, data;
char *keys, *values;
+ int values_len;
int res;
int pass;
struct ast_db_entry *last = NULL;
@@ -440,20 +438,18 @@
} else {
values = "<bad value>";
}
- if (keymatch(keys, prefix)) {
- cur = malloc(sizeof(struct ast_db_entry) + strlen(keys) + strlen(values) + 2);
- if (cur) {
- cur->next = NULL;
- cur->key = cur->data + strlen(values) + 1;
- strcpy(cur->data, values);
- strcpy(cur->key, keys);
- if (last) {
- last->next = cur;
- } else {
- ret = cur;
- }
- last = cur;
+ values_len = strlen(values) + 1;
+ if (keymatch(keys, prefix) && (cur = ast_malloc(sizeof(*cur) + strlen(keys) + 1 + values_len))) {
+ cur->next = NULL;
+ cur->key = cur->data + values_len;
+ strcpy(cur->data, values);
+ strcpy(cur->key, keys);
+ if (last) {
+ last->next = cur;
+ } else {
+ ret = cur;
}
+ last = cur;
}
}
ast_mutex_unlock(&dblock);
Modified: trunk/devicestate.c
URL: http://svn.digium.com/view/asterisk/trunk/devicestate.c?rev=9310&r1=9309&r2=9310&view=diff
==============================================================================
--- trunk/devicestate.c (original)
+++ trunk/devicestate.c Thu Feb 9 10:59:50 2006
@@ -143,11 +143,7 @@
{
struct devstate_cb *devcb;
- if (!callback)
- return -1;
-
- devcb = calloc(1, sizeof(*devcb));
- if (!devcb)
+ if (!callback || !(devcb = ast_calloc(1, sizeof(*devcb))))
return -1;
devcb->data = data;
@@ -198,16 +194,13 @@
static int __ast_device_state_changed_literal(char *buf)
{
char *device, *tmp;
- struct state_change *change = NULL;
+ struct state_change *change;
device = buf;
- tmp = strrchr(device, '-');
- if (tmp)
+ if ((tmp = strrchr(device, '-')))
*tmp = '\0';
- if (change_thread != AST_PTHREADT_NULL)
- change = calloc(1, sizeof(*change) + strlen(device));
-
- if (!change) {
+
+ if (change_thread == AST_PTHREADT_NULL || !(change = ast_calloc(1, sizeof(*change) + strlen(device)))) {
/* we could not allocate a change struct, or */
/* there is no background thread, so process the change now */
do_state_change(device);
Modified: trunk/dnsmgr.c
URL: http://svn.digium.com/view/asterisk/trunk/dnsmgr.c?rev=9310&r1=9309&r2=9310&view=diff
==============================================================================
--- trunk/dnsmgr.c (original)
+++ trunk/dnsmgr.c Thu Feb 9 10:59:50 2006
@@ -83,11 +83,7 @@
{
struct ast_dnsmgr_entry *entry;
- if (!result || ast_strlen_zero(name))
- return NULL;
-
- entry = calloc(1, sizeof(*entry) + strlen(name));
- if (!entry)
+ if (!result || ast_strlen_zero(name) || !(entry = ast_calloc(1, sizeof(*entry) + strlen(name))))
return NULL;
entry->result = result;
@@ -285,8 +281,7 @@
int dnsmgr_init(void)
{
- sched = sched_context_create();
- if (!sched) {
+ if (!(sched = sched_context_create())) {
ast_log(LOG_ERROR, "Unable to create schedule context.\n");
return -1;
}
More information about the svn-commits
mailing list