Ugrás a tartalomhoz

„Modul:CheckISBN” változatai közötti eltérés

A Wikipédiából, a szabad enciklopédiából
[ellenőrzött változat][ellenőrzött változat]
Tartalom törölve Tartalom hozzáadva
egyszerűsítés, naplózás a konzolra is hibakereséshez, paraméter átadása, különben semmire se megyünk vele…
Bean49Bot (vitalap | szerkesztései)
Bot: Modul:No globals helyett require('strict')
 
(5 közbenső módosítás, amit egy másik szerkesztő végzett, nincs mutatva)
1. sor: 1. sor:
require('strict')

local args = {}
local args = {}


local ou = ''
local ou = ''
function pop(...) -- idézőjeles rész és bővítmények az ou számára
local function pop(...) -- idézőjeles rész és bővítmények az ou számára
-- Ha nem kell, ne zabálja a memóriát
do return end
local mi = {...}
local mi = {...}
for _, v in ipairs(mi) do
for _, v in ipairs(mi) do
10. sor: 14. sor:
end
end


hibavan = false
local hibavan = false
kategorizalas_van = false
local kategorizalas_van = false


local function error(kategorizalas_kell, about)
local function error(kategorizalas_kell, about)
22. sor: 26. sor:
end
end
local r = about
local r = about
if type( about ) == "string" then
if type( about ) == 'string' then
if #about == 0 then
if #about == 0 then
r = "Error in Lua"
r = 'Lua-hiba'
end
end
else
else
30. sor: 34. sor:
end
end
return '<span class="error">' .. r .. '</span>'
return '<span class="error">' .. r .. '</span>'
end
--"<big><font color=\"red\">" ..' ('.. r..') ' .. "</font></big> "
--"<small><font color=\"black\">" ..' ('.. r..') ' .. "</font></small> "
end -- error()


local function isISBN10(str)
local function isISBN10(str)
local v, chsum, chnum, chd, i, j, chnumdo, eloirt_hossz
local v, chsum, chnum, chd, i, j, chnumdo, eloirt_hossz
v = str:gsub('[^%d]', '') -- a decimális jegyeken kívül mindent figyelmen kívül hagyunk
v = ''
pop('10', v)
for w in string.gmatch(str, "%d") do -- a decimális jegyeken kívül mindent figyelmen kívül hagyunk
chd = str:sub(-1, -1) -- check digit az utólsó
v = v .. w
end
pop("10",v)
chd = string.sub (str,-1,-1); -- check digit az utólsó
pop(chd)
pop(chd)
if chd == 'X' or chd == 'x' or tonumber(chd) ~= nil then
if chd == 'X' or chd == 'x' or tonumber(chd) ~= nil then
54. sor: 53. sor:
return false
return false
end
end
pop(chd,chnum)
pop(chd, chnum)
if #v ~= eloirt_hossz then -- kötőjelek nélkül 13 karakter hosszúnak kell lennie
if #v ~= eloirt_hossz then -- kötőjelek nélkül 10 karakter hosszúnak kell lennie
return false
return false
end
end
v = string.sub(v, 1, 9)
v = v:sub(1, 9)
pop(v, chd)
pop(v, chd)
68. sor: 67. sor:
local elsbyte = string.byte(v, (11 - j))
local elsbyte = string.byte(v, (11 - j))
chsum = chsum + (elsbyte - string.byte('0', 1)) * (11 - j)
chsum = chsum + (elsbyte - string.byte('0', 1)) * (11 - j)
end -- j ciklus
end
pop(chsum)
pop(chsum)
if chsum % 11 == 0 then
chnumdo = chsum % 11
chnumdo = 0
else
chnumdo = (chsum % 11) end
pop(chsum%11)
pop(chnumdo)
pop(chnumdo)
if chnumdo == chnum then
if chnumdo == chnum then
81. sor: 76. sor:
return false
return false
end
end
end
end -- isISBN10


