Streams: XTRIM will return an error if MAXLEN with a count < 0

This commit is contained in:
zhaozhao.zz 2018-07-18 00:12:24 +08:00
parent 20c6a7fe2c
commit da6b7516f1

View File

@ -2192,7 +2192,7 @@ void xtrimCommand(client *c) {
/* Argument parsing. */
int trim_strategy = TRIM_STRATEGY_NONE;
long long maxlen = 0; /* 0 means no maximum length. */
long long maxlen = -1; /* If left to -1 no trimming is performed. */
int approx_maxlen = 0; /* If 1 only delete whole radix tree nodes, so
the maxium length is not applied verbatim. */
@ -2211,6 +2211,11 @@ void xtrimCommand(client *c) {
}
if (getLongLongFromObjectOrReply(c,c->argv[i+1],&maxlen,NULL)
!= C_OK) return;
if (maxlen < 0) {
addReplyError(c,"The MAXLEN argument must be >= 0.");
return;
}
i++;
} else {
addReply(c,shared.syntaxerr);