Make global names in default mod use good naming convention and move backwards-compat...
authorPerttu Ahola <celeron55@gmail.com>
Sat, 3 Dec 2011 18:25:21 +0000 (20:25 +0200)
committerPerttu Ahola <celeron55@gmail.com>
Sat, 3 Dec 2011 18:25:21 +0000 (20:25 +0200)
data/builtin.lua
data/mods/default/init.lua
data/mods/experimental/init.lua
data/mods/legacy/depends.txt [new file with mode: 0644]
data/mods/legacy/init.lua [new file with mode: 0644]

index 5d6936d618f0ea5d6d676509c97ee1b12ff7d50f..2f167acfababb4e1ecd78db22e8c312d6312b9ff 100644 (file)
@@ -340,6 +340,77 @@ minetest.craftitem_eat = function(hp_change)
        end
 end
 
+--
+-- Default material types
+--
+
+function minetest.digprop_constanttime(time)
+       return {
+               diggability = "constant",
+               constant_time = time,
+       }
+end
+
+function minetest.digprop_stonelike(toughness)
+       return {
+               diggablity = "normal",
+               weight = toughness * 5,
+               crackiness = 1,
+               crumbliness = -0.1,
+               cuttability = -0.2,
+       }
+end
+
+function minetest.digprop_dirtlike(toughness)
+       return {
+               diggablity = "normal",
+               weight = toughness * 1.2,
+               crackiness = 0,
+               crumbliness = 1.2,
+               cuttability = -0.4,
+       }
+end
+
+function minetest.digprop_gravellike(toughness)
+       return {
+               diggablity = "normal",
+               weight = toughness * 2,
+               crackiness = 0.2,
+               crumbliness = 1.5,
+               cuttability = -1.0,
+       }
+end
+
+function minetest.digprop_woodlike(toughness)
+       return {
+               diggablity = "normal",
+               weight = toughness * 1.0,
+               crackiness = 0.75,
+               crumbliness = -1.0,
+               cuttability = 1.5,
+       }
+end
+
+function minetest.digprop_leaveslike(toughness)
+       return {
+               diggablity = "normal",
+               weight = toughness * (-0.5),
+               crackiness = 0,
+               crumbliness = 0,
+               cuttability = 2.0,
+       }
+end
+
+function minetest.digprop_glasslike(toughness)
+       return {
+               diggablity = "normal",
+               weight = toughness * 0.1,
+               crackiness = 2.0,
+               crumbliness = -1.0,
+               cuttability = -1.0,
+       }
+end
+
 --
 -- Creative inventory
 --
index 7383996b13bada6ee2882939dd33d121818eac1d..b32b6215abf2e2a53987f3427581a5372b5103d8 100644 (file)
@@ -1,3 +1,9 @@
+-- default (Minetest 0.4 mod)
+-- Most default stuff
+
+-- Quick documentation about the API
+-- =================================
+--
 -- Helper functions defined by builtin.lua:
 -- dump2(obj, name="_", dumped={})
 -- dump(obj, dumped={})
@@ -36,7 +42,7 @@
 --          ":experimental:tnt" when registering it.
 -- (also that mods is required to have "experimental" as a dependency)
 --
--- Default mod uses ":" for maintaining backwards compatibility.
+-- The legacy mod uses ":" for maintaining backwards compatibility.
 --
 -- Textures
 -- --------
 -- MapNode representation:
 -- {name="name", param1=num, param2=num}
 --
+-- param1 and param2 are 8 bit and 4 bit integers, respectively. They
+-- are reserved for certain automated functions. If you don't use these
+-- functions, you can use them to store arbitrary values.
+--
+-- param1 is reserved for the engine when:
+--   paramtype != "none"
+-- param2 is reserved for the engine when any of these are used:
+--   liquidtype == "flowing"
+--   drawtype == "flowingliquid"
+--   drawtype == "torchlike"
+--   drawtype == "signlike"
+--
 -- Position representation:
 -- {x=num, y=num, z=num}
 --
 -- stackstring/itemstring: A stack of items in serialized format.
 -- eg. 'node "dirt" 5'
--- eg. 'tool "WPick" 21323'
+-- eg. 'tool "default:pick_wood" 21323'
 -- eg. 'craft "apple" 2'
 --
 -- item: A single item in Lua table format.
 -- eg. {type="node", name="dirt"} 
 --     ^ a single dirt node
--- eg. {type="tool", name="WPick", wear=21323}
+-- eg. {type="tool", name="default:pick_wood", wear=21323}
 --     ^ a wooden pick about 1/3 weared out
 -- eg. {type="craft", name="apple"}
 --     ^ an apple.
 -- - add_node(pos, node)
 -- - remove_node(pos)
 -- - get_node(pos)
+--   ^ Returns {name="ignore", ...} for unloaded area
+-- - get_node_or_nil(pos)
+--   ^ Returns nil for unloaded area
 -- - add_luaentity(pos, name)
 -- - add_item(pos, itemstring)
 -- - add_rat(pos)
 --
 -- Node definition options:
 -- {
---     name = "somenode",
+--     name = "modname:somenode",
 --     drawtype = "normal",
 --     visual_scale = 1.0,
 --     tile_images = {"unknown_block.png"},
 --         cuttability = 0,
 --         flammability = 0,
 --     },
