2017-08-30 15:15:03 -07:00
|
|
|
--[[ Cleaner mod
|
2017-08-30 14:38:48 -07:00
|
|
|
License: CC0
|
|
|
|
]]
|
|
|
|
|
|
|
|
|
2017-08-30 15:15:03 -07:00
|
|
|
cleaner = {}
|
|
|
|
cleaner.name = core.get_current_modname()
|
2017-08-30 14:38:48 -07:00
|
|
|
|
|
|
|
local debug = core.settings:get_bool('enable_debug_mods')
|
|
|
|
|
|
|
|
local function log(level, msg)
|
2017-08-30 15:15:03 -07:00
|
|
|
core.log(level, '[' .. cleaner.name .. '] ' .. msg)
|
2017-08-30 14:38:48 -07:00
|
|
|
end
|
|
|
|
|
|
|
|
local function logDebug(msg)
|
|
|
|
if debug then
|
2017-08-30 15:15:03 -07:00
|
|
|
core.log('DEBUG: [' .. cleaner.name .. '] ' .. msg)
|
2017-08-30 14:38:48 -07:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2017-05-18 15:06:02 -07:00
|
|
|
|
2017-08-30 15:26:59 -07:00
|
|
|
-- ENTITIES
|
|
|
|
|
2017-08-30 14:57:18 -07:00
|
|
|
local old_entities = {}
|
2017-08-30 14:39:12 -07:00
|
|
|
|
|
|
|
-- Populate entities list from file in world path
|
|
|
|
local e_list = nil
|
|
|
|
local e_path = core.get_worldpath() .. '/clean_entities.txt'
|
|
|
|
local e_file = io.open(e_path, 'r')
|
|
|
|
if e_file then
|
|
|
|
e_list = e_file:read('*a')
|
|
|
|
e_file:close()
|
|
|
|
else
|
|
|
|
-- Create empty file
|
|
|
|
e_file = io.open(e_path, 'w')
|
|
|
|
if e_file then
|
|
|
|
e_file:close()
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
if e_list then
|
|
|
|
logDebug('Loading entities to clean from file ...')
|
|
|
|
|
|
|
|
e_list = string.split(e_list, '\n')
|
|
|
|
for _, entity_name in ipairs(e_list) do
|
|
|
|
table.insert(old_entities, entity_name)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2017-08-30 14:14:55 -07:00
|
|
|
for _, entity_name in ipairs(old_entities) do
|
2017-08-30 14:39:12 -07:00
|
|
|
logDebug('Cleaning entity: ' .. entity_name)
|
|
|
|
|
2017-08-30 14:14:55 -07:00
|
|
|
core.register_entity(':' .. entity_name, {
|
2017-05-18 15:06:02 -07:00
|
|
|
on_activate = function(self, staticdata)
|
|
|
|
self.object:remove()
|
|
|
|
end,
|
|
|
|
})
|
|
|
|
end
|
2017-08-30 15:26:59 -07:00
|
|
|
|
|
|
|
|
|
|
|
-- NODES
|
|
|
|
|
|
|
|
local old_nodes = {}
|
|
|
|
|
|
|
|
-- Populate nodes list from file in world path
|
|
|
|
local n_list = nil
|
|
|
|
local n_path = core.get_worldpath() .. '/clean_nodes.txt'
|
|
|
|
local n_file = io.open(n_path, 'r')
|
|
|
|
if n_file then
|
|
|
|
n_list = n_file:read('*a')
|
|
|
|
n_file:close()
|
|
|
|
else
|
|
|
|
-- Create empty file
|
|
|
|
n_file = io.open(n_path, 'w')
|
|
|
|
if n_file then
|
|
|
|
n_file:close()
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
if n_list then
|
|
|
|
logDebug('Loading nodes to clean from file ...')
|
|
|
|
|
|
|
|
n_list = string.split(n_list, '\n')
|
|
|
|
for _, node_name in ipairs(n_list) do
|
|
|
|
table.insert(old_nodes, node_name)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
for _, node_name in ipairs(old_nodes) do
|
2017-08-30 15:33:53 -07:00
|
|
|
logDebug('Cleaning node: ' .. node_name)
|
|
|
|
|
2017-08-30 15:26:59 -07:00
|
|
|
core.register_node(':' .. node_name, {
|
|
|
|
groups = {old=1},
|
|
|
|
})
|
|
|
|
end
|
|
|
|
|
|
|
|
core.register_abm({
|
|
|
|
nodenames = {'group:old'},
|
|
|
|
interval = 1,
|
|
|
|
chance = 1,
|
|
|
|
action = function(pos, node)
|
|
|
|
core.remove_node(pos)
|
|
|
|
end,
|
|
|
|
})
|