diff options
author | Matt Jordan <mjordan@digium.com> | 2015-11-23 08:43:29 -0600 |
---|---|---|
committer | Gerrit Code Review <gerrit2@gerrit.digium.api> | 2015-11-23 08:43:29 -0600 |
commit | 001b7f482ba717330c94b3e4dec2bd18ec57e916 (patch) | |
tree | b0effd97d14bc215381b134e4f8dee60672c83ef /res | |
parent | 0f88f909ec4f24cca4c7f6db0f2a6a915d14837b (diff) | |
parent | 3354b325c67824b4aa052fb81693d28e792886a6 (diff) |
Merge "res_statsd: Add functions that support variable arguments" into 13
Diffstat (limited to 'res')
-rw-r--r-- | res/res_statsd.c | 48 |
1 files changed, 48 insertions, 0 deletions
diff --git a/res/res_statsd.c b/res/res_statsd.c index b8b79be07..4eb526071 100644 --- a/res/res_statsd.c +++ b/res/res_statsd.c @@ -160,6 +160,54 @@ void AST_OPTIONAL_API_NAME(ast_statsd_log_full)(const char *metric_name, } +AST_THREADSTORAGE(statsd_buf); + +void AST_OPTIONAL_API_NAME(ast_statsd_log_string_va)(const char *metric_name, + const char *metric_type, const char *value, double sample_rate, ...) +{ + struct ast_str *buf; + va_list ap; + int res; + + buf = ast_str_thread_get(&statsd_buf, 128); + if (!buf) { + return; + } + + va_start(ap, sample_rate); + res = ast_str_set_va(&buf, 0, metric_name, ap); + va_end(ap); + + if (res == AST_DYNSTR_BUILD_FAILED) { + return; + } + + ast_statsd_log_string(ast_str_buffer(buf), metric_type, value, sample_rate); +} + +void AST_OPTIONAL_API_NAME(ast_statsd_log_full_va)(const char *metric_name, + const char *metric_type, intmax_t value, double sample_rate, ...) +{ + struct ast_str *buf; + va_list ap; + int res; + + buf = ast_str_thread_get(&statsd_buf, 128); + if (!buf) { + return; + } + + va_start(ap, sample_rate); + res = ast_str_set_va(&buf, 0, metric_name, ap); + va_end(ap); + + if (res == AST_DYNSTR_BUILD_FAILED) { + return; + } + + ast_statsd_log_full(ast_str_buffer(buf), metric_type, value, sample_rate); +} + void AST_OPTIONAL_API_NAME(ast_statsd_log)(const char *metric_name, const char *metric_type, intmax_t value) { |