BUG/MINOR: hlua: Fix Channel.line and Channel.data behavior regarding the doc
These both functions are buggy and don't respect the documentation. They
must wait for more data, if possible.
For Channel.data(), it must happen if not enough data was received orf if no
length was specified and no data was received. The first case is properly
handled but not the second one. An empty string is return instead. In
addition, if there is no data and the channel can't receive more data, 'nil'
value must be returned.
In the same spirit, for Channel.line(), we must try to wait for more data
when no line is found if not enough data was received or if no length was
specified. Here again, only the first case is properly handled. And for this
function too, 'nil' value must be returned if there is no data and the
channel can't receive more data.
This patch is related to the issue #1993. It must be backported as far as
2.5.
(cherry picked from commit 0ae2e63d85
)
Signed-off-by: Willy Tarreau <w@1wt.eu>
(cherry picked from commit 08554a4669b92f4d6c988a7dd4fd318c9e8ec903)
Signed-off-by: Christopher Faulet <cfaulet@haproxy.com>
This commit is contained in:
parent
48bb2f41aa
commit
c79c7f4912
26
src/hlua.c
26
src/hlua.c
@ -3214,11 +3214,22 @@ __LJMP static int hlua_channel_get_data_yield(lua_State *L, int status, lua_KCon
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (offset + len > output + input) {
|
/* Wait for more data if possible if no length was specified and there
|
||||||
|
* is no data or not enough data was received.
|
||||||
|
*/
|
||||||
|
if (!len || offset + len > output + input) {
|
||||||
if (!HLUA_CANT_YIELD(hlua_gethlua(L)) && !channel_input_closed(chn) && channel_may_recv(chn)) {
|
if (!HLUA_CANT_YIELD(hlua_gethlua(L)) && !channel_input_closed(chn) && channel_may_recv(chn)) {
|
||||||
/* Yield waiting for more data, as requested */
|
/* Yield waiting for more data, as requested */
|
||||||
MAY_LJMP(hlua_yieldk(L, 0, 0, hlua_channel_get_data_yield, TICK_ETERNITY, 0));
|
MAY_LJMP(hlua_yieldk(L, 0, 0, hlua_channel_get_data_yield, TICK_ETERNITY, 0));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* Return 'nil' if there is no data and the channel can't receive more data */
|
||||||
|
if (!len) {
|
||||||
|
lua_pushnil(L);
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Otherwise, return all data */
|
||||||
len = output + input - offset;
|
len = output + input - offset;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -3287,11 +3298,22 @@ __LJMP static int hlua_channel_get_line_yield(lua_State *L, int status, lua_KCon
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (offset + len > output + input) {
|
/* Wait for more data if possible if no line is found and no length was
|
||||||
|
* specified or not enough data was received.
|
||||||
|
*/
|
||||||
|
if (lua_gettop(L) != 3 || offset + len > output + input) {
|
||||||
if (!HLUA_CANT_YIELD(hlua_gethlua(L)) && !channel_input_closed(chn) && channel_may_recv(chn)) {
|
if (!HLUA_CANT_YIELD(hlua_gethlua(L)) && !channel_input_closed(chn) && channel_may_recv(chn)) {
|
||||||
/* Yield waiting for more data */
|
/* Yield waiting for more data */
|
||||||
MAY_LJMP(hlua_yieldk(L, 0, 0, hlua_channel_get_line_yield, TICK_ETERNITY, 0));
|
MAY_LJMP(hlua_yieldk(L, 0, 0, hlua_channel_get_line_yield, TICK_ETERNITY, 0));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* Return 'nil' if there is no data and the channel can't receive more data */
|
||||||
|
if (!len) {
|
||||||
|
lua_pushnil(L);
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Otherwise, return all data */
|
||||||
len = output + input - offset;
|
len = output + input - offset;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user