לדלג לתוכן

יחידה:פרמטרים

מתוך צפונות ויקי

function foo(frame)
	ans = ""
	namespace = "תבנית:"
	pframe = frame:getParent()
	local template = pframe:getTitle()
	local templatename = template
	if find1(templatename, namespace) == 1
		then templatename = mw.ustring.sub(templatename, len1(namespace) + 1) end
	local data = mw.loadData('יחידה:פרמטרים/' .. templatename)
	local numbered = 0
	local lastparam
	local mustnum = data[1]
	parameters = data[2]
	must = data[3]
	suggestions = data[4]
	for tt, t in ipairs(must) do
		checkmust(t) end
	for k, v in pairs(pframe.args) do
		if type(k) == "string"
			then checknamed(k)
			elseif not isempty(v)
					then numbered = k lastparam = v end end
	if mustnum < numbered
		then out("צריך מקסימום " .. mustnum .. " פרמטרים ללא שם, ישנם " .. numbered .. ', כשהאחרון הוא: "' .. lastparam .. '"') end
	if ans == ""
		then return ans end
	return '<div class=error><div class="parameters">' .. " '''שגיאת פרמטרים ב[[" .. template .. "]]:<br/>" .. ans .. 
			"''' </div></div>[[קטגוריה:שגיאות פרמטריות]]" 
end

function checkmust(must)
	for g, h in pairs(pframe.args) do
		if must == g .. ""
			then if isempty(h)
					then out("פרמטר חובה ריק: ''" .. g .. "''") end
				return end end
	out("פרמטר חובה חסר: ''" .. must .. "''")
end

function checknamed(k)
	local answer = "פרמטר לא ידוע: ''" .. k .. "''"
	for p1, p in ipairs(parameters) do
		if p == k
			then return end end
	if suggestions[k] ~= nil
		then answer = answer .. ', <span style = "color:green">מומלץ ' .. "''" .. suggestions[k] .. "''</span>" end
	out(answer)
end

function isempty(v)
	for i = 1, len1(v) do
		if mw.ustring.byte(v, i, i) > 32
			then return false end end
	return true
end

function out(new)
	ans = ans .. new .. "</br>"
end

function find1(str, what, where)
	local ans = mw.ustring.find(str, what, where, true)
	if ans == nil
		then ans = 0 end
	return ans
end

function len1(s)
	if s == nil
		then return 0 end
	return mw.ustring.len(s)
end

return {['main'] = foo}