Skip to content
Snippets Groups Projects
Commit feb1a434 authored by David M. Lee's avatar David M. Lee Committed by David M. Lee
Browse files

Portably sscanf tv_usec

In a timeval, tv_usec is defined as a suseconds_t, which could be
different underlying types on different platforms. Instead of trying to
scanf directly into the timeval, scanf into a long int, then copy that
into the timeval.

Change-Id: I29f22d049d3f7746b6c0cc23fbf4293bdaa5eb95
parent 49461f37
No related branches found
No related tags found
No related merge requests found
......@@ -223,9 +223,11 @@ STASIS_MESSAGE_TYPE_DEFN_LOCAL(cdr_prop_write_message_type);
static struct timeval cdr_retrieve_time(struct ast_channel *chan, const char *time_name)
{
struct timeval time;
struct timeval time = { 0 };
char *value = NULL;
char tempbuf[128];
long int tv_sec;
long int tv_usec;
if (ast_strlen_zero(ast_channel_name(chan))) {
/* Format request on a dummy channel */
......@@ -234,7 +236,11 @@ static struct timeval cdr_retrieve_time(struct ast_channel *chan, const char *ti
ast_cdr_getvar(ast_channel_name(chan), time_name, tempbuf, sizeof(tempbuf));
}
if (sscanf(tempbuf, "%ld.%ld", &time.tv_sec, &time.tv_usec) != 2) {
/* time.tv_usec is suseconds_t, which could be int or long */
if (sscanf(tempbuf, "%ld.%ld", &tv_sec, &tv_usec) == 2) {
time.tv_sec = tv_sec;
time.tv_usec = tv_usec;
} else {
ast_log(AST_LOG_WARNING, "Failed to fully extract '%s' from CDR\n", time_name);
}
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment