forked from minetest-mods/nether
fix bugs
fixes nullreference in find_surface_target_y, and ensure_remote_portal_then_teleport assuming a traditional portal shape. minor documentation work.
This commit is contained in:
parent
c106b88e98
commit
6401052f92
4
init.lua
4
init.lua
@ -49,7 +49,7 @@ nether.register_portal("nether_portal", {
|
|||||||
frame_node_name = "default:obsidian",
|
frame_node_name = "default:obsidian",
|
||||||
wormhole_node_name = "nether:portal",
|
wormhole_node_name = "nether:portal",
|
||||||
wormhole_node_color = 0, -- 0 is magenta
|
wormhole_node_color = 0, -- 0 is magenta
|
||||||
-- Warning: "Four per Em" spaces have been used to align the diagram in this text, rather
|
-- Warning: "Four per Em" spaces have been used to align the diagram in this text, rather
|
||||||
-- than ASCII spaces. If Minetest changes font this may need to be updated.
|
-- than ASCII spaces. If Minetest changes font this may need to be updated.
|
||||||
book_of_portals_pagetext = S([[ ──══♦♦♦◊ The Nether ◊♦♦♦══──
|
book_of_portals_pagetext = S([[ ──══♦♦♦◊ The Nether ◊♦♦♦══──
|
||||||
|
|
||||||
@ -96,7 +96,7 @@ The expedition parties have found no diamonds or gold, and after an experienced
|
|||||||
find_surface_anchorPos = function(realm_anchorPos)
|
find_surface_anchorPos = function(realm_anchorPos)
|
||||||
-- A portal definition doesn't normally need to provide a find_surface_anchorPos() function,
|
-- A portal definition doesn't normally need to provide a find_surface_anchorPos() function,
|
||||||
-- since find_surface_target_y() will be used by default, but Nether portals also scale position
|
-- since find_surface_target_y() will be used by default, but Nether portals also scale position
|
||||||
-- to create fast-travel:
|
-- to create fast-travel. Defining a custom function also means we can look for existing nearby portals:
|
||||||
|
|
||||||
-- Multiply x and z by a factor of 8 to implement Nether fast-travel
|
-- Multiply x and z by a factor of 8 to implement Nether fast-travel
|
||||||
local destination_pos = vector.multiply(realm_anchorPos, nether.FASTTRAVEL_FACTOR)
|
local destination_pos = vector.multiply(realm_anchorPos, nether.FASTTRAVEL_FACTOR)
|
||||||
|
@ -559,7 +559,7 @@ end
|
|||||||
-- this is to enforce that portals only link together in mutual pairs. It would be better for gameplay if I didn't apply
|
-- this is to enforce that portals only link together in mutual pairs. It would be better for gameplay if I didn't apply
|
||||||
-- that restriction, but it would require maintaining an accurate list of every portal that links to a portal so they
|
-- that restriction, but it would require maintaining an accurate list of every portal that links to a portal so they
|
||||||
-- could all be updated if the portal is destroyed. To keep the code simple I'm going to limit portals to only being
|
-- could all be updated if the portal is destroyed. To keep the code simple I'm going to limit portals to only being
|
||||||
-- the destination of a single lit portal at a time.
|
-- the destination of one lit portal at a time.
|
||||||
-- * suggested_anchorPos indicates where the portal should be built
|
-- * suggested_anchorPos indicates where the portal should be built
|
||||||
-- * destination_wormholePos is the wormholePos of the destination portal this one will be linked to.
|
-- * destination_wormholePos is the wormholePos of the destination portal this one will be linked to.
|
||||||
-- * suggested_orientation is the suggested schematic rotation: 0, 90, 180, 270 (0 meaning a portal that faces north/south - i.e. obsidian running east/west)
|
-- * suggested_orientation is the suggested schematic rotation: 0, 90, 180, 270 (0 meaning a portal that faces north/south - i.e. obsidian running east/west)
|
||||||
@ -575,7 +575,7 @@ local function locate_or_build_portal(portal_definition, suggested_anchorPos, su
|
|||||||
|
|
||||||
-- Searching for an existing portal at wormholePos seems better than at anchorPos, though isn't important
|
-- Searching for an existing portal at wormholePos seems better than at anchorPos, though isn't important
|
||||||
local suggested_wormholePos = portal_definition.shape.get_wormholePos_from_anchorPos(suggested_anchorPos, suggested_orientation)
|
local suggested_wormholePos = portal_definition.shape.get_wormholePos_from_anchorPos(suggested_anchorPos, suggested_orientation)
|
||||||
local found_anchorPos, found_orientation, is_ignited = is_portal_frame(portal_definition, suggested_wormholePos)
|
local found_anchorPos, found_orientation, is_ignited = is_portal_frame(portal_definition, suggested_wormholePos) -- can be optimized - check for portal at suggested_anchorPos first
|
||||||
|
|
||||||
if found_anchorPos ~= nil then
|
if found_anchorPos ~= nil then
|
||||||
-- A portal is already here, we don't have to build one, though we may need to ignite it
|
-- A portal is already here, we don't have to build one, though we may need to ignite it
|
||||||
@ -686,7 +686,7 @@ function nether.find_surface_target_y(target_x, target_z, portal_name)
|
|||||||
if groundNode == nil then
|
if groundNode == nil then
|
||||||
-- force the area to be loaded - it's going to be loaded anyway by volume_is_natural()
|
-- force the area to be loaded - it's going to be loaded anyway by volume_is_natural()
|
||||||
minetest.get_voxel_manip():read_from_map(shouldBeGroundPos, shouldBeGroundPos)
|
minetest.get_voxel_manip():read_from_map(shouldBeGroundPos, shouldBeGroundPos)
|
||||||
local groundNode = minetest.get_node(shouldBeGroundPos)
|
groundNode = minetest.get_node(shouldBeGroundPos)
|
||||||
end
|
end
|
||||||
if not groundNode.is_ground_content then
|
if not groundNode.is_ground_content then
|
||||||
surface_level = surface_level - 1
|
surface_level = surface_level - 1
|
||||||
@ -836,9 +836,10 @@ local function ensure_remote_portal_then_teleport(player, portal_definition, loc
|
|||||||
return -- the player has moved out of the portal
|
return -- the player has moved out of the portal
|
||||||
end
|
end
|
||||||
|
|
||||||
-- debounce - check player is still standing in the same portal that called this function
|
-- debounce - check player is still standing in the *same* portal that called this function
|
||||||
local meta = minetest.get_meta(playerPos)
|
local meta = minetest.get_meta(playerPos)
|
||||||
if not vector.equals(local_anchorPos, minetest.string_to_pos(meta:get_string("p1"))) then
|
local local_p1, local_p2 = portal_definition.shape:get_p1_and_p2_from_anchorPos(local_anchorPos, local_orientation)
|
||||||
|
if not vector.equals(local_p1, minetest.string_to_pos(meta:get_string("p1"))) then
|
||||||
if DEBUG then minetest.chat_send_all("the player already teleported from " .. minetest.pos_to_string(local_anchorPos) .. ", and is now standing in a different portal - " .. meta:get_string("p1")) end
|
if DEBUG then minetest.chat_send_all("the player already teleported from " .. minetest.pos_to_string(local_anchorPos) .. ", and is now standing in a different portal - " .. meta:get_string("p1")) end
|
||||||
return -- the player already teleported, and is now standing in a different portal
|
return -- the player already teleported, and is now standing in a different portal
|
||||||
end
|
end
|
||||||
@ -865,7 +866,7 @@ local function ensure_remote_portal_then_teleport(player, portal_definition, loc
|
|||||||
player:setpos(vector.add(destination_wormholePos, rotated_offset))
|
player:setpos(vector.add(destination_wormholePos, rotated_offset))
|
||||||
player:set_look_horizontal(player:get_look_horizontal() + rotation_angle)
|
player:set_look_horizontal(player:get_look_horizontal() + rotation_angle)
|
||||||
else
|
else
|
||||||
-- destination portal still needs to be built
|
-- destination portal either needs to be built or ignited
|
||||||
if DEBUG then minetest.chat_send_all("ensure_remote_portal_then_teleport() saw " .. dest_wormhole_node.name .. " at " .. minetest.pos_to_string(destination_wormholePos) .. " rather than a wormhole. Calling locate_or_build_portal()") end
|
if DEBUG then minetest.chat_send_all("ensure_remote_portal_then_teleport() saw " .. dest_wormhole_node.name .. " at " .. minetest.pos_to_string(destination_wormholePos) .. " rather than a wormhole. Calling locate_or_build_portal()") end
|
||||||
|
|
||||||
local new_dest_anchorPos, new_dest_orientation = locate_or_build_portal(portal_definition, destination_anchorPos, local_orientation, local_wormholePos)
|
local new_dest_anchorPos, new_dest_orientation = locate_or_build_portal(portal_definition, destination_anchorPos, local_orientation, local_wormholePos)
|
||||||
@ -925,8 +926,8 @@ function run_wormhole(pos, time_elapsed)
|
|||||||
if destination_wormholePos ~= nil and local_p1 ~= nil then
|
if destination_wormholePos ~= nil and local_p1 ~= nil then
|
||||||
|
|
||||||
-- force emerge of target area
|
-- force emerge of target area
|
||||||
minetest.get_voxel_manip():read_from_map(destination_wormholePos, destination_wormholePos)
|
minetest.get_voxel_manip():read_from_map(destination_wormholePos, destination_wormholePos) -- force load
|
||||||
if not minetest.get_node_or_nil(destination_wormholePos) then
|
if minetest.get_node_or_nil(destination_wormholePos) == nil then
|
||||||
minetest.emerge_area(vector.subtract(destination_wormholePos, 4), vector.add(destination_wormholePos, 4))
|
minetest.emerge_area(vector.subtract(destination_wormholePos, 4), vector.add(destination_wormholePos, 4))
|
||||||
end
|
end
|
||||||
|
|
||||||
@ -1070,7 +1071,7 @@ function register_frame_node(frame_node_name)
|
|||||||
ignite_portal(pos, node.name)
|
ignite_portal(pos, node.name)
|
||||||
end,
|
end,
|
||||||
action_off = function (pos, node)
|
action_off = function (pos, node)
|
||||||
extinguish_portal(pos, node.name)
|
extinguish_portal(pos, node.name, false)
|
||||||
end
|
end
|
||||||
}}
|
}}
|
||||||
extended_node_def.replaced_by_portalapi.on_destruct = extended_node_def.on_destruct
|
extended_node_def.replaced_by_portalapi.on_destruct = extended_node_def.on_destruct
|
||||||
@ -1187,6 +1188,7 @@ minetest.register_on_mods_loaded(function()
|
|||||||
end
|
end
|
||||||
|
|
||||||
-- todo: add to Treasurer mod TRMP https://github.com/poikilos/trmp_minetest_game
|
-- todo: add to Treasurer mod TRMP https://github.com/poikilos/trmp_minetest_game
|
||||||
|
-- todo: add to help modpack https://forum.minetest.net/viewtopic.php?t=15912
|
||||||
end
|
end
|
||||||
end)
|
end)
|
||||||
|
|
||||||
@ -1195,6 +1197,7 @@ end)
|
|||||||
-- ==================== --
|
-- ==================== --
|
||||||
|
|
||||||
|
|
||||||
|
-- The fallback defaults for registered portaldef tables
|
||||||
local portaldef_default = {
|
local portaldef_default = {
|
||||||
shape = PortalShape_Traditional,
|
shape = PortalShape_Traditional,
|
||||||
wormhole_node_name = "nether:portal",
|
wormhole_node_name = "nether:portal",
|
||||||
@ -1208,7 +1211,6 @@ local portaldef_default = {
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
function nether.register_portal(name, portaldef)
|
function nether.register_portal(name, portaldef)
|
||||||
|
|
||||||
assert(name ~= nil, "Unable to register portal: Name is nil")
|
assert(name ~= nil, "Unable to register portal: Name is nil")
|
||||||
@ -1313,6 +1315,8 @@ function nether.find_nearest_working_portal(portal_name, anchorPos, distance_lim
|
|||||||
local portal_info = contenders[dist]
|
local portal_info = contenders[dist]
|
||||||
if DEBUG then minetest.chat_send_all("checking portal from mod_storage at " .. minetest.pos_to_string(portal_info.anchorPos) .. " orientation " .. portal_info.orientation) end
|
if DEBUG then minetest.chat_send_all("checking portal from mod_storage at " .. minetest.pos_to_string(portal_info.anchorPos) .. " orientation " .. portal_info.orientation) end
|
||||||
|
|
||||||
|
-- the mod_storage list of portals is unreliable - e.g. it won't know if inactive portals have been
|
||||||
|
-- destroyed, so check the portal is still there
|
||||||
local portalFound, portalActive = is_portal_at_anchorPos(portal_definition, portal_info.anchorPos, portal_info.orientation, true)
|
local portalFound, portalActive = is_portal_at_anchorPos(portal_definition, portal_info.anchorPos, portal_info.orientation, true)
|
||||||
|
|
||||||
if portalFound then
|
if portalFound then
|
||||||
|
@ -14,7 +14,8 @@ Helper functions
|
|||||||
player builds. It checks the area for any nodes that aren't ground or
|
player builds. It checks the area for any nodes that aren't ground or
|
||||||
trees.
|
trees.
|
||||||
|
|
||||||
* `nether.find_surface_target_y(target_x, target_z, portal_name)`: returns a suitable anchorPos
|
* `nether.find_surface_target_y(target_x, target_z, portal_name)`: returns a
|
||||||
|
suitable anchorPos
|
||||||
* Can be used to implement custom find_surface_anchorPos() functions
|
* Can be used to implement custom find_surface_anchorPos() functions
|
||||||
* portal_name is optional, and providing it allows existing portals on the
|
* portal_name is optional, and providing it allows existing portals on the
|
||||||
surface to be reused.
|
surface to be reused.
|
||||||
@ -22,10 +23,11 @@ Helper functions
|
|||||||
* `nether.find_nearest_working_portal(portal_name, anchorPos, distance_limit, y_factor)`: returns
|
* `nether.find_nearest_working_portal(portal_name, anchorPos, distance_limit, y_factor)`: returns
|
||||||
an anchorPos, or nil if no portal was found within the the distance_limit.
|
an anchorPos, or nil if no portal was found within the the distance_limit.
|
||||||
* A y_factor of 0 means y does not affect the distance_limit, a y_factor
|
* A y_factor of 0 means y does not affect the distance_limit, a y_factor
|
||||||
of 1 means y is included, and a y_factor of 2 would squash the
|
of 1 means y is included (the default if y_factor is nil), and a y_factor
|
||||||
search-sphere by a factor of 2 on the y-axis, etc.
|
of 2 would squash the search-sphere by a factor of 2 on the y-axis, etc.
|
||||||
* Only portals in the same realm as the anchorPos will be returned, even if y_factor is 0.
|
* Only portals in the same realm as the anchorPos will be returned, even if
|
||||||
* Pass a nil or negative distance_limit to indicate no distance limit
|
y_factor is 0.
|
||||||
|
* Pass a nil (or negative) distance_limit to indicate no distance limit
|
||||||
|
|
||||||
|
|
||||||
API functions
|
API functions
|
||||||
@ -80,13 +82,19 @@ Used by `nether.register_portal`.
|
|||||||
-- Required. Return true if a portal at pos is in the realm, rather
|
-- Required. Return true if a portal at pos is in the realm, rather
|
||||||
than the surface world.
|
than the surface world.
|
||||||
|
|
||||||
find_realm_anchorPos = function(surface_anchorPos)
|
find_realm_anchorPos = function(surface_anchorPos),
|
||||||
-- Required. Return a position in the realm that a portal created at
|
-- Required. Return a position in the realm that a portal created at
|
||||||
-- surface_anchorPos will link to.
|
-- surface_anchorPos will link to.
|
||||||
|
-- Return an anchorPos or anchorPos, orientation
|
||||||
|
-- If orientation is not specified then the orientation of the surface
|
||||||
|
-- portal will be used.
|
||||||
|
|
||||||
find_surface_anchorPos = function(realm_anchorPos),
|
find_surface_anchorPos = function(realm_anchorPos),
|
||||||
-- Optional. If you don't use this then a position near the surface
|
-- Optional. If you don't use this then a position near the surface
|
||||||
-- will be picked.
|
-- will be picked.
|
||||||
|
-- Return an anchorPos or anchorPos, orientation
|
||||||
|
-- If orientation is not specified then the orientation of the realm
|
||||||
|
-- portal will be used.
|
||||||
|
|
||||||
on_run_wormhole,
|
on_run_wormhole,
|
||||||
on_ignite,
|
on_ignite,
|
||||||
|
Loading…
Reference in New Issue
Block a user