lua 脚本之高级篇 (面向对象的完全支持),有性能问题。

 

 

 

----------------------------------------------------------

--面向对象核心库

----------------------------------------------------------

 

----------------------------------------------------------

--base object

object = {}

 

function object:getName()

    return "unknow"

end

 

function object:resetHashCode()

    self.__hashcode = nil

    self:getHashCode()

end

 

function object:getHashCode()

    self.__hashcode = self.__hashcode or (os.time() + math.random())

    return  self.__hashcode

end

 

----------------------------------------------

-- create interface helper

function createInterface(object,name,func)

    warning(object[name] == nil,"Interface exists,create fail" .. name)

end

 

function callInsterface(object,name,...)

    local func =  object[name]

    return func(object,...)

end

 

function callmethod(object,name,...)

    local func =  object[name]

    return func(object,...)

end

 

function implementInterface(object,name,func)

    object[name] =  func

end

 

function createAbstract(object,name,func)

    object[name] =  function(self)

        warning(false,"not implement Abstract " .. name)

        return nil

    end

end

 

function createVirtualFunction(object,name,func)

    implementInterface(object,name,func)

end

 

function override(object,name,func)

    implementInterface(object,name,func)

end

 

function sealed(object)

    object.__sealed = true

end

 

----------------------------------------------

--oop helpers

 

local function addctor(class)

    assert(class,"class is nil value")

    if class.ctor == nil then

        class.ctor = function(self) end

    end

end

 

function registerFun_getInstance(cls)

    --    warning(cls.getInstance == false,"cls has function:getInstacnce")

    cls.__instance = nil;

    cls.getInstance =function()

        if cls.__instance == nil then

            assert(cls.new and type(cls.new)== "function","not found ctor function :new");

            cls.__instance = cls:new()

            return cls.__instance

        end

        return cls.__instance

    end

end

 

---向对象中添加临时数据

function setTempVariable(object,key,value)

    assert(key,"key is a nil value")

    assert(value~=nil,"value is a nil value")

    object.__tempData = object.__tempData or  {}

    object.__tempData["__"..key] = value

end

 

---查找对象中保存的临时数据

function getTempVariable(object,key)

    assert(object,"object is a nil value")

    assert(key,"key is a nil value")

    if object.__tempData == nil then  return nil end

    return  object.__tempData["__"..key]

end

 

 

 

function callSupper(instance,supperName,name,cls,...)

 

    if instance ~= nil then

        if instance.supper  == nil then return end

        if  instance.supper[supperName] ~=nil then

            for key, var in pairs( instance.supper[supperName]) do

                if key ==  name then

                    local fun = var

                    local returnValue,e = pcall(fun,cls or instance,...)

                    assert(e==nil,e)

                    return returnValue,true

                end

            end

        else

            for key, var in pairs(instance.supper) do

                if type(var) == "table" and key~="__index" and key ~= "__child" then

                    local returnValue,result = callSupper(var,supperName,name,instance,...)

                    if result == true then return returnValue,true end

                end

            end

        end

 

        if instance.__child ~=nil then

            local returnValue,result = callSupper(instance.__child,supperName,name,cls,...)

            if result == false and instance.__child.__child then

                returnValue,result = callSupper(instance.__child.__child,supperName,name,cls,...)

            end

            return returnValue,true

        end

    end

    return nil,false

end

 

---调用基类中的函数

function callSupperA(instance,supperName,name,...)

    return callSupper(instance,supperName,name,instance,...)

end

 

local function copyAllSupper(class,base)

    if base ~= nil and class ~= nil and base.supper ~= nil then

        class.supper = class.supper or {}

        for key, var in pairs(base.supper) do

            if class.supper[key] == nil then

                class.supper[key] =  var

            end

        end

    end

end

 

--继承帮助函数

--ext:扩展类,

--base:基类

--supper name

---------------------------------------------

--@param #table ext 当前类的定义

--@param #table base 当前类的要继承的类,一般也为table

--@param #string suppername 当前继承的基类的别名

--@return #table 一个新的对旬的实列

function inheritanceA(ext,base,suppername)

    --    assert(ext,"not set ext object.")

    --    assert(base,"not set base object.")

    --    assert(base.__sealed == nil,"基类设置为了禁止继承.")

    if base.__sealed ~= nil then

        assert(base.__sealed == nil,"基类设置为了禁止继承.")

        return

    end

 

    --metatable copy

    local function setmetatableA(tag,source)

        for k,v in pairs(source) do

            if tag[k] == nil then

                if type(v) == "table" and k ~= "__index" and k~= "__child" then

                    tag[k] = {}

                    setmetatableA (tag[k],v)

                    tag[k].__index = tag[k]

                else

                    tag[k] =  v

                end

            end

        end

        return tag

    end

 

    ext = setmetatableA(ext,base)

    ext.__index = ext

    --添加自己的构造函数

    if ext.new == nil then

        function ext.new  ( self )

            local instance = {}

            setmetatableA(instance,self)

            instance.__index = instance

            instance:ctor()

            instance:resetHashCode()

            return instance,ext.supper

        end

        addctor(ext)

    end

 

    ext.supper = ext.supper or {}

    setmetatableA(ext.supper,base)

    ext.supper.__child = ext

    ext.supper.__index = ext.supper;

 

    ---添加基类的默认构造函数

    if ext.supper and ext.supper.new == nil then

        ---此逻辑的意义不大

        ext.supper.new =  ext.supper.new or function ( self )

            local instance = {}

            setmetatableA(instance,self)

            instance:resetHashCode()

            return ext.supper,ext.supper or {}

        end

        addctor(ext.supper)

    end

 

    if suppername ~= nil and type(ext.supper[suppername])~= "function" then

        ext.supper[suppername] =  ext.supper[suppername] or {}

        setmetatableA(ext.supper[suppername],base)

        ext.supper[suppername].__index = ext.supper[suppername]

    end

 

    ext.__index = ext;

    ---注册单列接口

    registerFun_getInstance(ext)

    return ext,ext.supper

end

 

---继承对象实例

--@param #table ext 当前对象的实例

--@param #table base 基类的实例

function inheritance(ext,base)

    --    assert(false,"调用本函数只能通过supper来访问,如果多少继承,只有最后一次继承的会生效")

    return inheritanceA(ext or {},base,"__supper")

end

 

---继承自model 文件

--@param #table ext 当前对象的实例

--@param #string mname 当前要继承的模块对象

function inheritanceM(ext,mname)

    local obj = require (mname)

    assert(obj~=nil,"load mode error,mode name:"..mname)

    return inheritanceA(ext,obj,mname)

end

 

return object

posted @ 2015-01-04 14:54  czjone  阅读(1029)  评论(0编辑  收藏  举报