提交 1a603e1a 编写于 作者: A antirez

Streams: fix bug in XREAD last received ID processing.

上级 94af55c5
......@@ -524,9 +524,9 @@ void xreadCommand(client *c) {
/* Specifying "$" as last-known-id means that the client wants to be
* served with just the messages that will arrive into the stream
* starting from now. */
int id_idx = i - streams_arg - streams_count;
if (strcmp(c->argv[i]->ptr,"$") == 0) {
robj *o = lookupKeyRead(c->db,c->argv[i-streams_count]);
int id_idx = i - streams_arg - streams_count;
if (o) {
stream *s = o->ptr;
ids[id_idx] = s->last_id;
......@@ -536,7 +536,8 @@ void xreadCommand(client *c) {
}
continue;
}
if (streamParseIDOrReply(c,c->argv[i],ids+i,0) != C_OK) goto cleanup;
if (streamParseIDOrReply(c,c->argv[i],ids+id_idx,0) != C_OK)
goto cleanup;
}
/* Try to serve the client synchronously. */
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册