<?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%3ASmwUtil</id>
	<title>Modul:SmwUtil - 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%3ASmwUtil"/>
	<link rel="alternate" type="text/html" href="https://www.verzauberte-welten.de/index.php?title=Modul:SmwUtil&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:SmwUtil&amp;diff=4430&amp;oldid=prev</id>
		<title>imported&gt;Oetterer am 28. August 2017 um 13:05 Uhr</title>
		<link rel="alternate" type="text/html" href="https://www.verzauberte-welten.de/index.php?title=Modul:SmwUtil&amp;diff=4430&amp;oldid=prev"/>
		<updated>2017-08-28T13:05:56Z</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 p = {}&lt;br /&gt;
local classDebug = require('Module:Debug/class')&lt;br /&gt;
local getArgs = require('Module:Arguments').getArgs&lt;br /&gt;
local smw = mw.smw&lt;br /&gt;
local _TT = require('Module:TableTools')&lt;br /&gt;
&lt;br /&gt;
local cfg = {&lt;br /&gt;
	nameMainLabel = 'PageName',&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
local buildQueryFrom = function(stash)&lt;br /&gt;
	local query = {}&lt;br /&gt;
	if type(stash) == 'table' then&lt;br /&gt;
		for k, v in pairs(stash) do&lt;br /&gt;
			if type(v) == 'table' then&lt;br /&gt;
				for _, vv in pairs(v) do&lt;br /&gt;
					local val = vv&lt;br /&gt;
					if type(vv) == 'boolean' then&lt;br /&gt;
						val = vv and 'wahr' or 'falsch'&lt;br /&gt;
					end&lt;br /&gt;
					if type(k) == 'number' then&lt;br /&gt;
						table.insert(query, val)&lt;br /&gt;
					elseif type(val) == 'table' then&lt;br /&gt;
						error( 'While building set-query, detected invalid table value for key ' .. k .. ': ' .. _TT.printTable(val) )&lt;br /&gt;
					else&lt;br /&gt;
						table.insert(query, k .. '=' .. val)&lt;br /&gt;
					end&lt;br /&gt;
				end&lt;br /&gt;
			else&lt;br /&gt;
				local val = v&lt;br /&gt;
				if type(v) == 'boolean' then&lt;br /&gt;
					val = v and 'wahr' or 'falsch'&lt;br /&gt;
				end&lt;br /&gt;
				if type(k) == 'number' then&lt;br /&gt;
					table.insert(query, val)&lt;br /&gt;
				else&lt;br /&gt;
					table.insert(query, k .. '=' .. val)&lt;br /&gt;
				end&lt;br /&gt;
			end&lt;br /&gt;
		end&lt;br /&gt;
	else&lt;br /&gt;
		query[1] = stash&lt;br /&gt;
	end&lt;br /&gt;
	return query&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
local extractFieldFrom = function(s)&lt;br /&gt;
	local ret = '?' .. s:match('^%??([^#=]+).*$')&lt;br /&gt;
	local headline = s:find('=', 1, true) and&lt;br /&gt;
		s:match('^.*=([^=]*)$') or nil&lt;br /&gt;
	local formatter = s:find('#', 1, true) and&lt;br /&gt;
		s:match('^.*#([^=]*).*$') or nil&lt;br /&gt;
	if formatter and not formatter:find('-', 1, true) then&lt;br /&gt;
		formatter = formatter .. '-'&lt;br /&gt;
	end&lt;br /&gt;
	return ret .. ( formatter and ('#' .. formatter) or '' ) .. ( headline and ( '=' .. headline ) or '' )&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function p.ask(query, attributes, retainBlanks)&lt;br /&gt;
	classDebug:log(21, 'entering SmwUtil.ask', 'SmwUtil.ask')&lt;br /&gt;
	classDebug:log(23, ' with query: ' .. (query and _TT.printTable(query) or 'NONE'), 'SmwUtil.ask')&lt;br /&gt;
	classDebug:log(23, ' with attributes: ' .. (attributes and _TT.printTable(attributes) or 'NONE'), 'SmwUtil.ask')&lt;br /&gt;
	local select = query.select and query.select or (query.where and query.where or nil)&lt;br /&gt;
	local fields = query.fields&lt;br /&gt;
	local attributes = attributes or {}&lt;br /&gt;
	if not select or (type(select) == 'table' and _TT.size(select) == 0) or (#select == 0) then&lt;br /&gt;
		error('SmwUtil.ask: Argument query.select is missing or empty!', 2)&lt;br /&gt;
	end&lt;br /&gt;
	if type(attributes) == 'string' then&lt;br /&gt;
		attributes = { attributes }&lt;br /&gt;
	elseif type(attributes) ~= 'table' then&lt;br /&gt;
		error('SmwUtil.ask: Argument attributes has wrong parameter type (' .. type(attributes) .. '); must be table or string', 2)&lt;br /&gt;
	end&lt;br /&gt;
	if not attributes.limit then&lt;br /&gt;
		attributes.limit = 1000&lt;br /&gt;
	end&lt;br /&gt;
	local nameMainlabel = (attributes.mainlabel and attributes.mainlabel ~= '-') and attributes.mainlabel or cfg.nameMainLabel&lt;br /&gt;
	attributes.mainlabel = '-'&lt;br /&gt;
	-- now build the query&lt;br /&gt;
	local query = {}&lt;br /&gt;
	if type(select) == 'string' then&lt;br /&gt;
		table.insert(query, select)&lt;br /&gt;
	else&lt;br /&gt;
		for k, v in pairs(select) do&lt;br /&gt;
			if type(k) == 'number' then&lt;br /&gt;
				table.insert(query, v)&lt;br /&gt;
			else&lt;br /&gt;
				table.insert(query, '[[' .. k .. '::' .. v .. ']]')&lt;br /&gt;
			end&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	table.insert(query, '?#-=' .. nameMainlabel)&lt;br /&gt;
	if type(fields) == 'string' then&lt;br /&gt;
		table.insert(query, extractFieldFrom(fields))&lt;br /&gt;
	elseif type(fields) == 'table' then&lt;br /&gt;
		for _, v in pairs(fields) do&lt;br /&gt;
			table.insert(query, extractFieldFrom(v))&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	for k, v in pairs(attributes) do&lt;br /&gt;
		if type(k) == 'number' then&lt;br /&gt;
			table.insert(query, v)&lt;br /&gt;
		else&lt;br /&gt;
			table.insert(query, k .. '=' .. v)&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	local result = smw.ask(query)&lt;br /&gt;
	if type(result) == 'table' and result[nameMainlabel] then&lt;br /&gt;
		result[1] = nameMainlabel&lt;br /&gt;
	end&lt;br /&gt;
	return result, query&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function p.rawask(query, attributes)&lt;br /&gt;
	classDebug:log(21, 'entering SmwUtil.rawask', 'SmwUtil.rawask')&lt;br /&gt;
	classDebug:log(23, ' with query: ' .. (query and _TT.printTable(query) or 'NONE'), 'SmwUtil.rawask')&lt;br /&gt;
	classDebug:log(23, ' with attributes: ' .. (attributes and _TT.printTable(attributes) or 'NONE'), 'SmwUtil.rawask')&lt;br /&gt;
	local frame = mw.getCurrentFrame()&lt;br /&gt;
	local select = query.select and query.select or (query.where and query.where or nil)&lt;br /&gt;
	local fields = query.fields&lt;br /&gt;
	local selection = ''&lt;br /&gt;
	if type(select) == 'string' then&lt;br /&gt;
		selection = select&lt;br /&gt;
	elseif type(select) == 'table' then&lt;br /&gt;
		for k, v in pairs(select) do&lt;br /&gt;
			if type(k) == 'number' then&lt;br /&gt;
				selection = selection .. ' ' .. v&lt;br /&gt;
			else&lt;br /&gt;
				selection = selection .. ' [[' .. k .. '::' .. v .. ']]'&lt;br /&gt;
			end&lt;br /&gt;
		end&lt;br /&gt;
	else&lt;br /&gt;
		error('SmwUtil.rawask: Argument query.select has wrong parameter type (' .. type(select) .. '); must be table or string', 2)&lt;br /&gt;
	end&lt;br /&gt;
	local args = {}&lt;br /&gt;
	if type(fields) == 'string' then&lt;br /&gt;
		args[1] = mw.ustring.sub( fields, 1, 1 ) ~= '?' and '?' .. fields or fields&lt;br /&gt;
	elseif type(fields) == 'table' then&lt;br /&gt;
		for k, v in pairs(fields) do&lt;br /&gt;
			args[k] = mw.ustring.sub( v, 1, 1 ) ~= '?' and '?' .. v or v&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	if attributes then&lt;br /&gt;
		if type(attributes) == 'string' then&lt;br /&gt;
			table.insert(args, attributes)&lt;br /&gt;
		elseif type(attributes) == 'table' then&lt;br /&gt;
			for k, v in pairs(attributes) do&lt;br /&gt;
				args[k] = v&lt;br /&gt;
			end&lt;br /&gt;
		else&lt;br /&gt;
			error('SmwUtil.rawask: Argument attributes has wrong parameter type (' .. type(attributes) .. '); must be table or string', 2)&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	return frame:callParserFunction{ name = '#ask:' .. selection, args = args}&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function p.set(stash)&lt;br /&gt;
	classDebug:log(21, 'entering SmwUtil.set', 'SmwUtil.set')&lt;br /&gt;
	classDebug:log(23, ' with stash: ' .. (stash and _TT.printTable(stash) or 'NONE'), 'SmwUtil.set')&lt;br /&gt;
	if type(stash) ~= 'string' and type(stash) ~= 'table' then&lt;br /&gt;
		error('SmwUtil.set: Argument stash has wrong parameter type (' .. type(stash) .. '); must be table or string', 2)&lt;br /&gt;
	end&lt;br /&gt;
	-- build and execute query&lt;br /&gt;
	local query = buildQueryFrom(stash)&lt;br /&gt;
	local result = smw.set(query)&lt;br /&gt;
	if result == true then&lt;br /&gt;
		return ''&lt;br /&gt;
	else&lt;br /&gt;
		return result.error&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function p.show(page, field)&lt;br /&gt;
	classDebug:log(21, 'entering SmwUtil.show', 'SmwUtil.show')&lt;br /&gt;
	classDebug:log(23, ' with page: ' .. (page and page or 'NONE'), 'SmwUtil.show')&lt;br /&gt;
	classDebug:log(23, ' with field: ' .. (field and field or 'NONE'), 'SmwUtil.show')&lt;br /&gt;
	local frame = mw.getCurrentFrame()&lt;br /&gt;
	local page = page:match('^[%[]*([^%[%]]+)[%]]*$')&lt;br /&gt;
	local field = mw.ustring.sub( field, 1, 1 ) ~= '?' and '?' .. field or field&lt;br /&gt;
	return frame:callParserFunction('#show:' .. page, field)&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function p.subobject(stash, uid)&lt;br /&gt;
	classDebug:log(21, 'entering SmwUtil.subobject', 'SmwUtil.subobject')&lt;br /&gt;
	classDebug:log(23, ' with stash: ' .. (stash and _TT.printTable(stash) or 'NONE'), 'SmwUtil.subobject')&lt;br /&gt;
	classDebug:log(23, ' with uid: ' .. (uid and uid or 'NONE'), 'SmwUtil.subobject')&lt;br /&gt;
	if type(stash) ~= 'string' and type(stash) ~= 'table' then&lt;br /&gt;
		error('SmwUtil.subobject: Argument stash has wrong parameter type (' .. type(stash) .. '); must be table or string', 2)&lt;br /&gt;
	end&lt;br /&gt;
	-- build and execute query&lt;br /&gt;
	local uid = uid or nil&lt;br /&gt;
	local query = buildQueryFrom(stash)&lt;br /&gt;
	local result = smw.subobject(query, uid)&lt;br /&gt;
	if result == true then&lt;br /&gt;
		return ''&lt;br /&gt;
	else&lt;br /&gt;
		return result.error&lt;br /&gt;
	end&lt;br /&gt;
end &lt;br /&gt;
-- ************************************&lt;br /&gt;
-- alias definition&lt;br /&gt;
-- ************************************&lt;br /&gt;
&lt;br /&gt;
p.get = p.show&lt;br /&gt;
p.lua = p.ask&lt;br /&gt;
&lt;br /&gt;
return p&lt;/div&gt;</summary>
		<author><name>imported&gt;Oetterer</name></author>
	</entry>
</feed>