diff options
Diffstat (limited to 'lualibs-trac-inf.lua')
| -rw-r--r-- | lualibs-trac-inf.lua | 29 | 
1 files changed, 23 insertions, 6 deletions
| diff --git a/lualibs-trac-inf.lua b/lualibs-trac-inf.lua index eefc15a..79cbdba 100644 --- a/lualibs-trac-inf.lua +++ b/lualibs-trac-inf.lua @@ -11,20 +11,24 @@ if not modules then modules = { } end modules ['trac-inf'] = {  -- get warnings about assignments. This is more efficient than using rawset  -- and rawget. -local type, tonumber = type, tonumber +local type, tonumber, select = type, tonumber, select  local format, lower = string.format, string.lower  local concat = table.concat  local clock = os.gettimeofday or os.clock -- should go in environment -statistics       = statistics or { } -local statistics = statistics +local setmetatableindex = table.setmetatableindex +local serialize         = table.serialize +local formatters        = string.formatters -statistics.enable    = true -statistics.threshold = 0.01 +statistics              = statistics or { } +local statistics        = statistics + +statistics.enable       = true +statistics.threshold    = 0.01  local statusinfo, n, registered, timers = { }, 0, { }, { } -table.setmetatableindex(timers,function(t,k) +setmetatableindex(timers,function(t,k)      local v = { timing = 0, loadtime = 0 }      t[k] = v      return v @@ -178,6 +182,19 @@ function statistics.timed(action)      report("total runtime: %s",elapsedtime("run"))  end +-- goodie + +function statistics.tracefunction(base,tag,...) +    for i=1,select("#",...) do +        local name = select(i,...) +        local stat = { } +        local func = base[name] +        setmetatableindex(stat,function(t,k) t[k] = 0 return 0 end) +        base[name] = function(n,k,v) stat[k] = stat[k] + 1 return func(n,k,v) end +        statistics.register(formatters["%s.%s"](tag,name),function() return serialize(stat,"calls") end) +    end +end +  -- where, not really the best spot for this:  commands = commands or { } | 
