webmcp
view framework/env/trace/_render_sub_tree.lua @ 160:d5e5e8a9b79a
Added __tostring metamethod to JSON arrays and JSON objects
| author | jbe | 
|---|---|
| date | Thu Jul 31 03:57:11 2014 +0200 (2014-07-31) | 
| parents | 0de41d8e2cf8 | 
| children | 32ec28229bb5 | 
 line source
     1 local function open(class)
     2   slot.put('<li class="trace_' .. class .. '">')
     3 end
     4 local function open_head(node)
     5   slot.put('<div class="trace_head">')
     6   if node.start_hires_time and node.stop_hires_time then
     7     local total_duration = node.stop_hires_time - node.start_hires_time
     8     local child_duration = 0
     9     for i, child in ipairs(node) do
    10       if child.start_hires_time and child.stop_hires_time then
    11         child_duration = child_duration + child.stop_hires_time - child.start_hires_time
    12       end
    13     end
    14     local duration = total_duration - child_duration
    15     local start_text = math.floor(node.start_hires_time * 10000 + 0.5) / 10
    16     local total_duration_text = math.floor(total_duration * 10000 + 0.5) / 10
    17     local child_duration_text = math.floor(child_duration * 10000 + 0.5) / 10
    18     local duration_text = math.floor(duration * 10000 + 0.5) / 10
    19     slot.put('<div class="time">')
    20     slot.put('<span class="start_label">start:</span>')
    21     slot.put(" ")
    22     slot.put('<span class="start">' .. start_text .. 'ms</span>')
    23     slot.put(" | ")
    24     slot.put('<span class="duration_label">this:</span>')
    25     slot.put(" ")
    26     slot.put('<span class="duration">' .. duration_text .. 'ms</span>')
    27     slot.put(" | ")
    28     slot.put('<span class="child_duration_label">children:</span>')
    29     slot.put(" ")
    30     slot.put('<span class="child_duration">' .. child_duration_text .. 'ms</span>')
    31     slot.put(" | ")
    32     slot.put('<span class="total_duration_label">total:</span>')
    33     slot.put(" ")
    34     slot.put('<span class="total_duration">' .. total_duration_text .. 'ms</span>')
    35     slot.put('</div>')
    36   end
    37 end
    38 local function close_head()
    39   slot.put('</div>')
    40 end
    41 local function close()
    42   slot.put('</li>')
    43 end
    44 function trace._render_sub_tree(node)
    45   local function render_children(tail)
    46     if #node > 0 then
    47       slot.put('<ul class="trace_list">')
    48       for idx, child in ipairs(node) do
    49         trace._render_sub_tree(child)
    50       end
    51       if tail then
    52         slot.put(tail)
    53       end
    54       slot.put("</ul>")
    55     end
    56   end
    57   local function close_with_children()
    58     close_head()
    59     render_children()
    60     close()
    61   end
    62   local node_type = node.type
    63   if node_type == "root" then
    64     render_children()
    65   elseif node_type == "debug" then
    66     open("debug")
    67     slot.put(encode.html(node.message))
    68     close()
    69   elseif node_type == "debug_table" then
    70     open("debug")
    71     slot.put("<table>")
    72     if type(node.message) == "table" then
    73       for k, v in pairs(node.message) do
    74         slot.put("<tr><td>", encode.html(tostring(k)), "</td><td>", encode.html(tostring(v)), "</td></tr>")
    75       end
    76       slot.put("</table>")
    77     else
    78       slot.put("debug_table: not of table type")
    79     end
    80     close()
    81   elseif node_type == "traceback" then
    82     open("debug")
    83     slot.put('<pre>')
    84     slot.put(encode.html(node.message))
    85     slot.put('</pre>')
    86     close()
    87   elseif node_type == "request" then
    88     open("request")
    89     open_head(node)
    90     slot.put("REQUESTED")
    91     if node.view then
    92       slot.put(" VIEW")
    93     elseif node.action then
    94       slot.put(" ACTION")
    95     end
    96     slot.put(
    97       ": ",
    98       encode.html(node.module),
    99       "/",
   100       encode.html(node.view or node.action)
   101     )
   102     close_with_children()
   103   elseif node_type == "config" then
   104     open("config")
   105     open_head(node)
   106     slot.put('Configuration "', encode.html(node.name), '"')
   107     close_with_children()
   108   elseif node_type == "filter" then
   109     open("filter")
   110     open_head(node)
   111     slot.put(encode.html(node.path))
   112     close_with_children()
   113   elseif node_type == "view" then
   114     open("view")
   115     open_head(node)
   116     slot.put(
   117       "EXECUTE VIEW: ",
   118       encode.html(node.module),
   119       "/",
   120       encode.html(node.view)
   121     )
   122     close_with_children()
   123   elseif node_type == "action" then
   124     if
   125       node.status and (
   126         node.status == "ok" or
   127         string.find(node.status, "^ok_")
   128       )
   129     then
   130       open("action_success")
   131     elseif
   132       node.status and (
   133         node.status == "error" or
   134         string.find(node.status, "^error_")
   135       )
   136     then
   137       open("action_softfail")
   138     else
   139       open("action_neutral")
   140     end
   141     open_head(node)
   142     slot.put(
   143       "EXECUTE ACTION: ",
   144       encode.html(node.module),
   145       "/",
   146       encode.html(node.action)
   147     )
   148     close_head()
   149     if node.status == "softfail" then
   150       render_children(
   151         '<li class="trace_action_status">Status code: "' ..
   152         encode.html(node.failure_code) ..
   153         '"</li>'
   154       )
   155     else
   156       render_children()
   157     end
   158     close()
   159   elseif node_type == "redirect" then
   160     open("redirect")
   161     open_head(node)
   162     slot.put("303 REDIRECT TO VIEW: ", encode.html(node.module), "/", encode.html(node.view))
   163     close_with_children()
   164   elseif node_type == "forward" then
   165     open("forward")
   166     open_head(node)
   167     slot.put("INTERNAL FORWARD TO VIEW: ", encode.html(node.module), "/", encode.html(node.view))
   168     close_with_children()
   169   elseif node_type == "exectime" then
   170     open("exectime")
   171     open_head(node)
   172     slot.put(
   173       "Finished after " ..
   174       string.format("%.1f", extos.monotonic_hires_time() * 1000) ..
   175       ' ms (' ..
   176       string.format("%.1f", os.clock() * 1000) ..
   177       ' ms CPU)'
   178     )
   179     close_with_children()
   180   elseif node_type == "sql" then
   181     open("sql")
   182     if node.error_position then
   183       -- error position starts counting with 1
   184       local part1 = string.sub(node.command, 1, node.error_position - 1)
   185       --local part2 = string.sub(node.command, node.error_position - 1, node.error_position + 1)
   186       local part2 = string.sub(node.command, node.error_position)
   187       slot.put(encode.html(part1))
   188       slot.put('<span class="trace_error_position">⇒</span>')
   189       slot.put(encode.html(part2))
   190       --slot.put('</span>')
   191       --slot.put(encode.html(part3))
   192     else
   193       slot.put(encode.html(node.command))
   194     end
   195     close();
   196   elseif node_type == "error" then
   197     open("error")
   198     open_head(node)
   199     slot.put("UNEXPECTED ERROR")
   200     close_head()
   201     close()
   202   end
   203 end
