Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/libexec/httpd Cosmetic changes to Lua binding in bozohttpd.
details: https://anonhg.NetBSD.org/src/rev/9c16ad23a254
branches: trunk
changeset: 353933:9c16ad23a254
user: alnsn <alnsn%NetBSD.org@localhost>
date: Sun May 28 22:37:36 2017 +0000
description:
Cosmetic changes to Lua binding in bozohttpd.
- Don't use negative indicies to read arguments of Lua functions.
- On error, return nil, "error string".
- Use ssize_t for return values from bozo_read() and bozo_write().
- Prefer lstring especially when if saves you from appending NUL and
doing len + 1 which can potentially wraparound.
- Don't mix C allocations with Lua functions marked with "m" in the Lua
manual. Those functions may throw (longjump) and leak data allocated
by C function. In one case, I use luaL_Buffer, in the other case,
I rearranged calls a bit.
diffstat:
libexec/httpd/lua-bozo.c | 109 ++++++++++++++++++++++++----------------------
1 files changed, 57 insertions(+), 52 deletions(-)
diffs (169 lines):
diff -r 8c41495ffbde -r 9c16ad23a254 libexec/httpd/lua-bozo.c
--- a/libexec/httpd/lua-bozo.c Sun May 28 21:36:18 2017 +0000
+++ b/libexec/httpd/lua-bozo.c Sun May 28 22:37:36 2017 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: lua-bozo.c,v 1.14 2015/12/28 07:37:59 mrg Exp $ */
+/* $NetBSD: lua-bozo.c,v 1.15 2017/05/28 22:37:36 alnsn Exp $ */
/*
* Copyright (c) 2013 Marc Balmer <marc%msys.ch@localhost>
@@ -51,22 +51,8 @@
#define FORM "application/x-www-form-urlencoded"
-static int
-lua_flush(lua_State *L)
-{
- bozohttpd_t *httpd;
-
- lua_pushstring(L, "bozohttpd");
- lua_gettable(L, LUA_REGISTRYINDEX);
- httpd = lua_touserdata(L, -1);
- lua_pop(L, 1);
-
- bozo_flush(httpd, stdout);
- return 0;
-}
-
-static int
-lua_print(lua_State *L)
+static bozohttpd_t *
+httpd_instance(lua_State *L)
{
bozohttpd_t *httpd;
@@ -75,56 +61,72 @@
httpd = lua_touserdata(L, -1);
lua_pop(L, 1);
- bozo_printf(httpd, "%s\r\n", lua_tostring(L, -1));
+ return httpd;
+}
+
+static int
+lua_flush(lua_State *L)
+{
+ bozohttpd_t *httpd = httpd_instance(L);
+
+ bozo_flush(httpd, stdout);
+ return 0;
+}
+
+static int
+lua_print(lua_State *L)
+{
+ bozohttpd_t *httpd = httpd_instance(L);
+
+ bozo_printf(httpd, "%s\r\n", lua_tostring(L, 1));
return 0;
}
static int
lua_read(lua_State *L)
{
- bozohttpd_t *httpd;
- int n, len;
+ bozohttpd_t *httpd = httpd_instance(L);
+ luaL_Buffer lbuf;
char *data;
+ lua_Integer len;
+ ssize_t n;
- lua_pushstring(L, "bozohttpd");
- lua_gettable(L, LUA_REGISTRYINDEX);
- httpd = lua_touserdata(L, -1);
- lua_pop(L, 1);
+ len = luaL_checkinteger(L, 1);
+ data = luaL_buffinitsize(L, &lbuf, (size_t)len);
- len = luaL_checkinteger(L, -1);
- data = bozomalloc(httpd, len + 1);
- n = bozo_read(httpd, STDIN_FILENO, data, len);
- if (n >= 0) {
- data[n] = '\0';
- lua_pushstring(L, data);
- } else
+ if ((n = bozo_read(httpd, STDIN_FILENO, data, len)) >= 0) {
+ luaL_pushresultsize(&lbuf, n);
+ return 1;
+ } else {
lua_pushnil(L);
- free(data);
- return 1;
+ lua_pushstring(L, "bozo_read() call failed");
+ return 2;
+ }
}
static int
lua_register_handler(lua_State *L)
{
+ bozohttpd_t *httpd = httpd_instance(L);
lua_state_map_t *map;
lua_handler_t *handler;
- bozohttpd_t *httpd;
+ const char *name;
+ int ref;
lua_pushstring(L, "lua_state_map");
lua_gettable(L, LUA_REGISTRYINDEX);
map = lua_touserdata(L, -1);
- lua_pushstring(L, "bozohttpd");
- lua_gettable(L, LUA_REGISTRYINDEX);
- httpd = lua_touserdata(L, -1);
- lua_pop(L, 2);
+ lua_pop(L, 1);
+
+ name = luaL_checkstring(L, 1);
- luaL_checkstring(L, 1);
luaL_checktype(L, 2, LUA_TFUNCTION);
+ lua_pushvalue(L, 2);
+ ref = luaL_ref(L, LUA_REGISTRYINDEX);
handler = bozomalloc(httpd, sizeof(lua_handler_t));
-
- handler->name = bozostrdup(httpd, NULL, lua_tostring(L, 1));
- handler->ref = luaL_ref(L, LUA_REGISTRYINDEX);
+ handler->name = bozostrdup(httpd, NULL, name);
+ handler->ref = ref;
SIMPLEQ_INSERT_TAIL(&map->handlers, handler, h_next);
httpd->process_lua = 1;
return 0;
@@ -133,23 +135,26 @@
static int
lua_write(lua_State *L)
{
- bozohttpd_t *httpd;
+ bozohttpd_t *httpd = httpd_instance(L);
const char *data;
+ size_t len;
+ ssize_t n;
- lua_pushstring(L, "bozohttpd");
- lua_gettable(L, LUA_REGISTRYINDEX);
- httpd = lua_touserdata(L, -1);
- lua_pop(L, 1);
-
- data = luaL_checkstring(L, -1);
- lua_pushinteger(L, bozo_write(httpd, STDIN_FILENO, data, strlen(data)));
- return 1;
+ data = luaL_checklstring(L, 1, &len);
+ if ((n = bozo_write(httpd, STDIN_FILENO, data, len)) >= 0) {
+ lua_pushinteger(L, n);
+ return 1;
+ } else {
+ lua_pushnil(L);
+ lua_pushstring(L, "bozo_write() call failed");
+ return 2;
+ }
}
static int
luaopen_httpd(lua_State *L)
{
- struct luaL_Reg functions[] = {
+ static struct luaL_Reg functions[] = {
{ "flush", lua_flush },
{ "print", lua_print },
{ "read", lua_read },
Home |
Main Index |
Thread Index |
Old Index