2017-01-28 18:31:23 +01:00
|
|
|
local modname = core.get_current_modname() or "??"
|
2017-03-16 07:53:39 +01:00
|
|
|
local modstorage = core.get_mod_storage()
|
2017-09-26 00:11:20 +02:00
|
|
|
local mod_channel
|
2017-01-28 18:31:23 +01:00
|
|
|
|
2017-06-30 20:14:39 +02:00
|
|
|
dofile("preview:example.lua")
|
2017-01-22 00:20:55 +01:00
|
|
|
-- This is an example function to ensure it's working properly, should be removed before merge
|
|
|
|
core.register_on_shutdown(function()
|
2017-01-22 11:17:41 +01:00
|
|
|
print("[PREVIEW] shutdown client")
|
2017-01-22 00:20:55 +01:00
|
|
|
end)
|
|
|
|
|
2017-04-08 08:20:30 +02:00
|
|
|
core.register_on_connect(function()
|
|
|
|
print("[PREVIEW] Player connection completed")
|
2017-04-19 15:16:54 +02:00
|
|
|
local server_info = core.get_server_info()
|
|
|
|
print("Server version: " .. server_info.protocol_version)
|
|
|
|
print("Server ip: " .. server_info.ip)
|
|
|
|
print("Server address: " .. server_info.address)
|
|
|
|
print("Server port: " .. server_info.port)
|
2017-09-26 00:11:20 +02:00
|
|
|
|
|
|
|
mod_channel = core.mod_channel_join("experimental_preview")
|
|
|
|
end)
|
|
|
|
|
|
|
|
core.register_on_modchannel_message(function(channel, sender, message)
|
|
|
|
print("[PREVIEW][modchannels] Received message `" .. message .. "` on channel `"
|
|
|
|
.. channel .. "` from sender `" .. sender .. "`")
|
|
|
|
core.after(1, function()
|
|
|
|
mod_channel:send_all("CSM preview received " .. message)
|
|
|
|
end)
|
|
|
|
end)
|
|
|
|
|
|
|
|
core.register_on_modchannel_signal(function(channel, signal)
|
|
|
|
print("[PREVIEW][modchannels] Received signal id `" .. signal .. "` on channel `"
|
|
|
|
.. channel)
|
2017-04-08 08:20:30 +02:00
|
|
|
end)
|
|
|
|
|
2017-04-29 12:08:16 +02:00
|
|
|
core.register_on_placenode(function(pointed_thing, node)
|
|
|
|
print("The local player place a node!")
|
|
|
|
print("pointed_thing :" .. dump(pointed_thing))
|
|
|
|
print("node placed :" .. dump(node))
|
|
|
|
return false
|
|
|
|
end)
|
|
|
|
|
2017-05-06 21:12:44 +02:00
|
|
|
core.register_on_item_use(function(itemstack, pointed_thing)
|
|
|
|
print("The local player used an item!")
|
|
|
|
print("pointed_thing :" .. dump(pointed_thing))
|
|
|
|
print("item = " .. itemstack:get_name())
|
|
|
|
return false
|
|
|
|
end)
|
|
|
|
|
2017-01-22 00:20:55 +01:00
|
|
|
-- This is an example function to ensure it's working properly, should be removed before merge
|
2017-06-09 15:48:04 +02:00
|
|
|
core.register_on_receiving_chat_message(function(message)
|
2017-01-22 00:20:55 +01:00
|
|
|
print("[PREVIEW] Received message " .. message)
|
|
|
|
return false
|
|
|
|
end)
|
|
|
|
|
|
|
|
-- This is an example function to ensure it's working properly, should be removed before merge
|
2017-06-09 15:48:04 +02:00
|
|
|
core.register_on_sending_chat_message(function(message)
|
2017-01-22 00:20:55 +01:00
|
|
|
print("[PREVIEW] Sending message " .. message)
|
|
|
|
return false
|
|
|
|
end)
|
|
|
|
|
2017-01-22 11:17:41 +01:00
|
|
|
-- This is an example function to ensure it's working properly, should be removed before merge
|
2017-01-22 00:20:55 +01:00
|
|
|
core.register_on_hp_modification(function(hp)
|
|
|
|
print("[PREVIEW] HP modified " .. hp)
|
|
|
|
end)
|
|
|
|
|
2017-01-22 11:17:41 +01:00
|
|
|
-- This is an example function to ensure it's working properly, should be removed before merge
|
2017-01-22 00:20:55 +01:00
|
|
|
core.register_on_damage_taken(function(hp)
|
|
|
|
print("[PREVIEW] Damage taken " .. hp)
|
|
|
|
end)
|
2017-01-22 09:05:09 +01:00
|
|
|
|
2017-01-22 11:17:41 +01:00
|
|
|
-- This is an example function to ensure it's working properly, should be removed before merge
|
|
|
|
core.register_globalstep(function(dtime)
|
|
|
|
-- print("[PREVIEW] globalstep " .. dtime)
|
|
|
|
end)
|
|
|
|
|
2017-01-22 09:05:09 +01:00
|
|
|
-- This is an example function to ensure it's working properly, should be removed before merge
|
|
|
|
core.register_chatcommand("dump", {
|
2017-01-24 17:26:15 +01:00
|
|
|
func = function(param)
|
2017-01-22 09:05:09 +01:00
|
|
|
return true, dump(_G)
|
|
|
|
end,
|
2017-01-22 11:17:41 +01:00
|
|
|
})
|
|
|
|
|
2017-03-17 19:20:13 +01:00
|
|
|
core.register_chatcommand("colorize_test", {
|
|
|
|
func = function(param)
|
|
|
|
return true, core.colorize("red", param)
|
|
|
|
end,
|
|
|
|
})
|
|
|
|
|
2017-01-30 20:10:37 +01:00
|
|
|
core.register_chatcommand("test_node", {
|
|
|
|
func = function(param)
|
|
|
|
core.display_chat_message(dump(core.get_node({x=0, y=0, z=0})))
|
|
|
|
core.display_chat_message(dump(core.get_node_or_nil({x=0, y=0, z=0})))
|
|
|
|
end,
|
|
|
|
})
|
|
|
|
|
2017-03-16 10:34:54 +01:00
|
|
|
local function preview_minimap()
|
|
|
|
local minimap = core.ui.minimap
|
2017-05-20 10:12:37 +02:00
|
|
|
if not minimap then
|
|
|
|
print("[PREVIEW] Minimap is disabled. Skipping.")
|
|
|
|
return
|
|
|
|
end
|
2017-03-16 10:34:54 +01:00
|
|
|
minimap:set_mode(4)
|
2017-03-17 07:54:49 +01:00
|
|
|
minimap:show()
|
2017-03-16 10:34:54 +01:00
|
|
|
minimap:set_pos({x=5, y=50, z=5})
|
2017-04-14 09:04:41 +02:00
|
|
|
minimap:set_shape(math.random(0, 1))
|
2017-03-16 10:34:54 +01:00
|
|
|
|
|
|
|
print("[PREVIEW] Minimap: mode => " .. dump(minimap:get_mode()) ..
|
|
|
|
" position => " .. dump(minimap:get_pos()) ..
|
|
|
|
" angle => " .. dump(minimap:get_angle()))
|
|
|
|
end
|
2017-01-30 20:10:37 +01:00
|
|
|
|
2017-01-22 11:17:41 +01:00
|
|
|
core.after(2, function()
|
2017-01-28 18:31:23 +01:00
|
|
|
print("[PREVIEW] loaded " .. modname .. " mod")
|
2017-03-16 07:53:39 +01:00
|
|
|
modstorage:set_string("current_mod", modname)
|
|
|
|
print(modstorage:get_string("current_mod"))
|
2017-03-17 07:54:49 +01:00
|
|
|
preview_minimap()
|
|
|
|
end)
|
|
|
|
|
2017-09-26 00:11:20 +02:00
|
|
|
core.after(4, function()
|
|
|
|
if mod_channel:is_writeable() then
|
|
|
|
mod_channel:send_all("preview talk to experimental")
|
|
|
|
end
|
|
|
|
end)
|
|
|
|
|
2017-03-17 07:54:49 +01:00
|
|
|
core.after(5, function()
|
2017-05-20 10:12:37 +02:00
|
|
|
if core.ui.minimap then
|
|
|
|
core.ui.minimap:show()
|
|
|
|
end
|
2017-03-17 07:48:29 +01:00
|
|
|
|
|
|
|
print("[PREVIEW] Day count: " .. core.get_day_count() ..
|
|
|
|
" time of day " .. core.get_timeofday())
|
|
|
|
|
|
|
|
print("[PREVIEW] Node level: " .. core.get_node_level({x=0, y=20, z=0}) ..
|
|
|
|
" max level " .. core.get_node_max_level({x=0, y=20, z=0}))
|
|
|
|
|
|
|
|
print("[PREVIEW] Find node near: " .. dump(core.find_node_near({x=0, y=20, z=0}, 10,
|
|
|
|
{"group:tree", "default:dirt", "default:stone"})))
|
2017-01-22 11:17:41 +01:00
|
|
|
end)
|
2017-01-29 18:43:44 +01:00
|
|
|
|
|
|
|
core.register_on_dignode(function(pos, node)
|
2017-01-29 19:28:38 +01:00
|
|
|
print("The local player dug a node!")
|
|
|
|
print("pos:" .. dump(pos))
|
|
|
|
print("node:" .. dump(node))
|
|
|
|
return false
|
|
|
|
end)
|
|
|
|
|
|
|
|
core.register_on_punchnode(function(pos, node)
|
|
|
|
print("The local player punched a node!")
|
2017-01-31 14:18:52 +01:00
|
|
|
local itemstack = core.get_wielded_item()
|
|
|
|
--[[
|
|
|
|
-- getters
|
|
|
|
print(dump(itemstack:is_empty()))
|
|
|
|
print(dump(itemstack:get_name()))
|
|
|
|
print(dump(itemstack:get_count()))
|
|
|
|
print(dump(itemstack:get_wear()))
|
|
|
|
print(dump(itemstack:get_meta()))
|
2017-03-22 21:13:03 +01:00
|
|
|
print(dump(itemstack:get_metadata()
|
2017-01-31 14:18:52 +01:00
|
|
|
print(dump(itemstack:is_known()))
|
|
|
|
--print(dump(itemstack:get_definition()))
|
|
|
|
print(dump(itemstack:get_tool_capabilities()))
|
|
|
|
print(dump(itemstack:to_string()))
|
|
|
|
print(dump(itemstack:to_table()))
|
|
|
|
-- setters
|
|
|
|
print(dump(itemstack:set_name("default:dirt")))
|
|
|
|
print(dump(itemstack:set_count("95")))
|
|
|
|
print(dump(itemstack:set_wear(934)))
|
|
|
|
print(dump(itemstack:get_meta()))
|
|
|
|
print(dump(itemstack:get_metadata()))
|
|
|
|
--]]
|
|
|
|
print(dump(itemstack:to_table()))
|
2017-01-29 18:43:44 +01:00
|
|
|
print("pos:" .. dump(pos))
|
|
|
|
print("node:" .. dump(node))
|
|
|
|
return false
|
2017-01-30 20:10:37 +01:00
|
|
|
end)
|
2017-03-22 21:13:03 +01:00
|
|
|
|
2017-06-07 09:09:06 +02:00
|
|
|
core.register_chatcommand("privs", {
|
|
|
|
func = function(param)
|
|
|
|
return true, core.privs_to_string(minetest.get_privilege_list())
|
|
|
|
end,
|
|
|
|
})
|