summaryrefslogtreecommitdiff
path: root/land_title_register.lua
diff options
context:
space:
mode:
Diffstat (limited to 'land_title_register.lua')
-rw-r--r--land_title_register.lua139
1 files changed, 139 insertions, 0 deletions
diff --git a/land_title_register.lua b/land_title_register.lua
new file mode 100644
index 0000000..fa41bc6
--- /dev/null
+++ b/land_title_register.lua
@@ -0,0 +1,139 @@
+
+
+
+
+markers.get_area_info = function(pos)
+ local found = {}
+ for nr, area in pairs(areas.areas) do
+ if pos.x >= area.pos1.x and pos.x <= area.pos2.x and
+ pos.y >= area.pos1.y and pos.y <= area.pos2.y and
+ pos.z >= area.pos1.z and pos.z <= area.pos2.z then
+ area[ 'id' ] = nr;
+ table.insert( found, area )
+ end
+ end
+ return found;
+end
+
+
+
+markers.get_area_info_as_text = function(pos, name)
+
+ local text = 'Checking '..minetest.pos_to_string( pos )..'. Owned by: ';
+
+ local found_areas = markers.get_area_info( pos );
+--minetest.chat_send_player('singleplayer', 'Areas FOUND: '..minetest.serialize( found_areas ));
+
+ if( not( found_areas ) or #found_areas < 1 ) then
+ minetest.chat_send_player( name, text..'-nobody- (unprotected)');
+ return;
+ end
+
+ local parent = {};
+ for _, area in pairs( found_areas ) do
+ if( not( area[ 'parent' ] )) then
+ parent = area;
+ minetest.chat_send_player(name, ' '..areas:toString( area['id']))
+ end
+ end
+
+ if( #found_areas > 1 ) then
+ minetest.chat_send_player(name, ' Sub-owners of entire area:');
+
+ for _, area in pairs( found_areas ) do
+ if( area[ 'parent' ]==parent['nr'] ) then
+ if( parent.pos1.x == area.pos1.x
+ and parent.pos1.y == area.pos1.y
+ and parent.pos1.z == area.pos1.z
+ and parent.pos2.x == area.pos2.x
+ and parent.pos2.y == area.pos2.y
+ and parent.pos2.z == area.pos2.z) then
+
+ minetest.chat_send_player(name, ' '..areas:toString( area['id']))
+ end
+ end
+ end
+ end
+
+
+ if( #found_areas > 1 ) then
+ minetest.chat_send_player(name, ' Sub-owners:');
+
+ for _, area in pairs( found_areas ) do
+ if( area[ 'parent' ] ) then
+ minetest.chat_send_player(name, ' '..areas:toString( area['id']))
+ end
+ end
+ end
+
+ minetest.chat_send_player(name, 'ALL owners:');
+ for _, area in pairs( found_areas ) do
+ minetest.chat_send_player(name, ' '..areas:toString( area['id']))
+ end
+end
+
+
+minetest.register_tool( "markers:land_title_register",
+{
+ description = "Land title register. Left-click with it to get information about the land owner or to protect your own ground.",
+ groups = {},
+ inventory_image = "default_book.png", -- TODO
+ wield_image = "",
+ wield_scale = {x=1,y=1,z=1},
+ stack_max = 1, -- there is no need to have more than one
+ liquids_pointable = true, -- ground with only water on can be owned as well
+ -- the tool_capabilities are completely irrelevant here - no need to dig
+ tool_capabilities = {
+ full_punch_interval = 1.0,
+ max_drop_level=0,
+ groupcaps={
+ fleshy={times={[2]=0.80, [3]=0.40}, maxwear=0.05, maxlevel=1},
+ snappy={times={[2]=0.80, [3]=0.40}, maxwear=0.05, maxlevel=1},
+ choppy={times={[3]=0.90}, maxwear=0.05, maxlevel=0}
+ }
+ },
+ node_placement_prediction = nil,
+
+ on_place = function(itemstack, placer, pointed_thing)
+
+ if( placer == nil or pointed_thing == nil) then
+ return itemstack; -- nothing consumed
+ end
+ local name = placer:get_player_name();
+
+ -- the position is what we're actually looking for
+ local pos = minetest.get_pointed_thing_position( pointed_thing, 0 ); --under );
+
+ if( not( pos ) or not( pos.x )) then
+ minetest.chat_send_player( name, "Position not found.");
+ return;
+ end
+
+ local found_areas = markers.get_area_info_as_text( pos, placer:get_player_name() );
+-- TODO
+-- inspector.search_node( pos.x, pos.y, pos.z, name );
+ return itemstack; -- nothing consumed, nothing changed
+ end,
+
+
+ on_use = function(itemstack, placer, pointed_thing)
+
+ if( placer == nil or pointed_thing == nil) then
+ return itemstack; -- nothing consumed
+ end
+ local name = placer:get_player_name();
+
+ local pos = minetest.get_pointed_thing_position( pointed_thing, under );
+
+ if( not( pos ) or not( pos.x )) then
+ minetest.chat_send_player( name, "Position not found.");
+ return;
+ end
+-- TODO
+-- inspector.search_node( pos.x, pos.y, pos.z, name );
+ local found_areas = markers.get_area_info_as_text( pos, placer:get_player_name() );
+
+ return itemstack; -- nothing consumed, nothing changed
+ end,
+})
+