From 4a9e8078b9733b572795ed8c208c45dd35e50bb0 Mon Sep 17 00:00:00 2001 From: Tilghman Lesher <tilghman@meg.abyt.es> Date: Fri, 9 Jan 2009 18:30:55 +0000 Subject: [PATCH] When using ast_str with a non-ast_str-enabled API, we need to update the buffer or otherwise, we cannot use ast_str_strlen(). git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@168090 65c4cc65-6c06-0410-ace0-fbb531ad65f3 --- include/asterisk/strings.h | 10 ++++++++++ res/res_agi.c | 1 + 2 files changed, 11 insertions(+) diff --git a/include/asterisk/strings.h b/include/asterisk/strings.h index 529456c987..bf3cf32363 100644 --- a/include/asterisk/strings.h +++ b/include/asterisk/strings.h @@ -403,6 +403,16 @@ void ast_str_reset(struct ast_str *buf), } ) +/*! \brief Update the length of the buffer, after using ast_str merely as a buffer. + * \param buf A pointer to the ast_str string. + */ +AST_INLINE_API( +void ast_str_update(struct ast_str *buf), +{ + buf->__AST_STR_USED = strlen(buf->__AST_STR_STR); +} +) + /*! \brief Trims trailing whitespace characters from an ast_str string. * \param buf A pointer to the ast_str string. */ diff --git a/res/res_agi.c b/res/res_agi.c index 926d4d95bc..6151549e30 100644 --- a/res/res_agi.c +++ b/res/res_agi.c @@ -1861,6 +1861,7 @@ static int handle_dbget(struct ast_channel *chan, AGI *agi, int argc, char **arg do { res = ast_db_get(argv[2], argv[3], ast_str_buffer(buf), ast_str_size(buf)); + ast_str_update(buf); if (ast_str_strlen(buf) < ast_str_size(buf) - 1) { break; } -- GitLab