aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorSokomine <wegwerf@anarres.dyndns.org>2014-02-26 03:34:42 +0100
committerSokomine <wegwerf@anarres.dyndns.org>2014-02-26 03:34:42 +0100
commit28705b1cb66fa0e98b69b668cf915da539fc1ae9 (patch)
tree45e768893f3f0d6d046a2eeabd02ebd1786aad5e
parent0da4a93f95284d6c876c71b2e7a1a8b0e6662e94 (diff)
downloadapartment-28705b1cb66fa0e98b69b668cf915da539fc1ae9.tar.gz
apartment-28705b1cb66fa0e98b69b668cf915da539fc1ae9.tar.bz2
apartment-28705b1cb66fa0e98b69b668cf915da539fc1ae9.zip
better removal of buildig when spawn chest is built
-rw-r--r--handle_schematics.lua28
-rw-r--r--init.lua1
2 files changed, 19 insertions, 10 deletions
diff --git a/handle_schematics.lua b/handle_schematics.lua
index 18e0bee..7233a90 100644
--- a/handle_schematics.lua
+++ b/handle_schematics.lua
@@ -412,6 +412,7 @@ handle_schematics.place_schematic = function( pos, param2, path, mirror, replace
end
position_data.end_pos.y = position_data.start_pos.y + vector.v*position_data.max.y*do_copies.v;
end
+ return {start_pos = position_data.start_pos, end_pos = position_data.end_pos };
end
@@ -543,14 +544,19 @@ handle_schematics.on_receive_fields = function(pos, formname, fields, sender)
local replacement_param = { odd={{'default:clay',fields.replacement_1}},
even={{'default:clay',fields.replacement_2}}};
- handle_schematics.place_schematic( pos, nil, path, mirror,
+ local res = {};
+ res = handle_schematics.place_schematic( pos, nil, path, mirror,
replacement_function, replacement_param,
sender, {h=fields.h,v=fields.v},
{ apartment_type = fields.apartment_type, apartment_house_name = fields.apartment_house_name})
+ if( res and res.start_pos ) then
+ meta:set_string('start_pos', minetest.serialize( res.start_pos ));
+ meta:set_string('end_pos', minetest.serialize( res.end_pos ));
+ end
return;
end
-- TODO
- minetest.chat_send_player( pname, 'NOT YET IMPLEMENTED.');
+ minetest.chat_send_player( pname, 'Dig this spawner in order to remove the building.');
end
@@ -580,15 +586,17 @@ minetest.register_node("apartment:build_chest", {
after_dig_node = function(pos, oldnode, oldmetadata, digger)
local meta = minetest.get_meta( pos );
- -- TODO: remove the correct building
- local path = minetest.get_modpath("apartment")..'/schems/'..filename;
- local mirror = 0;
- local replacement_function = handle_schematics.replacement_function_decay;
- local replacement_param = nil;
+ if( oldmetadata and oldmetadata.fields and oldmetadata.fields.path ) then
- minetest.chat_send_player( digger:get_player_name(), 'Removing building '..tostring( path ));
- handle_schematics.place_schematic( pos, oldnode.param2, path, mirror, replacement_function, replacement_param, digger, {h=4,v=3} )
-
+ local replacement_function = handle_schematics.replacement_function_decay;
+ local replacement_param = nil;
+ local path = minetest.get_modpath("apartment")..'/schems/'..oldmetadata.fields.path;
+
+ minetest.chat_send_player( digger:get_player_name(), 'Removing building '..tostring( oldmetadata.fields.path ));
+ handle_schematics.place_schematic( pos, oldnode.param2, path, 0,
+ replacement_function, replacement_param, digger,
+ {h=oldmetadata.fields.h,v=oldmetadata.fields.v} )
+ end
end,
-- check if digging is allowed
diff --git a/init.lua b/init.lua
index 10705db..fb25067 100644
--- a/init.lua
+++ b/init.lua
@@ -26,6 +26,7 @@
--]]
-- Changelog:
+-- 24.02.14 Buildings can now be removed again (dig the spawn chest)
-- 25.02.14 Buildings can now be saved. Just prefix the apartment name with save_as_
-- start_pos and end_pos of apartments are now saved (necessary for the above mentioned save function).
-- Building spawner chest is now working.