2020-05-12 01:38:42 +02:00
-- ██████ ██████ ██ ██ ███ ██ ████████
-- ██ ██ ██ ██ ██ ████ ██ ██
-- ██ ██ ██ ██ ██ ██ ██ ██ ██
-- ██ ██ ██ ██ ██ ██ ██ ██ ██
-- ██████ ██████ ██████ ██ ████ ██
worldedit.register_command ( " count " , {
params = " " ,
description = " Counts all the nodes in the defined region. " ,
privs = { worldedit = true } ,
require_pos = 2 ,
parse = function ( params_text )
return true
end ,
nodes_needed = function ( name )
-- We don't actually modify anything, but without returning a
-- number here safe_region doesn't work
return worldedit.volume ( worldedit.pos1 [ name ] , worldedit.pos2 [ name ] )
end ,
func = function ( name )
2020-06-26 21:46:35 +02:00
local start_time = worldeditadditions.get_ms_time ( )
2020-05-12 01:38:42 +02:00
local success , counts , total = worldeditadditions.count ( worldedit.pos1 [ name ] , worldedit.pos2 [ name ] , target_node )
local result = worldeditadditions.make_ascii_table ( counts ) .. " \n " ..
string.rep ( " = " , 6 + # tostring ( total ) + 6 ) .. " \n " ..
" Total " .. total .. " nodes \n "
2020-06-26 21:46:35 +02:00
local time_taken = worldeditadditions.get_ms_time ( ) - start_time
2020-05-12 01:38:42 +02:00
2020-06-26 22:23:03 +02:00
minetest.log ( " action " , name .. " used //count at " .. worldeditadditions.vector . tostring ( worldedit.pos1 [ name ] ) .. " - " .. worldeditadditions.vector . tostring ( worldedit.pos2 [ name ] ) .. " , counting " .. total .. " nodes in " .. worldeditadditions.human_time ( time_taken ) )
2020-05-12 01:38:42 +02:00
return true , result
end
} )