mirror of
https://github.com/asterisk/asterisk.git
synced 2025-09-18 18:58:22 +00:00
cdr_pgsql.cl: REFACTOR Macro LENGTHEN_BUF
Remove repeated code on macro of assigned buffer to SQL vars. Add table and connection name to log error message when is not possible allocate memory. Change-Id: I1fbf37d286a032d38fdda72a9f736356956c9ffe
This commit is contained in:
@@ -101,34 +101,25 @@ struct columns {
|
||||
|
||||
static AST_RWLIST_HEAD_STATIC(psql_columns, columns);
|
||||
|
||||
#define LENGTHEN_BUF1(size) \
|
||||
do { \
|
||||
/* Lengthen buffer, if necessary */ \
|
||||
if (ast_str_strlen(sql) + size + 1 > ast_str_size(sql)) { \
|
||||
if (ast_str_make_space(&sql, ((ast_str_size(sql) + size + 3) / 512 + 1) * 512) != 0) { \
|
||||
ast_log(LOG_ERROR, "Unable to allocate sufficient memory. Insert CDR failed.\n"); \
|
||||
ast_free(sql); \
|
||||
ast_free(sql2); \
|
||||
AST_RWLIST_UNLOCK(&psql_columns); \
|
||||
ast_mutex_unlock(&pgsql_lock); \
|
||||
return -1; \
|
||||
} \
|
||||
} \
|
||||
#define LENGTHEN_BUF(size, var_sql) \
|
||||
do { \
|
||||
/* Lengthen buffer, if necessary */ \
|
||||
if (ast_str_strlen(var_sql) + size + 1 > ast_str_size(var_sql)) { \
|
||||
if (ast_str_make_space(&var_sql, ((ast_str_size(var_sql) + size + 3) / 512 + 1) * 512) != 0) { \
|
||||
ast_log(LOG_ERROR, "Unable to allocate sufficient memory. Insert CDR '%s:%s' failed.\n", pghostname, table); \
|
||||
ast_free(sql); \
|
||||
ast_free(sql2); \
|
||||
AST_RWLIST_UNLOCK(&psql_columns); \
|
||||
ast_mutex_unlock(&pgsql_lock); \
|
||||
return -1; \
|
||||
} \
|
||||
} \
|
||||
} while (0)
|
||||
|
||||
#define LENGTHEN_BUF2(size) \
|
||||
do { \
|
||||
if (ast_str_strlen(sql2) + size + 1 > ast_str_size(sql2)) { \
|
||||
if (ast_str_make_space(&sql2, ((ast_str_size(sql2) + size + 3) / 512 + 1) * 512) != 0) { \
|
||||
ast_log(LOG_ERROR, "Unable to allocate sufficient memory. Insert CDR failed.\n"); \
|
||||
ast_free(sql); \
|
||||
ast_free(sql2); \
|
||||
AST_RWLIST_UNLOCK(&psql_columns); \
|
||||
ast_mutex_unlock(&pgsql_lock); \
|
||||
return -1; \
|
||||
} \
|
||||
} \
|
||||
} while (0)
|
||||
#define LENGTHEN_BUF1(size) \
|
||||
LENGTHEN_BUF(size, sql);
|
||||
#define LENGTHEN_BUF2(size) \
|
||||
LENGTHEN_BUF(size, sql2);
|
||||
|
||||
/*! \brief Handle the CLI command cdr show pgsql status */
|
||||
static char *handle_cdr_pgsql_status(struct ast_cli_entry *e, int cmd, struct ast_cli_args *a)
|
||||
|
Reference in New Issue
Block a user