aboutsummaryrefslogtreecommitdiff
path: root/share/games/mesetint/mods/bucket
diff options
context:
space:
mode:
authorPerttu Ahola <celeron55@gmail.com>2012-03-19 20:44:07 +0200
committerPerttu Ahola <celeron55@gmail.com>2012-03-19 20:44:07 +0200
commit1f56d71f190c67325bdc413dfbc6c8e4b8284d98 (patch)
tree04c5ad77c48d9d38899ae9e8b5509b1c94ab30ac /share/games/mesetint/mods/bucket
parent1ff20da5b689d1a5e5a89f7ca086d88bc47f837d (diff)
downloadminetest-1f56d71f190c67325bdc413dfbc6c8e4b8284d98.tar.gz
minetest-1f56d71f190c67325bdc413dfbc6c8e4b8284d98.tar.bz2
minetest-1f56d71f190c67325bdc413dfbc6c8e4b8284d98.zip
Rework directory structure
Diffstat (limited to 'share/games/mesetint/mods/bucket')
-rw-r--r--share/games/mesetint/mods/bucket/depends.txt2
-rw-r--r--share/games/mesetint/mods/bucket/init.lua95
-rw-r--r--share/games/mesetint/mods/bucket/textures/bucket.pngbin0 -> 329 bytes
-rw-r--r--share/games/mesetint/mods/bucket/textures/bucket_lava.pngbin0 -> 363 bytes
-rw-r--r--share/games/mesetint/mods/bucket/textures/bucket_water.pngbin0 -> 369 bytes
5 files changed, 97 insertions, 0 deletions
diff --git a/share/games/mesetint/mods/bucket/depends.txt b/share/games/mesetint/mods/bucket/depends.txt
new file mode 100644
index 000000000..3a7daa1d7
--- /dev/null
+++ b/share/games/mesetint/mods/bucket/depends.txt
@@ -0,0 +1,2 @@
+default
+
diff --git a/share/games/mesetint/mods/bucket/init.lua b/share/games/mesetint/mods/bucket/init.lua
new file mode 100644
index 000000000..8ed9da522
--- /dev/null
+++ b/share/games/mesetint/mods/bucket/init.lua
@@ -0,0 +1,95 @@
+-- bucket (Minetest 0.4 mod)
+-- A bucket, which can pick up water and lava
+
+minetest.register_alias("bucket", "bucket:bucket_empty")
+minetest.register_alias("bucket_water", "bucket:bucket_water")
+minetest.register_alias("bucket_lava", "bucket:bucket_lava")
+
+minetest.register_craft({
+ output = 'bucket:bucket_empty 1',
+ recipe = {
+ {'default:steel_ingot', '', 'default:steel_ingot'},
+ {'', 'default:steel_ingot', ''},
+ }
+})
+
+bucket = {}
+bucket.liquids = {}
+
+-- Register a new liquid
+-- source = name of the source node
+-- flowing = name of the flowing node
+-- itemname = name of the new bucket item (or nil if liquid is not takeable)
+-- inventory_image = texture of the new bucket item (ignored if itemname == nil)
+-- This function can be called from any mod (that depends on bucket).
+function bucket.register_liquid(source, flowing, itemname, inventory_image)
+ bucket.liquids[source] = {
+ source = source,
+ flowing = flowing,
+ itemname = itemname,
+ }
+ bucket.liquids[flowing] = bucket.liquids[source]
+
+ if itemname ~= nil then
+ minetest.register_craftitem(itemname, {
+ inventory_image = inventory_image,
+ stack_max = 1,
+ liquids_pointable = true,
+ on_use = function(itemstack, user, pointed_thing)
+ -- Must be pointing to node
+ if pointed_thing.type ~= "node" then
+ return
+ end
+ -- Check if pointing to a liquid
+ n = minetest.env:get_node(pointed_thing.under)
+ if bucket.liquids[n.name] == nil then
+ -- Not a liquid
+ minetest.env:add_node(pointed_thing.above, {name=source})
+ elseif n.name ~= source then
+ -- It's a liquid
+ minetest.env:add_node(pointed_thing.under, {name=source})
+ end
+ return {name="bucket:bucket_empty"}
+ end
+ })
+ end
+end
+
+minetest.register_craftitem("bucket:bucket_empty", {
+ inventory_image = "bucket.png",
+ stack_max = 1,
+ liquids_pointable = true,
+ on_use = function(itemstack, user, pointed_thing)
+ -- Must be pointing to node
+ if pointed_thing.type ~= "node" then
+ return
+ end
+ -- Check if pointing to a liquid source
+ n = minetest.env:get_node(pointed_thing.under)
+ liquiddef = bucket.liquids[n.name]
+ if liquiddef ~= nil and liquiddef.source == n.name and liquiddef.itemname ~= nil then
+ minetest.env:add_node(pointed_thing.under, {name="air"})
+ return {name=liquiddef.itemname}
+ end
+ end,
+})
+
+bucket.register_liquid(
+ "default:water_source",
+ "default:water_flowing",
+ "bucket:bucket_water",
+ "bucket_water.png"
+)
+
+bucket.register_liquid(
+ "default:lava_source",
+ "default:lava_flowing",
+ "bucket:bucket_lava",
+ "bucket_lava.png"
+)
+
+minetest.register_craft({
+ type = "fuel",
+ recipe = "default:bucket_lava",
+ burntime = 60,
+})
diff --git a/share/games/mesetint/mods/bucket/textures/bucket.png b/share/games/mesetint/mods/bucket/textures/bucket.png
new file mode 100644
index 000000000..f165fd209
--- /dev/null
+++ b/share/games/mesetint/mods/bucket/textures/bucket.png
Binary files differ
diff --git a/share/games/mesetint/mods/bucket/textures/bucket_lava.png b/share/games/mesetint/mods/bucket/textures/bucket_lava.png
new file mode 100644
index 000000000..7cf27cd1f
--- /dev/null
+++ b/share/games/mesetint/mods/bucket/textures/bucket_lava.png
Binary files differ
diff --git a/share/games/mesetint/mods/bucket/textures/bucket_water.png b/share/games/mesetint/mods/bucket/textures/bucket_water.png
new file mode 100644
index 000000000..f220ec51e
--- /dev/null
+++ b/share/games/mesetint/mods/bucket/textures/bucket_water.png
Binary files differ