--- a/src/json.c Thu Jan 16 18:56:44 2025 +0100 +++ b/src/json.c Fri Jan 17 17:41:29 2025 +0100 @@ -393,10 +393,9 @@ bool all_printable = true; for (size_t i = 0; i < str.length; i++) { - bool escape = !isprint(str.ptr[i]) - || str.ptr[i] == '\\' - || str.ptr[i] == '"' - || (escape_slash && str.ptr[i] == '/'); + unsigned char c = str.ptr[i]; + bool escape = c < 0x20 || c == '\\' || c == '"' + || (escape_slash && c == '/'); if (all_printable && escape) { size_t capa = str.length + 32; @@ -408,30 +407,29 @@ } if (escape) { cxBufferPut(&buf, '\\'); - if (str.ptr[i] == '\"') { + if (c == '\"') { cxBufferPut(&buf, '\"'); - } else if (str.ptr[i] == '\n') { + } else if (c == '\n') { cxBufferPut(&buf, 'n'); - } else if (str.ptr[i] == '\t') { + } else if (c == '\t') { cxBufferPut(&buf, 't'); - } else if (str.ptr[i] == '\r') { + } else if (c == '\r') { cxBufferPut(&buf, 'r'); - } else if (str.ptr[i] == '\\') { + } else if (c == '\\') { cxBufferPut(&buf, '\\'); - } else if (str.ptr[i] == '/') { + } else if (c == '/') { cxBufferPut(&buf, '/'); - } else if (str.ptr[i] == '\f') { + } else if (c == '\f') { cxBufferPut(&buf, 'f'); - } else if (str.ptr[i] == '\b') { + } else if (c == '\b') { cxBufferPut(&buf, 'b'); } else { char code[6]; - snprintf(code, sizeof(code), "u%04x", - (unsigned int)(0xff & str.ptr[i])); + snprintf(code, sizeof(code), "u%04x", (unsigned int) c); cxBufferPutString(&buf, code); } } else if (!all_printable) { - cxBufferPut(&buf, str.ptr[i]); + cxBufferPut(&buf, c); } } if (!all_printable) {