<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="ru">
	<id>https://bukvica.org/w/index.php?action=history&amp;feed=atom&amp;title=%D0%9C%D0%BE%D0%B4%D1%83%D0%BB%D1%8C%3AWikidata%2Fdate</id>
	<title>Модуль:Wikidata/date - История изменений</title>
	<link rel="self" type="application/atom+xml" href="https://bukvica.org/w/index.php?action=history&amp;feed=atom&amp;title=%D0%9C%D0%BE%D0%B4%D1%83%D0%BB%D1%8C%3AWikidata%2Fdate"/>
	<link rel="alternate" type="text/html" href="https://bukvica.org/w/index.php?title=%D0%9C%D0%BE%D0%B4%D1%83%D0%BB%D1%8C:Wikidata/date&amp;action=history"/>
	<updated>2026-04-24T15:38:38Z</updated>
	<subtitle>История изменений этой страницы в вики</subtitle>
	<generator>MediaWiki 1.43.8</generator>
	<entry>
		<id>https://bukvica.org/w/index.php?title=%D0%9C%D0%BE%D0%B4%D1%83%D0%BB%D1%8C:Wikidata/date&amp;diff=238341&amp;oldid=prev</id>
		<title>Karaby: 1 версия импортирована</title>
		<link rel="alternate" type="text/html" href="https://bukvica.org/w/index.php?title=%D0%9C%D0%BE%D0%B4%D1%83%D0%BB%D1%8C:Wikidata/date&amp;diff=238341&amp;oldid=prev"/>
		<updated>2025-07-27T15:36:07Z</updated>

		<summary type="html">&lt;p&gt;1 версия импортирована&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;ru&quot;&gt;
				&lt;td colspan=&quot;2&quot; style=&quot;background-color: #fff; color: #202122; text-align: center;&quot;&gt;← Предыдущая версия&lt;/td&gt;
				&lt;td colspan=&quot;2&quot; style=&quot;background-color: #fff; color: #202122; text-align: center;&quot;&gt;Версия от 15:36, 27 июля 2025&lt;/td&gt;
				&lt;/tr&gt;&lt;tr&gt;&lt;td colspan=&quot;4&quot; class=&quot;diff-notice&quot; lang=&quot;ru&quot;&gt;&lt;div class=&quot;mw-diff-empty&quot;&gt;(нет различий)&lt;/div&gt;
&lt;/td&gt;&lt;/tr&gt;
&lt;!-- diff cache key wiki:diff:1.41:old-238340:rev-238341 --&gt;
&lt;/table&gt;</summary>
		<author><name>Karaby</name></author>
	</entry>
	<entry>
		<id>https://bukvica.org/w/index.php?title=%D0%9C%D0%BE%D0%B4%D1%83%D0%BB%D1%8C:Wikidata/date&amp;diff=238340&amp;oldid=prev</id>
		<title>Буквица&gt;Putnik: Турция перешла на Григорианский календарь только с 1926 года</title>
		<link rel="alternate" type="text/html" href="https://bukvica.org/w/index.php?title=%D0%9C%D0%BE%D0%B4%D1%83%D0%BB%D1%8C:Wikidata/date&amp;diff=238340&amp;oldid=prev"/>
		<updated>2025-02-19T20:00:09Z</updated>

		<summary type="html">&lt;p&gt;Турция перешла на Григорианский календарь только с 1926 года&lt;/p&gt;
&lt;p&gt;&lt;b&gt;Новая страница&lt;/b&gt;&lt;/p&gt;&lt;div&gt;--settings&lt;br /&gt;
local nowLabel = &amp;#039;наст.&amp;amp;nbsp;время&amp;#039;&lt;br /&gt;
&lt;br /&gt;
local moduleDates = require( &amp;quot;Module:Dates&amp;quot; )&lt;br /&gt;
local moduleWikidata = require( &amp;quot;Module:Wikidata&amp;quot; )&lt;br /&gt;
local dateCat = require(&amp;quot;Module:Infocards/dateCat&amp;quot;)&lt;br /&gt;
&lt;br /&gt;
-- FIXME: undeclared global variable, used 3 times&lt;br /&gt;
local infoclass&lt;br /&gt;
&lt;br /&gt;
local function deepcopy(orig)&lt;br /&gt;
	local orig_type = type(orig)&lt;br /&gt;
	local copy&lt;br /&gt;
	if orig_type == &amp;#039;table&amp;#039; then&lt;br /&gt;
		copy = {}&lt;br /&gt;
		for orig_key, orig_value in next, orig, nil do&lt;br /&gt;
			copy[deepcopy(orig_key)] = deepcopy(orig_value)&lt;br /&gt;
		end&lt;br /&gt;
		setmetatable(copy, deepcopy(getmetatable(orig)))&lt;br /&gt;
	else -- number, string, boolean, etc&lt;br /&gt;
		copy = orig&lt;br /&gt;
	end&lt;br /&gt;
	return copy&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
local function ageImpl ( bStructure, bPrecision, dStructure, dPrecision )&lt;br /&gt;
	if ( not bStructure or not dStructure or bPrecision &amp;lt; 10 or dPrecision &amp;lt; 10 ) then&lt;br /&gt;
		return nil&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	local shift = 0&lt;br /&gt;
	if ( bStructure.year &amp;lt; 0 and dStructure.year &amp;gt; 0 ) then&lt;br /&gt;
		shift = -1&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	if ( bPrecision == 10 or dPrecision == 10 ) then&lt;br /&gt;
		if ( bStructure.month &amp;lt; dStructure.month ) then&lt;br /&gt;
			return dStructure.year - bStructure.year + shift&lt;br /&gt;
		end&lt;br /&gt;
		if ( bStructure.month == dStructure.month ) then&lt;br /&gt;
			return nil&lt;br /&gt;
		end&lt;br /&gt;
		if ( bStructure.month &amp;gt; dStructure.month ) then&lt;br /&gt;
			return dStructure.year - bStructure.year - 1 + shift&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
 &lt;br /&gt;
	if ( bStructure.month &amp;lt; dStructure.month ) then&lt;br /&gt;
		return dStructure.year - bStructure.year + shift&lt;br /&gt;
	end&lt;br /&gt;
	if ( bStructure.month == dStructure.month ) then&lt;br /&gt;
		if ( bStructure.day &amp;lt;= dStructure.day ) then&lt;br /&gt;
			return dStructure.year - bStructure.year + shift&lt;br /&gt;
		else &lt;br /&gt;
			return dStructure.year - bStructure.year - 1 + shift&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	if ( bStructure.month &amp;gt; dStructure.month ) then&lt;br /&gt;
		return dStructure.year - bStructure.year - 1 + shift&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	return nil&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
