diff options
author | Daniel Sosa <sosa.daniel23@gmail.com> | 2015-01-03 02:29:28 -0600 |
---|---|---|
committer | Daniel Sosa <sosa.daniel23@gmail.com> | 2016-07-03 21:44:02 -0500 |
commit | 6cf8b924345e69f705ce7cc437e34d137bd773a6 (patch) | |
tree | 17013056835ae39886fdff8885895f1c04364ffa /worldedit_commands | |
parent | 0b97a7c74090492937a6a572babd0dcb9592aeed (diff) |
Reimplement /shift to make use of new marker functions
Diffstat (limited to 'worldedit_commands')
-rw-r--r-- | worldedit_commands/area.lua | 52 |
1 files changed, 18 insertions, 34 deletions
diff --git a/worldedit_commands/area.lua b/worldedit_commands/area.lua index b88b2f5..78b91d4 100644 --- a/worldedit_commands/area.lua +++ b/worldedit_commands/area.lua @@ -159,16 +159,15 @@ end minetest.register_chatcommand( "/shift", { - params = "[+|-]<amount> [x|y|z]", + params = "<amount> [up|down|left|right|front|back]", description = "Moves the selection region. Does not move contents.", privs = {worldedit=true}, func = function(name, param) local pos1 = worldedit.pos1[name] local pos2 = worldedit.pos2[name] - local find, _, sign, amount, axis = param:find("^([+-]?)(%d+)[%s+]?([xyz]?)$") + local find, _, amount, direction = param:find("(%d+)%s*(%l*)") if find == nil then - minetest.debug("entering if") worldedit.player_notify(name, "invalid usage: " .. param) return end @@ -178,36 +177,21 @@ minetest.register_chatcommand( return end - amount = tonumber(amount) - - local direction = "" - - if sign ~= nil and sign == '-' then - amount = amount * -1 - end + local axis, dirsign - if axis == "" then - direction, _ = worldedit.player_axis(name) - amount = amount * _ + if direction ~= "" then + axis, dirsign = worldedit.translate_direction(name, direction) else - direction = axis - end - - if direction == 'x' then - worldedit.pos1[name].x = pos1.x + amount - worldedit.pos2[name].x = pos2.x + amount - elseif direction == 'y' then - worldedit.pos1[name].y = pos1.y + amount - worldedit.pos2[name].y = pos2.y + amount - elseif direction == 'z' then - worldedit.pos1[name].z = pos1.z + amount - worldedit.pos2[name].z = pos2.z + amount - else - worldedit.player_notify(name, "unexpected error. direction = " .. direction) + axis, dirsign = worldedit.player_axis(name) end - worldedit.mark_pos1(name) - worldedit.mark_pos2(name) + if axis == nil or dirsign == nil then + return false, "Invalid usage: " .. param + end + + worldedit.move_marker(name, 1, axis, amount * dirsign) + worldedit.move_marker(name, 2, axis, amount * dirsign) + worldedit.update_markers(name) worldedit.player_notify(name, "Area shifted by " .. amount .. " in " .. direction .. " axis") end, @@ -239,7 +223,7 @@ minetest.register_chatcommand( mark = worldedit.get_marker_in_axis(name, axis, direction) if arg3 ~= "" then - axis, direction = worldedit.translate_directions(name, arg3) + axis, direction = worldedit.translate_direction(name, arg3) mark = worldedit.get_marker_in_axis(name, axis, direction) end @@ -247,7 +231,7 @@ minetest.register_chatcommand( local tmp = tonumber(arg2) if tmp == nil then - axis, direction = worldedit.translate_directions(name, arg2) + axis, direction = worldedit.translate_direction(name, arg2) mark = worldedit.get_marker_in_axis(name, axis, direction) else local tmpmark @@ -301,7 +285,7 @@ minetest.register_chatcommand( mark = worldedit.get_marker_in_axis(name, axis, direction) if arg3 ~= "" then - axis, direction = worldedit.translate_directions(name, arg3) + axis, direction = worldedit.translate_direction(name, arg3) mark = worldedit.get_marker_in_axis(name, axis, direction) end @@ -309,7 +293,7 @@ minetest.register_chatcommand( local tmp = tonumber(arg2) if tmp == nil then - axis, direction = worldedit.translate_directions(name, arg2) + axis, direction = worldedit.translate_direction(name, arg2) mark = worldedit.get_marker_in_axis(name, axis, direction) else local tmpmark @@ -438,7 +422,7 @@ end -- Translates up, down, left, right, front, back to their corresponding axes and directions according to faced direction -worldedit.translate_directions = function(name, direction) +worldedit.translate_direction = function(name, direction) local axis, dir = worldedit.player_axis(name) local resaxis, resdir |