<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="it">
	<id>https://it.wikijournal.org/w-wiki/index.php?action=history&amp;feed=atom&amp;title=Modulo%3AWikidata</id>
	<title>Modulo:Wikidata - Cronologia</title>
	<link rel="self" type="application/atom+xml" href="https://it.wikijournal.org/w-wiki/index.php?action=history&amp;feed=atom&amp;title=Modulo%3AWikidata"/>
	<link rel="alternate" type="text/html" href="https://it.wikijournal.org/w-wiki/index.php?title=Modulo:Wikidata&amp;action=history"/>
	<updated>2026-04-29T12:42:02Z</updated>
	<subtitle>Cronologia della pagina su questo sito</subtitle>
	<generator>MediaWiki 1.43.5</generator>
	<entry>
		<id>https://it.wikijournal.org/w-wiki/index.php?title=Modulo:Wikidata&amp;diff=165&amp;oldid=prev</id>
		<title>Philip: una versione importata</title>
		<link rel="alternate" type="text/html" href="https://it.wikijournal.org/w-wiki/index.php?title=Modulo:Wikidata&amp;diff=165&amp;oldid=prev"/>
		<updated>2025-02-19T08:06:15Z</updated>

		<summary type="html">&lt;p&gt;una versione importata&lt;/p&gt;
&lt;table style=&quot;background-color: #fff; color: #202122;&quot; data-mw=&quot;interface&quot;&gt;
				&lt;col class=&quot;diff-marker&quot; /&gt;
				&lt;col class=&quot;diff-content&quot; /&gt;
				&lt;col class=&quot;diff-marker&quot; /&gt;
				&lt;col class=&quot;diff-content&quot; /&gt;
				&lt;tr class=&quot;diff-title&quot; lang=&quot;it&quot;&gt;
				&lt;td colspan=&quot;2&quot; style=&quot;background-color: #fff; color: #202122; text-align: center;&quot;&gt;← Versione meno recente&lt;/td&gt;
				&lt;td colspan=&quot;2&quot; style=&quot;background-color: #fff; color: #202122; text-align: center;&quot;&gt;Versione delle 11:06, 19 feb 2025&lt;/td&gt;
				&lt;/tr&gt;&lt;tr&gt;&lt;td colspan=&quot;4&quot; class=&quot;diff-notice&quot; lang=&quot;it&quot;&gt;&lt;div class=&quot;mw-diff-empty&quot;&gt;(Nessuna differenza)&lt;/div&gt;
&lt;/td&gt;&lt;/tr&gt;
&lt;!-- diff cache key wikijournal_org-it__:diff:1.41:old-164:rev-165 --&gt;
&lt;/table&gt;</summary>
		<author><name>Philip</name></author>
	</entry>
	<entry>
		<id>https://it.wikijournal.org/w-wiki/index.php?title=Modulo:Wikidata&amp;diff=164&amp;oldid=prev</id>
		<title>it__&gt;Horcrux: inverto logica del parametro per retrocompatibilità</title>
		<link rel="alternate" type="text/html" href="https://it.wikijournal.org/w-wiki/index.php?title=Modulo:Wikidata&amp;diff=164&amp;oldid=prev"/>
		<updated>2023-06-08T12:42:32Z</updated>

		<summary type="html">&lt;p&gt;inverto logica del parametro per retrocompatibilità&lt;/p&gt;
