Merge pull request #2719 from Elv13/make_next_to_pos_optional
placement: Handle when the preferred position choice isn't set.
This commit is contained in:
commit
05b4735911
|
@ -1484,7 +1484,11 @@ function placement.next_to(d, args)
|
||||||
|
|
||||||
does_fit[pos.name] = fit and {geo, dir} or nil
|
does_fit[pos.name] = fit and {geo, dir} or nil
|
||||||
|
|
||||||
if fit and preferred_positions[pos.name] and preferred_positions[pos.name] < pref_idx then
|
-- preferred_positions is optional
|
||||||
|
local better_pos_idx = preferred_positions[pos.name]
|
||||||
|
and preferred_positions[pos.name] < pref_idx or false
|
||||||
|
|
||||||
|
if fit and (better_pos_idx or not pref_name) then
|
||||||
pref_idx = preferred_positions[pos.name]
|
pref_idx = preferred_positions[pos.name]
|
||||||
pref_name = pos.name
|
pref_name = pos.name
|
||||||
end
|
end
|
||||||
|
@ -1493,7 +1497,11 @@ function placement.next_to(d, args)
|
||||||
if fit then break end
|
if fit then break end
|
||||||
end
|
end
|
||||||
|
|
||||||
local ngeo, dir = unpack(does_fit[pref_name] or {}) --FIXME why does this happen
|
if not pref_name then return end
|
||||||
|
|
||||||
|
assert(does_fit[pref_name])
|
||||||
|
|
||||||
|
local ngeo, dir = unpack(does_fit[pref_name])
|
||||||
|
|
||||||
-- The requested placement isn't possible due to the lack of space, better
|
-- The requested placement isn't possible due to the lack of space, better
|
||||||
-- do nothing an try random things
|
-- do nothing an try random things
|
||||||
|
|
Loading…
Reference in New Issue