Modulo:Infobox nave: differenze tra le versioni
Contenuto cancellato Contenuto aggiunto
r |
arrotondamento eccessivo |
||
(17 versioni intermedie di 2 utenti non mostrate) | |||
Riga 1:
local p = {}
local getArgs = require('Module:Arguments').getArgs
local error_flag = false
---============================================================
-- Save argument in table
---============================================================
local function dump(t, ...)
local args = {...}
Line 15 ⟶ 19:
local pow = idp or 0
if idp then
local mult = 10^
local adder = (num >= 0 and 0.5) or -0.5
return math.floor(num * mult + adder) / mult
Line 23 ⟶ 27:
---============================================================
-- arrotonda in base all'ordine di grandezza: 11111->11110, 1111->1111, 111->111,1
---============================================================
local function round_auto(num)
local base = - math.floor(math.log10(math.abs(num))
if base < -3 then base = -3 end
return round(num, base)
end
Line 44 ⟶ 49:
end
---============================================================
-- Convert string to number ("," are considered as ".")
---============================================================
local function get_value(txt)
local s = txt
if s then
s = s:gsub("%.(%d%d%d)", "%1" )
local try_convert = s:gsub(",", ".")
return tonumber(try_convert)
end
end
---============================================================
-- Format
-- no breaking space as separator between thousands
---============================================================
local function format_value(value)
if value then
Line 96 ⟶ 73:
end
---============================================================
-- Return formatted error message and set error_flag to true
---============================================================
local function add_error(ignore_error, msg)
if ignore_error then return '' end
error_flag = true
return '<sup class="error" style="font-size:small;">' .. msg .. '</sup>'
end
local function format_m(m1_raw, m2_raw, factor, ignore_error)
if not (m1_raw or m2_raw) then
return
Line 112 ⟶ 98:
m1_formatted = format_value(tostring(m1_value))
elseif m1_raw then
m1_formatted = m1_raw
end
if m2_value then
m2_formatted = format_value(tostring(m2_value))
elseif m2_raw then
m2_formatted = m2_raw
end
return m1_formatted, m2_formatted
end
---============================================================
-- Format speed and convert from knots to km/h (or viceversa)
---============================================================
function p.speed(frame)
local args = getArgs(frame, {frameOnly = true})
local spd_kn = args[1]
local spd_kmh = args[2]
local spd_type = args[3]
if spd_kmh == nil and spd_kn == nil then return '' end
kn_formatted, kmh_formatted = format_m(spd_kn, spd_kmh, 1.852, true)
local out = {}
if spd_type then dump(out, spd_type, ": ") end
if kn_formatted then dump(out, kn_formatted, " [[Nodo (unità di misura)|nodi]]") end
if kmh_formatted then
if kn_formatted then dump(out, " (") end
dump(out, kmh_formatted, " [[Chilometro orario|km/h]]")
if kn_formatted then dump(out, ")") end
end
return table.concat(out)
end
---============================================================
-- Format range data (knots to km/h and nmi to km, or viceversa)
---============================================================
function p.range(frame)
local args = getArgs(frame)
Line 131 ⟶ 141:
local range_kmh = args[5]
local out = {}
local nmi_formatted, km_formatted = format_m(range_nmi, range_km,
local kn_formatted, kmh_formatted = format_m(range_kn, range_kmh, 1.852
if range_type then dump(out, range_type, ":") end
if nmi_formatted then
dump(out, nmi_formatted, "
if kn_formatted then
dump(out, " a ", kn_formatted, " [[nodo (unità di misura)|nodi]]")
Line 140 ⟶ 151:
end
if km_formatted then
if
if kmh_formatted then
dump(out, " a ", kmh_formatted, " [[chilometro orario|km/h]]")
end
if
end
-- add category error if necessary
if error_flag then
local current_page = mw.title.getCurrentTitle()
if current_page.namespace == 0 then
dump(out, "[[Categoria:Errori di compilazione del template Infobox nave]]")
end
end
Line 154 ⟶ 168:
end
---============================================================
-- Format a generic list of measure
---============================================================
function p.measure(frame)
local args = getArgs(frame, {parentOnly = true})
local parameters = getArgs(frame, {frameOnly = true})
local base_arg = parameters[1]
local base_type = parameters[2] or ''
local um = parameters[3]
um = (um and (' ' .. um)) or ''
if not base_arg then return end
local elements = {}
local value_txt = args[base_arg]
if not value_txt then return end
local value = get_value(value_txt)
if value then value_txt = format_value(tostring(value)) end
local value_type = args[base_type]
value_type = (value_type and (value_type .. ": ")) or ''
elements[1] = value_type .. value_txt .. um
local n = 2
while true do
local nchar = tostring(n)
value_txt = args[base_arg .. nchar]
if value_txt then
value = get_value(value_txt)
if value then value_txt = format_value(tostring(value)) end
value_type = args[base_type .. nchar]
value_type = (value_type and (value_type .. ": ")) or ''
elements[#elements+1] = value_type .. value_txt .. um
n = n + 1
else
break
end
end
if #elements == 1 then
return elements[1]
else
return '<UL><LI>' .. mw.text.listToText(elements, '</LI>\n<LI>', '</LI>\n<LI>') .. '</LI>\n</UL>'
end
end
return p
|