Merge "cdr_pgsql, cel_pgsql: Store maximum buffer size to prevent reallocation"

This commit is contained in:
Joshua Colp 2015-05-13 15:17:48 -05:00 committed by Gerrit Code Review
commit 4505f5e676
2 changed files with 19 additions and 0 deletions

View File

@ -75,6 +75,7 @@ static char *encoding;
static char *tz;
static int connected = 0;
/* Optimization to reduce number of memory allocations */
static int maxsize = 512, maxsize2 = 512;
static time_t connect_time = 0;
static int totalrecords = 0;
@ -453,6 +454,15 @@ static int pgsql_log(struct ast_cdr *cdr)
records++;
}
PQclear(result);
/* Next time, just allocate buffers that are that big to start with. */
if (ast_str_strlen(sql) > maxsize) {
maxsize = ast_str_strlen(sql);
}
if (ast_str_strlen(sql2) > maxsize2) {
maxsize2 = ast_str_strlen(sql2);
}
ast_free(sql);
ast_free(sql2);
}

View File

@ -74,6 +74,7 @@ static char *table;
static char *schema;
static int connected = 0;
/* Optimization to reduce number of memory allocations */
static int maxsize = 512, maxsize2 = 512;
static int usegmtime = 0;
@ -375,6 +376,14 @@ static void pgsql_log(struct ast_event *event)
}
PQclear(result);
/* Next time, just allocate buffers that are that big to start with. */
if (ast_str_strlen(sql) > maxsize) {
maxsize = ast_str_strlen(sql);
}
if (ast_str_strlen(sql2) > maxsize2) {
maxsize2 = ast_str_strlen(sql2);
}
ast_log_cleanup:
ast_free(sql);
ast_free(sql2);