Difference between revisions of "Module:HonorUtils"

From Pathfinder Wiki
(rename function's after the cleanup)
Line 3: Line 3:
 
local notUseLUAPattern = true
 
local notUseLUAPattern = true
  
function p.getVariantData( frame, variantType, variantNumber, landingPage )
+
function p.getVariantData( frame, landingPage, variantType, variantNumber )
 
-- check input variables
 
-- check input variables
 
if ( frame == nil ) then
 
if ( frame == nil ) then
Line 13: Line 13:
 
end
 
end
 
mw.log( 'HonorUtils.getVariantData (landingPage): '..landingPage )
 
mw.log( 'HonorUtils.getVariantData (landingPage): '..landingPage )
 +
local keyToStore = ''
 +
if (variantType == 'requirements') then
 +
 +
elseif (variantType == 'answerKey') then
 +
else
 +
mw.log( 'HonorUtils.getVariantData: Invalid variantType!' )
 +
return nil;
 +
end
 +
mw.log( 'HonorUtils.getVariantData: variantType ('..variantType..') resulted in keyToStore ('..keyToStore..')!' )
 +
 +
local srcIsHonor = false
 +
local parentFrame = frame:getParent()
 +
local tVariantData = getHonorVariants( variantType, landingPage, srcIsHonor, variantNumber)
 +
local variantName = variantType..'_'..variantNumber
 +
if (tVariantData == nil and parentFrame ~= nil and parentFrame.args[variantName] ~= nil) then
 +
mw.log('HonorUtils.getVariantData (parentFrame:getTitle): '..parentFrame:getTitle())
 +
-- get answer Variants
 +
tVariantData[1] = parentFrame.args[variantName]
 +
mw.log('HonorUtils.getVariantData (tVariantData[1]): '..tVariantData[1])
 +
else
 +
mw.log("HonorUtils.getVariantData (variantType_variantNumber): It isn't possible to get any data of the requested Variant! "..variantType..'_'..variantNumber)
 +
end
 
 
local timeStart1 = os.clock()
+
local tVariants = {
mw.log('test1: '..frame:preprocess( '{{#dpl:|debug=0|title=AY Honors/Music|include={HonorLanding}:answerKey_1}}' ))
+
keyToStore = tVariantData
mw.log('test duration 1: '..tostring(os.clock() - timeStart1))
+
}
 +
tVariants = expandHonorVariants( frame, tVariants )
 
 
timeStart1 = os.clock()
+
tVariants = translateHonorVariants( frame, tVariants )
mw.log('test2: '..frame:preprocess( '{{#dpl:|debug=0|title=AY Honors/Music|include={HonorLanding}:answerKey_1:answerKey_2:requirements_1:requirements_2}}' ))
+
return tVariants
mw.log('test duration 2: '..tostring(os.clock() - timeStart1))
 
 
end
 
end
  
Line 26: Line 48:
 
if ( frame == nil ) then
 
if ( frame == nil ) then
 
frame = mw.getCurrentFrame()
 
frame = mw.getCurrentFrame()
mw.log( 'HonorUtils.getExpandedHonorVriantsV2 (frame): '..frame:getTitle() )
+
mw.log( 'HonorUtils.getVariantsData (frame): '..frame:getTitle() )
 
end
 
end
 
if ( landingPage == nil or landingPage == "" ) then
 
if ( landingPage == nil or landingPage == "" ) then
Line 36: Line 58:
 
-- see if template has variants as arguments
 
-- see if template has variants as arguments
 
local tAnswerVariants = getHonorVariants( 'answerKey', landingPage, srcIsHonor )
 
local tAnswerVariants = getHonorVariants( 'answerKey', landingPage, srcIsHonor )
if ( tAnswerVariants == nil ) then
+
if ( tAnswerVariants == nil and parentFrame ~= nil ) then
mw.log('HonorUtils.getExpandedHonorVariantsV2 (parentFrame:getTitle): '..parentFrame:getTitle())
+
mw.log('HonorUtils.getVariantsData (parentFrame:getTitle): '..parentFrame:getTitle())
 
local cnt_answerKey_variants = parentFrame.args['cnt_answerKey_variants']
 
local cnt_answerKey_variants = parentFrame.args['cnt_answerKey_variants']
 
if ( cnt_answerKey_variants ~= nil and cnt_answerKey_variants ~= '' ) then
 
if ( cnt_answerKey_variants ~= nil and cnt_answerKey_variants ~= '' ) then
 
tAnswerVariants = {}
 
tAnswerVariants = {}
 
-- get answer Variants
 
-- get answer Variants
mw.log('HonorUtils.getExpandedHonorVariantsV2 (cnt_answerKey_variants): '..cnt_answerKey_variants)
+
mw.log('HonorUtils.getVariantsData (cnt_answerKey_variants): '..cnt_answerKey_variants)
 
for actVariant = 1, tonumber(cnt_answerKey_variants), 1 do
 
for actVariant = 1, tonumber(cnt_answerKey_variants), 1 do
mw.log('HonorUtils.getExpandedHonorVariantsV2 (actVariant) answerkey: '..actVariant)
+
mw.log('HonorUtils.getVariantsData (actVariant) answerkey: '..actVariant)
 
strActVariant = 'answerKey_' .. actVariant
 
strActVariant = 'answerKey_' .. actVariant
 
tAnswerVariants[actVariant] = parentFrame.args[strActVariant]
 
tAnswerVariants[actVariant] = parentFrame.args[strActVariant]
mw.log('HonorUtils.getExpandedHonorVariantsV2 (tAnswerVariants[actVariant]): '..tAnswerVariants[actVariant])
+
mw.log('HonorUtils.getVariantsData (tAnswerVariants[actVariant]): '..tAnswerVariants[actVariant])
 
end
 
end
 
end
 
end
 +
else
 +
mw.log("HonorUtils.getVariantsData: It isn't possible to get any answer variant's data!")
 
end
 
end
 
 
 
local tRequirementVariants = getHonorVariants( 'requirements', landingPage, srcIsHonor )
 
local tRequirementVariants = getHonorVariants( 'requirements', landingPage, srcIsHonor )
if ( tRequirementVariants == nil ) then
+
if ( tRequirementVariants == nil and parentFrame ~= nil ) then
 
local cnt_requirements_variants = parentFrame.args['cnt_requirements_variants']
 
local cnt_requirements_variants = parentFrame.args['cnt_requirements_variants']
 
if ( cnt_requirements_variants ~= nil and cnt_requirements_variants ~= ''  ) then
 
if ( cnt_requirements_variants ~= nil and cnt_requirements_variants ~= ''  ) then
 
tRequirementVariants = {}
 
tRequirementVariants = {}
 
-- get requirement Variants
 
-- get requirement Variants
mw.log('HonorUtils.getExpandedHonorVariantsV2 (cnt_answerKey_variants): '..cnt_requirements_variants)
+
mw.log('HonorUtils.getVariantsData (cnt_answerKey_variants): '..cnt_requirements_variants)
 
for actVariant = 1, tonumber(cnt_requirements_variants), 1 do
 
for actVariant = 1, tonumber(cnt_requirements_variants), 1 do
mw.log('HonorUtils.getExpandedHonorVariantsV2 (actVariant) requirements: '..actVariant)
+
mw.log('HonorUtils.getVariantsData (actVariant) requirements: '..actVariant)
 
strActVariant = 'requirements_' .. actVariant
 
strActVariant = 'requirements_' .. actVariant
 
tRequirementVariants[actVariant] = parentFrame.args[strActVariant]
 
tRequirementVariants[actVariant] = parentFrame.args[strActVariant]
mw.log('HonorUtils.getExpandedHonorVariantsV2 (tRequirementVariants[actVariant]): '..tRequirementVariants[actVariant])
+
mw.log('HonorUtils.getVariantsData (tRequirementVariants[actVariant]): '..tRequirementVariants[actVariant])
 
end
 
end
 
end
 
end
 +
else
 +
mw.log("HonorUtils.getVariantsData: It isn't possible to get any answer variant's data!")
 
end
 
end
 
local tVariants = {
 
local tVariants = {
Line 72: Line 98:
 
}
 
}
 
 
tVariants = p.expandHonorVariants( frame, tVariants )
+
tVariants = expandHonorVariants( frame, tVariants )
 
 
tVariants = p.translateHonorVariants( frame, tVariants )
+
tVariants = translateHonorVariants( frame, tVariants )
 
return tVariants
 
return tVariants
 
end
 
end
  
function p.expandHonorVariants( frame, tVariants )
+
function expandHonorVariants( frame, tVariants )
 
local tRetVariants = tVariants
 
local tRetVariants = tVariants
 
if ( tVariants == nil ) then
 
if ( tVariants == nil ) then
Line 142: Line 168:
 
end
 
end
  
function p.translateHonorVariants( frame, tVariants )
+
function translateHonorVariants( frame, tVariants )
 
local tRetVariants = tVariants
 
local tRetVariants = tVariants
 
if ( tRetVariants == nil ) then
 
if ( tRetVariants == nil ) then

Revision as of 09:09, 22 July 2021

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

local p = {}
local utilities = require ( "Module:Utilities" )
local notUseLUAPattern = true

function p.getVariantData( frame, landingPage, variantType, variantNumber )
	-- check input variables
	if ( frame == nil ) then
		frame = mw.getCurrentFrame()
	end
	mw.log( 'HonorUtils.getVariantData (frame): '..frame:getTitle() )
	if ( landingPage == nil or landingPage == "" ) then
		landingPage = frame:expandTemplate{ title='GetHonorLandingPage' }
	end
	mw.log( 'HonorUtils.getVariantData (landingPage): '..landingPage )
	local keyToStore = ''
	if (variantType == 'requirements') then
		
	elseif (variantType == 'answerKey') then
	else
		mw.log( 'HonorUtils.getVariantData: Invalid variantType!' )
		return nil;
	end
	mw.log( 'HonorUtils.getVariantData: variantType ('..variantType..') resulted in keyToStore ('..keyToStore..')!' )
	
	local srcIsHonor = false
	local parentFrame = frame:getParent()
	local tVariantData = getHonorVariants( variantType, landingPage, srcIsHonor, variantNumber)
	local variantName = variantType..'_'..variantNumber
	if (tVariantData == nil and parentFrame ~= nil and parentFrame.args[variantName] ~= nil) then
		mw.log('HonorUtils.getVariantData (parentFrame:getTitle): '..parentFrame:getTitle())
		-- get answer Variants
		tVariantData[1] = parentFrame.args[variantName]
		mw.log('HonorUtils.getVariantData (tVariantData[1]): '..tVariantData[1])
	else
		mw.log("HonorUtils.getVariantData (variantType_variantNumber): It isn't possible to get any data of the requested Variant! "..variantType..'_'..variantNumber)
	end
	
	local tVariants = {
		keyToStore = tVariantData
	}
	tVariants = expandHonorVariants( frame, tVariants )
	
	tVariants = translateHonorVariants( frame, tVariants )
	return tVariants
end

function p.getVariantsData( frame, landingPage )
	if ( frame == nil ) then
		frame = mw.getCurrentFrame()
		mw.log( 'HonorUtils.getVariantsData (frame): '..frame:getTitle() )
	end
	if ( landingPage == nil or landingPage == "" ) then
		landingPage = frame:expandTemplate{ title='GetHonorLandingPage' }
	end
	local parentFrame = frame:getParent()
	local srcIsHonor = false
	
	-- see if template has variants as arguments
	local tAnswerVariants = getHonorVariants( 'answerKey', landingPage, srcIsHonor )
	if ( tAnswerVariants == nil and parentFrame ~= nil ) then
		mw.log('HonorUtils.getVariantsData (parentFrame:getTitle): '..parentFrame:getTitle())
		local cnt_answerKey_variants = parentFrame.args['cnt_answerKey_variants']
		if ( cnt_answerKey_variants ~= nil and cnt_answerKey_variants ~= '' ) then
			tAnswerVariants = {}
			-- get answer Variants
			mw.log('HonorUtils.getVariantsData (cnt_answerKey_variants): '..cnt_answerKey_variants)
			for actVariant = 1, tonumber(cnt_answerKey_variants), 1 do
				mw.log('HonorUtils.getVariantsData (actVariant) answerkey: '..actVariant)
				strActVariant = 'answerKey_' .. actVariant
				tAnswerVariants[actVariant] = parentFrame.args[strActVariant]
				mw.log('HonorUtils.getVariantsData (tAnswerVariants[actVariant]): '..tAnswerVariants[actVariant])
			end
		end
	else
		mw.log("HonorUtils.getVariantsData: It isn't possible to get any answer variant's data!")
	end
	
	local tRequirementVariants = getHonorVariants( 'requirements', landingPage, srcIsHonor )
	if ( tRequirementVariants == nil and parentFrame ~= nil ) then
		local cnt_requirements_variants = parentFrame.args['cnt_requirements_variants']
		if ( cnt_requirements_variants ~= nil and cnt_requirements_variants ~= ''  ) then
			tRequirementVariants = {}
			-- get requirement Variants
			mw.log('HonorUtils.getVariantsData (cnt_answerKey_variants): '..cnt_requirements_variants)
			for actVariant = 1, tonumber(cnt_requirements_variants), 1 do
				mw.log('HonorUtils.getVariantsData (actVariant) requirements: '..actVariant)
				strActVariant = 'requirements_' .. actVariant
				tRequirementVariants[actVariant] = parentFrame.args[strActVariant]
				mw.log('HonorUtils.getVariantsData (tRequirementVariants[actVariant]): '..tRequirementVariants[actVariant])
			end
		end
	else
		mw.log("HonorUtils.getVariantsData: It isn't possible to get any answer variant's data!")
	end
	local tVariants = {
		answers = tAnswerVariants,
		requirements = tRequirementVariants
	}
	
	tVariants = expandHonorVariants( frame, tVariants )
	
	tVariants = translateHonorVariants( frame, tVariants )
	return tVariants
end

function expandHonorVariants( frame, tVariants )
	local tRetVariants = tVariants
	if ( tVariants == nil ) then
		mw.log('HonorUtils.expandHonorVariants: No Variants to Expand (nil)!')
		return {}
	end
	if ( tVariants['answers'] == nil ) then
		mw.log('HonorUtils.expandHonorVariants: No Answer Variants to Expand!')
	else
		-- expand the answer Variants
		local tAnswers = tVariants['answers']
		mw.log('HonorUtils.expandHonorVariants: There are '..#tAnswers..' Answer Variants to Expand!')
		for key, variant in pairs(tAnswers) do
			mw.log('HonorUtils.expandHonorVariants (key, variant): '..key..', '..variant)
			-- seperate Countries and Authority
			local tSplitAnsVariant = mw.text.split(variant, ';;', notUseLUAPattern)
			local tActVariant = {
				orig = variant,
				countries = {}
			}
			if ( tSplitAnsVariant[1] ~= '') then
				tActVariant['countries']['orig'] = tSplitAnsVariant[1]
				-- seperate the Countries
				tActVariant['countries']['split'] = mw.text.split(tActVariant['countries']['orig'], ';', notUseLUAPattern)
				mw.log('HonorUtils.expandHonorVariants (Countries - Orig): '..tActVariant['countries']['orig'])
			else
				mw.log('HonorUtils.expandHonorVariants: There are no countries for that variant!')
			end
			-- set the authority
			if ( tSplitAnsVariant[2] == nil ) then
				tActVariant['authority'] = nil
				mw.log('HonorUtils.expandHonorVariants (Authority): nil')
			else
				tActVariant['authority'] = tSplitAnsVariant[2]
				mw.log('HonorUtils.expandHonorVariants (Authority): '..tActVariant['authority'])
			end
			-- save act. Variant into the table
			tAnswers[key] = tActVariant
		end
		tVariants['answers'] = tAnswers
		mw.log('HonorUtils.expandHonorVariants: '..#tVariants['answers']..' Answer Variants expanded!')
	end
	if ( tVariants['requirements'] == nil ) then
		mw.log('HonorUtils.expandHonorVariants: No Requirement Variants to Expand!')
	else
		-- expand the requirement Variants
		local tRequirements = tVariants['requirements']
		mw.log('HonorUtils.expandHonorVariants: There are '..#tRequirements..' Requirement Variants to Expand!')
		for key, variant in pairs(tRequirements) do
			mw.log('HonorUtils.expandHonorVariants (key, variant): '..key..', '..variant)
			-- seperate Authorities
			local tSplitReqVariant = mw.text.split(variant, ';', notUseLUAPattern)
			local tActReqVariant = {
				orig = variant,
				authorities = tSplitReqVariant
			}
			tRequirements[key] = tActReqVariant
		end
		tVariants['requirements'] = tRequirements
		mw.log('HonorUtils.expandHonorVariants: '..#tVariants['requirements']..' Requirement Variants expanded!')
	end
	return tRetVariants
end

function translateHonorVariants( frame, tVariants )
	local tRetVariants = tVariants
	if ( tRetVariants == nil ) then
		mw.log('HonorUtils.translateHonorVariants: There are no Variants (nil)!')
	end
	if ( tRetVariants['answers'] == nil ) then
		mw.log('HonorUtils.translateHonorVariants: There are no Answer Variants!')
	else
		mw.log('HonorUtils.translateHonorVariants: There are '..#tRetVariants['answers']..' Answer Variants to translate!')
		for varKey, variant in pairs(tRetVariants['answers']) do
			if ( variant == nil or variant['countries'] == nil or variant['countries']['split'] == nil ) then
				mw.log('HonorUtils.translateHonorVariants: Answer Variant is invalid!')
			else
				mw.log('HonorUtils.translateHonorVariants: There are '..#variant['countries']['split']..' Answer Variant Countries to translate!')
				for countryKey, country in pairs(variant['countries']['split']) do
					local trans = utilities.localize( country, 'Countries' )
					-- check if Localization returned something, if not set the original string
					mw.log('HonorUtils.translateHonorVariants (country, trans): '..country..', '..trans)
					if ( trans == '' ) then
						trans = country
					end
					tRetVariants['answers'][varKey]['countries']['split'][countryKey] = {
						orig = country,
						translated = trans
					}
				end
				mw.log('HonorUtils.translateHonorVariants: '..#tRetVariants['answers'][varKey]['countries']['split']..' Answer Variant Countries were translated!')
			end
		end
		mw.log('HonorUtils.translateHonorVariants: '..#tRetVariants['answers']..' Answer Variants were translated!')
	end
	if ( tRetVariants['requirements'] == nil ) then
		mw.log('HonorUtils.translateHonorVariants: There are no Requirement Variants!')
	else
		mw.log('HonorUtils.translateHonorVariants: There are '..#tRetVariants['requirements']..' Requriement Variants to translate!')
		for varKey, variant in pairs(tRetVariants['requirements']) do
			if ( variant == nil or variant['authorities'] == nil ) then
				mw.log('HonorUtils.translateHonorVariants: Requriement Variant is invalid!')
			else
				mw.log('HonorUtils.translateHonorVariants: There are '..#variant['authorities']..' Requriement Variant Authorities to translate!')
				for authorityKey, authority in pairs(variant['authorities']) do
					local trans = utilities.localize( authority, 'Authorities' )
					-- check if Localization returned something, if not set the original string
					if ( trans == '' ) then
						trans = authority
					end
					tRetVariants['requirements'][varKey]['authorities'][authorityKey] = {
						orig = authority,
						translated = trans
					}
				end
				mw.log('HonorUtils.translateHonorVariants: '..#tRetVariants['requirements'][varKey]['authorities']..' Requriement Variant Authorities were translated!')
			end
		end
		mw.log('HonorUtils.translateHonorVariants: '..#tRetVariants['requirements']..' Requriement Variants were translated!')
	end
	return tRetVariants
end

function getHonorVariants( variantType, src, srcIsHonor, variantNumber )
	if (variantType == nil or variantType == '') then
		variantType = 'requirement'
	end
	local cntOfVariants = tonumber(p.getHonorMetadata(src, 'cnt_'..variantType..'_variants', srcIsHonor))
	if (cntOfVariants == nil or cntOfVariants == 0) then
		mw.log('HonorUtils.getHonorVariants: There are no '..variantType..' variants!')
		return nil
	end
	mw.log('HonorUtils.getHonorVariants (cntOfVariants): '..cntOfVariants)
	local actVariant = 0
	local tVariantArguments = {}
	if ( variantNumber ~= nil and variantNumber <= cntOfVariants ) then
		-- only get the defined Variant
		tVariantArguments[1] = variantType..'_'..variantNumber
	else
		-- get all variants
		for actVariant = 1, cntOfVariants, 1 do
			mw.log('HonorUtils.getHonorVariants (actVariant): '..actVariant)
			tVariantArguments[actVariant] = variantType .. '_' .. actVariant
		end
	end
	
	local strVariantArguments = mw.text.listToText(tVariantArguments, ':', ':')
	mw.log('HonorUtils.getHonorVariants (strVariantArguments): '..strVariantArguments)
	local strVariant = p.getHonorMetadata(src, strVariantArguments, srcIsHonor)
	strVariant = mw.ustring.gsub(strVariant,"[\n\r]", "")
	mw.log('HonorUtils.getHonorVariants (strVariant): '..strVariant)
	tVariants = mw.text.split(strVariant, '|', notUseLUAPattern)
	mw.log('HonorUtils.getHonorVariants (#tVariants): '..#tVariants)
	return tVariants
end

function p.getHonorMetadata(src, metadata, srcIsHonor)
	local frame = mw.getCurrentFrame()
	local lPage = ''
	if (src ~= '' and src ~= nil) then
		if (srcIsHonor == true) then
			lPage = 'AY Honors/' .. src
		else
			lPage = src
		end
	end
	lPage = frame:expandTemplate{ title = 'GetHonorLandingPage', args = {page = lPage}}
	return frame:preprocess( '{{#dpl:|debug=0|title=' .. lPage .. '|include={HonorLanding}:' .. metadata ..'}}' )
end

return p