Jump to content

Module:Sort title/sandbox: Difference between revisions

From Wikipedia, the free encyclopedia
Content deleted Content added
No edit summary
No edit summary
Line 4: Line 4:


--[[
--[[
Local function which is used to return a number without commas.
Local function which is used to return a title without its first word.
For example: 4,722 will become 4722.
--]]
--]]
local function cleanNumberFromCommas(title)
local function getTitleWithoutFirstWord(title)
return string.gsub(title, "(%d+)(,+)", "%1")
return mw.ustring.gsub(title, "^[^%s]*%s*", "")
end
end


Line 25: Line 24:


--[[
--[[
Local function which is used to return the title without its disambiguation.
Local function which is used to return a sort key for a specific part.
--]]
--]]
local function getTitleWithoutDisambiguation(title, disambiguation)
local function getSortKey(title, firstWord)
local newTitle = string.gsub(title, "%(".. disambiguation .. "%)", "")
local sortKey = title
if (isFirstWordAnArticle(firstWord) and firstWord ~= title) then
return mw.text.trim(newTitle)
title = getTitleWithoutFirstWord(title)
sortKey = title .. ", " .. firstWord
end
return sortKey
end

--TODO: DOC
local function convertRomanNumerals(romanNumerals)
local convertModule = require('Module:ConvertNumeric').roman_to_numeral
return tonumber(convertModule(romanNumerals))
end

--TODO: DOC
local function checkForRomanNumerals(title)
if (title) then
return mw.ustring.match(title, "[IVXLCDM]+")
else
return nil
end
end
end


--[[
--[[
Local function which is used to return a title without its first word.
Local function which is used to return the last word from a title.
--]]
--]]
local function getTitleWithoutFirstWord(title)
local function getLastWord(title)
return mw.ustring.gsub(title, "^[^%s]*%s*", "")
return string.match(title, "%s(%S+)$")
end
end


Line 47: Line 66:


--[[
--[[
Local function which is used to return a sort key for a specific part.
Local function which is used to return a number without commas.
For example: 4,722 will become 4722.
--]]
--]]
local function getSortKey(title, firstWord)
local function cleanNumberFromCommas(title)
return string.gsub(title, "(%d+)(,+)", "%1")
local sortKey = title
end
if (isFirstWordAnArticle(firstWord) and firstWord ~= title) then

title = getTitleWithoutFirstWord(title)
local function getTitlePartSortKey(title)
sortKey = title .. ", " .. firstWord
title = cleanNumberFromCommas(title)
local firstWord = getFirstWord(title)
local lastWord = getLastWord(title)
local romanNumerals = checkForRomanNumerals(title)
if (romanNumerals) then
local lastWordModified = convertRomanNumerals(romanNumerals)
title = string.gsub(title, lastWord, lastWordModified)
end
end
local sortKey = getSortKey(title, firstWord)
return sortKey
end
end


Line 66: Line 92:
return ""
return ""
end
end

local firstWord = getFirstWord(disambiguation)
return "(" .. getTitlePartSortKey(disambiguation) .. ")"
end
local disambiguationSortKey = getSortKey(disambiguation, firstWord)

return "(" .. disambiguationSortKey .. ")"
--[[
Local function which is used to return the title without its disambiguation.
--]]
local function getTitleWithoutDisambiguation(title, disambiguation)
local newTitle = string.gsub(title, "%(".. disambiguation .. "%)", "")
return mw.text.trim(newTitle)
end
end


Line 92: Line 124:
end
end


local firstWord = getFirstWord(title)
local disambiguation = getDisambiguation(title)
local disambiguation = getDisambiguation(title)
local disambiguationSortKey = getDisambiguationSortKey(disambiguation)
local disambiguationSortKey = getDisambiguationSortKey(disambiguation)
title = getTitleWithoutDisambiguation(title, disambiguation)
title = getTitleWithoutDisambiguation(title, disambiguation)
title = cleanNumberFromCommas(title)
title = getTitlePartSortKey(title)

title = getSortKey(title, firstWord)
local sortKey = title .. " " .. disambiguationSortKey
local sortKey = title .. " " .. disambiguationSortKey
return mw.text.trim(sortKey)
return mw.text.trim(sortKey)

