Skip to content

Latest commit

 

History

History
73 lines (55 loc) · 1.76 KB

api.md

File metadata and controls

73 lines (55 loc) · 1.76 KB

API

travelnet.get_travelnets(playername, create)

Returns the per-player travelnet data, for example:

-- auto-create a new entry if it not exists
local travelnets = travelnet.get_travelnets(playername, true)

-- return the exsiting data, nil if no entry found
local travelnets = travelnet.get_travelnets(playername)

travelnet.set_travelnets(playername, travelnets)

Sets and saves the updated travelnet data for the player NOTE: this function also perists changes

-- retrieve the player-data
local travelnets = travelnet.get_travelnets(playername)
-- add a station stub
travelnets["my_network"] = {}
-- save the modified data
travelnet.set_travelnets(playername, travelnets)

travelnet.register_travelnet_box

Lets you register your own travelnet boxes with a custom color, name and dye ingredient

Example for a pink travelnet:

travelnet.register_travelnet_box({
	nodename = "travelnet:travelnet_pink",
	color = "#FFC0CB",
	dye = "dye:pink"
})

fully custom nodes

Any node can be travelnet box if configured accordingly

Example to override mese to act as a travelnet:

minetest.override_item("default:mese", {
	groups = {
		travelnet = 1
	},

	after_place_node  = function(pos, placer, itemstack)
		local meta = minetest.get_meta(pos);
		travelnet.reset_formspec( meta );
		meta:set_string("owner", placer:get_player_name());
	end,

	on_receive_fields = travelnet.on_receive_fields,

	on_punch = function(pos, node, puncher)
		travelnet.update_formspec(pos, puncher:get_player_name(), nil)
	end,

	can_dig = function( pos, player )
		return travelnet.can_dig( pos, player, 'mese travelnet box' )
	end,

	after_dig_node = function(pos, oldnode, oldmetadata, digger)
		travelnet.remove_box( pos, oldnode, oldmetadata, digger )
	end,
})