4,599
edits
No edit summary Tag: Manual revert |
No edit summary Tag: Manual revert |
||
| (39 intermediate revisions by the same user not shown) | |||
| Line 16: | Line 16: | ||
local orgiArgs = frame.args | local orgiArgs = frame.args | ||
local args = {} | local args = {} | ||
if orgiArgs[1] == "{{{1}}}" or orgiArgs[2] == "{{{2}}}" or orgiArgs[4] == "{{{3}}}" then | |||
return error("Missing a parameter") | |||
end | |||
for k, v in pairs(orgiArgs) do | for k, v in pairs(orgiArgs) do | ||
v = v:match('^%s*(.-)%s*$') | v = v:match('^%s*(.-)%s*$') | ||
| Line 35: | Line 38: | ||
--Takes a short form date and converts it to a long form, and marks if it is only a year, or a month and year | --Takes a short form date and converts it to a long form, and marks if it is only a year, or a month and year | ||
function convertShortDate( | function convertShortDate(shortDate, calendar) | ||
--In place of a long if elseif, I've put all the months into a single variable, with each in its numerical place. | --In place of a long if elseif, I've put all the months into a single variable, with each in its numerical place. | ||
--This also allows us to add other calendars here | --This also allows us to add other calendars here | ||
| Line 50: | Line 53: | ||
--Takes the provided variable and seperates it out into a table | --Takes the provided variable and seperates it out into a table | ||
--Also marks if it is only a year or a month and year | --Also marks if it is only a year or a month and year | ||
local shortDate = Split(shortDate, "-") | |||
if | if shortDate[2] == nil then | ||
dateTable = {nil, nil, nil, tonumber(shortDate[1]), "year"} | |||
elseif | elseif shortDate[3] == nil then | ||
dateTable = {monthNames[tonumber(shortDate[1])], tonumber(shortDate[1]), nil, tonumber(shortDate[2]), "month-year"} | |||
else | else | ||
dateTable = {monthNames[tonumber(shortDate[1])], tonumber(shortDate[1]), tonumber(shortDate[2]), tonumber(shortDate[3]), "month-day-year"} | |||
end | end | ||
return dateTable | |||
return | |||
end | end | ||
--Writes that date based on what is given. | --Writes that date based on what is given. | ||
function writeDate( | function writeDate(dateTable) | ||
if | if dateTable[5] == "year" then | ||
return | return dateTable[4] | ||
elseif | elseif dateTable[5] == "month-year" then | ||
return | return dateTable[1].." ("..dateTable[2]..") "..dateTable[4] | ||
elseif | elseif dateTable[5] == "month-day-year" then | ||
return | return dateTable[1].." ("..dateTable[2]..") "..dateTable[3]..", "..dateTable[4] | ||
end | end | ||
end | end | ||
| Line 82: | Line 84: | ||
--Calculates a persons age using the specified calendar | --Calculates a persons age using the specified calendar | ||
function p._age(args) | function p._age(args) | ||
local birthDate = convertShortDate(args[1], args[4]) | |||
secondDate = args[2] | local secondDate = convertShortDate(args[2], args[4]) | ||
local status = args[3] | |||
--Checks which math formula to use, based on how much of the date there is. | --Checks which math formula to use, based on how much of the date there is. | ||
if | if birthDate[5] == "year" or secondDate == "year" then | ||
age = math.floor(secondDate[4] - birthDate[4]) | |||
elseif birthDate[5] == "month-year" or secondDate == "month-year" then | |||
if birthDate[2] <= secondDate[2] then | |||
age = math.floor(secondDate[4] - birthDate[4]) | |||
elseif birthDate[2] > secondDate[2] then | |||
age = math.floor(secondDate[4] - birthDate[4] - 1) | |||
end | |||
elseif birthDate[5] == "month-day-year" or secondDate == "month-day-year" then | |||
if birthDate[2] < secondDate[2] then | |||
age = math.floor(secondDate[4] - birthDate[4]) | |||
elseif birthDate[2] == secondDate[2] then | |||
if birthDate[3] <= secondDate[3] then | |||
age = math.floor(secondDate[4] - birthDate[4]) | |||
elseif birthDate[3] > secondDate[3] then | |||
age = math.floor(secondDate[4] - birthDate[4] - 1) | |||
end | |||
elseif birthDate[2] > secondDate[2] then | |||
age = math.floor(secondDate[4] - birthDate[4] - 1) | |||
end | |||
end | end | ||
--Determines if age or aged is required | --Determines if age or aged is required | ||
if status == "alive" then | if status == "alive" then | ||
local longDate = writeDate(birthDate) | |||
return longDate.." (age "..age..")" | |||
elseif status == "dead" then | elseif status == "dead" then | ||
return writeDate(secondDate).." (aged "..age..")" | return writeDate(secondDate).." (aged "..age..")" | ||