ମଡ୍ୟୁଲ:Date
Documentation for this module may be created at ମଡ୍ୟୁଲ:Date/doc
--[[
This module is intended for processing of date strings
]]
local date = {}
--[[
ISOyear
This function returns year part of date string.
Usage:
{{#invoke:Date|ISOyear|s=target_string}}
Parameters
s: The date string
If invoked using named parameters, Mediawiki will automatically remove any leading or
trailing whitespace from the target string.
]]
function date.ISOyear( frame )
local s = frame.args.s
-- if empty string then return it
if mw.ustring.len(s) == 0 then
return s
end
-- if number then return it
if tonumber( s ) then
return mw.ustring.format('%04i', s)
end
-- otherwise use regular expression match
s = mw.ustring.match( s, '(-?%d%d?%d?%d?)-' )
if s then
return mw.ustring.format('%04i', s)
else
return ''
end
end
--[[
Get the name of an era, based on Wikisource's definition.
This implements the logic of Template:What_era_is
]]
function date.era( year )
-- Unknown value.
if year == nil or tonumber( year ) == nil or string.lower( year ) == 'unknown' or year == '?' then
return 'Unknown era'
end
-- Handle numeric years.
year = tonumber( year )
if year == nil or year < 601 then
return 'Ancient'
elseif year < 1421 then
return 'Medieval'
elseif year < 1631 then
return 'Renaissance'
elseif year < 1900 then
return 'Early modern'
elseif year < ( tonumber( os.date( '%Y' ) ) + 1 ) then
return 'Modern'
else
return 'Future'
end
end
return date