Trim trailing spaces in error replies coming from rejectCommand (#7668)

fe8d6fe749 added rejectCommand which takes an robj reply and passes it
through addReplyErrorSafe to addReplyErrorLength.
The robj contains newline at it's end, but addReplyErrorSafe converts it
to spaces, and passes it to addReplyErrorLength which adds the protocol
newlines.

The result was that most error replies (like OOM) had extra two trailing
spaces in them.
This commit is contained in:
Oran Agra 2020-08-18 08:28:43 +03:00 committed by GitHub
parent 2ec11f941a
commit 05a4af3464

View File

@ -412,10 +412,14 @@ void addReplyError(client *c, const char *err) {
* is emitted. */
void addReplyErrorSafe(client *c, char *s, size_t len) {
size_t j;
/* Trim any newlines at the end (ones will be added by addReplyErrorLength) */
while (s[len-1] == '\r' || s[len-1] == '\n')
len--;
/* Replace any newlines in the rest of the string with spaces. */
for (j = 0; j < len; j++) {
if (s[j] == '\r' || s[j] == '\n') s[j] = ' ';
}
addReplyErrorLength(c,s,sdslen(s));
addReplyErrorLength(c,s,len);
}
void addReplyErrorFormat(client *c, const char *fmt, ...) {