وحدة:Check for unknown parameters

من ويكيبيديا، الموسوعة الحرة
اذهب إلى التنقل اذهب إلى البحث

وحدة:التحقق من المعلمات غير المدعومة يمكن إلحاق هذه الوحدة إلى قالب ما للتحقق من المعلمات المجهولة المستخدمة في المقالات المتصلة به.

تأخذ هذه الوحدة الوسائط البديلة من بيانات القالب صفحة توثيق القالب، وذلك في حالة وجود الوسيط غير المدعوم في خانة aliases لوسيط ما.

الاستخدام[عدل]

اساسي[عدل]

{{#invoke:check for unknown parameters|check
|unknown=[[Category:Some tracking category]]
|arg1|arg2|...|argN}}

أو لفرز المقالات في التصنيف حسب القيم المجهولة :

{{#invoke:check for unknown parameters|check
|unknown=[[Category:Some tracking category|_VALUE_]]
|preview=unknown parameter "_VALUE_"
|arg1|arg2|...|argN}}

أو لعرض رسالة خطأ حمراء واضحة:

{{#invoke:check for unknown parameters|check
|unknown=<span class="error">Sorry, I don't recognize _VALUE_</span>
|arg1|arg2|...|argN}}

Here, arg1, arg2, ..., argN, are the known parameters. Any parameter which is used, but not on this list, will cause the module to return whatever is passed with the unknown parameter. The _VALUE_ keyword, if used, will be changed to the name of the parameter. This is useful for either sorting the entries in a tracking category, or for provide more explicit information.

By default, the module makes no distinction between a defined-but-blank parameter and a non-blank parameter. To only track non-blank parameters use |ignoreblank=1.

By default, the module ignores blank positional parameters. To include blank positional parameters in the tracking use |showblankpositional=1.

التعابير النمطية[عدل]

هذه الوحدة تدعم التعابير النمطية، وهي مفيدة عندما تكون هناك الكثير من المعلمات المعروفة التي تستخدم نمط منتظم. على سبيل المثال من قالب: Infobox3cols:

| regexp1 = header[%d][%d]*
| regexp2 = label[%d][%d]*
| regexp3 = data[%d][%d]*[abc]?
| regexp4 = class[%d][%d]*[abc]?
| regexp5 = rowclass[%d][%d]*
| regexp6 = rowstyle[%d][%d]*
| regexp7 = rowcellstyle[%d][%d]*

لتتناسب مع جميع المعلمات من النموذج headerNUM، labelNUM، dataNUM، dataNUMa، dataNUMb، dataNUMc، rowcellstyleNUM، حيث NUM عبارة عن سلسلة من الأرقام.

مثال آخر:

| regexp1 = المنصب[%d][%d]*
| regexp2 = سبقه[%d][%d]*
| regexp3 = تبعه[%d][%d]*

يتيح تحديد المنصب1، المنصب2، المنصب3 ... إلخ.

أمثلة[عدل]

{{Infobox
| above = {{{name|}}}

| label1 = Height
| data1 = {{{height|}}}

| label2 = Weight
| data2 = {{{weight|}}}

| label3 = Website
| data3 = {{{website|}}}
}}<!-- 
  end infobox, start tracking
-->{{#invoke:Check for unknown parameters|check
| unknown = [[Category:Some tracking category|_VALUE_]]
| preview = unknown parameter "_VALUE_"
| name
| height | weight
| website
}}

قوالب تستخدم هذه الوحدة[عدل]

قائمة
القالب تصنيف التتبع
قالب:ضبط استنادي تصنيف:صفحات تستخدم الضبط الاستنادي مع عوامل متغيرة
قالب:صندوق معلومات شخص تصنيف:صفحات تستخدم قالب:صندوق معلومات شخص مع وسائط غير معروفة
قالب:معلومات حادث مدني تصنيف:صفحات تستخدم قالب:معلومات حادث مدني مع وسائط غير معروفة
قالب:معلومات مدينة تصنيف:صفحات تستخدم قالب:معلومات مدينة مع وسائط غير معروفة
قالب:Infobox Settlement تصنيف:مقالات إسكان تحتاج للصيانة

طالع أيضاً[عدل]

-- This module may be used to compare the arguments passed to the parent
-- with a list of arguments, returning a specified result if an argument is
-- not on the list
local p = {}

local TemplateData;
local get_Template_Data = require('Module:TemplateData')
local I10n ={ }

local function getTemplateData(title)
	if title and title ~="" then
		data  = get_Template_Data.readTemplateData(title)
		if data and data.params then
			for k, vv in pairs(data.params) do
				if vv.aliases then 
					for _, d in pairs(vv.aliases) do
						I10n[d] = k
						--mw.log( "I10n["..d.."] = ".. k )
					end
				end
			end
		end 
	end	
end

function getl10n(p)
	if p and p ~='' then 
		doo = I10n[p]
		if doo and doo ~=''  then
		doo = '<span style="color:#078e16"><strong>'.. doo ..'</strong></span>'
		doo = " فضلاً قم باستخدام '''".. doo .. "''' بدلاً منه."
		end
	end
	return doo 
end

local function trim(s)
	return s:match('^%s*(.-)%s*$')
end

local function isnotempty(s)
	return s and trim(s) ~= ''
end

