<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="de">
	<id>https://www.verzauberte-welten.de/index.php?action=history&amp;feed=atom&amp;title=Modul%3ADebug%2Fclass</id>
	<title>Modul:Debug/class - Versionsgeschichte</title>
	<link rel="self" type="application/atom+xml" href="https://www.verzauberte-welten.de/index.php?action=history&amp;feed=atom&amp;title=Modul%3ADebug%2Fclass"/>
	<link rel="alternate" type="text/html" href="https://www.verzauberte-welten.de/index.php?title=Modul:Debug/class&amp;action=history"/>
	<updated>2026-04-05T22:33:39Z</updated>
	<subtitle>Versionsgeschichte dieser Seite in Verzauberte Welten e.V.</subtitle>
	<generator>MediaWiki 1.39.8</generator>
	<entry>
		<id>https://www.verzauberte-welten.de/index.php?title=Modul:Debug/class&amp;diff=4413&amp;oldid=prev</id>
		<title>imported&gt;Oetterer am 2. Oktober 2015 um 18:14 Uhr</title>
		<link rel="alternate" type="text/html" href="https://www.verzauberte-welten.de/index.php?title=Modul:Debug/class&amp;diff=4413&amp;oldid=prev"/>
		<updated>2015-10-02T18:14:02Z</updated>

		<summary type="html">&lt;p&gt;&lt;/p&gt;
&lt;p&gt;&lt;b&gt;Neue Seite&lt;/b&gt;&lt;/p&gt;&lt;div&gt;local class = require('Module:Middleclass').class&lt;br /&gt;
local classDebug = class('Debug')&lt;br /&gt;
&lt;br /&gt;
-- ****************************************************************&lt;br /&gt;
-- *                          properties                          *&lt;br /&gt;
-- ****************************************************************&lt;br /&gt;
 &lt;br /&gt;
-- **************** initialization of table for private properties&lt;br /&gt;
local _private = setmetatable({}, {__mode = &amp;quot;k&amp;quot;})   -- weak table storing all private attributes&lt;br /&gt;
 &lt;br /&gt;
-- **************** declaration of private static properties&lt;br /&gt;
-- local _PROPERTY = require( 'Module:' )&lt;br /&gt;
local _debugLog = {}&lt;br /&gt;
local _numberingByChannel = {}&lt;br /&gt;
local _defaultDebugLevel = 1&lt;br /&gt;
local _defaultOutputType = 'pre'&lt;br /&gt;
local _LANG = mw.language.new( 'de' )&lt;br /&gt;
&lt;br /&gt;
-- ***************************************************************&lt;br /&gt;
-- *                           methods                           *&lt;br /&gt;
-- ***************************************************************&lt;br /&gt;
 &lt;br /&gt;
