update replacer_admin definition
parent
3e6b6e7801
commit
156484947b
87
replacer.lua
87
replacer.lua
|
@ -1,53 +1,40 @@
|
||||||
-- Admin replacer extension for Sokomine's replacer mod
|
-- Admin replacer extension for Sokomine's replacer mod
|
||||||
-- range was added and texture updated.
|
-- range was added and texture updated.
|
||||||
-- Everything else below is code by Sokomine.
|
-- Everything else below is code written by Sokomine.
|
||||||
minetest.register_tool( ":replacer:replacer_admin",
|
-- https://github.com/Sokomine/replacer
|
||||||
{
|
|
||||||
description = "Admin node replacement tool",
|
|
||||||
groups = {},
|
|
||||||
inventory_image = "replacer_replacer_admin.png",
|
|
||||||
wield_image = "",
|
|
||||||
wield_scale = {x=1,y=1,z=1},
|
|
||||||
stack_max = 1, -- it has to store information - thus only one can be stacked
|
|
||||||
liquids_pointable = true, -- it is ok to painit in/with water
|
|
||||||
node_placement_prediction = nil,
|
|
||||||
metadata = "default:dirt", -- default replacement: common dirt
|
|
||||||
range = 12,
|
|
||||||
on_place = function(itemstack, placer, pointed_thing)
|
|
||||||
|
|
||||||
if( placer == nil or pointed_thing == nil) then
|
minetest.register_tool( ":replacer:replacer_admin", {
|
||||||
return itemstack; -- nothing consumed
|
description = "Admin node replacement tool",
|
||||||
end
|
groups = {},
|
||||||
local name = placer:get_player_name();
|
inventory_image = "replacer_replacer_admin.png",
|
||||||
|
wield_image = "",
|
||||||
local keys=placer:get_player_control();
|
wield_scale = {x=1,y=1,z=1},
|
||||||
|
stack_max = 1,
|
||||||
if( not( keys["sneak"] )) then
|
liquids_pointable = true,
|
||||||
|
node_placement_prediction = nil,
|
||||||
return replacer.replace( itemstack, placer, pointed_thing, 0 ); end
|
range = 12,
|
||||||
|
on_place = function(itemstack, placer, pointed_thing)
|
||||||
|
if( placer == nil or pointed_thing == nil) then
|
||||||
if( pointed_thing.type ~= "node" ) then
|
return itemstack;
|
||||||
minetest.chat_send_player( name, " Error: No node selected.");
|
end
|
||||||
return nil;
|
local name = placer:get_player_name();
|
||||||
end
|
local keys=placer:get_player_control();
|
||||||
|
if( not( keys["sneak"] ) and not( keys["aux1"])) then
|
||||||
local pos = minetest.get_pointed_thing_position( pointed_thing, under );
|
return replacer.replace( itemstack, placer, pointed_thing, 0 ); end
|
||||||
local node = minetest.env:get_node_or_nil( pos );
|
if( pointed_thing.type ~= "node" ) then
|
||||||
|
minetest.chat_send_player( name, " Error: No node selected.");
|
||||||
local metadata = "default:dirt 0 0";
|
return nil;
|
||||||
if( node ~= nil and node.name ) then
|
end
|
||||||
metadata = node.name..' '..node.param1..' '..node.param2;
|
local pos = minetest.get_pointed_thing_position( pointed_thing, false );
|
||||||
end
|
local node = minetest.get_node_or_nil( pos );
|
||||||
itemstack:set_metadata( metadata );
|
|
||||||
|
local pattern = "default:dirt 0 0";
|
||||||
minetest.chat_send_player( name, "Node replacement tool set to: '"..metadata.."'.");
|
if( node ~= nil and node.name ) then
|
||||||
|
pattern = node.name..' '..node.param1..' '..node.param2;
|
||||||
return itemstack; -- nothing consumed but data changed
|
end
|
||||||
end,
|
return replacer.set_to(name, pattern, placer, itemstack)
|
||||||
|
end,
|
||||||
on_use = function(itemstack, user, pointed_thing)
|
on_use = function(itemstack, user, pointed_thing)
|
||||||
|
return replacer.replace( itemstack, user, pointed_thing, false );
|
||||||
return replacer.replace( itemstack, user, pointed_thing, above );
|
end,
|
||||||
end,
|
})
|
||||||
})
|
|
Loading…
Reference in New Issue