Difference between revisions of "Module:Language"

From Feed The Beast Wiki
Jump to: navigation, search
m (Reverted edits by Xbony2 (talk) to last revision by TheSatanicSanta)
Tag: Rollback
m
 
(2 intermediate revisions by the same user not shown)
Line 1: Line 1:
local langNames = mw.loadData( [[Module:Language/Names]] )
+
local langNames = require( [[Module:Language/Names]] )
local code = function( title )
+
local processArgs = require( [[Module:ProcessArgs]] )
  +
local subPage = ( title or mw.title.getCurrentTitle() ).subpageText:lower()
 
  +
local function code( title )
 
local titleObj = title or mw.title.getCurrentTitle()
  +
if not titleObj.isSubpage then
  +
return nil
 
end
  +
local subPage = titleObj.subpageText:lower()
 
if langNames[subPage] then
 
if langNames[subPage] then
 
return subPage
 
return subPage
 
end
 
end
 
end
 
end
local pageSuffix = function()
+
local function pageSuffix()
 
local langCode = code()
 
local langCode = code()
 
if langCode then
 
if langCode then
Line 16: Line 22:
 
local p = {}
 
local p = {}
   
  +
-- See {{L}}
 
p.link = function( f )
 
p.link = function( f )
local args = f or {}
+
local args = processArgs.normDefault( f )
if f == mw.getCurrentFrame() then
 
args = f:getParent().args
 
end
 
 
 
 
-- Get language suffix for links
 
-- Get language suffix for links
Line 28: Line 32:
 
 
 
local page = args[1] .. pageSuffix()
 
local page = args[1] .. pageSuffix()
  +
 
-- Get page name with suffix
 
-- Get page name with suffix
 
if args.dest then
 
if args.dest then
 
return page
 
return page
 
end
 
end
  +
 
-- Get page link with suffix and specified text
 
-- Get page link with suffix and specified text
 
return '[[' .. page .. '|' .. ( args.o or args[2] or args[1] ) .. ']]'
 
return '[[' .. page .. '|' .. ( args.o or args[2] or args[1] ) .. ']]'
 
end
 
end
   
  +
-- See {{Language}}
 
p.name = function( f )
 
p.name = function( f )
local args = f
+
local args = processArgs.normDefault( f )
if f == mw.getCurrentFrame() then
 
args = f:getParent().args
 
end
 
 
 
local langCode = code( args[1] and mw.title.new( args[1] ) ) or 'en'
+
local langCode = args[1] or 'en'
 
 
 
-- Get language code for specified title or current page
 
-- Get language code for specified title or current page
Line 50: Line 54:
 
 
 
local langName = langNames[langCode]
 
local langName = langNames[langCode]
  +
-- Get language name
 
  +
-- Get language name in English if the 2nd arg or 'en' arg is set
if args.en then
 
  +
if (args[2] and args[2] ~= '') or (args.en and args.en ~= '') then
 
return langName[1]
 
return langName[1]
 
end
 
end
  +
-- Get native name
 
 
-- Get language name in that language (autonym)
 
return langName[2]
 
return langName[2]
 
end
 
end
   
  +
-- See {{ML}}
-- This is not a communist function
 
p.modlink = function(f)
+
p.modlink = function( f )
local args = f or {}
+
local args = processArgs.normDefault( f )
if f == mw.getCurrentFrame() then
 
args = f:getParent().args
 
end
 
 
 
local name = require([[Module:Mods]]).getName(args[2])
+
local modname = require([[Module:Mods]]).getData(args[2]).name
 
 
if not name then
+
if not modname then
 
return 'No mod found'
 
return 'No mod found'
 
end
 
end
 
 
  +
local disambiguated = string.format("%s (%s)", args[1], modname)
args[2] = args[1]
 
  +
args[1] = args[1] .. ' (' .. name .. ')'
 
  +
return p.link{disambiguated, args.title or args[1]}
 
end
  +
  +
p.code = function( f )
  +
local args = processArgs.normDefault( f )
  +
  +
-- 'de' and 'Main Page/de' will be correctly processed regardless of the arg name
  +
-- These aliases are mainly to keep a standard
  +
local selected = args.code or args.title
  +
  +
local code = code( selected and mw.title.new(selected) or mw.title.getCurrentTitle() )
  +
 
if not code then
  +
return args.default or ''
 
end
 
 
return p.link(args)
+
return code
 
end
 
end
   

Latest revision as of 07:51, 27 December 2020

Documentation for this module may be created at Module:Language/doc

local langNames = require( [[Module:Language/Names]] )
local processArgs = require( [[Module:ProcessArgs]] )

local function code( title )
	local titleObj = title or mw.title.getCurrentTitle()
	if not titleObj.isSubpage then
		return nil
	end
	local subPage = titleObj.subpageText:lower()
	if langNames[subPage] then
		return subPage
	end
end
local function pageSuffix()
	local langCode = code()
	if langCode then
		return '/' .. langCode
	end
	return ''
end

local p = {}

-- See {{L}}
p.link = function( f )
	local args = processArgs.normDefault( f )
	
	-- Get language suffix for links
	if not args[1] or args[1]:lower() == 't' then
		return pageSuffix()
	end
	
	local page = args[1] .. pageSuffix()
	
	-- Get page name with suffix
	if args.dest then
		return page
	end
	
	-- Get page link with suffix and specified text
	return '[[' .. page .. '|' .. ( args.o or args[2] or args[1] ) .. ']]'
end

-- See {{Language}}
p.name = function( f )
	local args = processArgs.normDefault( f )
	
	local langCode = args[1] or 'en'
	
	-- Get language code for specified title or current page
	if args.code then
		return langCode
	end
	
	local langName = langNames[langCode]
	
	-- Get language name in English if the 2nd arg or 'en' arg is set
	if (args[2] and args[2] ~= '') or (args.en and args.en ~= '') then
		return langName[1]
	end
	
	-- Get language name in that language (autonym)
	return langName[2]
end

-- See {{ML}}
p.modlink = function( f )
	local args = processArgs.normDefault( f )
	
	local modname = require([[Module:Mods]]).getData(args[2]).name
	
	if not modname then
		return 'No mod found'
	end
	
	local disambiguated = string.format("%s (%s)", args[1], modname)
	
	return p.link{disambiguated, args.title or args[1]}
end

p.code = function( f )
	local args = processArgs.normDefault( f )
	
	-- 'de' and 'Main Page/de' will be correctly processed regardless of the arg name
	-- These aliases are mainly to keep a standard
	local selected = args.code or args.title
	
	local code = code( selected and mw.title.new(selected) or mw.title.getCurrentTitle() )
	
	if not code then
		return args.default or ''
	end
	
	return code
end

return p