prevent burning TNT from exploding
parent
2d7e37dcc8
commit
a0a3ea8309
61
init.lua
61
init.lua
|
@ -1,6 +1,6 @@
|
||||||
-- ANTI GRIEF by rnd
|
-- ANTI GRIEF by rnd
|
||||||
-- Copyright 2016 rnd
|
-- Copyright 2016 rnd
|
||||||
-- modified by SaKeL for Survival X Server
|
-- modified by SaKeL for Survival X Server
|
||||||
|
|
||||||
----------------------------------------------------------------------------
|
----------------------------------------------------------------------------
|
||||||
-- This program is free software: you can redistribute it and/or modify
|
-- This program is free software: you can redistribute it and/or modify
|
||||||
|
@ -29,13 +29,13 @@ function prevent_place_above(name)
|
||||||
local old_on_place = minetest.registered_craftitems[name] -- on_place
|
local old_on_place = minetest.registered_craftitems[name] -- on_place
|
||||||
local old_after_place_node = minetest.registered_nodes[name] --after_place_node
|
local old_after_place_node = minetest.registered_nodes[name] --after_place_node
|
||||||
--after_place_node = func(pos, placer, itemstack, pointed_thing)
|
--after_place_node = func(pos, placer, itemstack, pointed_thing)
|
||||||
|
|
||||||
if old_on_place and old_on_place.on_place then
|
if old_on_place and old_on_place.on_place then
|
||||||
|
|
||||||
old_on_place = old_on_place.on_place
|
old_on_place = old_on_place.on_place
|
||||||
|
|
||||||
minetest.registered_craftitems[name].on_place = function(itemstack, placer, pointed_thing)
|
minetest.registered_craftitems[name].on_place = function(itemstack, placer, pointed_thing)
|
||||||
|
|
||||||
local pos = pointed_thing.above
|
local pos = pointed_thing.above
|
||||||
local placer_name = placer:get_player_name()
|
local placer_name = placer:get_player_name()
|
||||||
local item_name = string.split(itemstack:get_name(), ":")[2]
|
local item_name = string.split(itemstack:get_name(), ":")[2]
|
||||||
|
@ -61,14 +61,14 @@ function prevent_place_above(name)
|
||||||
if old_after_place_node then
|
if old_after_place_node then
|
||||||
|
|
||||||
old_after_place_node = old_after_place_node.after_place_node
|
old_after_place_node = old_after_place_node.after_place_node
|
||||||
|
|
||||||
local table = minetest.registered_nodes[name]
|
local table = minetest.registered_nodes[name]
|
||||||
local table2 = {}
|
local table2 = {}
|
||||||
|
|
||||||
for i,v in pairs(table) do
|
for i,v in pairs(table) do
|
||||||
table2[i] = v
|
table2[i] = v
|
||||||
end
|
end
|
||||||
|
|
||||||
table2.after_place_node = function(pos, placer, itemstack, pointed_thing)
|
table2.after_place_node = function(pos, placer, itemstack, pointed_thing)
|
||||||
|
|
||||||
--after_place_node = func(pos, placer, itemstack, pointed_thing)
|
--after_place_node = func(pos, placer, itemstack, pointed_thing)
|
||||||
|
@ -97,11 +97,54 @@ function prevent_place_above(name)
|
||||||
|
|
||||||
minetest.register_node(":"..name, table2)
|
minetest.register_node(":"..name, table2)
|
||||||
return
|
return
|
||||||
end
|
end
|
||||||
|
|
||||||
return
|
return
|
||||||
end
|
end
|
||||||
|
|
||||||
|
-- prevent TNT explosion
|
||||||
|
minetest.after(0, function ()
|
||||||
|
local old_on_timer = minetest.registered_nodes["tnt:tnt_burning"]
|
||||||
|
|
||||||
|
if old_on_timer and old_on_timer.on_timer then
|
||||||
|
old_on_timer = old_on_timer.on_timer
|
||||||
|
|
||||||
|
minetest.registered_nodes["tnt:tnt_burning"].on_timer = function(pos, elapsed)
|
||||||
|
|
||||||
|
local meta = minetest.get_meta(pos)
|
||||||
|
local owner = meta:get_string("owner")
|
||||||
|
|
||||||
|
if not owner then
|
||||||
|
owner = ""
|
||||||
|
end
|
||||||
|
|
||||||
|
if pos.y > -150 and owner ~= "ADMIN" and owner ~= "SaKeL" then
|
||||||
|
minetest.sound_play("antigrief_fart", {pos = pos, gain = 1.5, max_hear_distance = 2*64})
|
||||||
|
minetest.remove_node(pos)
|
||||||
|
|
||||||
|
-- add effect
|
||||||
|
minetest.add_particlespawner({
|
||||||
|
amount = 64,
|
||||||
|
time = 0.5,
|
||||||
|
minpos = vector.subtract(pos, 1 / 2),
|
||||||
|
maxpos = vector.add(pos, 1 / 2),
|
||||||
|
minvel = {x = -10, y = -10, z = -10},
|
||||||
|
maxvel = {x = 10, y = 10, z = 10},
|
||||||
|
minacc = vector.new(),
|
||||||
|
maxacc = vector.new(),
|
||||||
|
minexptime = 1,
|
||||||
|
maxexptime = 2.5,
|
||||||
|
minsize = 1 * 3,
|
||||||
|
maxsize = 1 * 5,
|
||||||
|
texture = "tnt_smoke.png",
|
||||||
|
})
|
||||||
|
else
|
||||||
|
return old_on_timer(pos, elapsed)
|
||||||
|
end
|
||||||
|
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end)
|
||||||
|
|
||||||
minetest.after(0, function ()
|
minetest.after(0, function ()
|
||||||
prevent_place_above("bucket:bucket_water")
|
prevent_place_above("bucket:bucket_water")
|
||||||
|
|
Binary file not shown.
Loading…
Reference in New Issue