modlib/file.lua

153 lines
3.8 KiB
Lua

local dir_delim = ...
-- Localize globals
local io, minetest, modlib, string = io, minetest, modlib, string
-- Set environment
local _ENV = {}
setfenv(1, _ENV)
_ENV.dir_delim = dir_delim
function get_name(filepath)
return filepath:match("([^%" .. dir_delim .. "]+)$") or filepath
end
function split_extension(filename)
return filename:match"^(.*)%.(.*)$"
end
--! deprecated
get_extension = split_extension
function split_path(filepath)
return modlib.text.split(filepath, dir_delim)
end
-- concat_path is set by init.lua to avoid code duplication
function read(filename)
local file, err = io.open(filename, "r")
if file == nil then return nil, err end
local content = file:read"*a"
file:close()
return content
end
function read_binary(filename)
local file, err = io.open(filename, "rb")
if file == nil then return nil, err end
local content = file:read"*a"
file:close()
return content
end
function write_unsafe(filename, new_content)
local file, err = io.open(filename, "w")
if file == nil then return false, err end
file:write(new_content)
file:close()
return true
end
write = minetest and minetest.safe_file_write or write_unsafe
function write_binary_unsafe(filename, new_content)
local file, err = io.open(filename, "wb")
if file == nil then return false, err end
file:write(new_content)
file:close()
return true
end
write_binary = minetest and minetest.safe_file_write or write_binary_unsafe
function ensure_content(filename, ensured_content)
local content = read(filename)
if content ~= ensured_content then
return write(filename, ensured_content)
end
return true
end
function append(filename, new_content)
local file, err = io.open(filename, "a")
if file == nil then return false, err end
file:write(new_content)
file:close()
return true
end
function exists(filename)
local file, err = io.open(filename, "r")
if file == nil then return false, err end
file:close()
return true
end
function create_if_not_exists(filename, content)
if not exists(filename) then
return write(filename, content or "")
end
return false
end
function create_if_not_exists_from_file(filename, src_filename) return create_if_not_exists(filename, read(src_filename)) end
if not minetest then return end
-- Process Bridge Helpers
process_bridges = {}
function process_bridge_build(name, input, output, logs)
if not input or not output or not logs then
minetest.mkdir(minetest.get_worldpath() .. "/bridges/" .. name)
end
input = input or minetest.get_worldpath() .. "/bridges/" .. name .. "/input.txt"
output = output or minetest.get_worldpath() .. "/bridges/" .. name .. "/output.txt"
logs = logs or minetest.get_worldpath() .. "/bridges/" .. name .. "/logs.txt"
-- Clear input
write(input, "")
-- Clear output
write(output, "")
-- Create logs if not exists
create_if_not_exists(logs, "")
process_bridges[name] = {
input = input,
output = output,
logs = logs,
output_file = io.open(output, "a")
}
end
function process_bridge_listen(name, line_consumer, step)
local bridge = process_bridges[name]
modlib.minetest.register_globalstep(step or 0.1, function()
local content = io.open(bridge.input, "r")
local line = content:read()
while line do
line_consumer(line)
line = content:read()
end
write(bridge.input, "")
end)
end
function process_bridge_serve(name, step)
local bridge = process_bridges[name]
modlib.minetest.register_globalstep(step or 0.1, function()
bridge.output_file:close()
process_bridges[name].output_file = io.open(bridge.output, "a")
end)
end
function process_bridge_write(name, message)
local bridge = process_bridges[name]
bridge.output_file:write(message .. "\n")
end
function process_bridge_start(name, command, os_execute)
local bridge = process_bridges[name]
os_execute(string.format(command, bridge.output, bridge.input, bridge.logs))
end
-- Export environment
return _ENV