aboutsummaryrefslogtreecommitdiffstats
path: root/utils.c
diff options
context:
space:
mode:
authorkpfleming <kpfleming@f38db490-d61c-443f-a65b-d21fe96a405b>2006-01-06 19:19:17 +0000
committerkpfleming <kpfleming@f38db490-d61c-443f-a65b-d21fe96a405b>2006-01-06 19:19:17 +0000
commitdd5fd06f560dea96e36a0d0bd35421f8abc2b519 (patch)
tree1864ed197f7226117cb0d35e08b9dbd248135004 /utils.c
parentdbe96780b58d2e0253b2cf9f19b8a34477658358 (diff)
ensure that string field 'build' operation only evaluates arguments one time
fix some minor documentation errors return proper type from string field space allocator git-svn-id: http://svn.digium.com/svn/asterisk/trunk@7841 f38db490-d61c-443f-a65b-d21fe96a405b
Diffstat (limited to 'utils.c')
-rw-r--r--utils.c25
1 files changed, 23 insertions, 2 deletions
diff --git a/utils.c b/utils.c
index df2e393eb..cc3510541 100644
--- a/utils.c
+++ b/utils.c
@@ -943,8 +943,8 @@ int __ast_string_field_init(struct ast_string_field_pool *pool, size_t size,
return pool->base ? 0 : -1;
}
-char *__ast_string_field_alloc_space(struct ast_string_field_pool *pool, size_t needed,
- ast_string_field *fields, int num_fields)
+ast_string_field __ast_string_field_alloc_space(struct ast_string_field_pool *pool, size_t needed,
+ ast_string_field *fields, int num_fields)
{
char *result = NULL;
@@ -974,3 +974,24 @@ char *__ast_string_field_alloc_space(struct ast_string_field_pool *pool, size_t
pool->space -= needed;
return result;
}
+
+void __ast_string_field_index_build(struct ast_string_field_pool *pool,
+ ast_string_field *fields, int num_fields,
+ int index, const char *format, ...)
+{
+ char s;
+ size_t needed;
+ va_list ap1, ap2;
+
+ va_start(ap1, format);
+ va_copy(ap2, ap1);
+
+ needed = vsnprintf(&s, 1, format, ap1) + 1;
+
+ va_end(ap1);
+
+ if ((fields[index] = __ast_string_field_alloc_space(pool, needed, fields, num_fields)))
+ vsprintf((char *) fields[index], format, ap2);
+
+ va_end(ap2);
+}