---     cookresult_item = "", -- Cannot be cooked
+--     cookresult_itemstring = "", -- Cannot be cooked
 --     furnace_cooktime = 3.0,
 --     furnace_burntime = -1, -- Cannot be used as fuel
 -- }
 -- minetest.register_craftitem("modname_name", {
 --     image = "image.png",
 --     stack_max = <maximum number of items in stack>,
---     cookresult_item = itemstring (result of cooking),
+--     cookresult_itemstring = itemstring (result of cooking),
 --     furnace_cooktime = <cooking time>,
 --     furnace_burntime = <time to burn as fuel in furnace>,
 --     usable = <uh... some boolean value>,
 -- 
 -- Recipe:
 -- {
---     output = 'tool "STPick"',
+--     output = 'tool "default:pick_stone"',
 --     recipe = {
 --         {'node "cobble"', 'node "cobble"', 'node "cobble"'},
---         {'', 'craft "Stick"', ''},
---         {'', 'craft "Stick"', ''},
+--         {'', 'craft "default:stick"', ''},
+--         {'', 'craft "default:stick"', ''},
 --     }
 -- }
 --
 --     action = func(pos, node, active_object_count, active_object_count_wider),
 -- }
 
--- print("minetest dump: "..dump(minetest))
-
 WATER_ALPHA = 160
 WATER_VISC = 1
 LAVA_VISC = 7
 LIGHT_MAX = 14
 
+-- Definitions made by this mod that other mods can use too
+default = {}
+
 --
 -- Tool definition
 --
 
-minetest.register_tool(":WPick", {
+-- The hand
+minetest.register_tool(":", {
+       image = "",
+       basetime = 0.5,
+       dt_weight = 1,
+       dt_crackiness = 0,
+       dt_crumbliness = -1,
+       dt_cuttability = 0,
+       basedurability = 50,
+       dd_weight = 0,
+       dd_crackiness = 0,
+       dd_crumbliness = 0,
+       dd_cuttability = 0,
+})
+
+minetest.register_tool("default:pick_wood", {
        image = "tool_woodpick.png",
        basetime = 2.0,
        dt_weight = 0,
@@ -321,7 +358,7 @@ minetest.register_tool(":WPick", {
        dd_crumbliness = 0,
        dd_cuttability = 0,
 })
-minetest.register_tool(":STPick", {
+minetest.register_tool("default:pick_stone", {
        image = "tool_stonepick.png",
        basetime = 1.5,
        dt_weight = 0,
@@ -334,7 +371,7 @@ minetest.register_tool(":STPick", {
        dd_crumbliness = 0,
        dd_cuttability = 0,
 })
-minetest.register_tool(":SteelPick", {
+minetest.register_tool("default:pick_steel", {
        image = "tool_steelpick.png",
        basetime = 1.0,
        dt_weight = 0,
@@ -347,7 +384,7 @@ minetest.register_tool(":SteelPick", {
        dd_crumbliness = 0,
        dd_cuttability = 0,
 })
-minetest.register_tool(":MesePick", {
+minetest.register_tool("default:pick_mese", {
        image = "tool_mesepick.png",
        basetime = 0,
        dt_weight = 0,
@@ -360,7 +397,7 @@ minetest.register_tool(":MesePick", {
        dd_crumbliness = 0,
        dd_cuttability = 0,
 })
-minetest.register_tool(":WShovel", {
+minetest.register_tool("default:shovel_wood", {
        image = "tool_woodshovel.png",
        basetime = 2.0,
        dt_weight = 0.5,
@@ -373,7 +410,7 @@ minetest.register_tool(":WShovel", {
        dd_crumbliness = 0,
        dd_cuttability = 0,
 })
-minetest.register_tool(":STShovel", {
+minetest.register_tool("default:shovel_stone", {
        image = "tool_stoneshovel.png",
        basetime = 1.5,
        dt_weight = 0.5,
@@ -386,7 +423,7 @@ minetest.register_tool(":STShovel", {
        dd_crumbliness = 0,
        dd_cuttability = 0,
 })
-minetest.register_tool(":SteelShovel", {
+minetest.register_tool("default:shovel_steel", {
        image = "tool_steelshovel.png",
        basetime = 1.0,
        dt_weight = 0.5,
@@ -399,7 +436,7 @@ minetest.register_tool(":SteelShovel", {
        dd_crumbliness = 0,
        dd_cuttability = 0,
 })
-minetest.register_tool(":WAxe", {
+minetest.register_tool("default:axe_wood", {
        image = "tool_woodaxe.png",
        basetime = 2.0,
        dt_weight = 0.5,
@@ -412,7 +449,7 @@ minetest.register_tool(":WAxe", {
        dd_crumbliness = 0,
        dd_cuttability = 0,
 })
-minetest.register_tool(":STAxe", {
+minetest.register_tool("default:axe_stone", {
        image = "tool_stoneaxe.png",
        basetime = 1.5,
        dt_weight = 0.5,
@@ -425,7 +462,7 @@ minetest.register_tool(":STAxe", {
        dd_crumbliness = 0,
        dd_cuttability = 0,
 })
-minetest.register_tool(":SteelAxe", {
+minetest.register_tool("default:axe_steel", {
        image = "tool_steelaxe.png",
        basetime = 1.0,
        dt_weight = 0.5,
@@ -438,7 +475,7 @@ minetest.register_tool(":SteelAxe", {
        dd_crumbliness = 0,
        dd_cuttability = 0,
 })
-minetest.register_tool(":WSword", {
+minetest.register_tool("default:sword_wood", {
        image = "tool_woodsword.png",
        basetime = 3.0,
        dt_weight = 3,
@@ -451,7 +488,7 @@ minetest.register_tool(":WSword", {
        dd_crumbliness = 0,
        dd_cuttability = 0,
 })
-minetest.register_tool(":STSword", {
+minetest.register_tool("default:sword_stone", {
        image = "tool_stonesword.png",
        basetime = 2.5,
        dt_weight = 3,
@@ -464,7 +501,7 @@ minetest.register_tool(":STSword", {
        dd_crumbliness = 0,
        dd_cuttability = 0,
 })
-minetest.register_tool(":SteelSword", {
+minetest.register_tool("default:sword_steel", {
        image = "tool_steelsword.png",
        basetime = 2.0,
        dt_weight = 3,
@@ -477,210 +514,196 @@ minetest.register_tool(":SteelSword", {
        dd_crumbliness = 0,
        dd_cuttability = 0,
 })
--- The hand
-minetest.register_tool(":", {
-       image = "",
-       basetime = 0.5,
-       dt_weight = 1,
-       dt_crackiness = 0,
-       dt_crumbliness = -1,
-       dt_cuttability = 0,
-       basedurability = 50,
-       dd_weight = 0,
-       dd_crackiness = 0,
-       dd_crumbliness = 0,
-       dd_cuttability = 0,
-})
 
 --
 -- Crafting definition
 --
 
 minetest.register_craft({
-       output = 'node "wood" 4',
+       output = 'node "default:wood" 4',
        recipe = {
                {'node "tree"'},
        }
 })
 
 minetest.register_craft({
-       output = 'craft "Stick" 4',
+       output = 'craft "default:stick" 4',
        recipe = {
-               {'node "wood"'},
+               {'node "default:wood"'},
        }
 })
 
 minetest.register_craft({
-       output = 'node "wooden_fence" 2',
+       output = 'node "fence_wooden" 2',
        recipe = {
-               {'craft "Stick"', 'craft "Stick"', 'craft "Stick"'},
-               {'craft "Stick"', 'craft "Stick"', 'craft "Stick"'},
+               {'craft "default:stick"', 'craft "default:stick"', 'craft "default:stick"'},
+               {'craft "default:stick"', 'craft "default:stick"', 'craft "default:stick"'},
        }
 })
 
 minetest.register_craft({
-       output = 'node "sign_wall" 1',
+       output = 'node "default:sign_wall" 1',
        recipe = {
-               {'node "wood"', 'node "wood"', 'node "wood"'},
-               {'node "wood"', 'node "wood"', 'node "wood"'},
-               {'', 'craft "Stick"', ''},
+               {'node "default:wood"', 'node "default:wood"', 'node "default:wood"'},
+               {'node "default:wood"', 'node "default:wood"', 'node "default:wood"'},
+               {'', 'craft "default:stick"', ''},
        }
 })
 
 minetest.register_craft({
-       output = 'node "torch" 4',
+       output = 'node "default:torch" 4',
        recipe = {
-               {'craft "lump_of_coal"'},
-               {'craft "Stick"'},
+               {'craft "default:lump_of_coal"'},
+               {'craft "default:stick"'},
        }
 })
 
 minetest.register_craft({
-       output = 'tool "WPick"',
+       output = 'tool "default:pick_wood"',
        recipe = {
-               {'node "wood"', 'node "wood"', 'node "wood"'},
-               {'', 'craft "Stick"', ''},
-               {'', 'craft "Stick"', ''},
+               {'node "default:wood"', 'node "default:wood"', 'node "default:wood"'},
+               {'', 'craft "default:stick"', ''},
+               {'', 'craft "default:stick"', ''},
        }
 })
 
 minetest.register_craft({
-       output = 'tool "STPick"',
+       output = 'tool "default:pick_stone"',
        recipe = {
                {'node "cobble"', 'node "cobble"', 'node "cobble"'},
-               {'', 'craft "Stick"', ''},
-               {'', 'craft "Stick"', ''},
+               {'', 'craft "default:stick"', ''},
+               {'', 'craft "default:stick"', ''},
        }
 })
 
 minetest.register_craft({
-       output = 'tool "SteelPick"',
+       output = 'tool "default:pick_steel"',
        recipe = {
-               {'craft "steel_ingot"', 'craft "steel_ingot"', 'craft "steel_ingot"'},
-               {'', 'craft "Stick"', ''},
-               {'', 'craft "Stick"', ''},
+               {'craft "default:steel_ingot"', 'craft "default:steel_ingot"', 'craft "default:steel_ingot"'},
+               {'', 'craft "default:stick"', ''},
+               {'', 'craft "default:stick"', ''},
        }
 })
 
 minetest.register_craft({
-       output = 'tool "MesePick"',
+       output = 'tool "default:pick_mese"',
        recipe = {
                {'node "mese"', 'node "mese"', 'node "mese"'},
-               {'', 'craft "Stick"', ''},
-               {'', 'craft "Stick"', ''},
+               {'', 'craft "default:stick"', ''},
+               {'', 'craft "default:stick"', ''},
        }
 })
 
 minetest.register_craft({
-       output = 'tool "WShovel"',
+       output = 'tool "default:shovel_wood"',
        recipe = {
-               {'node "wood"'},
-               {'craft "Stick"'},
-               {'craft "Stick"'},
+               {'node "default:wood"'},
+               {'craft "default:stick"'},
+               {'craft "default:stick"'},
        }
 })
 
 minetest.register_craft({
-       output = 'tool "STShovel"',
+       output = 'tool "default:shovel_stone"',
        recipe = {
                {'node "cobble"'},
-               {'craft "Stick"'},
-               {'craft "Stick"'},
+               {'craft "default:stick"'},
+               {'craft "default:stick"'},
        }
 })
 
 minetest.register_craft({
-       output = 'tool "SteelShovel"',
+       output = 'tool "default:shovel_steel"',
        recipe = {
-               {'craft "steel_ingot"'},
-               {'craft "Stick"'},
-               {'craft "Stick"'},
+               {'craft "default:steel_ingot"'},
+               {'craft "default:stick"'},
+               {'craft "default:stick"'},
        }
 })
 
 minetest.register_craft({
-       output = 'tool "WAxe"',
+       output = 'tool "default:axe_wood"',
        recipe = {
-               {'node "wood"', 'node "wood"'},
-               {'node "wood"', 'craft "Stick"'},
-               {'', 'craft "Stick"'},
+               {'node "default:wood"', 'node "default:wood"'},
+               {'node "default:wood"', 'craft "default:stick"'},
+               {'', 'craft "default:stick"'},
        }
 })
 
 minetest.register_craft({
-       output = 'tool "STAxe"',
+       output = 'tool "default:axe_stone"',
        recipe = {
                {'node "cobble"', 'node "cobble"'},
-               {'node "cobble"', 'craft "Stick"'},
-               {'', 'craft "Stick"'},
+               {'node "cobble"', 'craft "default:stick"'},
+               {'', 'craft "default:stick"'},
        }
 })
 
 minetest.register_craft({
-       output = 'tool "SteelAxe"',
+       output = 'tool "default:axe_steel"',
        recipe = {
-               {'craft "steel_ingot"', 'craft "steel_ingot"'},
-               {'craft "steel_ingot"', 'craft "Stick"'},
-               {'', 'craft "Stick"'},
+               {'craft "default:steel_ingot"', 'craft "default:steel_ingot"'},
+               {'craft "default:steel_ingot"', 'craft "default:stick"'},
+               {'', 'craft "default:stick"'},
        }
 })
 
 minetest.register_craft({
-       output = 'tool "WSword"',
+       output = 'tool "default:sword_wood"',
        recipe = {
-               {'node "wood"'},
-               {'node "wood"'},
-               {'craft "Stick"'},
+               {'node "default:wood"'},
+               {'node "default:wood"'},
+               {'craft "default:stick"'},
        }
 })
 
 minetest.register_craft({
-       output = 'tool "STSword"',
+       output = 'tool "default:sword_stone"',
        recipe = {
                {'node "cobble"'},
                {'node "cobble"'},
-               {'craft "Stick"'},
+               {'craft "default:stick"'},
        }
 })
 
 minetest.register_craft({
-       output = 'tool "SteelSword"',
+       output = 'tool "default:sword_steel"',
        recipe = {
-               {'craft "steel_ingot"'},
-               {'craft "steel_ingot"'},
-               {'craft "Stick"'},
+               {'craft "default:steel_ingot"'},
+               {'craft "default:steel_ingot"'},
+               {'craft "default:stick"'},
        }
 })
 
 minetest.register_craft({
-       output = 'node "rail" 15',
+       output = 'node "default:rail" 15',
        recipe = {
-               {'craft "steel_ingot"', '', 'craft "steel_ingot"'},
-               {'craft "steel_ingot"', 'craft "Stick"', 'craft "steel_ingot"'},
-               {'craft "steel_ingot"', '', 'craft "steel_ingot"'},
+               {'craft "default:steel_ingot"', '', 'craft "default:steel_ingot"'},
+               {'craft "default:steel_ingot"', 'craft "default:stick"', 'craft "default:steel_ingot"'},
+               {'craft "default:steel_ingot"', '', 'craft "default:steel_ingot"'},
        }
 })
 
 minetest.register_craft({
-       output = 'node "chest" 1',
+       output = 'node "default:chest" 1',
        recipe = {
-               {'node "wood"', 'node "wood"', 'node "wood"'},
-               {'node "wood"', '', 'node "wood"'},
-               {'node "wood"', 'node "wood"', 'node "wood"'},
+               {'node "default:wood"', 'node "default:wood"', 'node "default:wood"'},
+               {'node "default:wood"', '', 'node "default:wood"'},
+               {'node "default:wood"', 'node "default:wood"', 'node "default:wood"'},
        }
 })
 
 minetest.register_craft({
-       output = 'node "locked_chest" 1',
+       output = 'node "default:chest_locked" 1',
        recipe = {
-               {'node "wood"', 'node "wood"', 'node "wood"'},
-               {'node "wood"', 'craft "steel_ingot"', 'node "wood"'},
-               {'node "wood"', 'node "wood"', 'node "wood"'},
+               {'node "default:wood"', 'node "default:wood"', 'node "default:wood"'},
+               {'node "default:wood"', 'craft "default:steel_ingot"', 'node "default:wood"'},
+               {'node "default:wood"', 'node "default:wood"', 'node "default:wood"'},
        }
 })
 
 minetest.register_craft({
-       output = 'node "furnace" 1',
+       output = 'node "default:furnace" 1',
        recipe = {
                {'node "cobble"', 'node "cobble"', 'node "cobble"'},
                {'node "cobble"', '', 'node "cobble"'},
@@ -689,16 +712,16 @@ minetest.register_craft({
 })
 
 minetest.register_craft({
-       output = 'node "steelblock" 1',
+       output = 'node "default:steelblock" 1',
        recipe = {
-               {'craft "steel_ingot"', 'craft "steel_ingot"', 'craft "steel_ingot"'},
-               {'craft "steel_ingot"', 'craft "steel_ingot"', 'craft "steel_ingot"'},
-               {'craft "steel_ingot"', 'craft "steel_ingot"', 'craft "steel_ingot"'},
+               {'craft "default:steel_ingot"', 'craft "default:steel_ingot"', 'craft "default:steel_ingot"'},
+               {'craft "default:steel_ingot"', 'craft "default:steel_ingot"', 'craft "default:steel_ingot"'},
+               {'craft "default:steel_ingot"', 'craft "default:steel_ingot"', 'craft "default:steel_ingot"'},
        }
 })
 
 minetest.register_craft({
-       output = 'node "sandstone" 1',
+       output = 'node "default:sandstone" 1',
        recipe = {
                {'node "sand"', 'node "sand"'},
                {'node "sand"', 'node "sand"'},
@@ -706,61 +729,61 @@ minetest.register_craft({
 })
 
 minetest.register_craft({
-       output = 'node "clay" 1',
+       output = 'node "default:clay" 1',
        recipe = {
-               {'craft "lump_of_clay"', 'craft "lump_of_clay"'},
-               {'craft "lump_of_clay"', 'craft "lump_of_clay"'},
+               {'craft "default:lump_of_clay"', 'craft "default:lump_of_clay"'},
+               {'craft "default:lump_of_clay"', 'craft "default:lump_of_clay"'},
        }
 })
 
 minetest.register_craft({
-       output = 'node "brick" 1',
+       output = 'node "default:brick" 1',
        recipe = {
-               {'craft "clay_brick"', 'craft "clay_brick"'},
-               {'craft "clay_brick"', 'craft "clay_brick"'},
+               {'craft "default:clay_brick"', 'craft "default:clay_brick"'},
+               {'craft "default:clay_brick"', 'craft "default:clay_brick"'},
        }
 })
 
 minetest.register_craft({
-       output = 'craft "paper" 1',
+       output = 'craft "default:paper" 1',
        recipe = {
                {'node "papyrus"', 'node "papyrus"', 'node "papyrus"'},
        }
 })
 
 minetest.register_craft({
-       output = 'craft "book" 1',
+       output = 'craft "default:book" 1',
        recipe = {
-               {'craft "paper"'},
-               {'craft "paper"'},
-               {'craft "paper"'},
+               {'craft "default:paper"'},
+               {'craft "default:paper"'},
+               {'craft "default:paper"'},
        }
 })
 
 minetest.register_craft({
-       output = 'node "bookshelf" 1',
+       output = 'node "default:bookshelf" 1',
        recipe = {
-               {'node "wood"', 'node "wood"', 'node "wood"'},
-               {'craft "book"', 'craft "book"', 'craft "book"'},
-               {'node "wood"', 'node "wood"', 'node "wood"'},
+               {'node "default:wood"', 'node "default:wood"', 'node "default:wood"'},
+               {'craft "default:book"', 'craft "default:book"', 'craft "default:book"'},
+               {'node "default:wood"', 'node "default:wood"', 'node "default:wood"'},
        }
 })
 
 minetest.register_craft({
-       output = 'node "ladder" 1',
+       output = 'node "default:ladder" 1',
        recipe = {
-               {'craft "Stick"', '', 'craft "Stick"'},
-               {'craft "Stick"', 'craft "Stick"', 'craft "Stick"'},
-               {'craft "Stick"', '', 'craft "Stick"'},
+               {'craft "default:stick"', '', 'craft "default:stick"'},
+               {'craft "default:stick"', 'craft "default:stick"', 'craft "default:stick"'},
+               {'craft "default:stick"', '', 'craft "default:stick"'},
        }
 })
 
 minetest.register_craft({
-       output = 'craft "apple_iron" 1',
+       output = 'craft "default:apple_iron" 1',
        recipe = {
-               {'', 'craft "steel_ingot"', ''},
-               {'craft "steel_ingot"', 'craft "apple"', 'craft "steel_ingot"'},
-               {'', 'craft "steel_ingot"', ''},
+               {'', 'craft "default:steel_ingot"', ''},
+               {'craft "default:steel_ingot"', 'craft "apple"', 'craft "default:steel_ingot"'},
+               {'', 'craft "default:steel_ingot"', ''},
        }
 })
 
@@ -768,166 +791,97 @@ minetest.register_craft({
 -- Node definitions
 --
 
-function digprop_constanttime(time)
-       return {
-               diggability = "constant",
-               constant_time = time,
-       }
-end
-
-function digprop_stonelike(toughness)
-       return {
-               diggablity = "normal",
-               weight = toughness * 5,
-               crackiness = 1,
-               crumbliness = -0.1,
-               cuttability = -0.2,
-       }
-end
-
-function digprop_dirtlike(toughness)
-       return {
-               diggablity = "normal",
-               weight = toughness * 1.2,
-               crackiness = 0,
-               crumbliness = 1.2,
-               cuttability = -0.4,
-       }
-end
-
-function digprop_gravellike(toughness)
-       return {
-               diggablity = "normal",
-               weight = toughness * 2,
-               crackiness = 0.2,
-               crumbliness = 1.5,
-               cuttability = -1.0,
-       }
-end
-
-function digprop_woodlike(toughness)
-       return {
-               diggablity = "normal",
-               weight = toughness * 1.0,
-               crackiness = 0.75,
-               crumbliness = -1.0,
-               cuttability = 1.5,
-       }
-end
-
-function digprop_leaveslike(toughness)
-       return {
-               diggablity = "normal",
-               weight = toughness * (-0.5),
-               crackiness = 0,
-               crumbliness = 0,
-               cuttability = 2.0,
-       }
-end
-
-function digprop_glasslike(toughness)
-       return {
-               diggablity = "normal",
-               weight = toughness * 0.1,
-               crackiness = 2.0,
-               crumbliness = -1.0,
-               cuttability = -1.0,
-       }
-end
-
--- Legacy nodes
-
-minetest.register_node(":stone", {
+minetest.register_node("default:stone", {
        tile_images = {"stone.png"},
        inventory_image = minetest.inventorycube("stone.png"),
        paramtype = "mineral",
        is_ground_content = true,
        often_contains_mineral = true, -- Texture atlas hint
-       material = digprop_stonelike(1.0),
+       material = minetest.digprop_stonelike(1.0),
        dug_item = 'node "cobble" 1',
 })
 
-minetest.register_node(":dirt_with_grass", {
+minetest.register_node("default:dirt_with_grass", {
        tile_images = {"grass.png", "mud.png", "mud.png^grass_side.png"},
        inventory_image = minetest.inventorycube("mud.png^grass_side.png"),
        is_ground_content = true,
-       material = digprop_dirtlike(1.0),
+       material = minetest.digprop_dirtlike(1.0),
        dug_item = 'node "dirt" 1',
 })
 
-minetest.register_node(":dirt_with_grass_footsteps", {
+minetest.register_node("default:dirt_with_grass_footsteps", {
        tile_images = {"grass_footsteps.png", "mud.png", "mud.png^grass_side.png"},
        inventory_image = "grass_footsteps.png",
        is_ground_content = true,
-       material = digprop_dirtlike(1.0),
+       material = minetest.digprop_dirtlike(1.0),
        dug_item = 'node "dirt" 1',
 })
 
-minetest.register_node(":dirt", {
+minetest.register_node("default:dirt", {
        tile_images = {"mud.png"},
        inventory_image = minetest.inventorycube("mud.png"),
        is_ground_content = true,
-       material = digprop_dirtlike(1.0),
+       material = minetest.digprop_dirtlike(1.0),
 })
 
-minetest.register_node(":sand", {
+minetest.register_node("default:sand", {
        tile_images = {"sand.png"},
        inventory_image = minetest.inventorycube("sand.png"),
        is_ground_content = true,
-       material = digprop_dirtlike(1.0),
-       cookresult_item = 'node "glass" 1',
+       material = minetest.digprop_dirtlike(1.0),
+       cookresult_itemstring = 'node "glass" 1',
 })
 
-minetest.register_node(":gravel", {
+minetest.register_node("default:gravel", {
        tile_images = {"gravel.png"},
        inventory_image = minetest.inventorycube("gravel.png"),
        is_ground_content = true,
-       material = digprop_gravellike(1.0),
+       material = minetest.digprop_gravellike(1.0),
 })
 
-minetest.register_node(":sandstone", {
+minetest.register_node("default:sandstone", {
        tile_images = {"sandstone.png"},
        inventory_image = minetest.inventorycube("sandstone.png"),
        is_ground_content = true,
-       material = digprop_dirtlike(1.0),  -- FIXME should this be stonelike?
+       material = minetest.digprop_dirtlike(1.0),  -- FIXME should this be stonelike?
        dug_item = 'node "sand" 1',  -- FIXME is this intentional?
 })
 
-minetest.register_node(":clay", {
+minetest.register_node("default:clay", {
        tile_images = {"clay.png"},
        inventory_image = minetest.inventorycube("clay.png"),
        is_ground_content = true,
-       material = digprop_dirtlike(1.0),
-       dug_item = 'craft "lump_of_clay" 4',
+       material = minetest.digprop_dirtlike(1.0),
+       dug_item = 'craft "default:lump_of_clay" 4',
 })
 
-minetest.register_node(":brick", {
+minetest.register_node("default:brick", {
        tile_images = {"brick.png"},
        inventory_image = minetest.inventorycube("brick.png"),
        is_ground_content = true,
-       material = digprop_stonelike(1.0),
-       dug_item = 'craft "clay_brick" 4',
+       material = minetest.digprop_stonelike(1.0),
+       dug_item = 'craft "default:clay_brick" 4',
 })
 
-minetest.register_node(":tree", {
+minetest.register_node("default:tree", {
        tile_images = {"tree_top.png", "tree_top.png", "tree.png"},
        inventory_image = minetest.inventorycube("tree_top.png", "tree.png", "tree.png"),
        is_ground_content = true,
-       material = digprop_woodlike(1.0),
-       cookresult_item = 'craft "lump_of_coal" 1',
+       material = minetest.digprop_woodlike(1.0),
+       cookresult_itemstring = 'craft "default:lump_of_coal" 1',
        furnace_burntime = 30,
 })
 
-minetest.register_node(":jungletree", {
+minetest.register_node("default:jungletree", {
        tile_images = {"jungletree_top.png", "jungletree_top.png", "jungletree.png"},
        inventory_image = minetest.inventorycube("jungletree_top.png", "jungletree.png", "jungletree.png"),
        is_ground_content = true,
-       material = digprop_woodlike(1.0),
-       cookresult_item = 'craft "lump_of_coal" 1',
+       material = minetest.digprop_woodlike(1.0),
+       cookresult_itemstring = 'craft "default:lump_of_coal" 1',
        furnace_burntime = 30,
 })
 
-minetest.register_node(":junglegrass", {
+minetest.register_node("default:junglegrass", {
        drawtype = "plantlike",
        visual_scale = 1.3,
        tile_images = {"junglegrass.png"},
@@ -935,32 +889,32 @@ minetest.register_node(":junglegrass", {
        light_propagates = true,
        paramtype = "light",
        walkable = false,
-       material = digprop_leaveslike(1.0),
+       material = minetest.digprop_leaveslike(1.0),
        furnace_burntime = 2,
 })
 
-minetest.register_node(":leaves", {
+minetest.register_node("default:leaves", {
        drawtype = "allfaces_optional",
        visual_scale = 1.3,
        tile_images = {"leaves.png"},
        inventory_image = minetest.inventorycube("leaves.png"),
        light_propagates = true,
        paramtype = "light",
-       material = digprop_leaveslike(1.0),
+       material = minetest.digprop_leaveslike(1.0),
        extra_dug_item = 'node "sapling" 1',
        extra_dug_item_rarity = 20,
        furnace_burntime = 1,
 })
 
-minetest.register_node(":cactus", {
+minetest.register_node("default:cactus", {
        tile_images = {"cactus_top.png", "cactus_top.png", "cactus_side.png"},
        inventory_image = minetest.inventorycube("cactus_top.png", "cactus_side.png", "cactus_side.png"),
        is_ground_content = true,
-       material = digprop_woodlike(0.75),
+       material = minetest.digprop_woodlike(0.75),
        furnace_burntime = 15,
 })
 
-minetest.register_node(":papyrus", {
+minetest.register_node("default:papyrus", {
        drawtype = "plantlike",
        tile_images = {"papyrus.png"},
        inventory_image = "papyrus.png",
@@ -968,19 +922,19 @@ minetest.register_node(":papyrus", {
        paramtype = "light",
        is_ground_content = true,
        walkable = false,
-       material = digprop_leaveslike(0.5),
+       material = minetest.digprop_leaveslike(0.5),
        furnace_burntime = 1,
 })
 
-minetest.register_node(":bookshelf", {
+minetest.register_node("default:bookshelf", {
        tile_images = {"wood.png", "wood.png", "bookshelf.png"},
        inventory_image = minetest.inventorycube("wood.png", "bookshelf.png", "bookshelf.png"),
        is_ground_content = true,
-       material = digprop_woodlike(0.75),
+       material = minetest.digprop_woodlike(0.75),
        furnace_burntime = 30,
 })
 
-minetest.register_node(":glass", {
+minetest.register_node("default:glass", {
        drawtype = "glasslike",
        tile_images = {"glass.png"},
        inventory_image = minetest.inventorycube("glass.png"),
@@ -988,10 +942,10 @@ minetest.register_node(":glass", {
        paramtype = "light",
        sunlight_propagates = true,
        is_ground_content = true,
-       material = digprop_glasslike(1.0),
+       material = minetest.digprop_glasslike(1.0),
 })
 
-minetest.register_node(":wooden_fence", {
+minetest.register_node("default:fence_wooden", {
        drawtype = "fencelike",
        tile_images = {"wood.png"},
        inventory_image = "fence.png",
@@ -1003,10 +957,10 @@ minetest.register_node(":wooden_fence", {
                fixed = {-1/7, -1/2, -1/7, 1/7, 1/2, 1/7},
        },
        furnace_burntime = 15,
-       material = digprop_woodlike(0.75),
+       material = minetest.digprop_woodlike(0.75),
 })
 
-minetest.register_node(":rail", {
+minetest.register_node("default:rail", {
        drawtype = "raillike",
        tile_images = {"rail.png", "rail_curved.png", "rail_t_junction.png", "rail_crossing.png"},
        inventory_image = "rail.png",
@@ -1018,10 +972,10 @@ minetest.register_node(":rail", {
                type = "fixed",
                --fixed = <default>
        },
-       material = digprop_dirtlike(0.75),
+       material = minetest.digprop_dirtlike(0.75),
 })
 
-minetest.register_node(":ladder", {
+minetest.register_node("default:ladder", {
        drawtype = "signlike",
        tile_images = {"ladder.png"},
        inventory_image = "ladder.png",
@@ -1038,39 +992,39 @@ minetest.register_node(":ladder", {
                --wall_side = = <default>
        },
        furnace_burntime = 5,
-       material = digprop_woodlike(0.5),
+       material = minetest.digprop_woodlike(0.5),
 })
 
-minetest.register_node(":coalstone", {
+minetest.register_node("default:coalstone", {
        tile_images = {"stone.png^mineral_coal.png"},
        inventory_image = "stone.png^mineral_coal.png",
        is_ground_content = true,
-       material = digprop_stonelike(1.5),
+       material = minetest.digprop_stonelike(1.5),
 })
 
-minetest.register_node(":wood", {
+minetest.register_node("default:wood", {
        tile_images = {"wood.png"},
        inventory_image = minetest.inventorycube("wood.png"),
        is_ground_content = true,
        furnace_burntime = 7,
-       material = digprop_woodlike(0.75),
+       material = minetest.digprop_woodlike(0.75),
 })
 
-minetest.register_node(":mese", {
+minetest.register_node("default:mese", {
        tile_images = {"mese.png"},
        inventory_image = minetest.inventorycube("mese.png"),
        is_ground_content = true,
        furnace_burntime = 30,
-       material = digprop_stonelike(0.5),
+       material = minetest.digprop_stonelike(0.5),
 })
 
-minetest.register_node(":cloud", {
+minetest.register_node("default:cloud", {
        tile_images = {"cloud.png"},
        inventory_image = minetest.inventorycube("cloud.png"),
        is_ground_content = true,
 })
 
-minetest.register_node(":water_flowing", {
+minetest.register_node("default:water_flowing", {
        drawtype = "flowingliquid",
        tile_images = {"water.png"},
        alpha = WATER_ALPHA,
@@ -1092,7 +1046,7 @@ minetest.register_node(":water_flowing", {
        },
 })
 
-minetest.register_node(":water_source", {
+minetest.register_node("default:water_source", {
        drawtype = "liquid",
        tile_images = {"water.png"},
        alpha = WATER_ALPHA,
@@ -1114,7 +1068,7 @@ minetest.register_node(":water_source", {
        },
 })
 
-minetest.register_node(":lava_flowing", {
+minetest.register_node("default:lava_flowing", {
        drawtype = "flowingliquid",
        tile_images = {"lava.png"},
        inventory_image = minetest.inventorycube("lava.png"),
@@ -1137,7 +1091,7 @@ minetest.register_node(":lava_flowing", {
        },
 })
 
-minetest.register_node(":lava_source", {
+minetest.register_node("default:lava_source", {
        drawtype = "liquid",
        tile_images = {"lava.png"},
        inventory_image = minetest.inventorycube("lava.png"),
@@ -1161,7 +1115,7 @@ minetest.register_node(":lava_source", {
        furnace_burntime = 60,
 })
 
-minetest.register_node(":torch", {
+minetest.register_node("default:torch", {
        drawtype = "torchlike",
        tile_images = {"torch_on_floor.png", "torch_on_ceiling.png", "torch.png"},
        inventory_image = "torch_on_floor.png",
@@ -1177,11 +1131,11 @@ minetest.register_node(":torch", {
                wall_bottom = {-0.1, -0.5, -0.1, 0.1, -0.5+0.6, 0.1},
                wall_side = {-0.5, -0.3, -0.1, -0.5+0.3, 0.3, 0.1},
        },
-       material = digprop_constanttime(0.0),
+       material = minetest.digprop_constanttime(0.0),
        furnace_burntime = 4,
 })
 
-minetest.register_node(":sign_wall", {
+minetest.register_node("default:sign_wall", {
        drawtype = "signlike",
        tile_images = {"sign_wall.png"},
        inventory_image = "sign_wall.png",
@@ -1197,78 +1151,78 @@ minetest.register_node(":sign_wall", {
                --wall_bottom = <default>
                --wall_side = <default>
        },
-       material = digprop_constanttime(0.5),
+       material = minetest.digprop_constanttime(0.5),
        furnace_burntime = 10,
 })
 
-minetest.register_node(":chest", {
+minetest.register_node("default:chest", {
        tile_images = {"chest_top.png", "chest_top.png", "chest_side.png",
                "chest_side.png", "chest_side.png", "chest_front.png"},
        inventory_image = minetest.inventorycube("chest_top.png", "chest_front.png", "chest_side.png"),
        paramtype = "facedir_simple",
-       metadata_name = "chest",
-       material = digprop_woodlike(1.0),
+       metadata_name = "default:chest",
+       material = minetest.digprop_woodlike(1.0),
        furnace_burntime = 30,
 })
 
-minetest.register_node(":locked_chest", {
+minetest.register_node("default:chest_locked", {
        tile_images = {"chest_top.png", "chest_top.png", "chest_side.png",
                "chest_side.png", "chest_side.png", "chest_lock.png"},
        inventory_image = minetest.inventorycube("chest_top.png", "chest_lock.png", "chest_side.png"),
        paramtype = "facedir_simple",
-       metadata_name = "locked_chest",
-       material = digprop_woodlike(1.0),
+       metadata_name = "default:chest_locked",
+       material = minetest.digprop_woodlike(1.0),
        furnace_burntime = 30,
 })
 
-minetest.register_node(":furnace", {
+minetest.register_node("default:furnace", {
        tile_images = {"furnace_side.png", "furnace_side.png", "furnace_side.png",
                "furnace_side.png", "furnace_side.png", "furnace_front.png"},
        inventory_image = minetest.inventorycube("furnace_side.png", "furnace_front.png", "furnace_side.png"),
        paramtype = "facedir_simple",
-       metadata_name = "furnace",
-       material = digprop_stonelike(3.0),
+       metadata_name = "default:furnace",
+       material = minetest.digprop_stonelike(3.0),
 })
 
-minetest.register_node(":cobble", {
+minetest.register_node("default:cobble", {
        tile_images = {"cobble.png"},
        inventory_image = minetest.inventorycube("cobble.png"),
        is_ground_content = true,
-       cookresult_item = 'node "stone" 1',
-       material = digprop_stonelike(0.9),
+       cookresult_itemstring = 'node "stone" 1',
+       material = minetest.digprop_stonelike(0.9),
 })
 
-minetest.register_node(":mossycobble", {
+minetest.register_node("default:mossycobble", {
        tile_images = {"mossycobble.png"},
        inventory_image = minetest.inventorycube("mossycobble.png"),
        is_ground_content = true,
-       material = digprop_stonelike(0.8),
+       material = minetest.digprop_stonelike(0.8),
 })
 
-minetest.register_node(":steelblock", {
+minetest.register_node("default:steelblock", {
        tile_images = {"steel_block.png"},
        inventory_image = minetest.inventorycube("steel_block.png"),
        is_ground_content = true,
-       material = digprop_stonelike(5.0),
+       material = minetest.digprop_stonelike(5.0),
 })
 
-minetest.register_node(":nyancat", {
+minetest.register_node("default:nyancat", {
        tile_images = {"nc_side.png", "nc_side.png", "nc_side.png",
                "nc_side.png", "nc_back.png", "nc_front.png"},
        inventory_image = "nc_front.png",
        paramtype = "facedir_simple",
-       material = digprop_stonelike(3.0),
+       material = minetest.digprop_stonelike(3.0),
        furnace_burntime = 1,
 })
 
-minetest.register_node(":nyancat_rainbow", {
+minetest.register_node("default:nyancat_rainbow", {
        tile_images = {"nc_rb.png"},
        inventory_image = "nc_rb.png",
-       material = digprop_stonelike(3.0),
+       material = minetest.digprop_stonelike(3.0),
        furnace_burntime = 1,
 })
 
-minetest.register_node(":sapling", {
+minetest.register_node("default:sapling", {
        drawtype = "plantlike",
        visual_scale = 1.0,
        tile_images = {"sapling.png"},
@@ -1276,11 +1230,11 @@ minetest.register_node(":sapling", {
        paramtype = "light",
        light_propagates = true,
        walkable = false,
-       material = digprop_constanttime(0.0),
+       material = minetest.digprop_constanttime(0.0),
        furnace_burntime = 10,
 })
 
-minetest.register_node(":apple", {
+minetest.register_node("default:apple", {
        drawtype = "plantlike",
        visual_scale = 1.0,
        tile_images = {"apple.png"},
@@ -1290,7 +1244,7 @@ minetest.register_node(":apple", {
        sunlight_propagates = true,
        walkable = false,
        dug_item = 'craft "apple" 1',
-       material = digprop_constanttime(0.0),
+       material = minetest.digprop_constanttime(0.0),
        furnace_burntime = 3,
 })
 
@@ -1298,72 +1252,72 @@ minetest.register_node(":apple", {
 -- Crafting items
 --
 
-minetest.register_craftitem(":Stick", {
+minetest.register_craftitem("default:stick", {
        image = "stick.png",
        --furnace_burntime = ...,
        on_place_on_ground = minetest.craftitem_place_item,
 })
 
-minetest.register_craftitem(":paper", {
+minetest.register_craftitem("default:paper", {
        image = "paper.png",
        on_place_on_ground = minetest.craftitem_place_item,
 })
 
-minetest.register_craftitem(":book", {
+minetest.register_craftitem("default:book", {
        image = "book.png",
        on_place_on_ground = minetest.craftitem_place_item,
 })
 
-minetest.register_craftitem(":lump_of_coal", {
+minetest.register_craftitem("default:lump_of_coal", {
        image = "lump_of_coal.png",
        furnace_burntime = 40;
        on_place_on_ground = minetest.craftitem_place_item,
 })
 
-minetest.register_craftitem(":lump_of_iron", {
+minetest.register_craftitem("default:lump_of_iron", {
        image = "lump_of_iron.png",
-       cookresult_item = 'craft "steel_ingot" 1',
+       cookresult_itemstring = 'craft "default:steel_ingot" 1',
        on_place_on_ground = minetest.craftitem_place_item,
 })
 
-minetest.register_craftitem(":lump_of_clay", {
+minetest.register_craftitem("default:lump_of_clay", {
        image = "lump_of_clay.png",
-       cookresult_item = 'craft "clay_brick" 1',
+       cookresult_itemstring = 'craft "default:clay_brick" 1',
        on_place_on_ground = minetest.craftitem_place_item,
 })
 
-minetest.register_craftitem(":steel_ingot", {
+minetest.register_craftitem("default:steel_ingot", {
        image = "steel_ingot.png",
        on_place_on_ground = minetest.craftitem_place_item,
 })
 
-minetest.register_craftitem(":clay_brick", {
+minetest.register_craftitem("default:clay_brick", {
        image = "clay_brick.png",
        on_place_on_ground = minetest.craftitem_place_item,
 })
 
-minetest.register_craftitem(":rat", {
+minetest.register_craftitem("default:rat", {
        image = "rat.png",
-       cookresult_item = 'craft "cooked_rat" 1',
+       cookresult_itemstring = 'craft "cooked_rat" 1',
        on_drop = function(item, dropper, pos)
                minetest.env:add_rat(pos)
                return true
        end,
 })
 
-minetest.register_craftitem(":cooked_rat", {
+minetest.register_craftitem("default:cooked_rat", {
        image = "cooked_rat.png",
-       cookresult_item = 'craft "scorched_stuff" 1',
+       cookresult_itemstring = 'craft "scorched_stuff" 1',
        on_place_on_ground = minetest.craftitem_place_item,
        on_use = minetest.craftitem_eat(6),
 })
 
-minetest.register_craftitem(":scorched_stuff", {
+minetest.register_craftitem("default:scorched_stuff", {
        image = "scorched_stuff.png",
        on_place_on_ground = minetest.craftitem_place_item,
 })
 
-minetest.register_craftitem(":firefly", {
+minetest.register_craftitem("default:firefly", {
        image = "firefly.png",
        on_drop = function(item, dropper, pos)
                minetest.env:add_firefly(pos)
@@ -1371,60 +1325,60 @@ minetest.register_craftitem(":firefly", {
        end,
 })
 
-minetest.register_craftitem(":apple", {
+minetest.register_craftitem("default:apple", {
        image = "apple.png",
        on_place_on_ground = minetest.craftitem_place_item,
        on_use = minetest.craftitem_eat(4),
 })
 
-minetest.register_craftitem(":apple_iron", {
+minetest.register_craftitem("default:apple_iron", {
        image = "apple_iron.png",
        on_place_on_ground = minetest.craftitem_place_item,
        on_use = minetest.craftitem_eat(8),
 })
 
-print(dump(minetest.registered_craftitems))
-
 --
 -- Creative inventory
 --
 
-minetest.add_to_creative_inventory('tool MesePick 0')
-minetest.add_to_creative_inventory('tool SteelPick 0')
-minetest.add_to_creative_inventory('tool SteelAxe 0')
-minetest.add_to_creative_inventory('tool SteelShovel 0')
-
-minetest.add_to_creative_inventory('node torch 0')
-minetest.add_to_creative_inventory('node cobble 0')
-minetest.add_to_creative_inventory('node dirt 0')
-minetest.add_to_creative_inventory('node stone 0')
-minetest.add_to_creative_inventory('node sand 0')
-minetest.add_to_creative_inventory('node sandstone 0')
-minetest.add_to_creative_inventory('node clay 0')
-minetest.add_to_creative_inventory('node brick 0')
-minetest.add_to_creative_inventory('node tree 0')
-minetest.add_to_creative_inventory('node leaves 0')
-minetest.add_to_creative_inventory('node cactus 0')
-minetest.add_to_creative_inventory('node papyrus 0')
-minetest.add_to_creative_inventory('node bookshelf 0')
-minetest.add_to_creative_inventory('node glass 0')
-minetest.add_to_creative_inventory('node fence 0')
-minetest.add_to_creative_inventory('node rail 0')
-minetest.add_to_creative_inventory('node mese 0')
-minetest.add_to_creative_inventory('node chest 0')
-minetest.add_to_creative_inventory('node furnace 0')
-minetest.add_to_creative_inventory('node sign_wall 0')
-minetest.add_to_creative_inventory('node water_source 0')
-minetest.add_to_creative_inventory('node lava_source 0')
-minetest.add_to_creative_inventory('node ladder 0')
+minetest.add_to_creative_inventory('tool "default:pick_mese" 0')
+minetest.add_to_creative_inventory('tool "default:pick_steel" 0')
+minetest.add_to_creative_inventory('tool "default:axe_steel" 0')
+minetest.add_to_creative_inventory('tool "default:shovel_steel" 0')
+
+minetest.add_to_creative_inventory('node "default:torch" 0')
+minetest.add_to_creative_inventory('node "default:cobble" 0')
+minetest.add_to_creative_inventory('node "default:dirt" 0')
+minetest.add_to_creative_inventory('node "default:stone" 0')
+minetest.add_to_creative_inventory('node "default:sand" 0')
+minetest.add_to_creative_inventory('node "default:sandstone" 0')
+minetest.add_to_creative_inventory('node "default:clay" 0')
+minetest.add_to_creative_inventory('node "default:brick" 0')
+minetest.add_to_creative_inventory('node "default:tree" 0')
+minetest.add_to_creative_inventory('node "default:leaves" 0')
+minetest.add_to_creative_inventory('node "default:cactus" 0')
+minetest.add_to_creative_inventory('node "default:papyrus" 0')
+minetest.add_to_creative_inventory('node "default:bookshelf" 0')
+minetest.add_to_creative_inventory('node "default:glass" 0')
+minetest.add_to_creative_inventory('node "default:fence" 0')
+minetest.add_to_creative_inventory('node "default:rail" 0')
+minetest.add_to_creative_inventory('node "default:mese" 0')
+minetest.add_to_creative_inventory('node "default:chest" 0')
+minetest.add_to_creative_inventory('node "default:furnace" 0')
+minetest.add_to_creative_inventory('node "default:sign_wall" 0')
+minetest.add_to_creative_inventory('node "default:water_source" 0')
+minetest.add_to_creative_inventory('node "default:lava_source" 0')
+minetest.add_to_creative_inventory('node "default:ladder" 0')
 
 --
 -- Some common functions
 --
 
+default.falling_node_names = {}
+
 function nodeupdate_single(p)
        n = minetest.env:get_node(p)
-       if n.name == "sand" or n.name == "gravel" then
+       if default.falling_node_names[n.name] ~= nil then
                p_bottom = {x=p.x, y=p.y-1, z=p.z}
                n_bottom = minetest.env:get_node(p_bottom)
                if n_bottom.name == "air" then
@@ -1450,8 +1404,10 @@ end
 -- Falling stuff
 --
 
-function register_falling_node(nodename, texture)
-       minetest.register_entity("default:falling_"..nodename, {
+function default.register_falling_node(nodename, texture)
+       default.falling_node_names[nodename] = true
+       -- Override naming conventions for stuff like :default:falling_default:sand
+       minetest.register_entity(":default:falling_"..nodename, {
                -- Static definition
                physical = true,
                collisionbox = {-0.5,-0.5,-0.5, 0.5,0.5,0.5},
@@ -1478,8 +1434,8 @@ function register_falling_node(nodename, texture)
        })
 end
 
-register_falling_node("sand", "sand.png")
-register_falling_node("gravel", "gravel.png")
+default.register_falling_node("default:sand", "sand.png")
+default.register_falling_node("default:gravel", "gravel.png")
 
 --
 -- Global callbacks
index b63bf76fc128742127058a71366de2279b6d8b1c..267b06919fd170c9abec2728962dc6923d937290 100644 (file)
@@ -11,7 +11,7 @@ minetest.register_node("experimental:luafurnace", {
        inventory_image = minetest.inventorycube("furnace_front.png"),
        paramtype = "facedir_simple",
        metadata_name = "generic",
-       material = digprop_stonelike(3.0),
+       material = minetest.digprop_stonelike(3.0),
 })
 
 minetest.register_on_placenode(function(pos, newnode, placer)
diff --git a/data/mods/legacy/depends.txt b/data/mods/legacy/depends.txt
new file mode 100644 (file)
index 0000000..3a7daa1
--- /dev/null
@@ -0,0 +1,2 @@
+default
+
diff --git a/data/mods/legacy/init.lua b/data/mods/legacy/init.lua
new file mode 100644 (file)
index 0000000..ec691c5
--- /dev/null
@@ -0,0 +1,1029 @@
+-- legacy (Minetest 0.4 mod)
+-- Provides as much backwards-compatibility as feasible
+
+WATER_ALPHA = 160
+WATER_VISC = 1
+LAVA_VISC = 7
+LIGHT_MAX = 14
+
+--
+-- Tool definition
+-- Compatibility to 0.3 and old 0.4
+--
+
+minetest.register_tool(":WPick", {
+       image = "tool_woodpick.png",
+       basetime = 2.0,
+       dt_weight = 0,
+       dt_crackiness = -0.5,
+       dt_crumbliness = 2,
+       dt_cuttability = 0,
+       basedurability = 30,
+       dd_weight = 0,
+       dd_crackiness = 0,
+       dd_crumbliness = 0,
+       dd_cuttability = 0,
+})
+minetest.register_tool(":STPick", {
+       image = "tool_stonepick.png",
+       basetime = 1.5,
+       dt_weight = 0,
+       dt_crackiness = -0.5,
+       dt_crumbliness = 2,
+       dt_cuttability = 0,
+       basedurability = 100,
+       dd_weight = 0,
+       dd_crackiness = 0,
+       dd_crumbliness = 0,
+       dd_cuttability = 0,
+})
+minetest.register_tool(":SteelPick", {
+       image = "tool_steelpick.png",
+       basetime = 1.0,
+       dt_weight = 0,
+       dt_crackiness = -0.5,
+       dt_crumbliness = 2,
+       dt_cuttability = 0,
+       basedurability = 333,
+       dd_weight = 0,
+       dd_crackiness = 0,
+       dd_crumbliness = 0,
+       dd_cuttability = 0,
+})
+minetest.register_tool(":MesePick", {
+       image = "tool_mesepick.png",
+       basetime = 0,
+       dt_weight = 0,
+       dt_crackiness = 0,
+       dt_crumbliness = 0,
+       dt_cuttability = 0,
+       basedurability = 1337,
+       dd_weight = 0,
+       dd_crackiness = 0,
+       dd_crumbliness = 0,
+       dd_cuttability = 0,
+})
+minetest.register_tool(":WShovel", {
+       image = "tool_woodshovel.png",
+       basetime = 2.0,
+       dt_weight = 0.5,
+       dt_crackiness = 2,
+       dt_crumbliness = -1.5,
+       dt_cuttability = 0.3,
+       basedurability = 30,
+       dd_weight = 0,
+       dd_crackiness = 0,
+       dd_crumbliness = 0,
+       dd_cuttability = 0,
+})
+minetest.register_tool(":STShovel", {
+       image = "tool_stoneshovel.png",
+       basetime = 1.5,
+       dt_weight = 0.5,
+       dt_crackiness = 2,
+       dt_crumbliness = -1.5,
+       dt_cuttability = 0.1,
+       basedurability = 100,
+       dd_weight = 0,
+       dd_crackiness = 0,
+       dd_crumbliness = 0,
+       dd_cuttability = 0,
+})
+minetest.register_tool(":SteelShovel", {
+       image = "tool_steelshovel.png",
+       basetime = 1.0,
+       dt_weight = 0.5,
+       dt_crackiness = 2,
+       dt_crumbliness = -1.5,
+       dt_cuttability = 0.0,
+       basedurability = 330,
+       dd_weight = 0,
+       dd_crackiness = 0,
+       dd_crumbliness = 0,
+       dd_cuttability = 0,
+})
+minetest.register_tool(":WAxe", {
+       image = "tool_woodaxe.png",
+       basetime = 2.0,
+       dt_weight = 0.5,
+       dt_crackiness = -0.2,
+       dt_crumbliness = 1,
+       dt_cuttability = -0.5,
+       basedurability = 30,
+       dd_weight = 0,
+       dd_crackiness = 0,
+       dd_crumbliness = 0,
+       dd_cuttability = 0,
+})
+minetest.register_tool(":STAxe", {
+       image = "tool_stoneaxe.png",
+       basetime = 1.5,
+       dt_weight = 0.5,
+       dt_crackiness = -0.2,
+       dt_crumbliness = 1,
+       dt_cuttability = -0.5,
+       basedurability = 100,
+       dd_weight = 0,
+       dd_crackiness = 0,
+       dd_crumbliness = 0,
+       dd_cuttability = 0,
+})
+minetest.register_tool(":SteelAxe", {
+       image = "tool_steelaxe.png",
+       basetime = 1.0,
+       dt_weight = 0.5,
+       dt_crackiness = -0.2,
+       dt_crumbliness = 1,
+       dt_cuttability = -0.5,
+       basedurability = 330,
+       dd_weight = 0,
+       dd_crackiness = 0,
+       dd_crumbliness = 0,
+       dd_cuttability = 0,
+})
+minetest.register_tool(":WSword", {
+       image = "tool_woodsword.png",
+       basetime = 3.0,
+       dt_weight = 3,
+       dt_crackiness = 0,
+       dt_crumbliness = 1,
+       dt_cuttability = -1,
+       basedurability = 30,
+       dd_weight = 0,
+       dd_crackiness = 0,
+       dd_crumbliness = 0,
+       dd_cuttability = 0,
+})
+minetest.register_tool(":STSword", {
+       image = "tool_stonesword.png",
+       basetime = 2.5,
+       dt_weight = 3,
+       dt_crackiness = 0,
+       dt_crumbliness = 1,
+       dt_cuttability = -1,
+       basedurability = 100,
+       dd_weight = 0,
+       dd_crackiness = 0,
+       dd_crumbliness = 0,
+       dd_cuttability = 0,
+})
+minetest.register_tool(":SteelSword", {
+       image = "tool_steelsword.png",
+       basetime = 2.0,
+       dt_weight = 3,
+       dt_crackiness = 0,
+       dt_crumbliness = 1,
+       dt_cuttability = -1,
+       basedurability = 330,
+       dd_weight = 0,
+       dd_crackiness = 0,
+       dd_crumbliness = 0,
+       dd_cuttability = 0,
+})
+
+--
+-- Crafting definition (recipe = legacy, output = default)
+-- Makes current compatible with 0.3 and old 0.4
+--
+
+minetest.register_craft({
+       output = 'node "default:wood" 4',
+       recipe = {
+               {'node "tree"'},
+       }
+})
+
+minetest.register_craft({
+       output = 'craft "default:stick" 4',
+       recipe = {
+               {'node "wood"'},
+       }
+})
+
+minetest.register_craft({
+       output = 'node "default:fence_wooden" 2',
+       recipe = {
+               {'craft "Stick"', 'craft "Stick"', 'craft "Stick"'},
+               {'craft "Stick"', 'craft "Stick"', 'craft "Stick"'},
+       }
+})
+
+minetest.register_craft({
+       output = 'node "default:sign_wall" 1',
+       recipe = {
+               {'node "wood"', 'node "wood"', 'node "wood"'},
+               {'node "wood"', 'node "wood"', 'node "wood"'},
+               {'', 'craft "Stick"', ''},
+       }
+})
+
+minetest.register_craft({
+       output = 'node "default:torch" 4',
+       recipe = {
+               {'craft "lump_of_coal"'},
+               {'craft "Stick"'},
+       }
+})
+
+minetest.register_craft({
+       output = 'tool "default:pick_wooden"',
+       recipe = {
+               {'node "wood"', 'node "wood"', 'node "wood"'},
+               {'', 'craft "Stick"', ''},
+               {'', 'craft "Stick"', ''},
+       }
+})
+
+minetest.register_craft({
+       output = 'tool "default:pick_stone"',
+       recipe = {
+               {'node "cobble"', 'node "cobble"', 'node "cobble"'},
+               {'', 'craft "Stick"', ''},
+               {'', 'craft "Stick"', ''},
+       }
+})
+
+minetest.register_craft({
+       output = 'tool "default:pick_steel"',
+       recipe = {
+               {'craft "steel_ingot"', 'craft "steel_ingot"', 'craft "steel_ingot"'},
+               {'', 'craft "Stick"', ''},
+               {'', 'craft "Stick"', ''},
+       }
+})
+
+minetest.register_craft({
+       output = 'tool "default:pick_mese"',
+       recipe = {
+               {'node "mese"', 'node "mese"', 'node "mese"'},
+               {'', 'craft "Stick"', ''},
+               {'', 'craft "Stick"', ''},
+       }
+})
+
+minetest.register_craft({
+       output = 'tool "default:shovel_wood"',
+       recipe = {
+               {'node "wood"'},
+               {'craft "Stick"'},
+               {'craft "Stick"'},
+       }
+})
+
+minetest.register_craft({
+       output = 'tool "default:shovel_stone"',
+       recipe = {
+               {'node "cobble"'},
+               {'craft "Stick"'},
+               {'craft "Stick"'},
+       }
+})
+
+minetest.register_craft({
+       output = 'tool "default:shovel_steel"',
+       recipe = {
+               {'craft "steel_ingot"'},
+               {'craft "Stick"'},
+               {'craft "Stick"'},
+       }
+})
+
+minetest.register_craft({
+       output = 'tool "default:axe_wooden"',
+       recipe = {
+               {'node "wood"', 'node "wood"'},
+               {'node "wood"', 'craft "Stick"'},
+               {'', 'craft "Stick"'},
+       }
+})
+
+minetest.register_craft({
+       output = 'tool "default:axe_stone"',
+       recipe = {
+               {'node "cobble"', 'node "cobble"'},
+               {'node "cobble"', 'craft "Stick"'},
+               {'', 'craft "Stick"'},
+       }
+})
+
+minetest.register_craft({
+       output = 'tool "default:axe_steel"',
+       recipe = {
+               {'craft "steel_ingot"', 'craft "steel_ingot"'},
+               {'craft "steel_ingot"', 'craft "Stick"'},
+               {'', 'craft "Stick"'},
+       }
+})
+
+minetest.register_craft({
+       output = 'tool "default:sword_wood"',
+       recipe = {
+               {'node "wood"'},
+               {'node "wood"'},
+               {'craft "Stick"'},
+       }
+})
+
+minetest.register_craft({
+       output = 'tool "default:sword_stone"',
+       recipe = {
+               {'node "cobble"'},
+               {'node "cobble"'},
+               {'craft "Stick"'},
+       }
+})
+
+minetest.register_craft({
+       output = 'tool "default:sword_steel"',
+       recipe = {
+               {'craft "steel_ingot"'},
+               {'craft "steel_ingot"'},
+               {'craft "Stick"'},
+       }
+})
+
+minetest.register_craft({
+       output = 'node "default:rail" 15',
+       recipe = {
+               {'craft "steel_ingot"', '', 'craft "steel_ingot"'},
+               {'craft "steel_ingot"', 'craft "Stick"', 'craft "steel_ingot"'},
+               {'craft "steel_ingot"', '', 'craft "steel_ingot"'},
+       }
+})
+
+minetest.register_craft({
+       output = 'node "default:chest" 1',
+       recipe = {
+               {'node "wood"', 'node "wood"', 'node "wood"'},
+               {'node "wood"', '', 'node "wood"'},
+               {'node "wood"', 'node "wood"', 'node "wood"'},
+       }
+})
+
+minetest.register_craft({
+       output = 'node "default:chest_locked" 1',
+       recipe = {
+               {'node "wood"', 'node "wood"', 'node "wood"'},
+               {'node "wood"', 'craft "steel_ingot"', 'node "wood"'},
+               {'node "wood"', 'node "wood"', 'node "wood"'},
+       }
+})
+
+minetest.register_craft({
+       output = 'node "default:furnace" 1',
+       recipe = {
+               {'node "cobble"', 'node "cobble"', 'node "cobble"'},
+               {'node "cobble"', '', 'node "cobble"'},
+               {'node "cobble"', 'node "cobble"', 'node "cobble"'},
+       }
+})
+
+minetest.register_craft({
+       output = 'node "default:steelblock" 1',
+       recipe = {
+               {'craft "steel_ingot"', 'craft "steel_ingot"', 'craft "steel_ingot"'},
+               {'craft "steel_ingot"', 'craft "steel_ingot"', 'craft "steel_ingot"'},
+               {'craft "steel_ingot"', 'craft "steel_ingot"', 'craft "steel_ingot"'},
+       }
+})
+
+minetest.register_craft({
+       output = 'node "default:sandstone" 1',
+       recipe = {
+               {'node "sand"', 'node "sand"'},
+               {'node "sand"', 'node "sand"'},
+       }
+})
+
+minetest.register_craft({
+       output = 'node "default:clay" 1',
+       recipe = {
+               {'craft "lump_of_clay"', 'craft "lump_of_clay"'},
+               {'craft "lump_of_clay"', 'craft "lump_of_clay"'},
+       }
+})
+
+minetest.register_craft({
+       output = 'node "default:brick" 1',
+       recipe = {
+               {'craft "clay_brick"', 'craft "clay_brick"'},
+               {'craft "clay_brick"', 'craft "clay_brick"'},
+       }
+})
+
+minetest.register_craft({
+       output = 'craft "default:paper" 1',
+       recipe = {
+               {'node "papyrus"', 'node "papyrus"', 'node "papyrus"'},
+       }
+})
+
+minetest.register_craft({
+       output = 'craft "default:book" 1',
+       recipe = {
+               {'craft "paper"'},
+               {'craft "paper"'},
+               {'craft "paper"'},
+       }
+})
+
+minetest.register_craft({
+       output = 'node "default:bookshelf" 1',
+       recipe = {
+               {'node "wood"', 'node "wood"', 'node "wood"'},
+               {'craft "book"', 'craft "book"', 'craft "book"'},
+               {'node "wood"', 'node "wood"', 'node "wood"'},
+       }
+})
+
+minetest.register_craft({
+       output = 'node "default:ladder" 1',
+       recipe = {
+               {'craft "Stick"', '', 'craft "Stick"'},
+               {'craft "Stick"', 'craft "Stick"', 'craft "Stick"'},
+               {'craft "Stick"', '', 'craft "Stick"'},
+       }
+})
+
+minetest.register_craft({
+       output = 'craft "default:apple_iron" 1',
+       recipe = {
+               {'', 'craft "steel_ingot"', ''},
+               {'craft "steel_ingot"', 'craft "apple"', 'craft "steel_ingot"'},
+               {'', 'craft "steel_ingot"', ''},
+       }
+})
+
+--
+-- Node compatibility with old 0.4
+--
+
+minetest.register_node(":stone", {
+       tile_images = {"stone.png"},
+       inventory_image = minetest.inventorycube("stone.png"),
+       paramtype = "mineral",
+       is_ground_content = true,
+       often_contains_mineral = true, -- Texture atlas hint
+       material = minetest.digprop_stonelike(1.0),
+       dug_item = 'node "cobble" 1',
+})
+
+minetest.register_node(":dirt_with_grass", {
+       tile_images = {"grass.png", "mud.png", "mud.png^grass_side.png"},
+       inventory_image = minetest.inventorycube("mud.png^grass_side.png"),
+       is_ground_content = true,
+       material = minetest.digprop_dirtlike(1.0),
+       dug_item = 'node "dirt" 1',
+})
+
+minetest.register_node(":dirt_with_grass_footsteps", {
+       tile_images = {"grass_footsteps.png", "mud.png", "mud.png^grass_side.png"},
+       inventory_image = "grass_footsteps.png",
+       is_ground_content = true,
+       material = minetest.digprop_dirtlike(1.0),
+       dug_item = 'node "dirt" 1',
+})
+
+minetest.register_node(":dirt", {
+       tile_images = {"mud.png"},
+       inventory_image = minetest.inventorycube("mud.png"),
+       is_ground_content = true,
+       material = minetest.digprop_dirtlike(1.0),
+})
+
+minetest.register_node(":sand", {
+       tile_images = {"sand.png"},
+       inventory_image = minetest.inventorycube("sand.png"),
+       is_ground_content = true,
+       material = minetest.digprop_dirtlike(1.0),
+       cookresult_itemstring = 'node "glass" 1',
+})
+
+minetest.register_node(":gravel", {
+       tile_images = {"gravel.png"},
+       inventory_image = minetest.inventorycube("gravel.png"),
+       is_ground_content = true,
+       material = minetest.digprop_gravellike(1.0),
+})
+
+minetest.register_node(":sandstone", {
+       tile_images = {"sandstone.png"},
+       inventory_image = minetest.inventorycube("sandstone.png"),
+       is_ground_content = true,
+       material = minetest.digprop_dirtlike(1.0),
+       dug_item = 'node "sand" 1',
+})
+
+minetest.register_node(":clay", {
+       tile_images = {"clay.png"},
+       inventory_image = minetest.inventorycube("clay.png"),
+       is_ground_content = true,
+       material = minetest.digprop_dirtlike(1.0),
+       dug_item = 'craft "lump_of_clay" 4',
+})
+
+minetest.register_node(":brick", {
+       tile_images = {"brick.png"},
+       inventory_image = minetest.inventorycube("brick.png"),
+       is_ground_content = true,
+       material = minetest.digprop_stonelike(1.0),
+       dug_item = 'craft "clay_brick" 4',
+})
+
+minetest.register_node(":tree", {
+       tile_images = {"tree_top.png", "tree_top.png", "tree.png"},
+       inventory_image = minetest.inventorycube("tree_top.png", "tree.png", "tree.png"),
+       is_ground_content = true,
+       material = minetest.digprop_woodlike(1.0),
+       cookresult_itemstring = 'craft "lump_of_coal" 1',
+       furnace_burntime = 30,
+})
+
+minetest.register_node(":jungletree", {
+       tile_images = {"jungletree_top.png", "jungletree_top.png", "jungletree.png"},
+       inventory_image = minetest.inventorycube("jungletree_top.png", "jungletree.png", "jungletree.png"),
+       is_ground_content = true,
+       material = minetest.digprop_woodlike(1.0),
+       cookresult_itemstring = 'craft "lump_of_coal" 1',
+       furnace_burntime = 30,
+})
+
+minetest.register_node(":junglegrass", {
+       drawtype = "plantlike",
+       visual_scale = 1.3,
+       tile_images = {"junglegrass.png"},
+       inventory_image = "junglegrass.png",
+       light_propagates = true,
+       paramtype = "light",
+       walkable = false,
+       material = minetest.digprop_leaveslike(1.0),
+       furnace_burntime = 2,
+})
+
+minetest.register_node(":leaves", {
+       drawtype = "allfaces_optional",
+       visual_scale = 1.3,
+       tile_images = {"leaves.png"},
+       inventory_image = minetest.inventorycube("leaves.png"),
+       light_propagates = true,
+       paramtype = "light",
+       material = minetest.digprop_leaveslike(1.0),
+       extra_dug_item = 'node "sapling" 1',
+       extra_dug_item_rarity = 20,
+       furnace_burntime = 1,
+})
+
+minetest.register_node(":cactus", {
+       tile_images = {"cactus_top.png", "cactus_top.png", "cactus_side.png"},
+       inventory_image = minetest.inventorycube("cactus_top.png", "cactus_side.png", "cactus_side.png"),
+       is_ground_content = true,
+       material = minetest.digprop_woodlike(0.75),
+       furnace_burntime = 15,
+})
+
+minetest.register_node(":papyrus", {
+       drawtype = "plantlike",
+       tile_images = {"papyrus.png"},
+       inventory_image = "papyrus.png",
+       light_propagates = true,
+       paramtype = "light",
+       is_ground_content = true,
+       walkable = false,
+       material = minetest.digprop_leaveslike(0.5),
+       furnace_burntime = 1,
+})
+
+minetest.register_node(":bookshelf", {
+       tile_images = {"wood.png", "wood.png", "bookshelf.png"},
+       inventory_image = minetest.inventorycube("wood.png", "bookshelf.png", "bookshelf.png"),
+       is_ground_content = true,
+       material = minetest.digprop_woodlike(0.75),
+       furnace_burntime = 30,
+})
+
+minetest.register_node(":glass", {
+       drawtype = "glasslike",
+       tile_images = {"glass.png"},
+       inventory_image = minetest.inventorycube("glass.png"),
+       light_propagates = true,
+       paramtype = "light",
+       sunlight_propagates = true,
+       is_ground_content = true,
+       material = minetest.digprop_glasslike(1.0),
+})
+
+minetest.register_node(":wooden_fence", {
+       drawtype = "fencelike",
+       tile_images = {"wood.png"},
+       inventory_image = "fence.png",
+       light_propagates = true,
+       paramtype = "light",
+       is_ground_content = true,
+       selection_box = {
+               type = "fixed",
+               fixed = {-1/7, -1/2, -1/7, 1/7, 1/2, 1/7},
+       },
+       furnace_burntime = 15,
+       material = minetest.digprop_woodlike(0.75),
+})
+
+minetest.register_node(":rail", {
+       drawtype = "raillike",
+       tile_images = {"rail.png", "rail_curved.png", "rail_t_junction.png", "rail_crossing.png"},
+       inventory_image = "rail.png",
+       light_propagates = true,
+       paramtype = "light",
+       is_ground_content = true,
+       walkable = false,
+       selection_box = {
+               type = "fixed",
+               --fixed = <default>
+       },
+       material = minetest.digprop_dirtlike(0.75),
+})
+
+minetest.register_node(":ladder", {
+       drawtype = "signlike",
+       tile_images = {"ladder.png"},
+       inventory_image = "ladder.png",
+       light_propagates = true,
+       paramtype = "light",
+       is_ground_content = true,
+       wall_mounted = true,
+       walkable = false,
+       climbable = true,
+       selection_box = {
+               type = "wallmounted",
+               --wall_top = = <default>
+               --wall_bottom = = <default>
+               --wall_side = = <default>
+       },
+       furnace_burntime = 5,
+       material = minetest.digprop_woodlike(0.5),
+})
+
+minetest.register_node(":coalstone", {
+       tile_images = {"stone.png^mineral_coal.png"},
+       inventory_image = "stone.png^mineral_coal.png",
+       is_ground_content = true,
+       material = minetest.digprop_stonelike(1.5),
+})
+
+minetest.register_node(":wood", {
+       tile_images = {"wood.png"},
+       inventory_image = minetest.inventorycube("wood.png"),
+       is_ground_content = true,
+       furnace_burntime = 7,
+       material = minetest.digprop_woodlike(0.75),
+})
+
+minetest.register_node(":mese", {
+       tile_images = {"mese.png"},
+       inventory_image = minetest.inventorycube("mese.png"),
+       is_ground_content = true,
+       furnace_burntime = 30,
+       material = minetest.digprop_stonelike(0.5),
+})
+
+minetest.register_node(":cloud", {
+       tile_images = {"cloud.png"},
+       inventory_image = minetest.inventorycube("cloud.png"),
+       is_ground_content = true,
+})
+
+minetest.register_node(":water_flowing", {
+       drawtype = "flowingliquid",
+       tile_images = {"water.png"},
+       alpha = WATER_ALPHA,
+       inventory_image = minetest.inventorycube("water.png"),
+       paramtype = "light",
+       light_propagates = true,
+       walkable = false,
+       pointable = false,
+       diggable = false,
+       buildable_to = true,
+       liquidtype = "flowing",
+       liquid_alternative_flowing = "water_flowing",
+       liquid_alternative_source = "water_source",
+       liquid_viscosity = WATER_VISC,
+       post_effect_color = {a=64, r=100, g=100, b=200},
+       special_materials = {
+               {image="water.png", backface_culling=false},
+               {image="water.png", backface_culling=true},
+       },
+})
+
+minetest.register_node(":water_source", {
+       drawtype = "liquid",
+       tile_images = {"water.png"},
+       alpha = WATER_ALPHA,
+       inventory_image = minetest.inventorycube("water.png"),
+       paramtype = "light",
+       light_propagates = true,
+       walkable = false,
+       pointable = false,
+       diggable = false,
+       buildable_to = true,
+       liquidtype = "source",
+       liquid_alternative_flowing = "water_flowing",
+       liquid_alternative_source = "water_source",
+       liquid_viscosity = WATER_VISC,
+       post_effect_color = {a=64, r=100, g=100, b=200},
+       special_materials = {
+               -- New-style water source material (mostly unused)
+               {image="water.png", backface_culling=false},
+       },
+})
+
+minetest.register_node(":lava_flowing", {
+       drawtype = "flowingliquid",
+       tile_images = {"lava.png"},
+       inventory_image = minetest.inventorycube("lava.png"),
+       paramtype = "light",
+       light_propagates = false,
+       light_source = LIGHT_MAX - 1,
+       walkable = false,
+       pointable = false,
+       diggable = false,
+       buildable_to = true,
+       liquidtype = "flowing",
+       liquid_alternative_flowing = "lava_flowing",
+       liquid_alternative_source = "lava_source",
+       liquid_viscosity = LAVA_VISC,
+       damage_per_second = 4*2,
+       post_effect_color = {a=192, r=255, g=64, b=0},
+       special_materials = {
+               {image="lava.png", backface_culling=false},
+               {image="lava.png", backface_culling=true},
+       },
+})
+
+minetest.register_node(":lava_source", {
+       drawtype = "liquid",
+       tile_images = {"lava.png"},
+       inventory_image = minetest.inventorycube("lava.png"),
+       paramtype = "light",
+       light_propagates = false,
+       light_source = LIGHT_MAX - 1,
+       walkable = false,
+       pointable = false,
+       diggable = false,
+       buildable_to = true,
+       liquidtype = "source",
+       liquid_alternative_flowing = "lava_flowing",
+       liquid_alternative_source = "lava_source",
+       liquid_viscosity = LAVA_VISC,
+       damage_per_second = 4*2,
+       post_effect_color = {a=192, r=255, g=64, b=0},
+       special_materials = {
+               -- New-style lava source material (mostly unused)
+               {image="lava.png", backface_culling=false},
+       },
+       furnace_burntime = 60,
+})
+
+minetest.register_node(":torch", {
+       drawtype = "torchlike",
+       tile_images = {"torch_on_floor.png", "torch_on_ceiling.png", "torch.png"},
+       inventory_image = "torch_on_floor.png",
+       paramtype = "light",
+       light_propagates = true,
+       sunlight_propagates = true,
+       walkable = false,
+       wall_mounted = true,
+       light_source = LIGHT_MAX-1,
+       selection_box = {
+               type = "wallmounted",
+               wall_top = {-0.1, 0.5-0.6, -0.1, 0.1, 0.5, 0.1},
+               wall_bottom = {-0.1, -0.5, -0.1, 0.1, -0.5+0.6, 0.1},
+               wall_side = {-0.5, -0.3, -0.1, -0.5+0.3, 0.3, 0.1},
+       },
+       material = minetest.digprop_constanttime(0.0),
+       furnace_burntime = 4,
+})
+
+minetest.register_node(":sign_wall", {
+       drawtype = "signlike",
+       tile_images = {"sign_wall.png"},
+       inventory_image = "sign_wall.png",
+       paramtype = "light",
+       light_propagates = true,
+       sunlight_propagates = true,
+       walkable = false,
+       wall_mounted = true,
+       metadata_name = "sign",
+       selection_box = {
+               type = "wallmounted",
+               --wall_top = <default>
+               --wall_bottom = <default>
+               --wall_side = <default>
+       },
+       material = minetest.digprop_constanttime(0.5),
+       furnace_burntime = 10,
+})
+
+minetest.register_node(":chest", {
+       tile_images = {"chest_top.png", "chest_top.png", "chest_side.png",
+               "chest_side.png", "chest_side.png", "chest_front.png"},
+       inventory_image = minetest.inventorycube("chest_top.png", "chest_front.png", "chest_side.png"),
+       paramtype = "facedir_simple",
+       metadata_name = "chest",
+       material = minetest.digprop_woodlike(1.0),
+       furnace_burntime = 30,
+})
+
+minetest.register_node(":locked_chest", {
+       tile_images = {"chest_top.png", "chest_top.png", "chest_side.png",
+               "chest_side.png", "chest_side.png", "chest_lock.png"},
+       inventory_image = minetest.inventorycube("chest_top.png", "chest_lock.png", "chest_side.png"),
+       paramtype = "facedir_simple",
+       metadata_name = "locked_chest",
+       material = minetest.digprop_woodlike(1.0),
+       furnace_burntime = 30,
+})
+
+minetest.register_node(":furnace", {
+       tile_images = {"furnace_side.png", "furnace_side.png", "furnace_side.png",
+               "furnace_side.png", "furnace_side.png", "furnace_front.png"},
+       inventory_image = minetest.inventorycube("furnace_side.png", "furnace_front.png", "furnace_side.png"),
+       paramtype = "facedir_simple",
+       metadata_name = "furnace",
+       material = minetest.digprop_stonelike(3.0),
+})
+
+minetest.register_node(":cobble", {
+       tile_images = {"cobble.png"},
+       inventory_image = minetest.inventorycube("cobble.png"),
+       is_ground_content = true,
+       cookresult_itemstring = 'node "stone" 1',
+       material = minetest.digprop_stonelike(0.9),
+})
+
+minetest.register_node(":mossycobble", {
+       tile_images = {"mossycobble.png"},
+       inventory_image = minetest.inventorycube("mossycobble.png"),
+       is_ground_content = true,
+       material = minetest.digprop_stonelike(0.8),
+})
+
+minetest.register_node(":steelblock", {
+       tile_images = {"steel_block.png"},
+       inventory_image = minetest.inventorycube("steel_block.png"),
+       is_ground_content = true,
+       material = minetest.digprop_stonelike(5.0),
+})
+
+minetest.register_node(":nyancat", {
+       tile_images = {"nc_side.png", "nc_side.png", "nc_side.png",
+               "nc_side.png", "nc_back.png", "nc_front.png"},
+       inventory_image = "nc_front.png",
+       paramtype = "facedir_simple",
+       material = minetest.digprop_stonelike(3.0),
+       furnace_burntime = 1,
+})
+
+minetest.register_node(":nyancat_rainbow", {
+       tile_images = {"nc_rb.png"},
+       inventory_image = "nc_rb.png",
+       material = minetest.digprop_stonelike(3.0),
+       furnace_burntime = 1,
+})
+
+minetest.register_node(":sapling", {
+       drawtype = "plantlike",
+       visual_scale = 1.0,
+       tile_images = {"sapling.png"},
+       inventory_image = "sapling.png",
+       paramtype = "light",
+       light_propagates = true,
+       walkable = false,
+       material = minetest.digprop_constanttime(0.0),
+       furnace_burntime = 10,
+})
+
+minetest.register_node(":apple", {
+       drawtype = "plantlike",
+       visual_scale = 1.0,
+       tile_images = {"apple.png"},
+       inventory_image = "apple.png",
+       paramtype = "light",
+       light_propagates = true,
+       sunlight_propagates = true,
+       walkable = false,
+       dug_item = 'craft "apple" 1',
+       material = minetest.digprop_constanttime(0.0),
+       furnace_burntime = 3,
+})
+
+--
+-- Crafting items
+-- Compatibility to 0.3 and old 0.4
+--
+
+minetest.register_craftitem(":Stick", {
+       image = "stick.png",
+       --furnace_burntime = ...,
+       on_place_on_ground = minetest.craftitem_place_item,
+})
+
+minetest.register_craftitem(":paper", {
+       image = "paper.png",
+       on_place_on_ground = minetest.craftitem_place_item,
+})
+
+minetest.register_craftitem(":book", {
+       image = "book.png",
+       on_place_on_ground = minetest.craftitem_place_item,
+})
+
+minetest.register_craftitem(":lump_of_coal", {
+       image = "lump_of_coal.png",
+       furnace_burntime = 40;
+       on_place_on_ground = minetest.craftitem_place_item,
+})
+
+minetest.register_craftitem(":lump_of_iron", {
+       image = "lump_of_iron.png",
+       cookresult_itemstring = 'craft "steel_ingot" 1',
+       on_place_on_ground = minetest.craftitem_place_item,
+})
+
+minetest.register_craftitem(":lump_of_clay", {
+       image = "lump_of_clay.png",
+       cookresult_itemstring = 'craft "clay_brick" 1',
+       on_place_on_ground = minetest.craftitem_place_item,
+})
+
+minetest.register_craftitem(":steel_ingot", {
+       image = "steel_ingot.png",
+       on_place_on_ground = minetest.craftitem_place_item,
+})
+
+minetest.register_craftitem(":clay_brick", {
+       image = "clay_brick.png",
+       on_place_on_ground = minetest.craftitem_place_item,
+})
+
+minetest.register_craftitem(":rat", {
+       image = "rat.png",
+       cookresult_itemstring = 'craft "cooked_rat" 1',
+       on_drop = function(item, dropper, pos)
+               minetest.env:add_rat(pos)
+               return true
+       end,
+})
+
+minetest.register_craftitem(":cooked_rat", {
+       image = "cooked_rat.png",
+       cookresult_itemstring = 'craft "scorched_stuff" 1',
+       on_place_on_ground = minetest.craftitem_place_item,
+       on_use = minetest.craftitem_eat(6),
+})
+
+minetest.register_craftitem(":scorched_stuff", {
+       image = "scorched_stuff.png",
+       on_place_on_ground = minetest.craftitem_place_item,
+})
+
+minetest.register_craftitem(":firefly", {
+       image = "firefly.png",
+       on_drop = function(item, dropper, pos)
+               minetest.env:add_firefly(pos)
+               return true
+       end,
+})
+
+minetest.register_craftitem(":apple", {
+       image = "apple.png",
+       on_place_on_ground = minetest.craftitem_place_item,
+       on_use = minetest.craftitem_eat(4),
+})
+
+minetest.register_craftitem(":apple_iron", {
+       image = "apple_iron.png",
+       on_place_on_ground = minetest.craftitem_place_item,
+       on_use = minetest.craftitem_eat(8),
+})
+
+--
+-- Falling stuff
+--
+
+default.register_falling_node("sand", "sand.png")
+default.register_falling_node("gravel", "gravel.png")
+
+--
+-- Global callbacks
+--
+
+function on_placenode(p, node)
+       nodeupdate(p)
+end
+minetest.register_on_placenode(on_placenode)
+
+function on_dignode(p, node)
+       nodeupdate(p)
+end
+minetest.register_on_dignode(on_dignode)
+
+-- END