Binding of Isaac: Rebirth Wiki
Advertisement

local p = {}

local bit32 = require( 'bit32' )

local w_frame = require( 'module:frame' )

local data = mw.loadData( 'module:dlc/data' )


function p.parse( f )
	return data.values[w_frame.args( f )[1] or ''] or 0
end


function p.test( f )
	local args = w_frame.args( f )
	return ( data.test[tonumber( args[1] )] or {} )[tonumber( args[2] ) or 15] or 0
end


p['context push'] = function ( f )
	local args   = w_frame.args( f )
	local filter = args.parsed or data.values[args[1]]
	if not filter then
		return
	end
	local frame   = mw.getCurrentFrame()
	local context = frame:callParserFunction( '#var:context' )
	filter = bit32.band( filter, tonumber( context ~= '' and mw.text.split( context, ' ' )[1] or 15 ) )
	if not filter then
		return
	end
	frame:callParserFunction( '#vardefine:context', filter .. ' ' .. context )
end


p['context test'] = function ( f )
	local args   = w_frame.args( f )
	local filter = tonumber( args.parsed or data.values[args[1]] )
	if not filter or not data.test[filter] then
		return 0
	end
	local context = mw.getCurrentFrame():callParserFunction( '#var:context' )
	return data.test[filter][tonumber( context ~= '' and mw.text.split( context, ' ' )[1] ) or 15] or 0
end


function p.find( f )
	local args   = w_frame.args( f )
	local filter = args[2] == 'last' and 8 or args[2] or tonumber( mw.getCurrentFrame():callParserFunction( '#var:context' ) ) or 15
	local parts
	for str in mw.text.gsplit( args[1], '▼' ) do
		parts = mw.text.split( str, '►' )
		if bit32.band( tonumber( parts[1] ), filter ) > 0 then
			return parts[2]
		end
	end
end


return p
Advertisement