local function isISBN13(str)
local function isISBN13(str)
local v, chsum, chnum, chd, i, j, chnumdo, eloirt_hossz
local v, chsum, chnum, chd, i, j, chnumdo
v = str:gsub('[^%d]', '') -- a decimális jegyeken kívül mindent figyelmen kívül hagyunk
v = ''
pop('v_1', v)
for w in string.gmatch(str, "%d") do -- a decimális jegyeken kívül mindent figyelmen kívül hagyunk
chd = str:sub(-1, -1) -- check digit az utolsó
v = v .. w
pop('chd_2', chd)
end
pop("v_1", v)
chd = string.sub (str, -1, -1) -- check digit az utolsó
pop("chd_2", chd)
if tonumber(chd) ~= nil then
if tonumber(chd) ~= nil then
chnum = string.byte(chd,1) - string.byte('0',1)
chnum = string.byte(chd, 1) - string.byte('0', 1)
else
else
return false
return false
end
end
pop("chd_3, chnum_1", chd, chnum)
pop('chd_3, chnum_1', chd, chnum)
if #v ~= 13 then -- kötőjelek nélkül 13 karakter hosszúnak kell lennie
if #v ~= 13 then -- kötőjelek nélkül 13 karakter hosszúnak kell lennie
109. sor: 101. sor:
chsum = 0
chsum = 0
for j = 1, 12 do -- z_13 = (10 - Summa (i=1,12) (z_i*(3^((i+1)%2))%10) %10
for j = 1, 12 do -- z_13 = (10 - Summa (i=1,12) (z_i*(3^((i+1)%2))%10) %10
elsbyte = string.byte(v,j);
elsbyte = string.byte(v, j);
--pop(elsbyte)
--pop(elsbyte)
chsum = chsum + (elsbyte - string.byte('0',1)) * 3^((j+1)%2)
chsum = chsum + (elsbyte - string.byte('0', 1)) * 3^((j+1)%2)
--pop(3^((j+1)%2))
--pop(3^((j+1)%2))
end -- j ciklus
end
pop(chsum)
pop(chsum)
chnumdo = chsum % 10
chnumdo = (10 - chsum % 10) % 10
chnumdo = (10 - chnumdo) % 10
pop(chnumdo)
pop(chnumdo)
if chnumdo == chnum then
if chnumdo == chnum then
125. sor: 116. sor:
return false
return false
end
end
end
end -- isISBN13


local function isI(str)
local function isI(str)
local v, eloirt_hossz, i, j, str1, str2, vizsgalandok, mindketto, elso, masodik
local v, eloirt_hossz
v = str:gsub('[^%dXx]', '') -- a decimális jegyeken kívül mindent figyelmen kívül hagyunk
v = ''
pop(v)
for w in string.gmatch(str, "[%dXx]") do -- a decimális jegyeken kívül mindent figyelmen kívül hagyunk
v = v .. w
end
pop(v)
eloirt_hossz = 10
eloirt_hossz = 10
pop("előírt hossza", eloirt_hossz)
pop('előírt hossza', eloirt_hossz)
if #v == eloirt_hossz then
if #v == eloirt_hossz then
pop("tizes")
pop('tízes')
return isISBN10(str)
return isISBN10(str)
elseif #v > eloirt_hossz then
elseif #v > eloirt_hossz then
pop("tizenhármas")
pop('tizenhármas')
return isISBN13(str)
return isISBN13(str)
else
else
return false
return false
end
end
end
end --function isI(str)


local function isISBN(str, link)
local function isISBN(str, link, no_isbn)
if type(str) ~= 'string' then
local i, j, elso_szelet, masodik_szelet
return error(false, 'Nem string bemenet az isISBN függvénynek')
end
local vizsgalandok = {}
local vizsgalandok = {}
str = string.gsub(str, '%s*', '') -- szóközök ki
str = str:gsub('[^%d%,Xx -]', '') -- minden ki, ami nem számjegy, vessző, X/x, szóköz vagy kötőjel
--[=[
str = string.gsub(str, '[^%d%,Xx]', '') -- minden, ami nem számjegy, nem vessző, vagy X vagy x ki
--[=[elso_szelet = string.sub(str,1,-2)
local elso_szelet, masodik_szelet
elso_szelet = string.sub(str,1,-2)
masodik_szelet = string.sub(str,-1,-1)
masodik_szelet = string.sub(str,-1,-1)
pop("elso_szelet, masodik_szelet",elso_szelet,masodik_szelet)
pop("elso_szelet, masodik_szelet",elso_szelet,masodik_szelet)
165. sor: 156. sor:
end
end
--]=]
--]=]
pop("str a ballaszt nélkül", str)
pop('str a ballaszt nélkül', str)
for w in string.gmatch(str, "[^%,]+") do
for w in str:gmatch('[^%,]+') do
w = mw.text.trim(w)
w = mw.text.trim(w)
pop("w", w .. "\n")
pop('w', w .. '\n')
if w ~= '' then
if w ~= '' then
table.insert(vizsgalandok, w)
table.insert(vizsgalandok, w)
174. sor: 165. sor:
end
end
local s = {}
local s = {}
local s_nyers = {}
local h = {}
local h = {}
local helyes=true
local h_nyers = {}
local helyes = true
local formatstring
local formatstring
if link then
if link and no_isbn then
formatstring = '[[Speciális:Könyvforrások/%s|ISBN %s]]'
formatstring = '[[Speciális:Könyvforrások/%s|%s]]'
elseif link then
formatstring = '[[Speciális:Könyvforrások/%s|ISBN&nbsp;%s]]'
elseif no_isbn then
formatstring = '%s'
else
else
formatstring = 'ISBN %s'
formatstring = 'ISBN %s'
end
end
for i=1, #vizsgalandok do
for _, vi in ipairs(vizsgalandok) do
if isI(vi) then
local vi = vizsgalandok[i]
table.insert(s, string.format(formatstring, vi:gsub('[ -]', ''), vi:gsub(' ', '&nbsp;')))
if isI(vizsgalandok[i]) then
table.insert(s, string.format(formatstring, vi, vi))
table.insert(s_nyers, vi)
pop('helyes előrehaladása', table.concat(s, ', '))
pop('helyes előrehaladása', table.concat(s, ', '))
else
else
helyes = false
helyes = false
table.insert(h, error(true, 'helytelen ISBN kód') .. ': ' .. vi)
table.insert(h, error(true, 'helytelen ISBN kód') .. ': ' .. vi)
table.insert(h_nyers, vi)
pop('hibás előrehaladása', table.concat(h, ', '))
pop('hibás előrehaladása', table.concat(h, ', '))
end
end
195. sor: 193. sor:
s = table.concat(s, ', ')
s = table.concat(s, ', ')
h = table.concat(h, ', ')
h = table.concat(h, ', ')
return helyes, s, h
return helyes, s, h, s_nyers, h_nyers
end -- isISBN
end -- isISBN


201. sor: 199. sor:
local jo_lista, mind
local jo_lista, mind
local alkategoriak = {}
local alkategoriak = {}
local isbn = nil
local isbn = args[1]
local link = nil
local link = (args.link ~= nil)
local no_isbn = (args['isbn szöveg nélkül'] ~= nil)
local hiba_jelzes = ''
local hiba_jelzes = ''
isbn = args[1]
local milyen_lista = args[2]

milyen_lista = args[2]
link = args.link
link = (link ~= nil)
pop('a kapott argumentum', isbn)
pop('a kapott argumentum', isbn)
pop('linkelve?', tostring(link))
pop('linkelve?', tostring(link))
-- ISBN lekezelése
-- ISBN lekezelése
if isbn then
if isbn then
pop("van isbn paraméter", isbn)
pop('van isbn paraméter', isbn)
--isbn=string.gsub(isbn,"ISBN",'') -- a beleírt ISBN szövegeket kivesszük
--isbn=string.gsub(isbn,"ISBN",'') -- a beleírt ISBN szövegeket kivesszük
local helyes=true
local helyes
helyes, isbn, hiba_jelzes = isISBN(isbn, link, no_isbn)
local isbn_str, hiba_str=''
helyes, isbn_str, hiba_str = isISBN(isbn, link)
isbn = isbn_str
hiba_jelzes=hiba_jelzes..hiba_str
if helyes then pop ("helyesek a paraméterek") end
if helyes then
pop('helyesek a paraméterek')
end
end
end -- ISBN lekezelése
if milyen_lista then
if milyen_lista then
mind=false
mind = false
if milyen_lista == 'jólista' then jo_lista = true; else jo_lista = false; end
jo_lista = (milyen_lista == 'jólista')
else mind=true
else
mind = true
end
end
-- output összeállítása
-- output összeállítása
local s
s=''
if isbn then
if isbn then
if hiba_jelzes then
if hiba_jelzes then
if mind then s=isbn..' '
if mind then
s = isbn
if hibavan then
if hibavan then
s = s ..' '..hiba_jelzes..' '
s = s ..' ' .. hiba_jelzes
-- a fölérendelt kategória marad hiba esetén
-- a fölérendelt kategória marad hiba esetén
if kategorizalas_van then s = s .. ' '.. "[[Kategória:Lapok helytelen ISBN kóddal]]" end
if kategorizalas_van then s = s .. ' [[Kategória:Lapok helytelen ISBN kóddal]]' end
end
end
else
else
if jo_lista then s = isbn..' '
if jo_lista then
s = isbn
else
elseif hibavan then
if hibavan then s = hiba_jelzes..' '
s = hiba_jelzes
-- a fölérendelt kategória marad hiba esetén
-- a fölérendelt kategória marad hiba esetén
if kategorizalas_van then s = s .. ' '.. "[[Kategória:Lapok helytelen ISBN kóddal]]" end
if kategorizalas_van then s = s .. ' [[Kategória:Lapok helytelen ISBN kóddal]]' end
end
end
end
end
end
256. sor: 253. sor:
end
end


function run(frame)
local function run(frame)
args = require('Modul:Arguments').getArgs(frame)
args = require('Modul:Arguments').getArgs(frame)
return _checkISBN(args)
return _checkISBN(args)

A lap jelenlegi, 2023. november 29., 23:44-kori változata

CheckISBN[mi ez?] • [dokumentáció: mutat, szerkeszt] • [tesztek: létrehozás]

require('strict')

local args = {}

local ou = ''
local function pop(...)  -- idézőjeles rész és bővítmények az ou számára
	-- Ha nem kell, ne zabálja a memóriát
	do return end
	local mi = {...}
	for _, v in ipairs(mi) do
		ou = ou .. v .. '\n'
		mw.log(v)
	end
end

local hibavan = false
local kategorizalas_van = false

local function error(kategorizalas_kell, about)
	-- Enclose errorMsg with <span>
	-- Precondition:
	--     about  -- string
	hibavan = true
	if kategorizalas_kell then
		kategorizalas_van = true
	end  
	local r = about
	if type( about ) == 'string' then
		if #about == 0 then
			r = 'Lua-hiba'
		end
	else
		r = tostring( about )
	end
	return '<span class="error">' .. r .. '</span>'
end

local function isISBN10(str)
	local v, chsum, chnum, chd, i, j, chnumdo, eloirt_hossz
	v = str:gsub('[^%d]', '') -- a decimális jegyeken kívül mindent figyelmen kívül hagyunk
	pop('10', v)
	chd = str:sub(-1, -1) -- check digit az utólsó
	pop(chd)
	if chd == 'X' or chd == 'x' or tonumber(chd) ~= nil then
		if chd == 'X' or chd == 'x' then
			chnum = 10
			eloirt_hossz = 9
		else
			chnum = string.byte(chd, 1) - string.byte('0', 1)
			eloirt_hossz = 10
		end
	else
		return false
	end
	pop(chd, chnum)
	
	if #v ~= eloirt_hossz then -- kötőjelek nélkül 10 karakter hosszúnak kell lennie
		return false
	end
	v = v:sub(1, 9)
	
	pop(v, chd)
	
	pop(chnum)
	chsum = 0
	for j = 10, 2, -1 do   
		local elsbyte = string.byte(v, (11 - j))
		chsum = chsum + (elsbyte - string.byte('0', 1)) * (11 - j)
	end
	pop(chsum)
	chnumdo = chsum % 11
	pop(chnumdo)
	if chnumdo == chnum then
		return true
	else
		return false
	end
end

local function isISBN13(str)
	local v, chsum, chnum, chd, i, j, chnumdo
	v = str:gsub('[^%d]', '') -- a decimális jegyeken kívül mindent figyelmen kívül hagyunk
	pop('v_1', v)
	chd = str:sub(-1, -1) -- check digit az utolsó
	pop('chd_2', chd)
	if tonumber(chd) ~= nil then
		chnum = string.byte(chd, 1) - string.byte('0', 1)
	else
		return false
	end
	pop('chd_3, chnum_1', chd, chnum)
	
	if #v ~= 13 then -- kötőjelek nélkül 13 karakter hosszúnak kell lennie
		return false
	end
	v = string.sub(v, 1, 12)
	
	pop(v, chd)
	
	local elsbyte
	chsum = 0
	for j = 1, 12 do   -- z_13 = (10 - Summa (i=1,12) (z_i*(3^((i+1)%2))%10) %10
		elsbyte = string.byte(v, j);
		--pop(elsbyte)
		chsum = chsum + (elsbyte - string.byte('0', 1)) * 3^((j+1)%2)
		--pop(3^((j+1)%2))
	end
	pop(chsum)
	chnumdo = (10 - chsum % 10) % 10
	pop(chnumdo)
	if chnumdo == chnum then
		pop("true")
		return true
	else
		pop("true")
		return false
	end
end

local function isI(str)
	local v, eloirt_hossz
	v = str:gsub('[^%dXx]', '') -- a decimális jegyeken kívül mindent figyelmen kívül hagyunk
	pop(v)
	eloirt_hossz = 10
	pop('előírt hossza', eloirt_hossz)
	if #v == eloirt_hossz then
		pop('tízes')
		return isISBN10(str)
	elseif #v > eloirt_hossz then
		pop('tizenhármas')
		return isISBN13(str)
	else
		return false
    end
end

local function isISBN(str, link, no_isbn)
	if type(str) ~= 'string' then
		return error(false, 'Nem string bemenet az isISBN függvénynek')
	end
	local vizsgalandok = {}
	str = str:gsub('[^%d%,Xx -]', '') -- minden ki, ami nem számjegy, vessző, X/x, szóköz vagy kötőjel
	--[=[
	local elso_szelet, masodik_szelet
	elso_szelet = string.sub(str,1,-2)
	masodik_szelet = string.sub(str,-1,-1)
	pop("elso_szelet, masodik_szelet",elso_szelet,masodik_szelet)
	
	if masodik_szelet == 'X' then 
		elso_szelet=string.gsub(elso_szelet,'[%a<>%[%]%-%(%)%/%=%"]','') -- (str,'[^%d%,X,x]','')
		elso_szelet=string.gsub(elso_szelet,"ó",'')
		str = elso_szelet ..  masodik_szelet
	else 
		str=string.gsub(str,'[%a<>%[%]%-%(%)%/%=%"]','') -- (str,'[^%d%,X,x]','')
		str=string.gsub(str,"ó",'')
	end
	--]=]
	pop('str a ballaszt nélkül', str)
	for w in str:gmatch('[^%,]+') do
		w = mw.text.trim(w)
		pop('w', w .. '\n')  
		if w ~= '' then
			table.insert(vizsgalandok, w)
		end
	end
	local s = {}
	local s_nyers = {}
	local h = {}
	local h_nyers = {}
	local helyes = true
	local formatstring
	if link and no_isbn then
		formatstring = '[[Speciális:Könyvforrások/%s|%s]]'
	elseif link then
		formatstring = '[[Speciális:Könyvforrások/%s|ISBN&nbsp;%s]]'
	elseif no_isbn then
		formatstring = '%s'
	else
		formatstring = 'ISBN %s'
	end
	for _, vi in ipairs(vizsgalandok) do
		if isI(vi) then
			table.insert(s, string.format(formatstring, vi:gsub('[ -]', ''), vi:gsub(' ', '&nbsp;')))
			table.insert(s_nyers, vi)
			pop('helyes előrehaladása', table.concat(s, ', '))
		else
			helyes = false
			table.insert(h, error(true, 'helytelen ISBN kód') .. ': ' .. vi)
			table.insert(h_nyers, vi)
			pop('hibás előrehaladása', table.concat(h, ', '))
		end
	end
	s = table.concat(s, ', ')
	h = table.concat(h, ', ')
    return helyes, s, h, s_nyers, h_nyers
end -- isISBN   

local function _checkISBN(args)
	local jo_lista, mind
	local alkategoriak = {}
	local isbn = args[1]
	local link = (args.link ~= nil)
	local no_isbn = (args['isbn szöveg nélkül'] ~= nil)
	local hiba_jelzes = ''
	local milyen_lista = args[2]

	pop('a kapott argumentum', isbn)
	pop('linkelve?', tostring(link))
	-- ISBN lekezelése
	if isbn then 
		pop('van isbn paraméter', isbn)
		--isbn=string.gsub(isbn,"ISBN",'') -- a beleírt ISBN szövegeket kivesszük
		local helyes
		helyes, isbn, hiba_jelzes = isISBN(isbn, link, no_isbn)
		
		if helyes then
			pop('helyesek a paraméterek')
		end                       
	end
	
	if milyen_lista then 
		mind = false
		jo_lista = (milyen_lista == 'jólista')
	else
		mind = true 
	end
	
	-- output összeállítása
	local s
	if isbn then
		if hiba_jelzes then
			if mind then
				s = isbn
				if hibavan then
					s = s ..' ' .. hiba_jelzes
					-- a fölérendelt kategória marad hiba esetén
					if kategorizalas_van then s = s .. ' [[Kategória:Lapok helytelen ISBN kóddal]]' end
				end
			else  
				if jo_lista then
					s = isbn
				elseif hibavan then
					s = hiba_jelzes
					-- a fölérendelt kategória marad hiba esetén
					if kategorizalas_van then s = s .. ' [[Kategória:Lapok helytelen ISBN kóddal]]' end
				end
			end
		end	
	end
	-- if ou  then s = s..ou  end --ez csak nyomkövetésnél kell, de akkor nagyon
	-- s = s .. mw.dumpObject(args) 
	return s
end

local function run(frame)
	args = require('Modul:Arguments').getArgs(frame)
	return _checkISBN(args)
end

local p = {
	run = run,
	isISBN = isISBN,
	argumentumok = args
}

return p