diff options
author | Determinant <[email protected]> | 2015-05-25 16:20:50 +0800 |
---|---|---|
committer | Determinant <[email protected]> | 2015-05-25 16:20:50 +0800 |
commit | 7dadb31a364c3dbe30c05c9a9040c48f1d4a9095 (patch) | |
tree | 6be00c4735f66e478d41936accaefb857b0f431e | |
parent | f6c23565901561cfe1d7c3c29266ee60ce1f7bdd (diff) |
add comments to nerv.c
-rw-r--r-- | nerv.c | 10 | ||||
-rw-r--r-- | nerv.lua | 2 |
2 files changed, 11 insertions, 1 deletions
@@ -17,8 +17,18 @@ void nerv_utils_init(lua_State *L) { int luaopen_libnerv(lua_State *L) { lua_newtable(L); + /* duplicate table */ lua_pushvalue(L, -1); + /* set table to global index */ lua_setfield(L, LUA_GLOBALSINDEX, "nerv"); + /* A table reference still remains. + * + * The following initialization functions should obey to the rule that they + * maintain the stack properly to guarantee the stack stays the same before + * and after invoking the call (i.e. stay balanced). + * + * Also note that they can make use of the value at top of the stack which + * references to the `nerv` global table. */ nerv_utils_init(L); nerv_point_init(L); nerv_matrix_init(L); @@ -1,7 +1,6 @@ require 'libnerv' require 'matrix.init' require 'io.init' --- nerv.class = require 'pl.class' nerv.utils = require 'pl.utils' function nerv.error(fmt, ...) @@ -12,6 +11,7 @@ function nerv.error_method_not_implement() nerv.error("method not implemented"); end +-- Torch C API wrapper function nerv.class(tname, parenttname) local function constructor(...) |