From c4b74e289abe0c5c62b64d4d8be16a1c89970435 Mon Sep 17 00:00:00 2001 From: Marko Lindqvist Date: Tue, 9 May 2023 18:59:51 +0300 Subject: [PATCH 9/9] Autoworkers: Fix assert failure because of recursive displacement Reported by alain_bkr See osdn #47992 Signed-off-by: Marko Lindqvist --- server/advisors/autosettlers.c | 14 ++++++++++---- 1 file changed, 10 insertions(+), 4 deletions(-) diff --git a/server/advisors/autosettlers.c b/server/advisors/autosettlers.c index 8df9aaf0d3..5d1fb7fad9 100644 --- a/server/advisors/autosettlers.c +++ b/server/advisors/autosettlers.c @@ -866,15 +866,21 @@ void auto_settler_findwork(struct player *pplayer, struct pf_path *path = NULL; struct city *taskcity; - /* time it will take worker to complete its given task */ + /* Time it will take worker to complete its given task */ int completion_time = 0; - if (recursion > unit_list_size(pplayer->units)) { - fc_assert(recursion <= unit_list_size(pplayer->units)); + /* Terminate what might be an inifite recursion of two units + * displacing each other, but leave enough space for + * finite recursion. */ + if (recursion > 5 + && recursion > unit_list_size(pplayer->units) * 1.5) { + log_normal("Workers displacing each other recursing too much."); + adv_unit_new_task(punit, AUT_NONE, NULL); set_unit_activity(punit, ACTIVITY_IDLE); send_unit_info(NULL, punit); - return; /* avoid further recursion. */ + + return; /* Avoid further recursion. */ } CHECK_UNIT(punit); -- 2.39.2