Modul:GetRecipes: Unterschied zwischen den Versionen

Aus Eco - Deutsches Wiki
Wechseln zu:Navigation, Suche
[unmarkierte Version][unmarkierte Version]
Keine Bearbeitungszusammenfassung
GrobyZockt (Diskussion | Beiträge)
Keine Bearbeitungszusammenfassung
Zeile 44: Zeile 44:
     local parser = require( "Module:CraftingParser" )
     local parser = require( "Module:CraftingParser" )


    -- priority: item > table > group
      -- priority: item > table > group
     if item ~= nil then
     if item ~= nil then
        if itemList[item] == nil then
if productsList[item] ~= nil then
            return '===Crafting Recipes===\n\'\'None\'\'\n===Used in Recipes (potentially deprecated due to removal of groups - clean this up)===\n\'\'None\'\'\n'
local built = 1
        end
for num = 1, #productsList[item] do
        for num = 1, #itemList[item] do
if (productsList[item][num] ~= '' and recipeList[productsList[item][num]] ~= nil) then
            --nil entries in itemList are causing errors. Need to deal with exceptions where entry is ''
products[built] = recipeList[productsList[item][num]]
            if itemList[item][num] ~= '' then --skip blank entry in array. Applies to Bars (Iron Bars, Steel Bars, etc).
built = built + 1
if recipeList[itemList[item][num]] ~= nil then --skip missing recipes as those use variants
end
recipes[num] = recipeList[itemList[item][num]]
end
end
if ingredientsList[item] ~= nil then
local built = 1
for num = 1, #ingredientsList[item] do
if (ingredientsList[item][num] ~= '' and recipeList[ingredientsList[item][num]] ~= nil) then
ingredients[built] = recipeList[ingredientsList[item][num]]
built = built + 1
end
end
            end
end
            --Handle situations where itemList has a single, blank entry. Set value to item name provided by the calling page. Occurs for all tools. Could cause other issues for invalid item names.
end
            if #itemList[item] == 1 and itemList[item][num] == '' then
            recipes[num] = recipeList[item]
      return parser.formattedItem( products, ingredients, item )
            end
        end
       
        return parser.formattedItem( recipes, item )
          
          
     elseif table ~= nil then
     elseif table ~= nil then
--GROUP deprecated
         for num = 1, #tableList[table] do
         --if group ~= nil then
             recipes[num] = recipeList[tableList[table][num]]
            --local count = 1
        end
            --for num = 1, #tableList[table] do
 
                --for gnum = 1, #groupList[group] do
                    --if tableList[table][num] == groupList[group][gnum] then
                        --recipes[count] = recipeList[tableList[table][num]]
                        --count = count + 1
                    --end
                --end
             --end
        --else
            for num = 1, #tableList[table] do
                recipes[num] = recipeList[tableList[table][num]]
            end
        --end
         return parser.formattedTable( recipes, table )
         return parser.formattedTable( recipes, table )
    --GROUP deprecated
 
    --elseif group ~= nil then
        --for num = 1, #groupList[group] do
            --recipes[num] = recipeList[groupList[group][num]]
        --end
        --return parser.formattedGroup( recipes, group )
     else
     else
         return 'Invalid use of parameters, please see [[Template:GetRecipes]].'
         return 'Invalid use of parameters, please see [[Template:GetRecipes]].'
     end
     end
end
end


return p
return p

Version vom 13. Februar 2021, 18:13 Uhr

Documentation

This module is called by Vorlage:GetRecipes, and is the entry point for modules in the system that displays crafting recipes. It takes the item passed to the template, and uses Modul:CraftingRecipes to get every recipe related to the item. The resulting list of recipes is then passed to Module:CraftingParser, and the results from CraftingParser are returned to the template.

If the template is passed, this module creates a table using details from the following Modules:


local p = {}


-- Grabs args from the parent frame
-- Trims and parses the args into a table, then returns the table
function norm()
    local origArgs = mw.getCurrentFrame():getParent().args
    local args = {}
    
    for k, v in pairs( origArgs ) do
        v = mw.text.trim( tostring( v ) )
        if v ~= '' then
            args[k] = v
        end
    end
    
    return args
end


-- Main entry point for the Module
function p.main()
    -- get args from the Template
    local args = norm()
    
    -- assign variables for item, table, and group
    local item = args.item
    local table = args.table
    local group = args.group

    -- load list of recipes
    local completeList = require( "Module:CraftingRecipes" )
    local recipeList = completeList.recipes
    local itemList = completeList.items
    local tableList = completeList.tables
    
    -- groups no longer exists. Need to check all dependencies on this throughout other modules. Expecting implication to be removal of 'used in' table in the wiki.
    --local groupList = completeList.groups
    
    -- initialize a table to store recipes
    local recipes = {}
    
    -- load CraftingParser
    local parser = require( "Module:CraftingParser" )

       -- priority: item > table > group
    if item ~= nil then
		if productsList[item] ~= nil then
			local built = 1
			for num = 1, #productsList[item] do
				if (productsList[item][num] ~= '' and recipeList[productsList[item][num]] ~= nil) then
					products[built] = recipeList[productsList[item][num]]
					built = built + 1
				end
			end			
		end
		
		if ingredientsList[item] ~= nil then
			local built = 1
			for num = 1, #ingredientsList[item] do			
				if (ingredientsList[item][num] ~= '' and recipeList[ingredientsList[item][num]] ~= nil) then
					ingredients[built] = recipeList[ingredientsList[item][num]]
					built = built + 1
				end
			end
		end
		
       return parser.formattedItem( products, ingredients, item )
        
    elseif table ~= nil then
        for num = 1, #tableList[table] do
            recipes[num] = recipeList[tableList[table][num]]
        end

        return parser.formattedTable( recipes, table )

    else
        return 'Invalid use of parameters, please see [[Template:GetRecipes]].'
    end
end

return p