Better number formating

Is it 120000 or 1200000?
This commit is contained in:
est31 2015-01-31 04:16:11 +01:00 committed by Vanessa Ezekowitz
parent 0c3f55e0c9
commit d9bf9830b0
6 changed files with 54 additions and 5 deletions

@ -1,3 +1,16 @@
--load config
local sepchar, baresepchar = nil, nil
do
local sepcode = technic.config:get("thousand_separator")
--default is SI style
sepchar = sepcode and string.char(sepcode) or " "
baresepchar = sepchar
--handling if sepchar is magic...
for magic in string.gmatch("().%+-*?[^$", ".") do
if sepchar == magic then sepchar = "%"..sepchar end
end
end
-- Only changes name, keeps other params
function technic.swap_node(pos, name)
local node = minetest.get_node(pos)
@ -44,3 +57,39 @@ function technic.get_or_load_node(pos)
local MinEdge, MaxEdge = vm:read_from_map(pos, pos)
return nil
end
function technic.format(str, ...)
local arg={...}
local param = nil
local percent = false
local res = ""
local i = 1
for c in str:gmatch"." do
if percent then
assert(c ~= "%") --syntax error
if c == "e" then
-- use enhanced number formatting
-- only works for unsigned numbers
local numstr = tostring(math.abs(arg[i]))
local a, b, body, frac = numstr:find("^(%d+)([.]?.-)$")
a = 1
body = body..baresepchar
while a ~= 0 do
body, a = body:gsub("(%d)(%d%d%d)"..sepchar, "%1"..sepchar.."%2"..sepchar, 1)
end
body = body:gsub(sepchar.."$", "")
res = res .. body .. frac
else
--use traditional string:format
res = res .. (string.format(("%"..c), arg[i]))
i = i + 1
end
percent = false
elseif c == "%" then
percent = true
else
res = res .. c
end
end
return res
end

@ -24,7 +24,7 @@ local run = function(pos, node)
local charge_to_give = math.floor((light + pos1.y) * 3)
charge_to_give = math.max(charge_to_give, 0)
charge_to_give = math.min(charge_to_give, 200)
meta:set_string("infotext", S("%s Active"):format(machine_name).." ("..charge_to_give.."EU)")
meta:set_string("infotext", technic.format(S("%s Active (%e EU)"), machine_name, charge_to_give))
meta:set_int("LV_EU_supply", charge_to_give)
else
meta:set_string("infotext", S("%s Idle"):format(machine_name))

@ -55,7 +55,7 @@ local run = function(pos, node)
meta:set_int("MV_EU_supply", power)
end
meta:set_string("infotext", machine_name.." ("..power.."EU)")
meta:set_string("infotext", technic.format("%s (%eEU)", machine_name, power))
end
minetest.register_node("technic:wind_mill", {

@ -142,7 +142,7 @@ function technic.register_battery_box(data)
.."^[lowpart:"..charge_percent
..":technic_power_meter_fg.png]")
local infotext = S("%s Battery Box: %d/%d"):format(tier,
local infotext = technic.format(S("%s Battery Box: %e/%e"), tier,
current_charge, max_charge)
if eu_input == 0 then
infotext = S("%s Idle"):format(infotext)

@ -28,7 +28,7 @@ function technic.register_solar_array(data)
local charge_to_give = math.floor((light + pos.y) * data.power)
charge_to_give = math.max(charge_to_give, 0)
charge_to_give = math.min(charge_to_give, data.power * 50)
meta:set_string("infotext", S("%s Active"):format(machine_name).." ("..charge_to_give.."EU)")
meta:set_string("infotext", technic.format(S("%s Active (%e EU)"), machine_name, charge_to_give))
meta:set_int(tier.."_EU_supply", charge_to_give)
else
meta:set_string("infotext", S("%s Idle"):format(machine_name))

@ -291,7 +291,7 @@ minetest.register_abm({
--dprint("Total BA demand:"..BA_eu_demand)
meta:set_string("infotext",
S("%s. Supply: %d Demand: %d"):format(
technic.format(S("%s. Supply: %e Demand: %e"),
machine_name, PR_eu_supply, RE_eu_demand))
-- If the PR supply is enough for the RE demand supply them all