Content added Content deleted
(get arguments from the parent frame if the current frame doesn't have any) |
(tweak logic to make it work like the actual template - the documentation was slightly wrong) |
||
Line 1: | Line 1: | ||
local p = {} |
local p = {} |
||
function p.yesno(frame) |
function p.yesno(frame) |
||
-- defaults |
-- defaults |
||
local retvals = { |
local retvals = { |
||
Line 9: | Line 9: | ||
["¬"] = "" |
["¬"] = "" |
||
} |
} |
||
-- Allow arguments to override defaults. |
-- Allow arguments to override defaults. |
||
-- 'any' tracks the presence of any arguments at all. |
-- 'any' tracks the presence of any arguments at all. |
||
Line 27: | Line 27: | ||
end |
end |
||
end |
end |
||
val = args[1] |
val = args[1] |
||
-- |
-- First deal with the case if val is nil, then deal with other cases. |
||
⚫ | |||
-- only when no params were provided. If any params at all were present, |
|||
-- the value must be considered blank. A bit weird, if you ask me. |
|||
⚫ | |||
return retvals['¬'] |
return retvals['¬'] |
||
end |
end |
||
val = |
val = val:lower() -- Coerce to blank if nil; make lowercase. |
||
val = val:match'^%s*(.*%S)' or '' -- Trim whitespace. |
val = val:match'^%s*(.*%S)' or '' -- Trim whitespace. |
||
if val == '' then |
if val == '' then |
||
return |
return retvals['blank'] or retvals['no'] |
||
elseif val == 'n' or val == 'no' or val == '0' then |
elseif val == 'n' or val == 'no' or val == '0' then |
||
return retvals['no'] |
return retvals['no'] |
||
Line 50: | Line 48: | ||
end |
end |
||
end |
end |
||
return p |
return p |