summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAnthony Zhang <azhang9@gmail.com>2013-01-12 18:29:57 -0500
committerAnthony Zhang <azhang9@gmail.com>2013-01-12 18:29:57 -0500
commit7cf84045d4dea9727f9db5e5de9a6524fc4ef1af (patch)
tree7fc04acbd62ca3cc8f0cea758818de2346359a21
parente2f1c4ef174443b2807aa94a209261546bbf19fb (diff)
Replace //homogenize with //replaceinverse (//homogenize x is equivalent to //replaceinverse air x), add documentation for it.
-rw-r--r--Chat Commands.md11
-rw-r--r--WorldEdit API.md6
-rw-r--r--worldedit/manipulations.lua33
-rw-r--r--worldedit_commands/init.lua23
4 files changed, 64 insertions, 9 deletions
diff --git a/Chat Commands.md b/Chat Commands.md
index 23920a4..9e9ccae 100644
--- a/Chat Commands.md
+++ b/Chat Commands.md
@@ -51,13 +51,22 @@ Set the current WorldEdit region to <node>.
### //replace <search node> <replace node>
-Replace all instances of <search node> with <place node> in the current WorldEdit region.
+Replace all instances of <search node> with <replace node> in the current WorldEdit region.
//replace cobble stone
//replace default:steelblock glass
//replace dirt flowers:flower_waterlily
//replace flowers:flower_rose flowers:flower_tulip
+### //replaceinverse <search node> <replace node>
+
+Replace all nodes other than <search node> with <replace node> in the current WorldEdit region.
+
+ //replaceinverse air stone
+ //replaceinverse water_source default:dirt
+ //replaceinverse mesecons:mesecon air
+ //replaceinverse default:steelblock default:glass
+
### //hollowsphere <radius> <node>
Add hollow sphere at WorldEdit position 1 with radius <radius>, composed of <node>.
diff --git a/WorldEdit API.md b/WorldEdit API.md
index 0b383ed..e033150 100644
--- a/WorldEdit API.md
+++ b/WorldEdit API.md
@@ -20,6 +20,12 @@ Replaces all instances of `searchnode` with `replacenode` in a region defined by
Returns the number of nodes replaced.
+### count = worldedit.replaceinverse(pos1, pos2, searchnode, replacenode)
+
+Replaces all nodes other than `searchnode` with `replacenode` in a region defined by positions `pos1` and `pos2`.
+
+Returns the number of nodes replaced.
+
### count = worldedit.copy(pos1, pos2, axis, amount)
Copies the region defined by positions `pos1` and `pos2` along the `axis` axis ("x" or "y" or "z") by `amount` nodes.
diff --git a/worldedit/manipulations.lua b/worldedit/manipulations.lua
index 253456c..c6bb9dd 100644
--- a/worldedit/manipulations.lua
+++ b/worldedit/manipulations.lua
@@ -74,6 +74,37 @@ worldedit.replace = function(pos1, pos2, searchnode, replacenode)
return count
end
+--replaces all nodes other than `searchnode` with `replacenode` in a region defined by positions `pos1` and `pos2`, returning the number of nodes replaced
+worldedit.replaceinverse = function(pos1, pos2, searchnode, replacenode)
+ local pos1, pos2 = worldedit.sort_pos(pos1, pos2)
+ local env = minetest.env
+
+ if minetest.registered_nodes[searchnode] == nil then
+ searchnode = "default:" .. searchnode
+ end
+
+ local pos = {x=pos1.x, y=0, z=0}
+ local node = {name=replacenode}
+ local count = 0
+ while pos.x <= pos2.x do
+ pos.y = pos1.y
+ while pos.y <= pos2.y do
+ pos.z = pos1.z
+ while pos.z <= pos2.z do
+ local name = env:get_node(pos).name
+ if name ~= "ignore" and name ~= searchnode then
+ env:add_node(pos, node)
+ count = count + 1
+ end
+ pos.z = pos.z + 1
+ end
+ pos.y = pos.y + 1
+ end
+ pos.x = pos.x + 1
+ end
+ return count
+end
+
--copies the region defined by positions `pos1` and `pos2` along the `axis` axis ("x" or "y" or "z") by `amount` nodes, returning the number of nodes copied
worldedit.copy = function(pos1, pos2, axis, amount)
local pos1, pos2 = worldedit.sort_pos(pos1, pos2)
@@ -383,4 +414,4 @@ worldedit.fixlight = function(pos1, pos2)
pos.x = pos.x + 1
end
return count
-end
+end
diff --git a/worldedit_commands/init.lua b/worldedit_commands/init.lua
index a2e6246..b568da3 100644
--- a/worldedit_commands/init.lua
+++ b/worldedit_commands/init.lua
@@ -197,9 +197,9 @@ minetest.register_chatcommand("/replace", {
end,
})
-minetest.register_chatcommand("/homogenize", {
- params = "<node>",
- description = "Replace all non-air nodes with <node> in the current WorldEdit region",
+minetest.register_chatcommand("/replaceinverse", {
+ params = "<search node> <replace node>",
+ description = "Replace all nodes other than <search node> with <replace node> in the current WorldEdit region",
privs = {worldedit=true},
func = function(name, param)
local pos1, pos2 = worldedit.pos1[name], worldedit.pos2[name]
@@ -208,13 +208,22 @@ minetest.register_chatcommand("/homogenize", {
return
end
- if not worldedit.node_is_valid(param) then
- minetest.chat_send_player(name, "Invalid node name: " .. param)
+ local found, _, searchnode, replacenode = param:find("^([^%s]+)%s+([^%s]+)$")
+ if found == nil then
+ minetest.chat_send_player(name, "Invalid usage: " .. param)
+ return
+ end
+ if not worldedit.node_is_valid(searchnode) then
+ minetest.chat_send_player(name, "Invalid search node name: " .. searchnode)
+ return
+ end
+ if not worldedit.node_is_valid(replacenode) then
+ minetest.chat_send_player(name, "Invalid replace node name: " .. replacenode)
return
end
- local count = worldedit.homogenize(pos1, pos2, param)
- minetest.chat_send_player(name, count .. " nodes homogenized")
+ local count = worldedit.replaceinverse(pos1, pos2, searchnode, replacenode)
+ minetest.chat_send_player(name, count .. " nodes replaced")
end,
})