-- **************** declaration of static methods&lt;br /&gt;
-- local _wrapLog		-- declaration ahead, so this private method can be used in the constructor and in other private methods&lt;br /&gt;
function classDebug:initialize(handler)	-- constructor&lt;br /&gt;
	-- initialize all private properties&lt;br /&gt;
	_private[self] = {&lt;br /&gt;
		handler = handler or 'NIL',&lt;br /&gt;
	}&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function classDebug.static:log(level, text, handler)&lt;br /&gt;
	local handler = handler or 'NIL'&lt;br /&gt;
	_numberingByChannel[handler] = _numberingByChannel[handler] and (_numberingByChannel[handler] + 1) or 1&lt;br /&gt;
	table.insert(_debugLog, {level = level,&lt;br /&gt;
							text = text,&lt;br /&gt;
							handler = handler,&lt;br /&gt;
							line = _numberingByChannel[handler],&lt;br /&gt;
							ts = _LANG:formatDate('H:i:s', nil, true)}&lt;br /&gt;
				)&lt;br /&gt;
	return true&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function classDebug.static:printLog(level, outputtype)&lt;br /&gt;
	local str = ''&lt;br /&gt;
	local level = level or _defaultDebugLevel&lt;br /&gt;
	local outputtype = outputtype and mw.ustring.lower(outputtype) or _defaultOutputType&lt;br /&gt;
	for _, entry in pairs(_debugLog) do&lt;br /&gt;
		if level &amp;gt;= entry.level then&lt;br /&gt;
			local line = entry.ts .. ' [' .. entry.handler .. '].' .. entry.line .. ' &amp;amp;lt;l:' .. entry.level .. '&amp;amp;gt; - ' .. entry.text&lt;br /&gt;
			if outputtype == 'ol' or outputtype == 'ul' then&lt;br /&gt;
				line = '&amp;lt;li&amp;gt;' .. line .. '&amp;lt;/li&amp;gt;'&lt;br /&gt;
			end&lt;br /&gt;
			str = str .. line .. '\n'&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	if #str &amp;gt; 0 then&lt;br /&gt;
		if outputtype == 'pre' then&lt;br /&gt;
			str = '&amp;lt;pre&amp;gt;\n' .. str .. '&amp;lt;/pre&amp;gt;\n'&lt;br /&gt;
		elseif outputtype == 'ul' then&lt;br /&gt;
			str = '&amp;lt;ul&amp;gt;\n' .. str .. '&amp;lt;/ul&amp;gt;\n'&lt;br /&gt;
		elseif outputtype == 'ol' then&lt;br /&gt;
			str = '&amp;lt;ol&amp;gt;\n' .. str .. '&amp;lt;/ol&amp;gt;\n'&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	return str&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
-- **************** declaration of private methods&lt;br /&gt;
-- none&lt;br /&gt;
&lt;br /&gt;
-- **************** declaration of public methods&lt;br /&gt;
function classDebug:__tostring()&lt;br /&gt;
	return tostring(self:getOutput())&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function classDebug:log(level, text)&lt;br /&gt;
	return classDebug:log(level, text, _private[self].handler)&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function classDebug:printLog(level, outputtype)&lt;br /&gt;
	local str = ''&lt;br /&gt;
	local level = level or _defaultDebugLevel&lt;br /&gt;
	local outputtype = outputtype and mw.ustring.lower(outputtype) or _defaultOutputType&lt;br /&gt;
	local handler = _private[self].handler&lt;br /&gt;
	for _, entry in pairs(_debugLog) do&lt;br /&gt;
		if handler == entry.handler then&lt;br /&gt;
			if level &amp;gt;= entry.level then&lt;br /&gt;
				local line = entry.ts .. ' [' .. entry.handler .. '].' .. entry.line .. ' &amp;amp;lt;l:' .. entry.level .. '&amp;amp;gt; - ' .. entry.text&lt;br /&gt;
				if outputtype == 'ol' or outputtype == 'ul' then&lt;br /&gt;
					line = '&amp;lt;li&amp;gt;' .. line .. '&amp;lt;/li&amp;gt;'&lt;br /&gt;
				end&lt;br /&gt;
				str = str .. line .. '\n'&lt;br /&gt;
			end&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	if #str &amp;gt; 0 then&lt;br /&gt;
		if outputtype == 'pre' then&lt;br /&gt;
			str = '&amp;lt;pre&amp;gt;\n' .. str .. '&amp;lt;/pre&amp;gt;\n'&lt;br /&gt;
		elseif outputtype == 'ul' then&lt;br /&gt;
			str = '&amp;lt;ul&amp;gt;\n' .. str .. '&amp;lt;/ul&amp;gt;\n'&lt;br /&gt;
		elseif outputtype == 'ol' then&lt;br /&gt;
			str = '&amp;lt;ol&amp;gt;\n' .. str .. '&amp;lt;/ol&amp;gt;\n'&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	return str&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
return classDebug&lt;/div&gt;</summary>
		<author><name>imported&gt;Oetterer</name></author>
	</entry>
</feed>