Module:TNTTools: Difference between revisions

From TestWiki
Content added Content deleted
(Created page with 'local p = {} local TNT = require('Module:TNT') local SA = require('Module:SimpleArgs') function TNTTabFull (TNTTab) if (string.sub(TNTTab, 1, 5)) ~= 'I18n/' t...')
 
m (6 revisions imported: Borrowing a module from Wikipedia.)
 
(5 intermediate revisions by 2 users not shown)
Line 2: Line 2:


local TNT = require('Module:TNT')
local TNT = require('Module:TNT')
local SA = require('Module:SimpleArgs')
--local SD = require('Module:SimpleDebug')


function TNTTabFull (TNTTab)
function p.TNTTabFull (TNTTab)
if (string.sub(TNTTab, 1, 5)) ~= 'I18n/' then
if (string.sub(TNTTab, 1, 5)) ~= 'I18n/' then
TNTTab = 'I18n/'..TNTTab
TNTTab = 'I18n/'..TNTTab
Line 14: Line 14:
end --TNTTabFull
end --TNTTabFull


function p.GetTabTrans (TNTTab, S, CaseSensitive)
function p.TNTTabCommons (TNTTab)
return 'Commons:Data:'..p.TNTTabFull(TNTTab)
end

function p.LnkTNTTab (TNTTab)
return '[['..p.TNTTabCommons(TNTTab)..']]'
end

function I18nStr (TNTTab, S, IsMsg, params)
TNTTab = p.TNTTabFull (TNTTab)
local SEnd = TNT.format(TNTTab, S, unpack(params)) or ''
if SEnd == '' then
SEnd = TNT.formatInLanguage('en',TNTTab, S, unpack(params))
if IsMsg then
local icon = '[[File:Arbcom ru editing.svg|12px|Not found "'..S..'" in current language. Click here for to edit it.|link='..p.TNTTabCommons(TNTTab)..']]'
SEnd = SEnd..icon
end
end
return SEnd
end --I18nStr

function p.GetMsgP (TNTTab, S, ...)
return I18nStr (TNTTab, S, true, {...})
end

function p.GetStrP (TNTTab, S, ...)
return I18nStr (TNTTab, S, false, {...})
end

function p.TabTransCS (TNTTab, S, CaseSensitive)
CaseSensitive = ((CaseSensitive ~= nil) and (CaseSensitive == true)) or true
CaseSensitive = ((CaseSensitive ~= nil) and (CaseSensitive == true)) or true
local Wds = TNT.format (TNTTabFull(TNTTab), S)
local Wds = TNT.format (p.TNTTabFull(TNTTab), S)
if not CaseSensitive then
if not CaseSensitive then
Wds = string.lower (Wds)
Wds = string.lower (Wds)
end
end
return mw.text.split (Wds, '|')
return mw.text.split (Wds, '|')
end --GetTabTrans
end --TabTransCS


function p.GetSTransWithParams (TNTTab, S, ...)
function p.TabTransMT (TNTTab, S, MaxTrans)
return TNT.format (TNTTabFull(TNTTab), S, {...}) or ''
local FN = p.TNTTabFull(TNTTab)
local tab = mw.text.split (TNT.format (FN, S), '|')
end
if #tab > MaxTrans then