function p.check (frame)
	local args = frame.args
	local pargs = frame:getParent().args
	local ignoreblank = isnotempty(frame.args['ignoreblank'])
	local showblankpos = isnotempty(frame.args['showblankpositional'])
	local knownargs = {}
	local template = frame.args['template']
	if template and template ~='' then 
		un = '[[تصنيف:صفحات تستخدم قالب:'.. template ..' مع وسائط غير معروفة|_VALUE_]]' 
		--data  = getTemplateData(template)
	else 
		un = '[[تصنيف:صفحات تستخدم قوالب بوسائط غير معروفة|_VALUE_]]' 
	end
	local unknown = frame.args['unknown'] or un
	--local preview = frame.args['preview'] or 'الوسيط <span style="color:#cc0000"><strong>_VALUE_</strong></span> غير مدعوم يرجى مراجعته'
	local preview = frame.args['preview'] or 'الوسيط <span style="color:#cc0000"><strong>_VALUE_</strong></span> غير مدعوم'

	local values1 = {}
	local values = {}
	local res = {}
	local category = {}
	local res1 = {}
	local regexps = {}

	-- create the list of known args, regular expressions, and the return string
	for k, v in pairs(args) do
		if type(k) == 'number' then
			v = trim(v)
			knownargs[v] = 1
		elseif k:find('^regexp[1-9][0-9]*$') then
			table.insert(regexps, '^' .. v .. '$')
		end
	end
	-- loop over the parent args, and make sure they are on the list
	for k, v in pairs(pargs) do
		if type(k) == 'string' and knownargs[k] == nil then
			local knownflag = false
			for i, regexp in ipairs(regexps) do
				if mw.ustring.match(k, regexp) then
					knownflag = true
					break
				end
			end
			if not knownflag and ( not ignoreblank or isnotempty(v) )  then
				k = mw.ustring.gsub(k, '[^%w\-_ ]', '?')
				table.insert(values, k)
			end
		elseif I10n[k] then table.insert(values1, k)
		elseif type(k) == 'number'  and
		 knownargs[tostring(k)] == nil and
		 ( showblankpos or isnotempty(v) )
		then
			local vlen = mw.ustring.len(v)
			v = mw.ustring.sub(v, 1, (vlen < 25) and vlen or 25) 
			v = mw.ustring.gsub(v, '[^%w\-_ ]', '?')
			table.insert(values, k .. ' = ' .. v .. ((vlen >= 25) and ' ...' or ''))
		end
	end
	if isnotempty(preview) then 
		preview = '<span style="color:#800000"><strong>تحذير:</strong></span>'
		 		 .. preview 
	elseif preview == nil then
		preview = unknown
	end
	if template and template ~='' 
		then tem = 'في [[قالب:'.. template ..' ]] '
	end
	-- add resuls to the output tables
	if #values > 0 or #values1 > 0 then
		dop = ' (هذه الرسالة تظهر عند المعاينة فقط)'
		div = '<div class="hatnote" >'
		ss = 'الوسائط التالية غير مدعومة '
		ca = div ..  '<span style="color:#800000"><strong>'.. ss .. (tem or '') ..' يرجى مراجعتها:'
		.. dop .. ' </strong></span>'
		table.insert( res, ca )
		if frame:preprocess( "{{REVISIONID}}" ) == "" then
			unknown = preview
		end
		for k, v in pairs(values) do
			if v == '' then v = ' ' end
			-- Fix odd bug for | = which gets stripped to the empty string and
			-- breaks category links
			--	unknown = unknown 
			cat = unknown:gsub('_VALUE_', v)
			table.insert(category, cat)
			local dp = getl10n(v)
			rr =  unknown:gsub('_VALUE_', v)
			if dp and dp ~='' 
				then 
					oo =  rr .. (dp or '')
					table.insert(res, oo)
				else 
					rr ='الوسيط <span style="color:#cc0000"><strong>' .. v ..'</strong></span>'
					table.insert(res1, rr)
			end
		end
		for k, v in pairs(values1) do
			if v == '' then v = ' ' end
			cat = unknown:gsub('_VALUE_', v)
			local dp = getl10n(v)
			rr =  unknown:gsub('_VALUE_', v)
			if dp and dp ~='' 
				then 
					oo =  rr .. (dp or '')
					table.insert(res, oo)
				else 
					rr ='الوسيط <span style="color:#cc0000"><strong>' .. v ..'</strong></span>'
					table.insert(res1, rr)
			end
		end
	end
	if #res1 > 0 then
		if #res1 == 1 then
		--	catemass = 'يجب تبديلها، طالع صفحة [[قالب:'.. template..'/شرح|توثيق القالب]] لمعرفة الوسائط البديلة'
			catemass = 'غير مدعوم، يجب تبديله، طالع صفحة توثيق القالب لمعرفة الوسائط البديلة.'
		else
			catemass = 'وسائط غير مدعومة، يجب تبديلها، طالع صفحة توثيق القالب لمعرفة الوسائط البديلة.'
		end
	table.insert(res1, catemass)
	end
	ap = table.concat(res1, ' ، ')
	table.insert(res, ap)
	va = '</div>'
	--table.insert(res, va)
	cac = table.concat(res, '\n*')
	if cac ~= "" then
		cac = cac .. va
	end
	if frame:preprocess( "{{REVISIONID}}" ) == "" 
	then
		return cac
	else 
		return table.concat(category)
	end
end


return p