Integrate core C implementation
This commit is contained in:
parent
40639695cb
commit
9a203c52dd
3 changed files with 21 additions and 1 deletions
|
@ -1,2 +1,12 @@
|
|||
include ../../build/config.mk
|
||||
include ../../build/module.mk
|
||||
|
||||
%.o: %.c
|
||||
$(COMPILE) $(LUA_CFLAGS) $(FPIC) -c -o $@ $<
|
||||
|
||||
compile: src/luci_cutil.o
|
||||
mkdir -p dist$(LUCI_LIBRARYDIR)
|
||||
$(LINK) $(SHLIB_FLAGS) -o dist$(LUCI_LIBRARYDIR)/cutil.so src/luci_cutil.o
|
||||
|
||||
clean: luaclean
|
||||
rm src/*.o
|
|
@ -31,6 +31,7 @@ local debug = require "debug"
|
|||
local ldebug = require "luci.debug"
|
||||
local string = require "string"
|
||||
local coroutine = require "coroutine"
|
||||
local cutil = require "luci.cutil"
|
||||
|
||||
local getmetatable, setmetatable = getmetatable, setmetatable
|
||||
local rawget, rawset, unpack = rawget, rawset, unpack
|
||||
|
@ -44,6 +45,7 @@ module "luci.util"
|
|||
--
|
||||
-- Pythonic string formatting extension
|
||||
--
|
||||
--[[
|
||||
getmetatable("").__mod = function(a, b)
|
||||
if not b then
|
||||
return a
|
||||
|
@ -53,6 +55,7 @@ getmetatable("").__mod = function(a, b)
|
|||
return a:format(b)
|
||||
end
|
||||
end
|
||||
]]--
|
||||
|
||||
|
||||
--
|
||||
|
@ -60,6 +63,7 @@ end
|
|||
--
|
||||
|
||||
-- Instantiates a class
|
||||
--[[
|
||||
local function _instantiate(class, ...)
|
||||
local inst = setmetatable({}, {__index = class})
|
||||
|
||||
|
@ -69,6 +73,7 @@ local function _instantiate(class, ...)
|
|||
|
||||
return inst
|
||||
end
|
||||
]]--
|
||||
|
||||
--- Create a Class object (Python-style object model).
|
||||
-- The class object can be instantiated by calling itself.
|
||||
|
@ -84,12 +89,15 @@ end
|
|||
-- @return A class object
|
||||
-- @see instanceof
|
||||
-- @see clone
|
||||
--[[
|
||||
function class(base)
|
||||
return setmetatable({}, {
|
||||
__call = _instantiate,
|
||||
__index = base
|
||||
})
|
||||
end
|
||||
]]--
|
||||
class = cutil.class
|
||||
|
||||
--- Test whether the given object is an instance of the given class.
|
||||
-- @param object Object instance
|
||||
|
|
|
@ -91,11 +91,13 @@ static int luci__instantiate(lua_State *L) {
|
|||
|
||||
/* luci.cutil.class(baseclass) */
|
||||
static int luci_class(lua_State *L) {
|
||||
int n = lua_gettop(L);
|
||||
|
||||
/* Create class */
|
||||
lua_newtable(L);
|
||||
|
||||
/* Create metatable and register parent class if any */
|
||||
if (lua_istable(L, 1)) {
|
||||
if (n && lua_istable(L, 1)) {
|
||||
lua_createtable(L, 0, 2);
|
||||
lua_pushvalue(L, 1);
|
||||
lua_setfield(L, -2, "__index");
|
||||
|
|
Loading…
Reference in a new issue