error (string.format('Found %s translations for "%s". Search in [[:commons:data:%s]]',#tab,S,FN))
function p.GetTabOr1Trans (TNTTab, S, MaxTrans)
-- Translation not required
local Trans = p.GetTabTrans (TNTTab, S)
if WithTrans then
tab = mw.text.split (Trans, '|')
if #tab > MaxTrans then
error (string.format('Found %s translations for "%s". Search in [[:commons:data:%s.tab]]',#tab,S,TNTTab), 0)
-- Translation not required
end
return tab
else
return Trans
end
end
return tab
end --GetTabOr1Trans
end --TabTransMT


function p.SFoundInTNTArr (TNTTab, val, CaseSensitive, S)
function p.SFoundInTNTArr (TNTTab, val, CaseSensitive, S)
Line 45: Line 66:
error('Not arguments trying to find "'..val..'"') --It doesn't require translation, only for degug
error('Not arguments trying to find "'..val..'"') --It doesn't require translation, only for degug
end
end
local Arr = p.GetTabTrans (TNTTab, S, CaseSensitive)
local Arr = p.TabTransCS (TNTTab, S, CaseSensitive)
if not CaseSensitive then
if not CaseSensitive then
val = string.lower (val)
val = string.lower (val)
Line 72: Line 93:
end --IdxFromTabTrans
end --IdxFromTabTrans


function p.Str (frame)
local args, NArgs = SA.GetArgs (frame)
local tab = SA.GetStrArgsFromPos (args, NArgs, 3)
return TNT.format (TNTTabFull(args[1]), args[2], unpack(tab))
end --Str

function p.FoundStrBool (frame)
local args = SA.GetArgs (frame)
return p.SFoundInTNTArr (args[1], args[2], SA.GetBoolFromArgs (args,3), args[4])
end
function p.FoundStrNum (frame)
local args = SA.GetArgs (frame)
if p.SFoundInTNTArr (args[1], args[2], SA.GetBoolFromArgs (args,3), args[4]) then
return 1
else
return 0
end
end --FoundStrNum
function p.FoundIdx (frame)
local args, NArgs = SA.GetArgs (frame)
local tab = SA.GetStrArgsFromPos (args, NArgs, 4)
return p.IdxFromTabTrans (args[1], args[2], SA.GetBoolFromArgs (args,3), tab)
end --FoundIdx
return p
return p

Latest revision as of 14:22, 1 January 2022

Contains functions linked to Module:TNT, which at the same time make calls to multilingual tables, located in Commons, for the creation of modules and multilingual templates.

TNTTools has:

  • Question functions: with boolean or numerical indexed return. To be called from other modules or from templates. With:
    • Case sensitive option.
    • Possibility of more than one translated text value (where each value is separated by "|").
  • To put aside write, adding "I18n/" as a prefix and ".tab" extension as a suffix for the table names.

local p = {}

local TNT = require('Module:TNT')
--local SD = require('Module:SimpleDebug')

function p.TNTTabFull (TNTTab)
	if (string.sub(TNTTab, 1, 5)) ~= 'I18n/' then
		TNTTab = 'I18n/'..TNTTab
	end	
	if (string.sub(TNTTab, string.len(TNTTab)-3)) ~= '.tab' then
		TNTTab = TNTTab..'.tab'
	end	
	return TNTTab
end --TNTTabFull

function p.TNTTabCommons (TNTTab)
	return 'Commons:Data:'..p.TNTTabFull(TNTTab)
end	

function p.LnkTNTTab (TNTTab)
	return '[['..p.TNTTabCommons(TNTTab)..']]'
end

function I18nStr (TNTTab, S, IsMsg, params)
	TNTTab = p.TNTTabFull (TNTTab)
	local SEnd = TNT.format(TNTTab, S, unpack(params)) or ''
	if SEnd == '' then
		SEnd = TNT.formatInLanguage('en',TNTTab, S, unpack(params))
		if IsMsg then
			local icon = '[[File:Arbcom ru editing.svg|12px|Not found "'..S..'" in current language. Click here for to edit it.|link='..p.TNTTabCommons(TNTTab)..']]'
			SEnd = SEnd..icon	
		end	
	end	
	return SEnd
end --I18nStr

function p.GetMsgP (TNTTab, S, ...)
	return I18nStr (TNTTab, S, true, {...})
end

function p.GetStrP (TNTTab, S, ...)
	return I18nStr (TNTTab, S, false, {...})
end

function p.TabTransCS (TNTTab, S, CaseSensitive)
	CaseSensitive = ((CaseSensitive ~= nil) and (CaseSensitive == true)) or true
	local Wds = TNT.format (p.TNTTabFull(TNTTab), S)
	if not CaseSensitive then
		Wds = string.lower (Wds)
	end	
    return mw.text.split (Wds, '|')
end --TabTransCS

function p.TabTransMT (TNTTab, S, MaxTrans)
	local FN = p.TNTTabFull(TNTTab)
	local tab = mw.text.split (TNT.format (FN, S), '|')
	if #tab > MaxTrans then
		error (string.format('Found %s translations for "%s". Search in [[:commons:data:%s]]',#tab,S,FN)) 
							-- Translation not required
	end
	return tab
end --TabTransMT

function p.SFoundInTNTArr (TNTTab, val, CaseSensitive, S)
	if (S == nil) or (S == '') then
		error('Not arguments trying to find "'..val..'"') --It doesn't require translation, only for degug
	end	
	local Arr = p.TabTransCS (TNTTab, S, CaseSensitive)
	if not CaseSensitive then
		val = string.lower (val)
	end	
	for I, W in ipairs(Arr) do
		if W == val then
			return true
		end	
	end	
	return false
end --SFoundInTNTArr

function p.IdxFromTabTrans (TNTTab, val, CaseSensitive, ...)
	local Arr = unpack(arg)
	if Arr == nil then
		error('Not arguments trying to find "'..val..'"') --It doesn't require translation, only for degug
	end	
	local Idx = 0
	for I, W in ipairs(Arr) do
		if p.SFoundInTNTArr (TNTTab, val, CaseSensitive, W) then
			Idx = I
			break
		end	
	end	
	return Idx
end	--IdxFromTabTrans

return p