diff options
| author | Gael-de-Sailly <gael.chretien@akeonet.com> | 2017-02-22 18:24:35 +0100 | 
|---|---|---|
| committer | Gael-de-Sailly <gael.chretien@akeonet.com> | 2017-02-22 18:24:35 +0100 | 
| commit | d4e9de50a98544923be71f5be49139ed25e52cfc (patch) | |
| tree | 81dfc2285508f7d262941e00a8a0f7530fcdfb53 | |
| parent | 4d8c2610bc3bb6529643f62aea6c8e043be9ff13 (diff) | |
Limit radius to 120 even for players with server privilege.
| -rw-r--r-- | init.lua | 9 | 
1 files changed, 8 insertions, 1 deletions
@@ -3,6 +3,8 @@ local function mapfix(minp, maxp)  	vm:update_liquids()  	vm:write_to_map()  	vm:update_map() +	local emin, emax = vm:get_emerged_area() +	print(minetest.pos_to_string(emin), minetest.pos_to_string(emax))  end  local previous = os.time() @@ -17,6 +19,10 @@ minetest.register_chatcommand("mapfix", {  	func = function(name, param)  		local pos = vector.round(minetest.get_player_by_name(name):getpos())  		local size = tonumber(param) or default_size + +		if size >= 121 then +			return false, "Radius is too big" +		end  		local privs = minetest.check_player_privs(name, {server=true})  		local time = os.time() @@ -29,12 +35,13 @@ minetest.register_chatcommand("mapfix", {  			previous = time  		end +		minetest.log("action", name .. " uses mapfix at " .. minetest.pos_to_string(vector.round(pos)) .. " with radius " .. size) +  		size = math.max(math.floor(size - 8), 0) -- When passed to get_voxel_manip, positions are rounded up, to a multiple of 16 nodes in each direction. By subtracting 8 it's rounded to the nearest chunk border. max is used to avoid negative radius.  		local minp = vector.subtract(pos, size)  		local maxp = vector.add(pos, size) -		minetest.log("action", name .. " uses mapfix at " .. minetest.pos_to_string(vector.round(pos)) .. " with radius " .. size)  		mapfix(minp, maxp)  		return true, "Done."  	end,  | 
