X-Git-Url: https://git.notmuchmail.org/git?p=notmuch;a=blobdiff_plain;f=json.c;h=f90b0fa245324204347070d870ac22257e0d6f95;hp=96141433d578b037aa9dbd2217ccb6ff40ecad04;hb=a48f3687785b2c138b2c47848bd05512fc893a0b;hpb=cfa95eec27b3002b22bb7e1734b90fbbbff2c284 diff --git a/json.c b/json.c index 96141433..f90b0fa2 100644 --- a/json.c +++ b/json.c @@ -47,29 +47,39 @@ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN * THE SOFTWARE. */ + char * -json_quote_str(const void *ctx, const char *str) +json_quote_chararray(const void *ctx, const char *str, const size_t len) { const char *ptr; char *ptr2; char *out; - int len = 0; + size_t loop; + size_t required; - if (!str) - return NULL; + if (len == 0) + return (char *)"\"\""; - for (ptr = str; *ptr; len++, ptr++) { + for (loop = 0, required = 0, ptr = str; + loop < len; + loop++, required++, ptr++) { if (*ptr < 32 || *ptr == '\"' || *ptr == '\\') - len++; + required++; } - out = talloc_array (ctx, char, len + 3); + /* + * + 3 for: + * - leading quotation mark, + * - trailing quotation mark, + * - trailing NULL. + */ + out = talloc_array (ctx, char, required + 3); ptr = str; ptr2 = out; *ptr2++ = '\"'; - while (*ptr) { + for (loop = 0; loop < len; loop++) { if (*ptr > 31 && *ptr != '\"' && *ptr != '\\') { *ptr2++ = *ptr++; } else { @@ -91,3 +101,9 @@ json_quote_str(const void *ctx, const char *str) return out; } + +char * +json_quote_str(const void *ctx, const char *str) +{ + return (json_quote_chararray (ctx, str, strlen (str))); +}