Revision as of 18:44, 17 July 2019

local match = require("Module:String")._match

local p = {}

--[[
Local function which is used to return a title without its first word.
--]]
local function getTitleWithoutFirstWord(title)
	return mw.ustring.gsub(title, "^[^%s]*%s*", "")
end

--[[
Local function which is used to check if the word is an article.
Returns true if it is, false if it isn't.
--]]
local function isFirstWordAnArticle(word)
	word = string.lower(word)
	if (word == "a" or word == "an" or word == "the") then
		return true
	else
		return false
	end
end

--[[
Local function which is used to return a sort key for a specific part.
--]]
local function getSortKey(title, firstWord)
	local sortKey = title
	if (isFirstWordAnArticle(firstWord) and firstWord ~= title) then
		title = getTitleWithoutFirstWord(title)
		sortKey = title .. ", " .. firstWord
	end
	
	return sortKey
end

--TODO: DOC
local function convertRomanNumerals(romanNumerals)
	local convertModule = require('Module:ConvertNumeric').roman_to_numeral
	return tonumber(convertModule(romanNumerals))
end

--TODO: DOC
local function checkForRomanNumerals(title)
	if (title) then
		return mw.ustring.match(title, "[IVXLCDM]+")
	else
		return nil
	end
end

--[[
Local function which is used to return the last word from a title.
--]]
local function getLastWord(title)
	return string.match(title, "%s(%S+)$")
end

--[[
Local function which is used to return the first word from a title.
--]]
local function getFirstWord(title)
	return match(title, "^[^%s]*", 1, 1, false, "")
end

--[[
Local function which is used to return a number without commas.
For example: 4,722 will become 4722.
--]]
local function cleanNumberFromCommas(title)
	return string.gsub(title, "(%d+)(,+)", "%1")
end

local function getTitlePartSortKey(title)
	title = cleanNumberFromCommas(title)
	local firstWord = getFirstWord(title)
	local lastWord = getLastWord(title)
	local romanNumerals = checkForRomanNumerals(title)
	if (romanNumerals) then
		local lastWordModified = convertRomanNumerals(romanNumerals)
		title = string.gsub(title, lastWord, lastWordModified)
	end
	local sortKey = getSortKey(title, firstWord)
end

--[[
Local function which is used to return the disambiguation sort key.
--]]
local function getDisambiguationSortKey(disambiguation)
	if (disambiguation == "") then
		return ""
	end

	return "(" .. getTitlePartSortKey(disambiguation) .. ")"
end

--[[
Local function which is used to return the title without its disambiguation.
--]]
local function getTitleWithoutDisambiguation(title, disambiguation)
	local newTitle = string.gsub(title, "%(".. disambiguation .. "%)", "")
	return mw.text.trim(newTitle)
end

--[[
Local function which is used to return the disambiguation from a title.
--]]
local function getDisambiguation(title)
	local disambiguation = match(title, "%s%((.-)%)", 1, -1, false, "")
	if (disambiguation == "") then
		return ""
	else
		return disambiguation
	end
end

--[[
The main function.
--]]
local function _main(title)
	if (not title) then
		title = mw.title.getCurrentTitle().text
	end

	local disambiguation = getDisambiguation(title)
	local disambiguationSortKey = getDisambiguationSortKey(disambiguation)
	
	title = getTitleWithoutDisambiguation(title, disambiguation)
	title = getTitlePartSortKey(title)

	local sortKey = title .. " " .. disambiguationSortKey
	return mw.text.trim(sortKey)
end

--[[
Public function which allows modules to retrieve a sort key.
--]]
function p._getSortKey()
	return _main(nil)
end

--[[
Public function which allows templates to retrieve a sort key.
--]]
function p.getSortKey(frame)
	return p._main(nil) 
end

--[[
Public function which allows templates to retrieve the sort key inside a DEFAULTSORT.
--]]
function p.getDefaultSort(frame)
	local sortKey = p._main(nil)
	return frame:preprocess{text = "{{DEFAULTSORT:" .. sortKey .. "}}"} 
end

--[[
Public function which is used for testing various names and not the current page name.
--]]
function p.testcases(frame)
	local getArgs = require('Module:Arguments').getArgs
	local args = getArgs(frame)
	return _main(args[1])
end

return p