diff options
author | Wuzzy <almikes@aol.com> | 2016-12-17 13:27:24 +0100 |
---|---|---|
committer | Wuzzy <almikes@aol.com> | 2016-12-17 13:27:24 +0100 |
commit | e0c33f6db8af1a5d75c4634ad4a12170c035ce96 (patch) | |
tree | 67cab7456c49bc2749d45d8a97b5792072afc1ef | |
parent | 233e84438f304000048194f4a5b0766f4f2137bc (diff) |
Fix bad comparison of uses and mintime
-rw-r--r-- | init.lua | 40 |
1 files changed, 26 insertions, 14 deletions
@@ -919,34 +919,40 @@ doc.new_category("tools", { sorting = "function", -- Roughly sort tools based on their capabilities. Tools which dig the same stuff end up in the same group sorting_data = function(entry1, entry2) + local entries = { entry1, entry2 } -- Hand beats all - if entry1.eid == "" then return true end - if entry2.eid == "" then return false end + if entries[1].eid == "" then return true end + if entries[2].eid == "" then return false end -- No tool capabilities = instant loser - if entry1.data.def.tool_capabilities == nil then return false end - if entry2.data.def.tool_capabilities == nil then return true end + if entries[1].data.def.tool_capabilities == nil then return false end + if entries[2].data.def.tool_capabilities == nil then return true end local comp = {} - comp[1] = {} - comp[2] = {} - comp[1].gc = entry1.data.def.tool_capabilities.groupcaps - comp[2].gc = entry2.data.def.tool_capabilities.groupcaps + for e=1, 2 do + comp[e] = {} + comp[e].gc = entries[e].data.def.tool_capabilities.groupcaps + end -- No group capabilities = instant loser if comp[1].gc == nil then return false end if comp[2].gc == nil then return true end for e=1, 2 do local groups = {} local gc = comp[e].gc - local group, mintime + local group, mintime = nil, nil local groupcount = 0 - local uses + local uses = nil for k,v in pairs(gc) do + local maxlevel = v.maxlevel + if maxlevel == nil then + maxlevel = 1 + end if groupcount == 0 then group = k - uses = v.uses + uses = v.uses * math.pow(3, v.maxlevel) end for rating, time in pairs(v.times) do - if mintime == nil or time < mintime then - mintime = time + local realtime = time / v.maxlevel + if mintime == nil or realtime < mintime then + mintime = realtime end end if groups[k] ~= true then @@ -957,7 +963,13 @@ doc.new_category("tools", { comp[e].count = groupcount comp[e].group = group comp[e].mintime = mintime - comp[e].uses = uses + if uses then + comp[e].uses = uses + elseif type(entries[e].data.def._doc_items_durability) == "number" then + comp[e].uses = entries[e].data.def._doc_items_durability + else + comp[e].uses = 0 + end end -- We want to sort out digging tools with multiple capabilities |