Location via proxy:   [ UP ]  
[Report a bug]   [Manage cookies]                

Modulo:IsLatin

Versione del 21 giu 2023 alle 13:54 di GryffindorD (discussione | contributi) (Protetto "Modulo:IsLatin": Modulo usato in maniera estensiva ([Modifica=Consentito solo agli utenti autoconvalidati] (infinito) [Spostamento=Consentito solo agli utenti autoconvalidati] (infinito)))
(diff) ← Versione meno recente | Versione attuale (diff) | Versione più recente → (diff)

Modulo per identificare la presenza di caratteri non compresi nell'alfabeto latino e non facenti parte dei blocchi tra "General Punctuation" e "Mathematical Operators". Da un'idea di WOSlinker.

La funzione analizza una stringa di testo e non restituisce nulla se trova almeno un carattere che non rientra negli intervalli sopra specificati, altrimenti restituisce "sì". Si può farne uso anche attraverso il template {{IsLatin}} o può essere richiamata da altro modulo per ottenere rispettivamente "false" e "true". Di seguito alcuni esempi d'uso:

Testo da analizzare Codice da usare Risultato visualizzato
ciao {{#invoke:IsLatin|IsLatin|ciao}}
o {{IsLatin|ciao}}
你好 {{#invoke:IsLatin|IsLatin|你好}}
o {{IsLatin|你好}}
привет {{#invoke:IsLatin|IsLatin|привет}}
o {{IsLatin|привет}}
cześć {{#invoke:IsLatin|IsLatin|cześć}}
o {{IsLatin|cześć}}
سلام {{#invoke:IsLatin|IsLatin|سلام}}
o {{IsLatin|سلام}}

local p = {}

-- Funzione per l'utilizzo da altro modulo
function p._IsLatin(args)
	local txt = args[1] or ''
	if mw.text.trim(txt) == '' then return nil end
	
	local len = mw.ustring.len(txt)
	local pos = 1
	while (pos <= len) do
		local charval = mw.ustring.codepoint(mw.ustring.sub(txt, pos))
		if charval >= 880 and charval < 8192 then
			return false
		elseif charval >= 8960 then
			return false
		end
		pos = pos + 1
	end
	return true
end

-- Funzione per il template IsLatin
function p.IsLatin(frame)
	return p._IsLatin(frame.args) and 'sì' or ''
end

return p