Модуль:Languages

ХӀокху модулах лаьцна хааман Модуль:Languages/doc агӀо кхолла мега

-- Меттанашца болхбен модуль ISO 639

-- меттанийн талицица хаамийн модуль схьаеллар
local languages = mw.loadData('Module:Languages/data')
local p = {}

-- Талла, еса-м ца елла параметр
local function isEmpty(s)
	return s == nil or s == ''
end

-- гӀодаран функцино, дӀайоху пробелаш
local function trimstr(s)
  return (s:gsub("^%s*(.-)%s*$", "%1"))
end

-- меттан код кхочу, юхаерзайо хьажориг а, нормализаци йина меттан код а (я деса могӀанаш)
local function get_lang_data(code)
    local l = languages[code];
    if l ~= nil then
        return "[[" .. l[2] .. "|" .. l[1] .. "]]", code
    elseif code ~= "" then
        return code, ""
    else
        return "", ""
    end
end

function p.getRefHtmlFrame( frame )
	return p.getRefHtml( trimstr( frame.args[1] ) )
end

function p.getRefHtml( code )
	local l = languages[code];
	if l == nil then
		mw.log( 'Language description for code ' .. code .. ' not found' )
        return ""
    else
        return '<span class="ref-info" title="' .. l[ 2 ] .. '" style="cursor:help">(' .. l[ 1 ] .. ')</span>'
    end
end

function p.getWikidataRefHtmlFrame( frame )
	return p.getWikidataRefHtml( trimstr( frame.args[1] ) )
end

function p.getWikidataRefHtml( wikidataItemId )
	local codeByItemId = mw.loadData( "Module:Wikidata/Language-codes" )
	local code = codeByItemId[ wikidataItemId ];
	if code == nil then
		mw.log( 'Language code not found for ' .. wikidataItemId )
		return ""
	end
	return p.getRefHtml( code )
end

-- zh тӀеоьцу, йуххаерзайо аббревиатура
function p.abbr(frame)
	local code = trimstr( frame.args[1] )
	if not isEmpty(code) then
		return (languages[code] and languages[code][1] or '')
	end
end

-- zh тӀеоьцу|我|tt|мин, йухаерзайо йаззаман цӀе Module:Languages/data
function p.name(frame)
	local code = trimstr( frame.args[1] )
	if code ~= nil and code ~= '' then
		return (languages[code] and languages[code][2] or '')
	end
end

-- тӀеоьцу zh|我|tt|мин, юхаерзайо исписка цӀоьмалгца
function p.list(frame)
    local curr_lang = nil
    local result = nil

    for n, v in frame:argumentPairs() do
		local trimmed = trimstr(v)
		if curr_lang == nil then
		if trimmed ~= '' then
			-- нагахь мотт йукъахь биснехь, буьтар хьалхарниг
			curr_lang = trimstr(v)
		end
		else
		if trimmed ~= '' then
			local link, lang_code = get_lang_data(curr_lang)
			local list_item
			if lang_code ~= '' then
				list_item = link .. "&nbsp;<span dir='auto' lang='" .. lang_code .. "'>" .. trimmed .. "</span>"
			else
				list_item = link .. " <span class='unknown-foreign-lang'>" .. trimmed .. "</span>".."[[Category:Википеди:Ца бевзанчу меттанашкара йаззамаш]]"
			end
			
			if result == nil then
				result = list_item
			else
				result = result .. ", " .. list_item
			end
		else
		-- Йаьсса текст — тӀаккха, болу мотт тӀаьхьарчунца богӀу
		local link, lang_code = get_lang_data(curr_lang)
		if result == nil then
			result = link
		else
			result = result .. ", " .. link
		end
		end
		
		curr_lang = nil
      end
    end
    
    -- #invoke:Languages|list|yue йухаерзоеза хьажорг текст йоцуш
    if curr_lang ~= nil then
        local link, lang_code = get_lang_data(curr_lang)
        if result ~= nil then
            result = result .. ", " .. link
        else
            result = link
        end
    end
    return result
end

-- zh тӀеоьцу|tt, йухаерзоеза ref-zh, ref-tt
function p.list_ref(frame)
	local result = ''
	local v = frame.args['чохь'] or nil
	local ref = nil

	if v then
		ref = '&nbsp;<span class="ref-info" style="cursor:help;" title="%2%">&#091;%1%&#093;</span>'
	else
		ref = '&nbsp;<span class="ref-info" style="cursor:help;" title="%2%">(%1%)</span>'
	end

	for x, lg in pairs( frame.args ) do
		local code = trimstr(lg)
		if code ~= '' and code ~= 'в' then
			local l = languages[code]
			if l and l ~= nil then
				result = result .. mw.ustring.gsub(mw.ustring.gsub(ref, '%%2%%', p._transform_lang(code)), '%%1%%', l[1])
			else
				if mw.title.new('ref-' .. code, 10).exists == false then
					code = 'und'
				end
				result = result .. frame:expandTemplate{ title = 'ref-' .. code } .. '[[Category:Википеди:Йевзаш йоцу (ref) код йолу йаззамаш]]'
			end
		end
	end

	return result
end

-- Меттан цӀе предложни дожаре йалайо
function p._transform_lang(code)
	if isEmpty(languages[code]) then return '&lt;цаевза код ' .. code .. '&gt;' end
    if languages[code][3] then return languages[code][3] end
    local ln = mw.ustring.lower(
        languages[code] and languages[code][2]
        or mw.language.fetchLanguageName(code,'ru')
     ):gsub('%s+мотт%s+',  ' '):gsub('%s*%(?мотт%)?%s*',  '')
    if not ln then return 'маттахь ISO-кодаца '..code..' (?)' end
    if ln:match('.*лингва$') then return ln:gsub('а$','е') end
    if mw.ustring.match(ln,'[сц]кан$') or ln:match('ан$') or mw.ustring.match(ln,'[сц]кан%s%b()$') or ln:match('ан%s%b()$')
    then
        ln = mw.ustring.gsub(
            mw.ustring.gsub(ln, 'н([ан])й(%A)', function(y,s) return (y=='ийн' and 'ан' or 'нем')..s end)
                :gsub('ан$', 'ан'),
            '([сц]к)ан(%A)', '%1ан%2'
        ):gsub('скан$', 'скан'):gsub('цкан$', 'цкан');
        if ln:match('%)$') and not (ln:match('ан%)$') or ln:match('нем%)$')) -- «маттахь» билгалдаккхале, нагахь иза лега ца лахь
        then 
            local r,s=ln:gsub('(%s)(%b())$','%1маттахь%1%2');
            if s==1 then return r end
        end
        return ln..' маттахь'
    else
        return ln..' маттахь'
    end
end

function p.transform_lang(frame)
	return p._transform_lang(trimstr(frame.args[1]))
end

return p