-- accepts table of time+precision values&lt;br /&gt;
local function ageCurrent ( bTable )&lt;br /&gt;
	local possibleAge = &amp;quot;NYA&amp;quot; -- it means &amp;quot;Not Yet Assigned&amp;quot;, not what you imagined!&lt;br /&gt;
&lt;br /&gt;
	for bKey, bValue in pairs(bTable) do&lt;br /&gt;
		if ( bValue.unknown ) then&lt;br /&gt;
			return nil&lt;br /&gt;
		end&lt;br /&gt;
		local bStructure = bValue.structure&lt;br /&gt;
		local bPrecision = bValue.precision&lt;br /&gt;
&lt;br /&gt;
		local dStructure = os.date( &amp;quot;*t&amp;quot; )&lt;br /&gt;
&lt;br /&gt;
		local calculatedAge = ageImpl ( bStructure, bPrecision, dStructure, 11 )&lt;br /&gt;
		if ( possibleAge == &amp;quot;NYA&amp;quot; ) then&lt;br /&gt;
			possibleAge = calculatedAge&lt;br /&gt;
		else&lt;br /&gt;
			if ( possibleAge ~= calculatedAge ) then&lt;br /&gt;
				possibleAge = nil&lt;br /&gt;
			end&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	return possibleAge&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
-- accepts tables of time+precision values&lt;br /&gt;
local function age ( bTable, dTable )&lt;br /&gt;
	local possibleAge = &amp;quot;NYA&amp;quot; -- it means &amp;quot;Not Yet Assigned&amp;quot;, not what you imagined!&lt;br /&gt;
&lt;br /&gt;
	for bKey, bValue in pairs( bTable ) do&lt;br /&gt;
		if ( bValue.unknown ) then&lt;br /&gt;
			return nil&lt;br /&gt;
		end&lt;br /&gt;
		local bStructure = bValue.structure&lt;br /&gt;
		local bPrecision = bValue.precision&lt;br /&gt;
