diff options
author | Kenneth Graunke <kenneth@whitecape.org> | 2011-10-24 19:33:16 -0700 |
---|---|---|
committer | Ian Romanick <ian.d.romanick@intel.com> | 2011-10-25 17:51:43 -0700 |
commit | ca95593d49a2d99a16c160c2a04acc4be007d8a4 (patch) | |
tree | 15754272e39bd38e586b73817983dfd1dd4deed0 /src/glsl/ralloc.c | |
parent | 960d722bf7db636863a05ddf9258236fccb58ecd (diff) | |
download | external_mesa3d-ca95593d49a2d99a16c160c2a04acc4be007d8a4.zip external_mesa3d-ca95593d49a2d99a16c160c2a04acc4be007d8a4.tar.gz external_mesa3d-ca95593d49a2d99a16c160c2a04acc4be007d8a4.tar.bz2 |
ralloc: Add new [v]asprintf_rewrite_tail functions.
This can be useful if you want to create a bunch of temporary strings
with a common prefix. For example, when iterating over uniform
structure fields, one might want to create temporary strings like
"pallete.primary", "palette.outline", and "pallette.shadow".
This could be done by overwriting the '.' with a null-byte and calling
ralloc_asprintf_append, but that incurs the cost of strlen("pallete")
every time...when this is already known.
These new functions allow you rewrite the tail of the string, given a
starting index. If the starting index is the length of the string, this
is equivalent to appending.
Signed-off-by: Kenneth Graunke <kenneth@whitecape.org>
Reviewed-by: Ian Romanick <ian.d.romanick@intel.com>
Diffstat (limited to 'src/glsl/ralloc.c')
-rw-r--r-- | src/glsl/ralloc.c | 27 |
1 files changed, 23 insertions, 4 deletions
diff --git a/src/glsl/ralloc.c b/src/glsl/ralloc.c index fb48a91..2967598 100644 --- a/src/glsl/ralloc.c +++ b/src/glsl/ralloc.c @@ -439,7 +439,27 @@ ralloc_asprintf_append(char **str, const char *fmt, ...) bool ralloc_vasprintf_append(char **str, const char *fmt, va_list args) { - size_t existing_length, new_length; + assert(str != NULL); + size_t existing_length = *str ? strlen(*str) : 0; + return ralloc_vasprintf_rewrite_tail(str, existing_length, fmt, args); +} + +bool +ralloc_asprintf_rewrite_tail(char **str, size_t start, const char *fmt, ...) +{ + bool success; + va_list args; + va_start(args, fmt); + success = ralloc_vasprintf_rewrite_tail(str, start, fmt, args); + va_end(args); + return success; +} + +bool +ralloc_vasprintf_rewrite_tail(char **str, size_t start, const char *fmt, + va_list args) +{ + size_t new_length; char *ptr; assert(str != NULL); @@ -450,14 +470,13 @@ ralloc_vasprintf_append(char **str, const char *fmt, va_list args) return true; } - existing_length = strlen(*str); new_length = printf_length(fmt, args); - ptr = resize(*str, existing_length + new_length + 1); + ptr = resize(*str, start + new_length + 1); if (unlikely(ptr == NULL)) return false; - vsnprintf(ptr + existing_length, new_length + 1, fmt, args); + vsnprintf(ptr + start, new_length + 1, fmt, args); *str = ptr; return true; } |