&lt;p&gt;&lt;b&gt;Nuova pagina&lt;/b&gt;&lt;/p&gt;&lt;div&gt;--[[&lt;br /&gt;
* Modulo per implementare le funzionalità dei template:&lt;br /&gt;
* {{Wikidata}}, {{WikidataQ}}, {{WikidataIdx}}, {{WikidataN}}, {{WikidataLabel}}, {{WikidataDescription}}&lt;br /&gt;
* {{WikidataLink}}, {{WikidataId}}, {{WikidataTipo}} e {{WikidataIstanza}}.&lt;br /&gt;
* Permette di accedere a Wikidata in modo più avanzato rispetto a {{#property}}.&lt;br /&gt;
&lt;br /&gt;
* Per la maggior parte riscritto e ampliato a partire dalla versione iniziale a:&lt;br /&gt;
* http://test2.wikipedia.org/w/index.php?title=Module:Wikidata&amp;amp;oldid=52322&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
-- =============================================================================&lt;br /&gt;
-- Non utilizzare mai mw.wikibase.getEntity, per esempio un solo utilizzo di&lt;br /&gt;
-- mw.wikibase.getEntity(&amp;#039;Q183&amp;#039;) fa aumentare di 7 MB l&amp;#039;utilizzo di memoria&lt;br /&gt;
-- per Lua ed è molto lenta se ripetuta (unico utilizzo in getDatatype,&lt;br /&gt;
-- solo per proprietà, non essendoci alternative).&lt;br /&gt;
-- =============================================================================&lt;br /&gt;
&lt;br /&gt;
require(&amp;#039;strict&amp;#039;)&lt;br /&gt;
&lt;br /&gt;
local getArgs = require(&amp;#039;Module:Arguments&amp;#039;).getArgs&lt;br /&gt;
local mConvert = require(&amp;#039;Module:Conversione&amp;#039;)&lt;br /&gt;
local mLanguages = require(&amp;#039;Module:Lingue&amp;#039;)&lt;br /&gt;
&lt;br /&gt;
-- Categoria per le pagine con errori&lt;br /&gt;
local errorCategory = &amp;#039;[[Categoria:Voci con errori del modulo Wikidata]]&amp;#039;&lt;br /&gt;
&lt;br /&gt;
-- Messaggi&lt;br /&gt;
local i18n = {&lt;br /&gt;
	errors = {&lt;br /&gt;
		[&amp;#039;entityid-param-not-provided&amp;#039;] = &amp;quot;Parametro &amp;#039;&amp;#039;entityid&amp;#039;&amp;#039; non fornito&amp;quot;,&lt;br /&gt;
		[&amp;#039;property-param-not-provided&amp;#039;] = &amp;quot;Parametro &amp;#039;&amp;#039;property&amp;#039;&amp;#039; non fornito&amp;quot;,&lt;br /&gt;
		[&amp;#039;qualifier-param-not-provided&amp;#039;] = &amp;quot;Parametro &amp;#039;&amp;#039;qualifier&amp;#039;&amp;#039; non fornito&amp;quot;,&lt;br /&gt;
		[&amp;#039;value-param-not-provided&amp;#039;] = &amp;quot;Parametro &amp;#039;&amp;#039;valore&amp;#039;&amp;#039; da ricercare non fornito&amp;quot;,&lt;br /&gt;
		[&amp;#039;entity-not-found&amp;#039;] = &amp;#039;Entità non trovata&amp;#039;,&lt;br /&gt;
		[&amp;#039;unknown-claim-type&amp;#039;] = &amp;#039;Tipo asserzione sconosciuta&amp;#039;,&lt;br /&gt;
		[&amp;#039;unknown-snak-type&amp;#039;] = &amp;#039;Tipo di snak sconosciuto&amp;#039;,&lt;br /&gt;
		[&amp;#039;unknown-datavalue-type&amp;#039;] = &amp;#039;Tipo di dato sconosciuto&amp;#039;,&lt;br /&gt;
		[&amp;#039;unknown-entity-type&amp;#039;] = &amp;#039;Tipo di entità sconosciuta&amp;#039;,&lt;br /&gt;
		[&amp;#039;unknown-output-format&amp;#039;] = &amp;#039;Formato di output sconosciuto&amp;#039;&lt;br /&gt;
	},&lt;br /&gt;
	somevalue = &amp;quot;&amp;#039;&amp;#039;valore sconosciuto&amp;#039;&amp;#039;&amp;quot;,&lt;br /&gt;
	novalue = &amp;quot;&amp;#039;&amp;#039;nessun valore&amp;#039;&amp;#039;&amp;quot;,&lt;br /&gt;
	datatypes = {&lt;br /&gt;
		[&amp;#039;commonsMedia&amp;#039;] = &amp;#039;file multimediale su Commons&amp;#039;,&lt;br /&gt;
		[&amp;#039;external-id&amp;#039;] = &amp;#039;identificativo esterno&amp;#039;,&lt;br /&gt;
		[&amp;#039;geo-shape&amp;#039;] = &amp;#039;forma geografica&amp;#039;,&lt;br /&gt;
		[&amp;#039;globe-coordinate&amp;#039;] = &amp;#039;coordinate geografiche&amp;#039;,&lt;br /&gt;
		[&amp;#039;math&amp;#039;] = &amp;#039;espressione matematica&amp;#039;,&lt;br /&gt;
		[&amp;#039;monolingualtext&amp;#039;] = &amp;#039;testo monolingua&amp;#039;,&lt;br /&gt;
		[&amp;#039;quantity&amp;#039;] = &amp;#039;quantità&amp;#039;,&lt;br /&gt;
		[&amp;#039;string&amp;#039;] = &amp;#039;stringa&amp;#039;,&lt;br /&gt;
		[&amp;#039;tabular-data&amp;#039;] = &amp;#039;tabular data&amp;#039;,&lt;br /&gt;
		[&amp;#039;time&amp;#039;] = &amp;#039;data e ora&amp;#039;,&lt;br /&gt;
		[&amp;#039;url&amp;#039;] = &amp;#039;URL&amp;#039;,&lt;br /&gt;
		[&amp;#039;wikibase-item&amp;#039;] = &amp;#039;elemento&amp;#039;,&lt;br /&gt;
		[&amp;#039;wikibase-property&amp;#039;] = &amp;#039;proprietà&amp;#039;&lt;br /&gt;
	}&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
local p = {}&lt;br /&gt;
&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
--                             Formatters&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
local function errhandler(msg)&lt;br /&gt;
	local cat = mw.title.getCurrentTitle().namespace == 0 and errorCategory or &amp;#039;&amp;#039;&lt;br /&gt;
	return string.format(&amp;#039;&amp;lt;span class=&amp;quot;error&amp;quot;&amp;gt;%s&amp;lt;/span&amp;gt;%s&amp;#039;, msg, cat)&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
local function formatList(values, ordered)&lt;br /&gt;
	local fmt = ordered and &amp;#039;&amp;lt;ol&amp;gt;&amp;lt;li&amp;gt;%s&amp;lt;/li&amp;gt;&amp;lt;/ol&amp;gt;&amp;#039; or &amp;#039;&amp;lt;ul&amp;gt;&amp;lt;li&amp;gt;%s&amp;lt;/li&amp;gt;&amp;lt;/ul&amp;gt;&amp;#039;&lt;br /&gt;
	return #values &amp;gt; 0 and string.format(fmt, mw.text.listToText(values, &amp;#039;&amp;lt;/li&amp;gt;&amp;lt;li&amp;gt;&amp;#039;, &amp;#039;&amp;lt;/li&amp;gt;&amp;lt;li&amp;gt;&amp;#039;)) or &amp;#039;&amp;#039;&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
local function formatExtLink(url)&lt;br /&gt;
	local protocols = { ftp = true, http = true, https = true }&lt;br /&gt;
&lt;br /&gt;
	local success, uri = pcall(function() return mw.uri.new(url) end)&lt;br /&gt;
	if success and uri.protocol and protocols[uri.protocol] then&lt;br /&gt;
		local dest = tostring(uri)&lt;br /&gt;
		return string.format(&amp;#039;&amp;lt;span style=&amp;quot;word-break: break-all;&amp;quot;&amp;gt;[%s %s]&amp;lt;/span&amp;gt;&amp;#039;, dest, dest:gsub(uri.protocol .. &amp;#039;://&amp;#039;, &amp;#039;&amp;#039;))	&lt;br /&gt;
	else&lt;br /&gt;
		return url&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
local function formatEntityId(entityId)&lt;br /&gt;
	local label = mw.wikibase.getLabel(entityId)&lt;br /&gt;
	local siteLink = mw.wikibase.getSitelink(entityId)&lt;br /&gt;
	local ret&lt;br /&gt;
	if entityId == mw.wikibase.getEntityIdForCurrentPage() then&lt;br /&gt;
		ret = siteLink&lt;br /&gt;
	elseif siteLink and label then&lt;br /&gt;
		ret = mw.getContentLanguage():ucfirst(label) == siteLink and&lt;br /&gt;
			  string.format(&amp;#039;[[%s]]&amp;#039;, label) or&lt;br /&gt;
			  string.format(&amp;#039;[[%s|%s]]&amp;#039;, siteLink, label)&lt;br /&gt;
	elseif siteLink then&lt;br /&gt;
		ret = string.format(&amp;#039;[[%s]]&amp;#039;, siteLink)&lt;br /&gt;
	elseif label then&lt;br /&gt;
		ret = label&lt;br /&gt;
	else&lt;br /&gt;
		ret = &amp;#039;&amp;#039;&lt;br /&gt;
	end&lt;br /&gt;
	return ret&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
local function formatMonolingualtext(value, args)&lt;br /&gt;
	local ret = &amp;#039;&amp;#039;&lt;br /&gt;
	if not args.includelang or args.includelang:match(&amp;#039;%f[a-z]&amp;#039; .. value.language .. &amp;#039;%f[^a-z]&amp;#039;) then&lt;br /&gt;
		if not args.excludelang or not args.excludelang:match(&amp;#039;%f[a-z]&amp;#039; .. value.language .. &amp;#039;%f[^a-z]&amp;#039;) then&lt;br /&gt;
			ret = value.text&lt;br /&gt;
			if args.showlang then&lt;br /&gt;
				ret = mLanguages.lingue({ value.language }) .. &amp;#039;&amp;amp;nbsp;&amp;#039; .. ret&lt;br /&gt;
			end&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	return ret&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
local function formatTimeWithPrecision(time, precision)&lt;br /&gt;
	local months = {&lt;br /&gt;
		&amp;#039;gennaio&amp;#039;, &amp;#039;febbraio&amp;#039;, &amp;#039;marzo&amp;#039;, &amp;#039;aprile&amp;#039;, &amp;#039;maggio&amp;#039;, &amp;#039;giugno&amp;#039;,&lt;br /&gt;
		&amp;#039;luglio&amp;#039;, &amp;#039;agosto&amp;#039;, &amp;#039;settembre&amp;#039;, &amp;#039;ottobre&amp;#039;, &amp;#039;novembre&amp;#039;, &amp;#039;dicembre&amp;#039;&lt;br /&gt;
	}&lt;br /&gt;
	local ret, year, month, day&lt;br /&gt;
 &lt;br /&gt;
	year, month, day = time:match(&amp;#039;(%d+)%-(%d%d)%-(%d%d).+&amp;#039;)&lt;br /&gt;
	year, month, day = tonumber(year), tonumber(month), tonumber(day)&lt;br /&gt;
	if precision == 9 then&lt;br /&gt;
		ret = year&lt;br /&gt;
	elseif precision == 10 then&lt;br /&gt;
		ret = months[month] .. &amp;#039; &amp;#039; .. year&lt;br /&gt;
	elseif precision == 11 then&lt;br /&gt;
		ret = day .. &amp;#039; &amp;#039; .. months[month] .. &amp;#039; &amp;#039; .. year&lt;br /&gt;
		ret = ret:gsub(&amp;#039;^1%s&amp;#039;, &amp;#039;1º &amp;#039;)&lt;br /&gt;
	end&lt;br /&gt;
	if precision &amp;gt;= 9 and precision &amp;lt;= 11 then&lt;br /&gt;
		ret = ret .. (time:sub(1, 1) == &amp;#039;-&amp;#039; and &amp;#039; a.C.&amp;#039; or &amp;#039;&amp;#039;)&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	return ret&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
local function formatTime(value, args)&lt;br /&gt;
	local ret&lt;br /&gt;
 &lt;br /&gt;
	if args.time == &amp;#039;precision&amp;#039; then&lt;br /&gt;
		ret = value.precision&lt;br /&gt;
	elseif args.time == &amp;#039;calendarmodel&amp;#039; then&lt;br /&gt;
		ret = value.calendarmodel&lt;br /&gt;
	elseif args.time == &amp;#039;year&amp;#039; and value.precision &amp;gt;= 9 then&lt;br /&gt;
		ret = formatTimeWithPrecision(value.time, 9)&lt;br /&gt;
	elseif args.time == &amp;#039;month&amp;#039; and value.precision &amp;gt;= 10 then&lt;br /&gt;
		ret = formatTimeWithPrecision(value.time, 10)&lt;br /&gt;
	elseif args.time == &amp;#039;day&amp;#039; and value.precision &amp;gt;= 11 then&lt;br /&gt;
		ret = formatTimeWithPrecision(value.time, 11)&lt;br /&gt;
	elseif not args.time then&lt;br /&gt;
		ret = formatTimeWithPrecision(value.time, value.precision)&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	return ret or &amp;#039;&amp;#039;&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
local function formatGlobecoordinate(value, args)&lt;br /&gt;
	local ret&lt;br /&gt;
	if args.coord == &amp;#039;latitude&amp;#039; then&lt;br /&gt;
		ret = value.latitude&lt;br /&gt;
	elseif args.coord == &amp;#039;longitude&amp;#039; then&lt;br /&gt;
		ret = value.longitude&lt;br /&gt;
	elseif args.coord == &amp;#039;globe&amp;#039; then&lt;br /&gt;
		ret = value.globe&lt;br /&gt;
	else&lt;br /&gt;
		ret = string.format(&amp;#039;%s, %s&amp;#039;, value.latitude, value.longitude)&lt;br /&gt;
	end&lt;br /&gt;
	return ret&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
local function formatFromPattern(str, args)&lt;br /&gt;
	local pattern = args.pattern&lt;br /&gt;
	pattern = mw.ustring.gsub(pattern, &amp;#039;\\{&amp;#039;, &amp;#039;{&amp;#039;)&lt;br /&gt;
	pattern = mw.ustring.gsub(pattern, &amp;#039;\\}&amp;#039;, &amp;#039;}&amp;#039;)&lt;br /&gt;
	return mw.getCurrentFrame():preprocess(mw.message.newRawMessage(pattern, str):plain())&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
local function formatUserValue(value, args)&lt;br /&gt;
	if args.extlink then&lt;br /&gt;
		value = formatExtLink(value)&lt;br /&gt;
	end&lt;br /&gt;
	return args.pattern and formatFromPattern(value, args) or value&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
local function getEntityIdFromValue(value)&lt;br /&gt;
	local prefix = &amp;#039;&amp;#039;&lt;br /&gt;
	if value[&amp;#039;entity-type&amp;#039;] == &amp;#039;item&amp;#039; then&lt;br /&gt;
		prefix = &amp;#039;Q&amp;#039;&lt;br /&gt;
	elseif value[&amp;#039;entity-type&amp;#039;] == &amp;#039;property&amp;#039; then&lt;br /&gt;
		prefix = &amp;#039;P&amp;#039;&lt;br /&gt;
	else&lt;br /&gt;
		error(i18n.errors[&amp;#039;unknown-entity-type&amp;#039;])&lt;br /&gt;
	end&lt;br /&gt;
	return prefix .. value[&amp;#039;numeric-id&amp;#039;]&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
local function formatUnitSymbol(entityId, args)&lt;br /&gt;
	local ret&lt;br /&gt;
	for _, lang in ipairs({ &amp;#039;mul&amp;#039;, &amp;#039;it&amp;#039;, &amp;#039;en&amp;#039; }) do&lt;br /&gt;
		ret = p._getProperty({ &amp;#039;P5061&amp;#039;, includelang = lang, from = entityId })&lt;br /&gt;
		if ret and ret ~= &amp;#039;&amp;#039; then&lt;br /&gt;
			break&lt;br /&gt;
		else&lt;br /&gt;
			ret = nil&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	local space = ret == &amp;#039;°&amp;#039; and &amp;#039;&amp;#039; or &amp;#039; &amp;#039;&lt;br /&gt;
	if ret and args.showunitlink then&lt;br /&gt;
		local link = mw.wikibase.getSitelink(entityId)&lt;br /&gt;
		if link then&lt;br /&gt;
			ret = string.format(&amp;#039;[[%s|%s]]&amp;#039;, link, ret)&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	return ret and (space .. ret) or &amp;#039;&amp;#039;&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
-- http://lua-users.org/wiki/SimpleRound&lt;br /&gt;
local function round(num, idp)&lt;br /&gt;
	local mult = 10 ^ (idp or 0)&lt;br /&gt;
	return math.floor(num * mult + 0.5) / mult&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
local function formatQuantity(value, args)&lt;br /&gt;
	local ret = tonumber(value.amount)&lt;br /&gt;
&lt;br /&gt;
	if (args.unit or args.showunit) and value.unit ~= &amp;#039;1&amp;#039; then&lt;br /&gt;
		local unitId = mw.ustring.match(value.unit, &amp;#039;Q%d+&amp;#039;)&lt;br /&gt;
		if args.unit then&lt;br /&gt;
			local opts = {&lt;br /&gt;
				showunit = args.showunit,&lt;br /&gt;
				showunitlink = args.showunitlink,&lt;br /&gt;
				formatnum = args.formatnum,&lt;br /&gt;
				rounding = args.rounding&lt;br /&gt;
			}&lt;br /&gt;
			ret = mConvert._main(ret, unitId, args.unit, opts)&lt;br /&gt;
		else&lt;br /&gt;
			-- se è richiesto solo il simbolo dell&amp;#039;unità&lt;br /&gt;
			-- senza la conversione lo ottiene da P5061&lt;br /&gt;
			ret = args.rounding and round(ret, args.rounding) or ret&lt;br /&gt;
			if args.formatnum then&lt;br /&gt;
				ret = mw.language.getContentLanguage():formatNum(ret)&lt;br /&gt;
			end&lt;br /&gt;
			ret = ret .. formatUnitSymbol(unitId, args)&lt;br /&gt;
		end&lt;br /&gt;
	elseif args.formatnum then&lt;br /&gt;
		ret = args.rounding and round(ret, args.rounding) or ret&lt;br /&gt;
		ret = mw.language.getContentLanguage():formatNum(ret)&lt;br /&gt;
	elseif args.formatduration and value.unit ~= &amp;#039;1&amp;#039; then&lt;br /&gt;
		local unitId = mw.ustring.match(value.unit, &amp;#039;Q%d+&amp;#039;)&lt;br /&gt;
		ret = mConvert._main(ret, unitId, &amp;#039;second&amp;#039;)&lt;br /&gt;
		ret = ret and mw.language.getContentLanguage()&lt;br /&gt;
				:formatDuration(tonumber(ret), { &amp;#039;days&amp;#039;, &amp;#039;hours&amp;#039;, &amp;#039;minutes&amp;#039;, &amp;#039;seconds&amp;#039; })&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	return ret&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
local function formatDatavalue(datavalue, snakdatatype, args)&lt;br /&gt;
	local ret&lt;br /&gt;
&lt;br /&gt;
	if datavalue.type == &amp;#039;wikibase-entityid&amp;#039; then&lt;br /&gt;
		local entityId = getEntityIdFromValue(datavalue.value)&lt;br /&gt;
		if args.showprop then&lt;br /&gt;
			ret = p._getProperty({ args.showprop, n = 1, from = entityId, formatting = args.formatting }) or &amp;#039;&amp;#039;&lt;br /&gt;
		elseif args.formatting then&lt;br /&gt;
			local formatting = args.formatting:lower()&lt;br /&gt;
			ret = (formatting == &amp;#039;raw&amp;#039; or formatting == &amp;#039;id&amp;#039;) and entityId or&lt;br /&gt;
				formatting == &amp;#039;label&amp;#039; and mw.wikibase.getLabel(entityId) or&lt;br /&gt;
				formatting == &amp;#039;title&amp;#039; and (mw.wikibase.getSitelink(entityId) or &amp;#039;&amp;#039;) or&lt;br /&gt;
				error(i18n.errors[&amp;#039;unknown-output-format&amp;#039;])&lt;br /&gt;
		else&lt;br /&gt;
			ret = formatEntityId(entityId)&lt;br /&gt;
		end&lt;br /&gt;
	elseif datavalue.type == &amp;#039;string&amp;#039; then&lt;br /&gt;
		ret = datavalue.value&lt;br /&gt;
		if args.extlink and snakdatatype == &amp;#039;url&amp;#039; then&lt;br /&gt;
			ret = formatExtLink(ret)&lt;br /&gt;
		elseif args.urlencode then&lt;br /&gt;
			ret = mw.uri.encode(ret)&lt;br /&gt;
		end&lt;br /&gt;
	elseif datavalue.type == &amp;#039;monolingualtext&amp;#039; then&lt;br /&gt;
		ret = formatMonolingualtext(datavalue.value, args)&lt;br /&gt;
	elseif datavalue.type == &amp;#039;time&amp;#039; then&lt;br /&gt;
		if args.formatting == &amp;#039;raw&amp;#039; then&lt;br /&gt;
			ret = datavalue.value.time&lt;br /&gt;
		else&lt;br /&gt;
			ret = formatTime(datavalue.value, args)&lt;br /&gt;
		end&lt;br /&gt;
	elseif datavalue.type == &amp;#039;globecoordinate&amp;#039; then&lt;br /&gt;
		ret = formatGlobecoordinate(datavalue.value, args)&lt;br /&gt;
	elseif datavalue.type == &amp;#039;quantity&amp;#039; then&lt;br /&gt;
		ret = formatQuantity(datavalue.value, args)&lt;br /&gt;
	else&lt;br /&gt;
		error(i18n.errors[&amp;#039;unknown-datavalue-type&amp;#039;])&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	return ret&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
local function formatSnak(snak, args)&lt;br /&gt;
	if snak.snaktype == &amp;#039;somevalue&amp;#039; then&lt;br /&gt;
		return i18n[&amp;#039;somevalue&amp;#039;]&lt;br /&gt;
	elseif snak.snaktype == &amp;#039;novalue&amp;#039; then&lt;br /&gt;
		return i18n[&amp;#039;novalue&amp;#039;]&lt;br /&gt;
	elseif snak.snaktype == &amp;#039;value&amp;#039; then&lt;br /&gt;
		return formatDatavalue(snak.datavalue, snak.datatype, args)&lt;br /&gt;
	else&lt;br /&gt;
		error(i18n.errors[&amp;#039;unknown-snak-type&amp;#039;])&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
-- È al plurale perché anche i qualifier possono avere più di un valore&lt;br /&gt;
-- (si ottiene inserendo due volte lo stesso qualifier)&lt;br /&gt;
local function formatQualifiers(claim, qualifierId, args, rawTable, retTable)&lt;br /&gt;
	local formattedQualifiers = retTable or {}&lt;br /&gt;
&lt;br /&gt;
	if claim.qualifiers and claim.qualifiers[qualifierId] then&lt;br /&gt;
		local qualifiers = claim.qualifiers[qualifierId]&lt;br /&gt;
		-- con args.nq seleziona solo l&amp;#039;n-esimo qualifier&lt;br /&gt;
		if args.nq then&lt;br /&gt;
			local n = tonumber(args.nq)&lt;br /&gt;
			qualifiers = (n and n &amp;lt;= #qualifiers) and { qualifiers[n] } or {}&lt;br /&gt;
		end&lt;br /&gt;
		-- qualifier filtrati per snaktype, default &amp;quot;value&amp;quot;&lt;br /&gt;
		args.snaktype = args.snaktype or &amp;#039;value&amp;#039;&lt;br /&gt;
		for _, qualifier in ipairs(qualifiers) do&lt;br /&gt;
			if qualifier.snaktype == args.snaktype or args.snaktype == &amp;#039;all&amp;#039; then&lt;br /&gt;
				local formattedQualifier = formatSnak(qualifier, args)&lt;br /&gt;
				if formattedQualifier ~= &amp;#039;&amp;#039; then&lt;br /&gt;
					if args.pattern then&lt;br /&gt;
						formattedQualifier = formatFromPattern(formattedQualifier, args)&lt;br /&gt;
						if formattedQualifier ~= &amp;#039;&amp;#039; then&lt;br /&gt;
							table.insert(formattedQualifiers, formattedQualifier)&lt;br /&gt;
						end&lt;br /&gt;
					else&lt;br /&gt;
						table.insert(formattedQualifiers, formattedQualifier)&lt;br /&gt;
					end&lt;br /&gt;
				end&lt;br /&gt;
			end&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	if rawTable then&lt;br /&gt;
		return formattedQualifiers&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	return #formattedQualifiers &amp;gt; 0 and&lt;br /&gt;
		   mw.text.listToText(formattedQualifiers, args.separator, args.conjunction) or nil&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
local function appendQualifiers(statement, text, args)&lt;br /&gt;
	local formattedQualifiers = {}&lt;br /&gt;
	local qualifierIds = mw.text.split(args.showqualifiers, &amp;#039;,&amp;#039;)&lt;br /&gt;
	for _, qualifierId in ipairs(qualifierIds) do&lt;br /&gt;
		if statement.qualifiers[qualifierId] then&lt;br /&gt;
			local formattedQualifier = formatQualifiers(statement, qualifierId, args)&lt;br /&gt;
			table.insert(formattedQualifiers, formattedQualifier)&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	if #formattedQualifiers &amp;gt; 0 then&lt;br /&gt;
		text = string.format(&amp;#039;%s (%s)&amp;#039;, text, mw.text.listToText(formattedQualifiers, &amp;#039;, &amp;#039;, &amp;#039;, &amp;#039;))&lt;br /&gt;
	end&lt;br /&gt;
	return text&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
local function formatStatement(statement, args)&lt;br /&gt;
	if not statement.type or statement.type ~= &amp;#039;statement&amp;#039; then&lt;br /&gt;
		error(i18n.errors[&amp;#039;unknown-claim-type&amp;#039;])&lt;br /&gt;
	end&lt;br /&gt;
 &lt;br /&gt;
	local ret = formatSnak(statement.mainsnak, args)&lt;br /&gt;
	-- eventuale showqualifiers&lt;br /&gt;
	if args.showqualifiers and statement.qualifiers then&lt;br /&gt;
		ret = appendQualifiers(statement, ret, args)&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	return ret&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
local function formatStatements(claims, args, rawTable)&lt;br /&gt;
	local formattedStatements = {}&lt;br /&gt;
&lt;br /&gt;
	for _, claim in ipairs(claims) do&lt;br /&gt;
		local formattedStatement = formatStatement(claim, args)&lt;br /&gt;
		if formattedStatement ~= &amp;#039;&amp;#039; then&lt;br /&gt;
			-- eventuale pattern&lt;br /&gt;
			if args.pattern then&lt;br /&gt;
				formattedStatement = formatFromPattern(formattedStatement, args)&lt;br /&gt;
				if formattedStatement ~= &amp;#039;&amp;#039; then&lt;br /&gt;
					table.insert(formattedStatements, formattedStatement)&lt;br /&gt;
				end&lt;br /&gt;
			else&lt;br /&gt;
				table.insert(formattedStatements, formattedStatement)&lt;br /&gt;
			end&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	if rawTable then&lt;br /&gt;
		return formattedStatements&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	return ((args.list or args.orderedlist) and #formattedStatements &amp;gt; 1) and&lt;br /&gt;
		   formatList(formattedStatements, args.orderedlist ~= nil) or &lt;br /&gt;
		   mw.text.listToText(formattedStatements, args.separator, args.conjunction)&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
--                      Lettura e selezione statement&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
-- Restituisce true se lo statement contiene il qualifier richiesto con un dato valore (o uno tra più valori separati da virgola)&lt;br /&gt;
local function hasQualifierValue(statement, qualifierId, qualifierValue)&lt;br /&gt;
	local ret = false&lt;br /&gt;
	for _, qualifier in ipairs(statement.qualifiers[qualifierId]) do&lt;br /&gt;
		local isItem = qualifier.snaktype == &amp;#039;value&amp;#039; and&lt;br /&gt;
					   qualifier.datavalue.type == &amp;#039;wikibase-entityid&amp;#039;&lt;br /&gt;
		local qualifierValues = mw.text.split(qualifierValue, &amp;#039;,&amp;#039;)&lt;br /&gt;
		for _, qualifierHas in ipairs(qualifierValues) do&lt;br /&gt;
			-- per le proprietà di tipo item il confronto è eseguito sull&amp;#039;id&lt;br /&gt;
			if formatSnak(qualifier, isItem and { formatting = &amp;#039;raw&amp;#039; } or {}) == qualifierHas then&lt;br /&gt;
				ret = true&lt;br /&gt;
				break&lt;br /&gt;
			end&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	return ret&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
-- Restituisce i claim con il rank richiesto&lt;br /&gt;
local function filterRankValue(claims, rank)&lt;br /&gt;
	local ret = {}&lt;br /&gt;
	for _, claim in ipairs(claims) do&lt;br /&gt;
		if claim.rank == rank then&lt;br /&gt;
			table.insert(ret, claim)&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	return ret&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
-- Restituisce una sequence Lua contenente gli statement per la property richiesta,&lt;br /&gt;
-- anche vuota se la proprietà non esiste, o non ci sono valori che soddisfano i criteri&lt;br /&gt;
-- (&amp;quot;rank&amp;quot;, &amp;quot;qualifier&amp;quot;, &amp;quot;qualifiertype&amp;quot;, &amp;quot;noqualifier&amp;quot;, ...).&lt;br /&gt;
-- Restituisce nil solo se la pagina non è collegata a un elemento Wikidata e non è indicato il from.&lt;br /&gt;
local function getClaims(propertyId, args)&lt;br /&gt;
	local entityId, claims, filteredClaims&lt;br /&gt;
	&lt;br /&gt;
	entityId = args.from or mw.wikibase.getEntityIdForCurrentPage()&lt;br /&gt;
	if not entityId then&lt;br /&gt;
		return nil&lt;br /&gt;
	end&lt;br /&gt;
	&lt;br /&gt;
	-- il default rank è &amp;#039;best&amp;#039;&lt;br /&gt;
	args.rank = args.rank or &amp;#039;best&amp;#039;&lt;br /&gt;
	if args.rank == &amp;#039;best&amp;#039; then&lt;br /&gt;
		claims = mw.wikibase.getBestStatements(entityId, propertyId)&lt;br /&gt;
	else&lt;br /&gt;
		-- statements filtrati per rank&lt;br /&gt;
		claims = mw.wikibase.getAllStatements(entityId, propertyId)&lt;br /&gt;
		claims = filterRankValue(claims, args.rank)&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	-- statements filtrati per snaktype, default &amp;quot;value&amp;quot;&lt;br /&gt;
	args.snaktype = args.snaktype or &amp;#039;value&amp;#039;&lt;br /&gt;
	if args.snaktype and args.snaktype ~= &amp;#039;all&amp;#039; then&lt;br /&gt;
		filteredClaims = {}&lt;br /&gt;
		for _, claim in ipairs(claims) do&lt;br /&gt;
			if claim.mainsnak.snaktype == args.snaktype then&lt;br /&gt;
				table.insert(filteredClaims, claim)&lt;br /&gt;
			end&lt;br /&gt;
		end&lt;br /&gt;
		claims = filteredClaims&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	-- statements filtrati per qualifier&lt;br /&gt;
	if args.qualifier then&lt;br /&gt;
		filteredClaims = {}&lt;br /&gt;
		for _, claim in ipairs(claims) do&lt;br /&gt;
			if claim.qualifiers and claim.qualifiers[args.qualifier] then&lt;br /&gt;
				if args.qualifiervalue then&lt;br /&gt;
					if hasQualifierValue(claim, args.qualifier, args.qualifiervalue) then&lt;br /&gt;
						table.insert(filteredClaims, claim)&lt;br /&gt;
					end&lt;br /&gt;
				else&lt;br /&gt;
					table.insert(filteredClaims, claim)&lt;br /&gt;
				end&lt;br /&gt;
			end&lt;br /&gt;
		end&lt;br /&gt;
		claims = filteredClaims&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	-- statements filtrati per essere senza un qualifier&lt;br /&gt;
	if args.noqualifier then&lt;br /&gt;
		filteredClaims = {}&lt;br /&gt;
		for _, claim in ipairs(claims) do&lt;br /&gt;
			if not (claim.qualifiers and claim.qualifiers[args.noqualifier]) then&lt;br /&gt;
				table.insert(filteredClaims, claim)&lt;br /&gt;
			end&lt;br /&gt;
		end&lt;br /&gt;
		claims = filteredClaims&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	-- statements filtrati per non avere un certo valore a un certo qualifier opzionale&lt;br /&gt;
	if args.qualifieroptnovalue and args.qualifiervalue then&lt;br /&gt;
		filteredClaims = {}&lt;br /&gt;
		for _, claim in ipairs(claims) do&lt;br /&gt;
			if claim.qualifiers and claim.qualifiers[args.qualifieroptnovalue] then&lt;br /&gt;
				if not hasQualifierValue(claim, args.qualifieroptnovalue, args.qualifiervalue) then&lt;br /&gt;
					table.insert(filteredClaims, claim)&lt;br /&gt;
				end&lt;br /&gt;
			else&lt;br /&gt;
				table.insert(filteredClaims, claim)&lt;br /&gt;
			end&lt;br /&gt;
		end&lt;br /&gt;
		claims = filteredClaims&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	-- con args.qualifiertype=latest restituisce solo il più recente&lt;br /&gt;
	if args.qualifier and args.qualifiertype == &amp;#039;latest&amp;#039; then&lt;br /&gt;
		local latest, latestTime&lt;br /&gt;
		for _, claim in ipairs(claims) do&lt;br /&gt;
			if claim.qualifiers and claim.qualifiers[args.qualifier] then&lt;br /&gt;
				for _, qualifier in ipairs(claim.qualifiers[args.qualifier]) do&lt;br /&gt;
					if qualifier.datavalue.type == &amp;#039;time&amp;#039; then&lt;br /&gt;
						if not latestTime or qualifier.datavalue.value.time &amp;gt; latestTime then&lt;br /&gt;
							latest = claim&lt;br /&gt;
							latestTime = qualifier.datavalue.value.time&lt;br /&gt;
						end&lt;br /&gt;
					end&lt;br /&gt;
				end&lt;br /&gt;
			end&lt;br /&gt;
		end&lt;br /&gt;
		claims = latest and { latest } or {}&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	-- con args.n restituisce solo l&amp;#039;n-esimo elemento&lt;br /&gt;
	if args.n then&lt;br /&gt;
		local n = tonumber(args.n)&lt;br /&gt;
		claims = (n and n &amp;lt;= #claims) and { claims[n] } or {}&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	return claims&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
--                  Funzioni esportate per altri moduli&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
function p._getClaims(propertyId, args)&lt;br /&gt;
	return getClaims(propertyId, args or {})&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function p._formatStatement(statement, args)&lt;br /&gt;
	return formatStatement(statement, args or {})&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function p._formatQualifiers(claim, qualifierId, args, rawTable, retTable)&lt;br /&gt;
	return formatQualifiers(claim, qualifierId, args or {}, rawTable, retTable)&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
-- Restituisce il valore di una proprietà di Wikidata oppure nil se l&amp;#039;entity o&lt;br /&gt;
-- la proprietà non esistono, o se per parametri di selezione gli statement sono zero.&lt;br /&gt;
function p._getProperty(args, rawTable)&lt;br /&gt;
	local propertyId, value, claims, ret&lt;br /&gt;
&lt;br /&gt;
	-- parametri posizionali&lt;br /&gt;
	propertyId = args[1] and string.upper(args[1])&lt;br /&gt;
	if not propertyId then&lt;br /&gt;
		error(i18n.errors[&amp;#039;property-param-not-provided&amp;#039;], 2)&lt;br /&gt;
	end&lt;br /&gt;
	value = args[2]&lt;br /&gt;
	-- fix uppercase&lt;br /&gt;
	args.qualifier = args.qualifier and string.upper(args.qualifier)&lt;br /&gt;
&lt;br /&gt;
	if value then&lt;br /&gt;
		ret = formatUserValue(value, args)&lt;br /&gt;
	elseif args.wd ~= &amp;#039;no&amp;#039; then&lt;br /&gt;
		claims = getClaims(propertyId, args)&lt;br /&gt;
		ret = (claims and #claims &amp;gt; 0) and formatStatements(claims, args, rawTable) or nil&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	return ret&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
-- Restituisce il valore di un qualifier di una proprietà di Wikidata,&lt;br /&gt;
-- o nil se l&amp;#039;entity o la proprietà non esistono, o se per parametri di selezione non ci sono risultati.&lt;br /&gt;
function p._getQualifier(args)&lt;br /&gt;
	local propertyId, qualifierId, value, claims, ret&lt;br /&gt;
&lt;br /&gt;
	-- parametri posizionali&lt;br /&gt;
	propertyId = args[1] and string.upper(args[1])&lt;br /&gt;
	if not propertyId then&lt;br /&gt;
		error(i18n.errors[&amp;#039;property-param-not-provided&amp;#039;], 2)&lt;br /&gt;
	end&lt;br /&gt;
	qualifierId = args[2] and string.upper(args[2])&lt;br /&gt;
	if not qualifierId then&lt;br /&gt;
		error(i18n.errors[&amp;#039;qualifier-param-not-provided&amp;#039;], 2)&lt;br /&gt;
	end&lt;br /&gt;
	value = args[3]&lt;br /&gt;
&lt;br /&gt;
	if value then&lt;br /&gt;
		ret = formatUserValue(value, args)&lt;br /&gt;
	elseif args.wd ~= &amp;#039;no&amp;#039; then&lt;br /&gt;
		claims = getClaims(propertyId, args)&lt;br /&gt;
		if claims and #claims &amp;gt; 0 then&lt;br /&gt;
			local formattedQualifiers = {}&lt;br /&gt;
			for _, claim in ipairs(claims) do&lt;br /&gt;
				formattedQualifiers = formatQualifiers(claim, qualifierId, args, true, formattedQualifiers)&lt;br /&gt;
			end&lt;br /&gt;
			ret = #formattedQualifiers &amp;gt; 0 and&lt;br /&gt;
				  mw.text.listToText(formattedQualifiers, args.separator, args.conjunction) or nil&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	return ret&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
-- Restituisce l&amp;#039;indice dello statement con il valore richiesto, o nil se non trovato.&lt;br /&gt;
function p._indexOf(args)&lt;br /&gt;
	local ret, propertyId, value, claims&lt;br /&gt;
&lt;br /&gt;
	-- parametri posizionali&lt;br /&gt;
	propertyId = args[1] and string.upper(args[1])&lt;br /&gt;
	if not propertyId then&lt;br /&gt;
		error(i18n.errors[&amp;#039;property-param-not-provided&amp;#039;], 2)&lt;br /&gt;
	end&lt;br /&gt;
	value = args[2]&lt;br /&gt;
	if not value then&lt;br /&gt;
		error(i18n.errors[&amp;#039;value-param-not-provided&amp;#039;], 2)&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	claims = getClaims(propertyId, args)&lt;br /&gt;
	if claims and #claims &amp;gt; 0 then&lt;br /&gt;
		args.formatting = &amp;#039;raw&amp;#039;&lt;br /&gt;
		for i, claim in ipairs(claims) do&lt;br /&gt;
			if formatStatement(claim, args) == value then&lt;br /&gt;
				ret = i&lt;br /&gt;
				break&lt;br /&gt;
			end&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	return ret&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
-- Restituisce il numero di statement di una proprietà di Wikidata.&lt;br /&gt;
function p._N(args)&lt;br /&gt;
	local propertyId, claims&lt;br /&gt;
&lt;br /&gt;
	-- parametri posizionali&lt;br /&gt;
	propertyId = args[1] and string.upper(args[1])&lt;br /&gt;
	if not propertyId then&lt;br /&gt;
		error(i18n.errors[&amp;#039;property-param-not-provided&amp;#039;], 2)&lt;br /&gt;
	end&lt;br /&gt;
	-- get claims&lt;br /&gt;
	claims = getClaims(propertyId, args)&lt;br /&gt;
&lt;br /&gt;
	return claims and #claims or 0&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
-- Restituisce true se la propriertà specificata ha come valore&lt;br /&gt;
-- almeno uno tra gli entityId passati come argomento.&lt;br /&gt;
function p._propertyHasEntity(propertyId, args)&lt;br /&gt;
	local statements = p._getProperty({ propertyId, from = args.from, formatting = &amp;#039;raw&amp;#039; }, true)&lt;br /&gt;
	if statements then&lt;br /&gt;
		for _, statement in ipairs(statements) do&lt;br /&gt;
			for _, entityId in ipairs(args) do&lt;br /&gt;
				if statement == entityId then&lt;br /&gt;
					return true&lt;br /&gt;
				end&lt;br /&gt;
			end&lt;br /&gt;
		end&lt;br /&gt;
&lt;br /&gt;
		-- Se non è stato trovato alcun valore, controlla se questo sia ereditato&lt;br /&gt;
		-- tramite la proprietà &amp;quot;sottoclasse di&amp;quot; (P279) scavando in profondità&lt;br /&gt;
		-- fino all&amp;#039;esaurirsi del numero specificato in args.recursion.&lt;br /&gt;
		--[[ TODO: Valutare se sia opportuna una ricerca ricorsiva potenzialmente infinita.&lt;br /&gt;
			Per farlo si può aggiungere un parametro (opzionale) maxDepth&lt;br /&gt;
			che svolga l&amp;#039;attuale funzione di recursion e cambiare quest&amp;#039;ultimo&lt;br /&gt;
			in un parametro booleano.&lt;br /&gt;
		]]&lt;br /&gt;
		args.recursion = tonumber(args.recursion) or 0&lt;br /&gt;
		if args.recursion &amp;gt; 0 then&lt;br /&gt;
			local recursion = args.recursion&lt;br /&gt;
			if type(args.loadedEntities) ~= &amp;#039;table&amp;#039; then&lt;br /&gt;
				args.loadedEntities = setmetatable({}, {&lt;br /&gt;
					__newindex = function(t, k, v)&lt;br /&gt;
						rawset(t, k, v)&lt;br /&gt;
						rawset(t, #t+1, k)&lt;br /&gt;
					end })&lt;br /&gt;
				args.loadedEntities[args.from or mw.wikibase.getEntityIdForCurrentPage()] = true&lt;br /&gt;
			end&lt;br /&gt;
			for _, statement in ipairs(statements) do&lt;br /&gt;
				if not args.loadedEntities[statement] then&lt;br /&gt;
					args.loadedEntities[statement] = true&lt;br /&gt;
					args.recursion = args.recursion - 1&lt;br /&gt;
					args.from = statement&lt;br /&gt;
					if p._propertyHasEntity(&amp;#039;P279&amp;#039;, args) then&lt;br /&gt;
						return true, args.loadedEntities&lt;br /&gt;
					end&lt;br /&gt;
					args.recursion = recursion&lt;br /&gt;
				end&lt;br /&gt;
			end&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	return false, args.loadedEntities&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
-- Restituisce true se la proprietà P31 (instance of) ha come valore almeno uno tra gli entityId specificati&lt;br /&gt;
function p._instanceOf(args)&lt;br /&gt;
	return p._propertyHasEntity(&amp;#039;P31&amp;#039;, args)&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
-- Restituisce true se la proprietà P279 (subclass of) ha come valore almeno uno tra gli entityId specificati&lt;br /&gt;
function p._subclassOf(args)&lt;br /&gt;
	return p._propertyHasEntity(&amp;#039;P279&amp;#039;, args)&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
-- Restituisce l&amp;#039;etichetta di un item o di una proprietà Wikidata.&lt;br /&gt;
function p._getLabel(args)&lt;br /&gt;
	local entityId = args[1] and string.upper(args[1])&lt;br /&gt;
	local ret&lt;br /&gt;
	if args[2] then&lt;br /&gt;
		ret = mw.wikibase.getLabelByLang(entityId, args[2])&lt;br /&gt;
	else&lt;br /&gt;
		ret = mw.wikibase.getLabel(entityId)&lt;br /&gt;
	end&lt;br /&gt;
	return ret&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
-- Restituisce la descrizione di un item o di una proprietà Wikidata.&lt;br /&gt;
function p._getDescription(args)&lt;br /&gt;
	local entityId = args[1] and string.upper(args[1])&lt;br /&gt;
	local ret = mw.wikibase.getDescription(entityId)&lt;br /&gt;
	return ret&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
-- Restituisce il titolo della pagina collegata a un dato item Wikidata.&lt;br /&gt;
function p._getLink(args) &lt;br /&gt;
	-- parametri posizionali&lt;br /&gt;
	local entityId = args[1] and string.upper(args[1])&lt;br /&gt;
	if not entityId then&lt;br /&gt;
		error(i18n.errors[&amp;#039;entityid-param-not-provided&amp;#039;], 2)&lt;br /&gt;
	end&lt;br /&gt;
	&lt;br /&gt;
	return entityId:sub(1, 1) == &amp;#039;Q&amp;#039; and formatEntityId(entityId) or nil&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
-- Restituisce il datatype di una proprietà Wikidata.&lt;br /&gt;
function p._getDatatype(args) &lt;br /&gt;
	local propertyId, entity&lt;br /&gt;
&lt;br /&gt;
	-- parametri posizionali&lt;br /&gt;
	propertyId = args[1] and string.upper(args[1])&lt;br /&gt;
	if not propertyId then&lt;br /&gt;
		error(i18n.errors[&amp;#039;property-param-not-provided&amp;#039;], 2)&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	entity = mw.wikibase.getEntity(propertyId)&lt;br /&gt;
	if not entity then&lt;br /&gt;
		error(i18n.errors[&amp;#039;entity-not-found&amp;#039;], 2)&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	if not i18n.datatypes[entity.datatype] then&lt;br /&gt;
		error(i18n.errors[&amp;#039;unknown-datavalue-type&amp;#039;], 2)&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	return i18n.datatypes[entity.datatype]&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
-- Restituisce l&amp;#039;ID dell&amp;#039;item Wikidata collegato alla pagina corrente o a una pagina specificata&lt;br /&gt;
-- (nota: se il parametro followRedirects è valorizzato con &amp;quot;no&amp;quot;, segue i redirect fermandosi al primo redirect collegato a un elemento)&lt;br /&gt;
function p._getId(args)&lt;br /&gt;
	local ret&lt;br /&gt;
	local followRedirects = not args.followRedirects or args.followRedirects ~= &amp;quot;no&amp;quot;&lt;br /&gt;
	if args[1] then&lt;br /&gt;
		local title = mw.title.new(args[1])&lt;br /&gt;
		while title do&lt;br /&gt;
			local id = mw.wikibase.getEntityIdForTitle(title.prefixedText)&lt;br /&gt;
			if id then&lt;br /&gt;
				ret = id&lt;br /&gt;
				break&lt;br /&gt;
			else&lt;br /&gt;
				title = followRedirects and title.redirectTarget or nil&lt;br /&gt;
			end&lt;br /&gt;
		end&lt;br /&gt;
	else&lt;br /&gt;
		ret = mw.wikibase.getEntityIdForCurrentPage()&lt;br /&gt;
	end&lt;br /&gt;
	return ret&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
--                  Funzioni esportate per i template&lt;br /&gt;
-------------------------------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
-- Funzione per il template {{Wikidata}}&lt;br /&gt;
function p.getProperty(frame)&lt;br /&gt;
	return select(2, xpcall(function()&lt;br /&gt;
		return p._getProperty(getArgs(frame, { parentOnly = true }))&lt;br /&gt;
	end, errhandler))&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
-- Funzione per il template {{WikidataQ}}&lt;br /&gt;
function p.getQualifier(frame)&lt;br /&gt;
	return select(2, xpcall(function()&lt;br /&gt;
		return p._getQualifier(getArgs(frame, { parentOnly = true }))&lt;br /&gt;
	end, errhandler))&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
-- Funzione per il template {{WikidataIdx}}&lt;br /&gt;
function p.indexOf(frame)&lt;br /&gt;
	return select(2, xpcall(function()&lt;br /&gt;
		return p._indexOf(getArgs(frame, { parentOnly = true }))&lt;br /&gt;
	end, errhandler))&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
-- Funzione per il template {{WikidataN}}&lt;br /&gt;
function p.N(frame)&lt;br /&gt;
	return select(2, xpcall(function()&lt;br /&gt;
		return p._N(getArgs(frame, { parentOnly = true }))&lt;br /&gt;
	end, errhandler))&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
-- Funzione per il template {{WikidataLabel}}&lt;br /&gt;
function p.getLabel(frame)&lt;br /&gt;
	return select(2, xpcall(function()&lt;br /&gt;
		return p._getLabel(getArgs(frame, { parentOnly = true }))&lt;br /&gt;
	end, errhandler))&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
-- Funzione per il template {{WikidataDescription}}&lt;br /&gt;
function p.getDescription(frame)&lt;br /&gt;
	return select(2, xpcall(function()&lt;br /&gt;
		return p._getDescription(getArgs(frame, { parentOnly = true }))&lt;br /&gt;
	end, errhandler))&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
-- Funzione per il template {{WikidataLink}}&lt;br /&gt;
function p.getLink(frame)&lt;br /&gt;
	return select(2, xpcall(function()&lt;br /&gt;
		return p._getLink(getArgs(frame, { parentOnly = true }))&lt;br /&gt;
	end, errhandler))&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
-- Funzione per il template {{WikidataIstanza}}&lt;br /&gt;
function p.instanceOf(frame)&lt;br /&gt;
	return select(2, xpcall(function()&lt;br /&gt;
		return p._instanceOf(getArgs(frame, { parentOnly = true })) and 1 or &amp;#039;&amp;#039;&lt;br /&gt;
	end, errhandler))&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
-- Funzione per il template {{WikidataTipo}}&lt;br /&gt;
function p.getDatatype(frame)&lt;br /&gt;
	return select(2, xpcall(function()&lt;br /&gt;
		return p._getDatatype(getArgs(frame, { parentOnly = true }))&lt;br /&gt;
	end, errhandler))&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
-- Funzione per il template {{WikidataId}}&lt;br /&gt;
function p.getId(frame)&lt;br /&gt;
	return select(2, xpcall(function()&lt;br /&gt;
		return p._getId(getArgs(frame, { parentOnly = true }))&lt;br /&gt;
	end, errhandler))&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
-- Funzione per il template {{WikidataValido}}&lt;br /&gt;
function p.checkProperty(frame)&lt;br /&gt;
	return select(2, xpcall(function()&lt;br /&gt;
		return p._N(getArgs(frame, { parentOnly = true })) &amp;gt; 0 and 1 or &amp;#039;&amp;#039;&lt;br /&gt;
	end, errhandler))&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
-- Funzione per il template {{WikidataClasse}}&lt;br /&gt;
function p.propertyHasEntity(frame)&lt;br /&gt;
	local args = getArgs(frame)&lt;br /&gt;
	local propertyId = args[1]&lt;br /&gt;
	return select(2, xpcall(function()&lt;br /&gt;
		return p._propertyHasEntity(propertyId, args) and 1 or &amp;#039;&amp;#039;&lt;br /&gt;
	end, errhandler))&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
return p&lt;/div&gt;</summary>
		<author><name>it__&gt;Horcrux</name></author>
	</entry>
</feed>