&lt;br /&gt;
		for dKey, dValue in pairs( dTable ) do&lt;br /&gt;
			if ( dValue.unknown ) then&lt;br /&gt;
				return nil&lt;br /&gt;
			end&lt;br /&gt;
			local dStructure = dValue.structure&lt;br /&gt;
			local dPrecision = dValue.precision&lt;br /&gt;
			if ( bValue.calendar == &amp;#039;julian&amp;#039; and dValue.calendar == &amp;#039;gregorian&amp;#039; ) then&lt;br /&gt;
				-- to calculate age, need to adjust bStructure to gregorian calendar&lt;br /&gt;
				local shift = math.floor(bStructure.year/100-2) - math.floor(bStructure.year/400)&lt;br /&gt;
				-- TODO: re-implement this properly&lt;br /&gt;
				bStructure.day = bStructure.day + shift&lt;br /&gt;
			end&lt;br /&gt;
&lt;br /&gt;
			local calculatedAge = ageImpl ( bStructure, bPrecision, dStructure, dPrecision )&lt;br /&gt;
			if ( possibleAge == &amp;quot;NYA&amp;quot; ) then&lt;br /&gt;
				possibleAge = calculatedAge&lt;br /&gt;
			else&lt;br /&gt;
				if ( possibleAge ~= calculatedAge ) then&lt;br /&gt;
					possibleAge = nil&lt;br /&gt;
				end&lt;br /&gt;
			end&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	return possibleAge&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
local function parseISO8601Date(str)&lt;br /&gt;
	local pattern = &amp;quot;(%-?%d+)%-(%d+)%-(%d+)T&amp;quot;&lt;br /&gt;
	local Y, M, D = mw.ustring.match( str, pattern )&lt;br /&gt;
	return tonumber(Y), tonumber(M), tonumber(D)&lt;br /&gt;
end&lt;br /&gt;
 &lt;br /&gt;
local function parseISO8601Time(str)&lt;br /&gt;
	local pattern = &amp;quot;T(%d+):(%d+):(%d+)%Z&amp;quot;&lt;br /&gt;
	local H, M, S = mw.ustring.match( str, pattern)&lt;br /&gt;
	return tonumber(H), tonumber(M), tonumber(S)&lt;br /&gt;
end&lt;br /&gt;
 &lt;br /&gt;
local function parseISO8601Offset(str)&lt;br /&gt;
	if str:sub(-1)==&amp;quot;Z&amp;quot; then return 0,0 end -- ends with Z, Zulu time&lt;br /&gt;
 &lt;br /&gt;
	-- matches ±hh:mm, ±hhmm or ±hh; else returns nils &lt;br /&gt;
	local pattern = &amp;quot;([-+])(%d%d):?(%d?%d?)$&amp;quot;&lt;br /&gt;
	local sign, oh, om = mw.ustring.match( str, pattern) &lt;br /&gt;
	sign, oh, om = sign or &amp;quot;+&amp;quot;, oh or &amp;quot;00&amp;quot;, om or &amp;quot;00&amp;quot;&lt;br /&gt;
 &lt;br /&gt;
	return tonumber(sign .. oh), tonumber(sign .. om)&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
local function parseISO8601(str)&lt;br /&gt;
	if &amp;#039;table&amp;#039; == type(str) then&lt;br /&gt;
		if str.args and str.args[1] then&lt;br /&gt;
			str = &amp;#039;&amp;#039; .. str.args[1]&lt;br /&gt;
		else&lt;br /&gt;
			return &amp;#039;unknown argument type: &amp;#039; .. type( str ) .. &amp;#039;: &amp;#039; .. table.tostring( str )&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	local Y,M,D = parseISO8601Date(str)&lt;br /&gt;
	local h,m,s = parseISO8601Time(str)&lt;br /&gt;
	local oh,om = parseISO8601Offset(str)&lt;br /&gt;
&lt;br /&gt;
	if not Y or not M or not D or not h or not m or not s or not oh or not om then&lt;br /&gt;
		return nil&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	return tonumber(os.time({year=Y, month=M, day=D, hour=(h+oh), min=(m+om), sec=s}))&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
local function parseClaim ( claim )&lt;br /&gt;
	if ( claim.mainsnak.snaktype == &amp;quot;value&amp;quot; ) then&lt;br /&gt;
		local timeISO8601 = string.gsub( string.gsub( tostring( claim.mainsnak.datavalue.value.time ), &amp;#039;-00%-&amp;#039;, &amp;#039;-01-&amp;#039; ), &amp;#039;-00T&amp;#039;, &amp;#039;-01T&amp;#039; )&lt;br /&gt;
		local unixtime = parseISO8601( timeISO8601 )&lt;br /&gt;
		local structure = os.date(&amp;quot;*t&amp;quot;, unixtime)&lt;br /&gt;
		local precision = tonumber( claim.mainsnak.datavalue.value.precision )&lt;br /&gt;
		local calendarmodel = &amp;#039;gregorian&amp;#039;&lt;br /&gt;
		if (mw.ustring.find(claim.mainsnak.datavalue.value.calendarmodel, &amp;#039;Q1985786&amp;#039;, 1, true)) then&lt;br /&gt;
			calendarmodel = &amp;#039;julian&amp;#039;&lt;br /&gt;
		end&lt;br /&gt;
		local item = { structure=structure, precision=precision, calendar = calendarmodel }&lt;br /&gt;
		return item&lt;br /&gt;
	elseif ( claim.mainsnak.snaktype == &amp;quot;novalue&amp;quot; ) then&lt;br /&gt;
		-- novalue&lt;br /&gt;
		return { unknown=&amp;quot;novalue&amp;quot; }&lt;br /&gt;
	else&lt;br /&gt;
		--unknown &lt;br /&gt;
		return { unknown=&amp;quot;unknown&amp;quot; }&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
-- returns table of time+precision values for specified property&lt;br /&gt;
local function parseProperty ( context, options, propertyId )&lt;br /&gt;
	if ( not context ) then error( &amp;#039;context not specified&amp;#039;); end&lt;br /&gt;
	if ( not options ) then error( &amp;#039;options not specified&amp;#039;); end&lt;br /&gt;
	if ( not options.entity ) then error( &amp;#039;options.entity is missing&amp;#039;); end&lt;br /&gt;
	if ( not propertyId ) then error( &amp;#039;propertyId not specified&amp;#039;); end&lt;br /&gt;
&lt;br /&gt;
	local claims = context.selectClaims( options, propertyId )&lt;br /&gt;
	if not claims then&lt;br /&gt;
		return nil&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	local result = {}&lt;br /&gt;
	for key, claim in pairs( claims ) do&lt;br /&gt;
		table.insert ( result, parseClaim( claim ) )&lt;br /&gt;
	end&lt;br /&gt;
	return result&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
-- проверка на совпадающие даты с разной моделью календаря&lt;br /&gt;
local function checkDupDates( t )&lt;br /&gt;
	if #t &amp;gt; 1 then&lt;br /&gt;
		local removed = false&lt;br /&gt;
		local j = 1&lt;br /&gt;
		-- проверка на совпадающие даты с разной моделью календаря&lt;br /&gt;
		while (j &amp;lt;= #t)  do&lt;br /&gt;
			local i = 1&lt;br /&gt;
			while (i &amp;lt;= #t)  do&lt;br /&gt;
				if i ~= j then&lt;br /&gt;
					if (os.time(t[j].structure) == os.time(t[i].structure)) then&lt;br /&gt;
						if ((t[j].calendarmodel == &amp;#039;gregorian&amp;#039;) and &lt;br /&gt;
							(t[i].calendarmodel == &amp;#039;julian&amp;#039;)) then&lt;br /&gt;
							removed = true&lt;br /&gt;
							break&lt;br /&gt;
						else&lt;br /&gt;
							table.remove(t, i)&lt;br /&gt;
						end&lt;br /&gt;
					else&lt;br /&gt;
					  i = i + 1&lt;br /&gt;
					end&lt;br /&gt;
				else&lt;br /&gt;
					i = i + 1&lt;br /&gt;
				end&lt;br /&gt;
			end&lt;br /&gt;
			if removed then&lt;br /&gt;
				removed = false&lt;br /&gt;
				table.remove(t, j)&lt;br /&gt;
			else&lt;br /&gt;
				j = j+1&lt;br /&gt;
			end&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
-- returns first qualifier of specified propertyId&lt;br /&gt;
local function getQualifierWithDataValue( statement, qualifierPropertyId )&lt;br /&gt;
	if ( statement.qualifiers&lt;br /&gt;
			and statement.qualifiers[qualifierPropertyId] ) then&lt;br /&gt;
		local qualifiers = statement.qualifiers[qualifierPropertyId]&lt;br /&gt;
		for _, qualifier in ipairs( qualifiers ) do&lt;br /&gt;
			if (qualifier.datavalue) then&lt;br /&gt;
				return qualifier&lt;br /&gt;
			end&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	return nil&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
local p = {}&lt;br /&gt;
&lt;br /&gt;
local function formatDecade( time, categoryNamePrefix )&lt;br /&gt;
	local bce = &amp;#039;&amp;#039;&lt;br /&gt;
	local year&lt;br /&gt;
	if time.year &amp;lt; 0 then&lt;br /&gt;
		bce = &amp;#039; до н. э.&amp;#039;&lt;br /&gt;
		year = math.floor( math.abs( time.year ) / 10 ) * 10&lt;br /&gt;
	else&lt;br /&gt;
		year = math.floor( time.year / 10 ) * 10&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	local unit = &amp;#039;-е&amp;#039;&lt;br /&gt;
	if isGenitive then&lt;br /&gt;
		unit = &amp;#039;-х&amp;#039;&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	local value = &amp;#039;&amp;#039; .. year .. unit .. bce&lt;br /&gt;
&lt;br /&gt;
	if categoryNamePrefix then&lt;br /&gt;
		return value .. &amp;#039;[[Category:&amp;#039; .. categoryNamePrefix .. &amp;#039; в &amp;#039; .. year .. &amp;#039;-е годы&amp;#039; .. bce .. &amp;#039;]]&amp;#039;&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	return value&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
local function formatCentury( time, categoryNamePrefix, isGenitive )&lt;br /&gt;
	local moduleRoman = require( &amp;#039;Module:RomanNumber&amp;#039; )&lt;br /&gt;
	local bce = &amp;#039;&amp;#039;&lt;br /&gt;
	local century&lt;br /&gt;
	if time.year &amp;lt; 0 then&lt;br /&gt;
		bce = &amp;#039; до н. э.&amp;#039;&lt;br /&gt;
		century = math.floor( ( math.abs( time.year ) - 1 ) / 100 ) + 1&lt;br /&gt;
	else&lt;br /&gt;
		century = math.floor( ( time.year - 1 ) / 100 ) + 1&lt;br /&gt;
	end&lt;br /&gt;
	&lt;br /&gt;
	local unit = &amp;#039;век&amp;#039;&lt;br /&gt;
	if isGenitive then&lt;br /&gt;
		unit = &amp;#039;века&amp;#039;&lt;br /&gt;
	end&lt;br /&gt;
	&lt;br /&gt;
	local infix = &amp;#039; в &amp;#039;&lt;br /&gt;
	if century == 2 then&lt;br /&gt;
		infix = &amp;#039; во &amp;#039;&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	if moduleRoman then&lt;br /&gt;
		century = moduleRoman.toRomanNumber( century )&lt;br /&gt;
	end&lt;br /&gt;
	local value = &amp;#039;[[&amp;#039; .. century .. &amp;#039; век&amp;#039; .. bce .. &amp;#039;|&amp;#039; .. century .. &amp;#039; &amp;#039; .. unit .. bce .. &amp;#039;]]&amp;#039;&lt;br /&gt;
&lt;br /&gt;
	if categoryNamePrefix then&lt;br /&gt;
		return value .. &amp;#039;[[Category:&amp;#039; .. categoryNamePrefix .. infix .. century .. &amp;#039; веке&amp;#039; .. bce .. &amp;#039;]]&amp;#039;&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	return value&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
local function formatMillenium( time, categoryNamePrefix, isGenitive )&lt;br /&gt;
	local bce = &amp;#039;&amp;#039;&lt;br /&gt;
	local millenium&lt;br /&gt;
	if time.year &amp;lt; 0 then&lt;br /&gt;
		bce = &amp;#039; до н. э.&amp;#039;&lt;br /&gt;
		millenium = math.floor( ( math.abs( time.year ) - 1 ) / 1000 ) + 1&lt;br /&gt;
	else&lt;br /&gt;
		millenium = math.floor( ( time.year - 1 ) / 1000 ) + 1&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	local unit = &amp;#039;-е тысячелетие&amp;#039;&lt;br /&gt;
	if isGenitive then&lt;br /&gt;
		unit = &amp;#039;-го тысячелетия&amp;#039;&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	local value = &amp;#039;[[&amp;#039; .. millenium .. &amp;#039;-е тысячелетие&amp;#039; .. bce .. &amp;#039;|&amp;#039; .. millenium .. unit .. bce .. &amp;#039;]]&amp;#039;&lt;br /&gt;
	if categoryNamePrefix then&lt;br /&gt;
		local infix = &amp;#039; в &amp;#039;&lt;br /&gt;
		if millenium == 2 then&lt;br /&gt;
			infix = &amp;#039; во &amp;#039;&lt;br /&gt;
		end&lt;br /&gt;
		return value .. &amp;#039;[[Category:&amp;#039; .. categoryNamePrefix .. infix .. millenium .. &amp;#039;-м тысячелетии&amp;#039; .. bce .. &amp;#039;]]&amp;#039;&lt;br /&gt;
	else&lt;br /&gt;
		return value&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
local function formatDateImpl( value, options, microformatClass, categoryPrefix, leftBracket, rightBracket, nolinks, isGenitive )&lt;br /&gt;
	if ( not value ) then error( &amp;#039;value not specified&amp;#039;); end&lt;br /&gt;
	if ( not options ) then error( &amp;#039;options not specified&amp;#039;); end&lt;br /&gt;
&lt;br /&gt;
	-- The calendar model used for saving the data is always the proleptic Gregorian calendar according to ISO 8601.&lt;br /&gt;
	local timeISO8601 = string.gsub( string.gsub( tostring( value.time ), &amp;#039;-00%-&amp;#039;, &amp;#039;-01-&amp;#039; ), &amp;#039;-00T&amp;#039;, &amp;#039;-01T&amp;#039; )&lt;br /&gt;
	local unixtime = parseISO8601( timeISO8601 )&lt;br /&gt;
	&lt;br /&gt;
	if not unixtime then&lt;br /&gt;
		return &amp;#039;&amp;#039;&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	local structure = os.date(&amp;quot;*t&amp;quot;, unixtime)&lt;br /&gt;
	local precision = tonumber( value.precision )&lt;br /&gt;
	&lt;br /&gt;
	if precision &amp;lt;= 6 then&lt;br /&gt;
		return formatMillenium( structure, categoryPrefix, isGenitive )&lt;br /&gt;
	end	&lt;br /&gt;
	if precision == 7 then&lt;br /&gt;
		return formatCentury( structure, categoryPrefix, isGenitive )&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	if precision == 8 then&lt;br /&gt;
		return formatDecade( structure, categoryPrefix, isGenitive )&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	if precision == 9 then&lt;br /&gt;
		local tCopy = deepcopy( structure )&lt;br /&gt;
		tCopy.day = nil&lt;br /&gt;
		tCopy.month = nil&lt;br /&gt;
		return moduleDates.formatWikiImpl( tCopy, tCopy, infoclass, categoryPrefix, leftBracket, rightBracket, nolinks )&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	-- year and month only&lt;br /&gt;
	if precision == 10 then&lt;br /&gt;
		local tCopy = deepcopy( structure )&lt;br /&gt;
		tCopy.day = nil&lt;br /&gt;
		return moduleDates.formatWikiImpl( tCopy, tCopy, infoclass, categoryPrefix, leftBracket, rightBracket, nolinks )&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	local calendarmodel = &amp;#039;gregorian&amp;#039;&lt;br /&gt;
	if (mw.ustring.find(value.calendarmodel, &amp;#039;Q1985786&amp;#039;, 1, true)) then&lt;br /&gt;
		calendarmodel = &amp;#039;julian&amp;#039;&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	if (calendarmodel == &amp;#039;gregorian&amp;#039;) then&lt;br /&gt;
		return moduleDates.formatWikiImpl( structure, structure, microformatClass, categoryPrefix, leftBracket, rightBracket, nolinks )&lt;br /&gt;
	else&lt;br /&gt;
		return p.formatAsJulian( timeISO8601, infoclass, categoryPrefix, leftBracket, rightBracket, nolinks )&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
local function formatApproximateDateClaim( context, options, statement, unknownDateCategory )&lt;br /&gt;
	if ( not context ) then error( &amp;#039;context not specified&amp;#039;); end&lt;br /&gt;
	if ( not options ) then error( &amp;#039;options not specified&amp;#039;); end&lt;br /&gt;
	if ( not options.entity ) then error( &amp;#039;options.entity is missing&amp;#039;); end&lt;br /&gt;
	if ( not statement ) then error( &amp;#039;statement not specified&amp;#039;); end&lt;br /&gt;
	if options.nocat then unknownDateCategory = &amp;quot;&amp;quot; end&lt;br /&gt;
	&lt;br /&gt;
	local qNotSoonerThan = getQualifierWithDataValue( statement, &amp;#039;P1319&amp;#039; )&lt;br /&gt;
	local qNotLaterThan = getQualifierWithDataValue( statement, &amp;#039;P1326&amp;#039; )&lt;br /&gt;
	if ( qNotSoonerThan or qNotLaterThan ) then&lt;br /&gt;
		local results = {}&lt;br /&gt;
		if ( qNotSoonerThan ) then&lt;br /&gt;
			local formattedDate = formatDateImpl( qNotSoonerThan.datavalue.value, {}, nil, nil, options.leftBracket, options.rightBracket, options.nolinks, true )&lt;br /&gt;
			local value = &amp;#039;не&amp;amp;nbsp;ранее&amp;amp;nbsp;&amp;#039; .. context.wrapSnak( formattedDate, qNotSoonerThan.hash )&lt;br /&gt;
			table.insert( results, context.wrapQualifier( value, &amp;#039;P1319&amp;#039; ) )&lt;br /&gt;
		end&lt;br /&gt;
		if ( qNotLaterThan ) then&lt;br /&gt;
			local formattedDate = formatDateImpl( qNotLaterThan.datavalue.value, {}, nil, nil, options.leftBracket, options.rightBracket, options.nolinks, true )&lt;br /&gt;
			local value = &amp;#039;не&amp;amp;nbsp;позднее&amp;amp;nbsp;&amp;#039; .. context.wrapSnak( formattedDate, qNotLaterThan.hash )&lt;br /&gt;
			table.insert( results, context.wrapQualifier( value, &amp;#039;P1326&amp;#039; ) )&lt;br /&gt;
		end&lt;br /&gt;
		return mw.text.listToText( results, &amp;#039; и &amp;#039; , &amp;#039; и &amp;#039; ) .. unknownDateCategory .. context.formatRefs( options, statement )&lt;br /&gt;
	end&lt;br /&gt;
	&lt;br /&gt;
	return nil&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function p.formatDateOfBirthClaim( context, options, statement )&lt;br /&gt;
	local value = formatApproximateDateClaim( context, options, statement, dateCat.categoryUnknownBirthDate )&lt;br /&gt;
	if value then&lt;br /&gt;
		return value&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	options[&amp;#039;conjunction&amp;#039;] = &amp;#039;&amp;amp;#32;или&amp;amp;#32;&amp;#039;&lt;br /&gt;
	options[&amp;#039;value-module&amp;#039;] = &amp;#039;Wikidata/date&amp;#039;&lt;br /&gt;
	options[&amp;#039;value-function&amp;#039;] = &amp;#039;formatBirthDate&amp;#039;&lt;br /&gt;
	options.i18n.somevalue = &amp;#039;\&amp;#039;\&amp;#039;неизвестно\&amp;#039;\&amp;#039;&amp;#039; .. dateCat.categoryUnknownBirthDate&lt;br /&gt;
	&lt;br /&gt;
	local circumstances = context.getSourcingCircumstances( statement )&lt;br /&gt;
	for _, itemId in ipairs( circumstances ) do&lt;br /&gt;
		if itemId == &amp;#039;Q5727902&amp;#039; then&lt;br /&gt;
			options.isGenitive = true&lt;br /&gt;
			break&lt;br /&gt;
		end&lt;br /&gt;
	end	&lt;br /&gt;
&lt;br /&gt;
	local result = context.formatStatementDefault( context, options, statement )&lt;br /&gt;
&lt;br /&gt;
	local bTable = { parseClaim( statement ) }&lt;br /&gt;
	local dTable = parseProperty ( context, options, &amp;#039;P570&amp;#039; )&lt;br /&gt;
&lt;br /&gt;
	if ( bTable and not dTable ) then&lt;br /&gt;
		local age = ageCurrent( bTable )&lt;br /&gt;
		if ( age ) then&lt;br /&gt;
			if ( options.suppressAge == nil or options.suppressAge == &amp;#039;&amp;#039; ) then&lt;br /&gt;
				result = result .. &amp;#039; &amp;lt;span style=&amp;quot;white-space:nowrap;&amp;quot;&amp;gt;(&amp;#039; .. age .. &amp;#039; &amp;#039; .. mw.language.new( &amp;#039;ru&amp;#039; ):plural( age, &amp;#039;год&amp;#039;, &amp;#039;года&amp;#039;, &amp;#039;лет&amp;#039;) .. &amp;#039;)&amp;lt;/span&amp;gt;&amp;#039;&lt;br /&gt;
			end&lt;br /&gt;
			if ( not options.nocat ) then&lt;br /&gt;
				if ( age &amp;gt; 115 ) then&lt;br /&gt;
					result = result .. dateCat.categoryBigCurrentAge&lt;br /&gt;
				elseif (age &amp;gt;= 0) then&lt;br /&gt;
					result = result .. dateCat.categoryBiographiesOfLivingPersons&lt;br /&gt;
				else&lt;br /&gt;
					result = result .. dateCat.categoryNegativeAge&lt;br /&gt;
				end&lt;br /&gt;
			end&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	return result&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function p.formatDateOfDeathClaim( context, options, statement )&lt;br /&gt;
	local value = formatApproximateDateClaim( context, options, statement, dateCat.categoryUnknownDeathDate )&lt;br /&gt;
	if value then&lt;br /&gt;
		return value&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	options[&amp;#039;conjunction&amp;#039;] = &amp;#039;&amp;amp;#32;или&amp;amp;#32;&amp;#039;&lt;br /&gt;
	options[&amp;#039;value-module&amp;#039;] = &amp;#039;Wikidata/date&amp;#039;&lt;br /&gt;
	options[&amp;#039;value-function&amp;#039;] = &amp;#039;formatDeathDate&amp;#039;&lt;br /&gt;
	options.i18n.somevalue = &amp;#039;\&amp;#039;\&amp;#039;неизвестно\&amp;#039;\&amp;#039;&amp;#039; .. dateCat.categoryUnknownDeathDate&lt;br /&gt;
&lt;br /&gt;
	local circumstances = context.getSourcingCircumstances( statement )&lt;br /&gt;
	for _, itemId in ipairs( circumstances ) do&lt;br /&gt;
		if itemId == &amp;#039;Q5727902&amp;#039; then&lt;br /&gt;
			options.isGenitive = true&lt;br /&gt;
			break&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	local result = context.formatStatementDefault( context, options, statement )&lt;br /&gt;
&lt;br /&gt;
	local bTable = parseProperty ( context, options, &amp;#039;P569&amp;#039; )&lt;br /&gt;
	local dTable = { parseClaim( statement ) }&lt;br /&gt;
&lt;br /&gt;
	if ( bTable and dTable ) then&lt;br /&gt;
		local age = age( bTable, dTable )&lt;br /&gt;
		if ( age ) then&lt;br /&gt;
			if ( options.suppressAge == nil or options.suppressAge == &amp;#039;&amp;#039; ) then&lt;br /&gt;
				result = result .. &amp;#039; &amp;lt;span style=&amp;quot;white-space:nowrap;&amp;quot;&amp;gt;(&amp;#039; .. age .. &amp;#039; &amp;#039; .. mw.language.new( &amp;#039;ru&amp;#039; ):plural( age, &amp;#039;год&amp;#039;, &amp;#039;года&amp;#039;, &amp;#039;лет&amp;#039;) .. &amp;#039;)&amp;lt;/span&amp;gt;&amp;#039;&lt;br /&gt;
			end&lt;br /&gt;
			if ( not options.nocat and age &amp;lt; 0) then&lt;br /&gt;
				result = result .. dateCat.categoryNegativeAge&lt;br /&gt;
			end&lt;br /&gt;
		end&lt;br /&gt;
		&lt;br /&gt;
		-- returns category to recently deceased persons&lt;br /&gt;
		local unixAvailable, unixDateOfDeath = pcall(function()&lt;br /&gt;
			local r = os.time(dTable[1].structure)&lt;br /&gt;
			if ( r ~= os.time() ) then&lt;br /&gt;
				return r&lt;br /&gt;
			end&lt;br /&gt;
			error()&lt;br /&gt;
		end)&lt;br /&gt;
		if ( unixAvailable and os.time() - unixDateOfDeath &amp;lt; 31536000 and not options.nocat ) then&lt;br /&gt;
			result = result .. dateCat.categoryRecentlyDeceased&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	return result&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
-- Reentry point for Wikidata Snak formatting&lt;br /&gt;
function p.formatBirthDate( context, options, value )&lt;br /&gt;
	if ( not context ) then error( &amp;#039;context not specified&amp;#039;); end&lt;br /&gt;
	if ( not options ) then error( &amp;#039;options not specified&amp;#039;); end&lt;br /&gt;
	if ( not value ) then error( &amp;#039;value not specified&amp;#039;); end&lt;br /&gt;
	&lt;br /&gt;
	local microformatClass = nil&lt;br /&gt;
	if options.microformat ~= &amp;#039;-&amp;#039; then&lt;br /&gt;
		microformatClass = options.microformat or &amp;#039;bday&amp;#039;&lt;br /&gt;
	end&lt;br /&gt;
	if ( options.nocat ) then&lt;br /&gt;
		return formatDateImpl( value, options, microformatClass, nil, options.leftBracket, options.rightBracket, options.nolinks, options.isGenitive )&lt;br /&gt;
	else&lt;br /&gt;
		return formatDateImpl( value, options, microformatClass, &amp;#039;Родившиеся&amp;#039;, options.leftBracket, options.rightBracket, options.nolinks, options.isGenitive )&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
-- Reentry point for Wikidata Snak formatting&lt;br /&gt;
function p.formatDeathDate( context, options, value )&lt;br /&gt;
	if ( not context ) then error( &amp;#039;context not specified&amp;#039;); end&lt;br /&gt;
	if ( not options ) then error( &amp;#039;options not specified&amp;#039;); end&lt;br /&gt;
	if ( not value ) then error( &amp;#039;value not specified&amp;#039;); end&lt;br /&gt;
&lt;br /&gt;
	local microformatClass = nil&lt;br /&gt;
	if options.microformat ~= &amp;#039;-&amp;#039; then&lt;br /&gt;
		microformatClass = options.microformat or &amp;#039;dday&amp;#039;&lt;br /&gt;
	end&lt;br /&gt;
	if ( options.nocat and options.nocat ~= &amp;#039;&amp;#039; ) then&lt;br /&gt;
		return formatDateImpl( value, options, microformatClass, nil, options.leftBracket, options.rightBracket, options.nolinks, options.isGenitive )&lt;br /&gt;
	else&lt;br /&gt;
		return formatDateImpl( value, options, microformatClass, &amp;#039;Умершие&amp;#039;, options.leftBracket, options.rightBracket, options.nolinks, options.isGenitive )&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
-- Reentry point for Wikidata Snak formatting -- default one&lt;br /&gt;
function p.formatDate( context, options, value )&lt;br /&gt;
	if ( not context ) then error( &amp;#039;context not specified&amp;#039;); end&lt;br /&gt;
	if ( not options ) then error( &amp;#039;options not specified&amp;#039;); end&lt;br /&gt;
	if ( not value ) then error( &amp;#039;value not specified&amp;#039;); end&lt;br /&gt;
&lt;br /&gt;
	local microformatClass = options.microformat or nil&lt;br /&gt;
	if ( options.nocat and options.nocat ~= &amp;#039;&amp;#039; ) then&lt;br /&gt;
		return formatDateImpl( value, options, microformatClass, nil, options.leftBracket, options.rightBracket, options.nolinks, options.isGenitive )&lt;br /&gt;
	else&lt;br /&gt;
		local categoryPrefix = options.categoryPrefix or nil&lt;br /&gt;
		return formatDateImpl( value, options, microformatClass, categoryPrefix, options.leftBracket, options.rightBracket, options.nolinks, options.isGenitive )&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function p.formatDateIntervalProperty( context, options )&lt;br /&gt;
	if ( not context ) then error( &amp;#039;context not specified&amp;#039; ); end&lt;br /&gt;
	if ( not options ) then error( &amp;#039;options not specified&amp;#039; ); end&lt;br /&gt;
	if ( not options.entity ) then error( &amp;#039;options.entity missing&amp;#039; ); end&lt;br /&gt;
&lt;br /&gt;
	-- Получение нужных утверждений&lt;br /&gt;
	local WDS = require( &amp;#039;Module:WikidataSelectors&amp;#039; )&lt;br /&gt;
	local fromProperty = options.property&lt;br /&gt;
	if options.from and options.from ~= &amp;#039;&amp;#039; then&lt;br /&gt;
		fromProperty = options.from&lt;br /&gt;
	end&lt;br /&gt;
	local fromClaims = WDS.load( options.entityId, fromProperty )&lt;br /&gt;
	local toClaims = WDS.load( options.entityId, options.to )&lt;br /&gt;
&lt;br /&gt;
	if fromClaims == nil and toClaims == nil then&lt;br /&gt;
		return &amp;#039;&amp;#039;&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	local formattedFromClaims = {}&lt;br /&gt;
	if fromClaims then&lt;br /&gt;
		for i, claim in ipairs( fromClaims ) do&lt;br /&gt;
			local formattedStatement = context.formatStatement( options, claim )&lt;br /&gt;
			if formattedStatement then&lt;br /&gt;
				formattedStatement = &amp;#039;&amp;lt;span class=&amp;quot;wikidata-claim&amp;quot; data-wikidata-property-id=&amp;quot;&amp;#039; .. string.upper( options.property ) .. &amp;#039;&amp;quot; data-wikidata-claim-id=&amp;quot;&amp;#039; .. claim.id .. &amp;#039;&amp;quot;&amp;gt;&amp;#039; .. formattedStatement .. &amp;#039;&amp;lt;/span&amp;gt;&amp;#039;&lt;br /&gt;
				table.insert( formattedFromClaims, formattedStatement )&lt;br /&gt;
			end&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	local formattedToClaims = {}&lt;br /&gt;
	local toOptions = deepcopy( options )&lt;br /&gt;
	toOptions.property = options.to&lt;br /&gt;
	toOptions.novalue = nowLabel&lt;br /&gt;
	if toClaims then&lt;br /&gt;
		for i, claim in ipairs( toClaims ) do&lt;br /&gt;
			local formattedStatement = context.formatStatement( toOptions, claim )&lt;br /&gt;
			if formattedStatement then&lt;br /&gt;
				formattedStatement = &amp;#039;&amp;lt;span class=&amp;quot;wikidata-claim&amp;quot; data-wikidata-property-id=&amp;quot;&amp;#039; .. string.upper( toOptions.property ) .. &amp;#039;&amp;quot; data-wikidata-claim-id=&amp;quot;&amp;#039; .. claim.id .. &amp;#039;&amp;quot;&amp;gt;&amp;#039; .. formattedStatement .. &amp;#039;&amp;lt;/span&amp;gt;&amp;#039;&lt;br /&gt;
				table.insert( formattedToClaims, formattedStatement )&lt;br /&gt;
			end&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	local out = &amp;#039;&amp;#039;&lt;br /&gt;
	local fromOut = mw.text.listToText( formattedFromClaims, options.separator, options.conjunction )&lt;br /&gt;
	local toOut = mw.text.listToText( formattedToClaims, options.separator, options.conjunction )&lt;br /&gt;
&lt;br /&gt;
	if fromOut ~= &amp;#039;&amp;#039; or toOut ~= &amp;#039;&amp;#039; then&lt;br /&gt;
		if fromOut ~= &amp;#039;&amp;#039; then&lt;br /&gt;
			out = fromOut&lt;br /&gt;
		else&lt;br /&gt;
			out = &amp;#039;?&amp;#039;&lt;br /&gt;
		end&lt;br /&gt;
&lt;br /&gt;
		if toOut ~= &amp;#039;&amp;#039; then&lt;br /&gt;
			out = out .. &amp;#039; — &amp;#039; .. toOut&lt;br /&gt;
		else&lt;br /&gt;
			local withinClaims = nil&lt;br /&gt;
			if options.within then&lt;br /&gt;
				WDS.load( options.entityId, options.within )&lt;br /&gt;
			end&lt;br /&gt;
			if withinClaims == nil then&lt;br /&gt;
				out = &amp;#039;с &amp;#039; .. out&lt;br /&gt;
			else&lt;br /&gt;
				out = out .. &amp;#039; — &amp;#039; .. nowLabel&lt;br /&gt;
			end&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	if out ~= &amp;#039;&amp;#039; then&lt;br /&gt;
		if options.before then&lt;br /&gt;
			out = options.before .. out&lt;br /&gt;
		end&lt;br /&gt;
		if options.after then&lt;br /&gt;
			out = out .. options.after&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	return out&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
local lowestBoundary = &amp;#039;1582-10-05T00:00:00Z&amp;#039;&lt;br /&gt;
local lastBoundary = &amp;#039;1926-01-01T00:00:00Z&amp;#039; -- Turkey&lt;br /&gt;
&lt;br /&gt;
local boundaries = {&lt;br /&gt;
	-- from (G) till next will be diff(G = J + diff), at current&lt;br /&gt;
	{ lowestBoundary,         10 },&lt;br /&gt;
	{ &amp;#039;1700-02-29T00:00:00Z&amp;#039;, 11 },&lt;br /&gt;
	{ &amp;#039;1800-02-29T00:00:00Z&amp;#039;, 12 },&lt;br /&gt;
	{ &amp;#039;1900-02-29T00:00:00Z&amp;#039;, 13 },&lt;br /&gt;
	{ lastBoundary, &amp;#039;&amp;#039; },&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
-- Передаваемое время обязано быть по Юлианскому календарю (старому стилю)&lt;br /&gt;
function p.formatAsJulian( julTimeISO8601, infocardClass, categoryNamePrefix, leftBracket, rightBracket, nolinks )&lt;br /&gt;
	if &amp;#039;table&amp;#039; == type( julTimeISO8601 ) then&lt;br /&gt;
		if julTimeISO8601.args and julTimeISO8601.args[1] then&lt;br /&gt;
			julTimeISO8601 = julTimeISO8601.args[1]&lt;br /&gt;
		else&lt;br /&gt;
			return &amp;#039;unknown argument type: &amp;#039; .. type( julTime ) .. &amp;#039;: &amp;#039; .. table.tostring( julTime )&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	julTimeISO8601 = mw.text.trim( julTimeISO8601 )&lt;br /&gt;
	julTimeISO8601 = string.gsub( julTimeISO8601, &amp;#039;^+&amp;#039;, &amp;#039;&amp;#039; )&lt;br /&gt;
	local julTime = parseISO8601( julTimeISO8601 )&lt;br /&gt;
	local t = os.date( &amp;quot;*t&amp;quot;, julTime )&lt;br /&gt;
&lt;br /&gt;
	if ( julTime &amp;lt; parseISO8601( lowestBoundary ) ) then&lt;br /&gt;
		-- only julian&lt;br /&gt;
		if string.find( julTimeISO8601, &amp;#039;-02-29T&amp;#039;, 1, true ) then&lt;br /&gt;
			t = { year = t.year, month = 2, day = 29 }&lt;br /&gt;
		end&lt;br /&gt;
		return moduleDates.formatWikiImpl( t, t, infocardClass, categoryNamePrefix, leftBracket, rightBracket, nolinks )&lt;br /&gt;
	end&lt;br /&gt;
	if ( julTimeISO8601 &amp;gt;= lastBoundary ) then&lt;br /&gt;
		return &amp;quot;&amp;#039;&amp;#039;некорректная дата (юлианский календарь не используется после 1926-01-01)&amp;#039;&amp;#039;&amp;quot;&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	-- julian and grigorian&lt;br /&gt;
	for i = 1, #boundaries, 1 do&lt;br /&gt;
		local b1 = boundaries[i][1]&lt;br /&gt;
		local b2 = boundaries[i + 1][1]&lt;br /&gt;
		if ( b1 &amp;lt;= julTimeISO8601 and julTimeISO8601 &amp;lt; b2 ) then&lt;br /&gt;
			local diff = boundaries[i][2]&lt;br /&gt;
			if string.sub( julTimeISO8601, 1, 10 ) == string.sub( boundaries[i][1], 1, 10 ) then&lt;br /&gt;
				t = { year = t.year, month = 2, day = 29 }&lt;br /&gt;
				diff = diff - 1&lt;br /&gt;
			end&lt;br /&gt;
			local gregTime = os.date( &amp;quot;*t&amp;quot;, julTime + diff * 24 * 60 * 60 )&lt;br /&gt;
			return moduleDates.formatWikiImpl( t, gregTime, infocardClass, categoryNamePrefix, leftBracket, rightBracket, nolinks )&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	return &amp;quot;&amp;#039;&amp;#039;ошибка в модуле Модуль:Wikidata/date&amp;#039;&amp;#039;&amp;quot;&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
return p&lt;/div&gt;</summary>
		<author><name>Буквица&gt;Putnik</name></author>
	</entry>
</feed>