From patchwork Sat Oct 25 03:25:49 2025 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Peter Kjellerstedt X-Patchwork-Id: 73014 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org Received: from aws-us-west-2-korg-lkml-1.web.codeaurora.org (localhost.localdomain [127.0.0.1]) by smtp.lore.kernel.org (Postfix) with ESMTP id 2B643CCD1BF for ; Sat, 25 Oct 2025 03:26:04 +0000 (UTC) Received: from DB3PR0202CU003.outbound.protection.outlook.com (DB3PR0202CU003.outbound.protection.outlook.com [52.101.84.32]) by mx.groups.io with SMTP id smtpd.web10.800.1761362763202441577 for ; Fri, 24 Oct 2025 20:26:03 -0700 Authentication-Results: mx.groups.io; dkim=fail reason="dkim: body hash did not verify" header.i=@axis.com header.s=selector1 header.b=itFSVXlf; spf=pass (domain: axis.com, ip: 52.101.84.32, mailfrom: peter.kjellerstedt@axis.com) ARC-Seal: i=1; a=rsa-sha256; s=arcselector10001; d=microsoft.com; cv=none; b=LZXvIFb1VeXldChEuSTkvAuiGYu9qfLrIM9cZhX2eFFm59ornCM7FClnacQflh90hSoXRHgOaEerybVPg7wkFjpOcVIhMD6QTtCf0gLEuJPXRJ0ssPITWGxbl/lbL6k++r1FH25ds+VeYexK0wMPXNBM73BT0blUvml/gUyGKXStd02Kab0HrKh+r1UJI+9wb1XfQq6FEurHnwuQ7uBky6y7bKrw0hxBGlg/2v4LtiuhCwH5/fEgwgLQqP4gcIfwk4+MFdwMcZ4DZ862CDl8VB/d2PWGMvxfmHW1q5DGLeRDe8StWc1W+UiavHW/pOfK+IwaWYpUHLZoFLSKLOwWZA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com; s=arcselector10001; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-AntiSpam-MessageData-ChunkCount:X-MS-Exchange-AntiSpam-MessageData-0:X-MS-Exchange-AntiSpam-MessageData-1; bh=w9vyxYvlIa16Ma4vjpGmiMXrS5fOJCJHPY+ytvR9Ta0=; b=BkX1ENnwfFCDhIEJUiZ5/Qf5x2TkNbEHHUmX2z7dST0rerO31N2TD+eyQhPX3UpdFRbQvN2y2NnrEhX6VQfcMA9Lrs/Sj0aBc3OHyYjfv5W1rSSgwAOM79pTC1XVkABPp5/BkdN5tQmr+R/KljXKHDvoX5l76bysC3APZzMnzaySAaA9cXiwpjFc5O9WFrVWs6OHrFwT8P385QUlsELZBxfSEYsZCu3rPu/XMxTz/9jegva3v3EttBLELIeiHm8+Jjbns13CYJzerpLzj76XzcCHN3rfMeFLqGT98f4ZULhpoo4e4KxspC1YafTHhZtNkSKtSErn/qH/n/CexrzNCw== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass (sender ip is 195.60.68.100) smtp.rcpttodomain=lists.openembedded.org smtp.mailfrom=axis.com; dmarc=pass (p=none sp=none pct=100) action=none header.from=axis.com; dkim=none (message not signed); arc=none (0) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=axis.com; s=selector1; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=w9vyxYvlIa16Ma4vjpGmiMXrS5fOJCJHPY+ytvR9Ta0=; b=itFSVXlfT8Nd9OIVg3UXHxhEYD4a1a+xicMNB3XqJuvUy2m3JAdz1QZrSYUSIUfTczuRbXxT07oYO0cG87KlqNI7MMgxfuQ92EtjA5booJF6iN6zMYZUoc1VB18maGKVT60nTws/K37TvuS5xbZvn1yhBm7k8UxdUr0g9dOXf0w= Received: from DU6P191CA0009.EURP191.PROD.OUTLOOK.COM (2603:10a6:10:540::9) by DBBPR02MB10556.eurprd02.prod.outlook.com (2603:10a6:10:53c::12) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.9253.15; Sat, 25 Oct 2025 03:25:58 +0000 Received: from DB1PEPF000509E6.eurprd03.prod.outlook.com (2603:10a6:10:540:cafe::71) by DU6P191CA0009.outlook.office365.com (2603:10a6:10:540::9) with Microsoft SMTP Server (version=TLS1_3, cipher=TLS_AES_256_GCM_SHA384) id 15.20.9253.15 via Frontend Transport; Sat, 25 Oct 2025 03:25:53 +0000 X-MS-Exchange-Authentication-Results: spf=pass (sender IP is 195.60.68.100) smtp.mailfrom=axis.com; dkim=none (message not signed) header.d=none;dmarc=pass action=none header.from=axis.com; Received-SPF: Pass (protection.outlook.com: domain of axis.com designates 195.60.68.100 as permitted sender) receiver=protection.outlook.com; client-ip=195.60.68.100; helo=mail.axis.com; pr=C Received: from mail.axis.com (195.60.68.100) by DB1PEPF000509E6.mail.protection.outlook.com (10.167.242.56) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.20.9253.7 via Frontend Transport; Sat, 25 Oct 2025 03:25:57 +0000 Received: from SE-MAILARCH01W.axis.com (10.20.40.15) by se-mail01w.axis.com (10.20.40.7) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.2507.61; Sat, 25 Oct 2025 05:25:55 +0200 Received: from se-mail02w.axis.com (10.20.40.8) by SE-MAILARCH01W.axis.com (10.20.40.15) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.2507.61; Sat, 25 Oct 2025 05:25:55 +0200 Received: from se-intmail01x.se.axis.com (10.4.0.28) by se-mail02w.axis.com (10.20.40.8) with Microsoft SMTP Server id 15.1.2507.61 via Frontend Transport; Sat, 25 Oct 2025 05:25:55 +0200 Received: from pc56063-2339.se.axis.com (pc56063-2339.se.axis.com [10.92.3.2]) by se-intmail01x.se.axis.com (Postfix) with ESMTP id 2E84E62D6 for ; Sat, 25 Oct 2025 05:25:55 +0200 (CEST) Received: by pc56063-2339.se.axis.com (Postfix, from userid 14323) id E260B1207A3; Sat, 25 Oct 2025 05:25:53 +0200 (CEST) From: Peter Kjellerstedt To: Subject: [PATCHv2 1/2] knotty: Some improvements to TerminalFilter.updateFooter() Date: Sat, 25 Oct 2025 05:25:49 +0200 Message-ID: <20251025032550.2730352-1-pkj@axis.com> X-Mailer: git-send-email 2.43.0 MIME-Version: 1.0 X-EOPAttributedMessage: 0 X-MS-PublicTrafficType: Email X-MS-TrafficTypeDiagnostic: DB1PEPF000509E6:EE_|DBBPR02MB10556:EE_ X-MS-Office365-Filtering-Correlation-Id: f69341f2-361d-4358-e85f-08de13763661 X-MS-Exchange-SenderADCheck: 1 X-MS-Exchange-AntiSpam-Relay: 0 X-Microsoft-Antispam: BCL:0;ARA:13230040|376014|82310400026|1800799024|36860700013; X-Microsoft-Antispam-Message-Info: DTD+zjEzkCek/2fCbTTY520CQHEyWmClzwbo5QetECl2dorr+Vyd8ID+Av+y9dKTH2fSvSBgb/8cGe8NjUvICP1Rmsil/NSC1omsMpo4yB4IeTqf3ayJa1cxSy5L4/7ZB54vA/eGGy1PTdDXpdWYBaSF6igW0hPtbZqY/6X4rf9vm016rt38HjujXg5pdDxHC3O0gPm6CSBTZsvTBYkFCcboBaWO7Kz+YKpq/vLBvhDGuxvUQYQbclGdAfTKcQj1IzWyDNYxK/qTApk5YEBc0qVkC/pIWF9oEQIBXUlQQMgsu97qXM02X6UrnF51FdsN4lshUyGuOkIx5JZR7YrrPMqyMYDsc/bzqMMTB+0O+atJPJ7S+7wtImAYtVYdzedVvuE9H/AgtUHeVZlBM76zcJt6aQV2Fz5MUhUumyMX6yVc4T2xy0F1D71SRbTBpzRpzQthYFSNBabvi9fBj3Yv0YXttp6qJXwD8I9n1DL2SEEkXKT+Ss4LBhf3yyzwrlhxHGjYCijezZXirHbx11vq5wEcKOgPRCg215XvXO74LlsjUATQcOV89F3KQ+TS3GH4HGTgM7oTCOPIirp8UTcdhjAfPMEYihVHAuQHDNGkE2P0agunn4US1OVo2sb7vdTWP6ya6NqGCuszWJLIlUrC2HcsoKyXB4IPN316JcyzR5nuWjBZqE/QDdssJid1AOPDiIILC9H5Y10R84agT9JLeFKP8Ny2Nmr7q/nNNgv1jZJITfW9OiSErs2a+Z3OZzyNRxjnK+lBHCq30ary2I6QYLpS9GN+kb5/i5ecAxi/K2qnNOml9eHs8KDxfriDmgzLtcvDNnZZTvSK0AnIJhSdk42R74JOMwIRV38nYF7FGmUdxMoorDfJ/2dWG6IQ2wiXk4you6TX54XjYoybJgTiFfjc3wKGPudiMvjU2ZHiS4gV82J2iiKUO5DKIqZB6ytY96/nuGOI6QUPbYr1kIkDsver6U5hvPXUhAQJZskxaorGoiMLc/cC99oOCan9RZlb0TCuEyinUn5NMXk7WFmMWNj3lyCvDkfeuUvjYCAE8ensu+FIx4tfCClwtsl1dH3RqY7PItEKlOi+k1ItmXKiUbIfg3CXKJu0dUdNNLQA7SAc3jp0k4dgAit7k/uWVFozv/Fdl1lvmdn0ssbeAwO/qkbApW9U2kFRVyTRPpj9Fu2SMOj4jdfm+qwTuVPkLzQgYZVSQLWPdNreWgj23lvxVSK1B6qae4FS+N8c/Z3g4SU91e6u2u+ZTq+pGFZxR1KISl9IKthNNKZGHoiyV1ohFk9nVw3X53Hkl3Uov8Fub9m0XtRQZKYwbRn9pV7gLYBGmOlDu/83egs22nBFkQIYHKK29F77Fh9LeGAaJxkxj0vuIiKP63irRECvqL5WN0L/5n/3swRFA0kwAXnquIw1BygteGrriVyFcbs8/qUs/vp6dOt+ljGAXS5o2UxJMt1XZQr07nwB6TC3hvX8VIoBkaxbnrA6ZPtbVgEQiDQ3NiJN1fBTPdcvFFSV9vvr2NoSfdqQfwx6U43QiXBchRR1yOUVihJ7YL/WpdeWnGzCrkU= X-Forefront-Antispam-Report: CIP:195.60.68.100;CTRY:SE;LANG:en;SCL:1;SRV:;IPV:NLI;SFV:NSPM;H:mail.axis.com;PTR:InfoDomainNonexistent;CAT:NONE;SFS:(13230040)(376014)(82310400026)(1800799024)(36860700013);DIR:OUT;SFP:1101; X-OriginatorOrg: axis.com X-MS-Exchange-CrossTenant-OriginalArrivalTime: 25 Oct 2025 03:25:57.2132 (UTC) X-MS-Exchange-CrossTenant-Network-Message-Id: f69341f2-361d-4358-e85f-08de13763661 X-MS-Exchange-CrossTenant-Id: 78703d3c-b907-432f-b066-88f7af9ca3af X-MS-Exchange-CrossTenant-OriginalAttributedTenantConnectingIp: TenantId=78703d3c-b907-432f-b066-88f7af9ca3af;Ip=[195.60.68.100];Helo=[mail.axis.com] X-MS-Exchange-CrossTenant-AuthSource: DB1PEPF000509E6.eurprd03.prod.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Anonymous X-MS-Exchange-CrossTenant-FromEntityHeader: HybridOnPrem X-MS-Exchange-Transport-CrossTenantHeadersStamped: DBBPR02MB10556 List-Id: X-Webhook-Received: from li982-79.members.linode.com [45.33.32.79] by aws-us-west-2-korg-lkml-1.web.codeaurora.org with HTTPS for ; Sat, 25 Oct 2025 03:26:04 -0000 X-Groupsio-URL: https://lists.openembedded.org/g/bitbake-devel/message/18215 * Correct/improve a couple of comments. * Iterate over the values (tasks) of activetasks rather than the keys (TIDs) as the TIDs were only used to lookup the tasks. Signed-off-by: Peter Kjellerstedt --- PATCHv2: No changes. bitbake/lib/bb/ui/knotty.py | 28 ++++++++++++++-------------- 1 file changed, 14 insertions(+), 14 deletions(-) diff --git a/bitbake/lib/bb/ui/knotty.py b/bitbake/lib/bb/ui/knotty.py index 00258c80ff..6f03bf2faa 100644 --- a/bitbake/lib/bb/ui/knotty.py +++ b/bitbake/lib/bb/ui/knotty.py @@ -260,16 +260,16 @@ class TerminalFilter(object): self.helper.needUpdate = True need_update = self.helper.needUpdate else: - # Do not let to update faster then _DEFAULT_PRINT_INTERVAL + # Do not update faster than _DEFAULT_PRINT_INTERVAL # to avoid heavy print() flooding. need_update = self.helper.needUpdate and (deltatime > self._DEFAULT_PRINT_INTERVAL) - if self.footer_present and (not need_update): - # Footer update is not need. + if self.footer_present and not need_update: + # Footer update is not needed. return - else: - # Footer update is need and store its "lasttime" value. - self.lasttime = currenttime + + # Remember the time when the footer was last updated. + self.lasttime = currenttime self.helper.needUpdate = False if (not self.helper.tasknumber_total or self.helper.tasknumber_current == self.helper.tasknumber_total) and not len(activetasks): @@ -281,16 +281,16 @@ class TerminalFilter(object): self._footer_buf.seek(0) tasks = [] - for t in activetasks.keys(): - start_time = activetasks[t].get("starttime", None) + for task in activetasks.values(): + start_time = task.get("starttime", None) if start_time: - msg = "%s - %s (pid %s)" % (activetasks[t]["title"], self.elapsed(currenttime - start_time), activetasks[t]["pid"]) + msg = "%s - %s (pid %s)" % (task["title"], self.elapsed(currenttime - start_time), task["pid"]) else: - msg = "%s (pid %s)" % (activetasks[t]["title"], activetasks[t]["pid"]) - progress = activetasks[t].get("progress", None) + msg = "%s (pid %s)" % (task["title"], task["pid"]) + progress = task.get("progress", None) if progress is not None: - pbar = activetasks[t].get("progressbar", None) - rate = activetasks[t].get("rate", None) + pbar = task.get("progressbar", None) + rate = task.get("rate", None) if not pbar or pbar.bouncing != (progress < 0): if progress < 0: pbar = BBProgress("0: %s" % msg, 100, widgets=[' ', progressbar.BouncingSlider(), ''], extrapos=3, resize_handler=self.sigwinch_handle) @@ -299,7 +299,7 @@ class TerminalFilter(object): pbar = BBProgress("0: %s" % msg, 100, widgets=[' ', progressbar.Percentage(), ' ', progressbar.Bar(), ''], extrapos=5, resize_handler=self.sigwinch_handle) pbar.bouncing = False pbar.fd = self._footer_buf - activetasks[t]["progressbar"] = pbar + task["progressbar"] = pbar tasks.append((pbar, msg, progress, rate, start_time)) else: tasks.append(msg) From patchwork Sat Oct 25 03:25:50 2025 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Peter Kjellerstedt X-Patchwork-Id: 73015 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org Received: from aws-us-west-2-korg-lkml-1.web.codeaurora.org (localhost.localdomain [127.0.0.1]) by smtp.lore.kernel.org (Postfix) with ESMTP id 2DAF2CCF9E0 for ; Sat, 25 Oct 2025 03:26:04 +0000 (UTC) Received: from OSPPR02CU001.outbound.protection.outlook.com (OSPPR02CU001.outbound.protection.outlook.com [40.107.159.40]) by mx.groups.io with SMTP id smtpd.web11.814.1761362762478113873 for ; Fri, 24 Oct 2025 20:26:03 -0700 Authentication-Results: mx.groups.io; dkim=fail reason="dkim: body hash did not verify" header.i=@axis.com header.s=selector1 header.b=WgOjT6p2; spf=pass (domain: axis.com, ip: 40.107.159.40, mailfrom: peter.kjellerstedt@axis.com) ARC-Seal: i=1; a=rsa-sha256; s=arcselector10001; d=microsoft.com; cv=none; b=jN/jSqsiGXcKTf6SFMd2dOftd9Kuec/i/aXvHgIDVyOSvDapqup/kuVJ51hUSmUauK4SdClNN4ExgeHVAfjG314ZoVRjJDCfU9f1FuNLkShYLgJ8ELDE/uUkH/aiYNfQ6faRVzDNN2YzaI886JMzMohJFrxY33C/p0WdoQ30FEwbZbh9GWvBwD2KPk+wGZbUmdLz3aWDuxH7ILoGJ+1ph5dc2ofBef73kwswymDUoTdIqoHUdMD9q2gwCuP95J1HG7H2xYT5qS3YLzxiCKJFfeB0JJ9OEDPsBuR+chltjMGkrDT6R18XQFGIjJzaf/80TVb9agvx27PIhJfR0S+bjA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com; s=arcselector10001; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-AntiSpam-MessageData-ChunkCount:X-MS-Exchange-AntiSpam-MessageData-0:X-MS-Exchange-AntiSpam-MessageData-1; bh=tzymOA3YtMljUz7DyC7Ut0Mlo8sb6XZKzd+0WOsSx0I=; b=Nudyx9samCScNd9+yP1zw7P9TKVtKWdERtQubnrWvJ9TyLpwd8S3r6tGeQv/GV/Mhf8r6o3HA0asELN/nh9D3B6Ah6FvaiQZx1OC3wPSEzE3U5Cu/4bjtUvVJybE3PjEhgG7S50sW5Jo9jD6tvFt6QCehgNIuo0wVLFpNWeugU9e6JB9h4yW7ySMIxMBaKgKPhKOH2PIUzf9810yM3fht1gk5z+nYNg/a28itw3ODGWqc41roE3sZjXKvBNR1VCAIur70XhAs5hKTWUUjWqHnNheS2qlWtn+W2ngei0aPahZfzskDyv7xNbwRcgnOlJ7UbW0fZUarYi8gvCjajw1HQ== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass (sender ip is 195.60.68.100) smtp.rcpttodomain=lists.openembedded.org smtp.mailfrom=axis.com; dmarc=pass (p=none sp=none pct=100) action=none header.from=axis.com; dkim=none (message not signed); arc=none (0) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=axis.com; s=selector1; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=tzymOA3YtMljUz7DyC7Ut0Mlo8sb6XZKzd+0WOsSx0I=; b=WgOjT6p2Kjaa9RBVQkeE8+q0cCiFnkmY6J1n+Lw7C7S1ksFK2KGTaFgxrUISNx9fjWg/BrPI3Ffhyly1An2NML1jnMdyoUjIJMvUOHkTKoilv+hJHPFVsri6E3tlAqUtfL0sly9/WEUQv5N+mdk9j37Zryw92vQ2XgXGFx7PLY8= Received: from DU6P191CA0019.EURP191.PROD.OUTLOOK.COM (2603:10a6:10:540::23) by DBAPR02MB6294.eurprd02.prod.outlook.com (2603:10a6:10:197::15) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.9253.15; Sat, 25 Oct 2025 03:25:57 +0000 Received: from DB1PEPF000509E6.eurprd03.prod.outlook.com (2603:10a6:10:540:cafe::8a) by DU6P191CA0019.outlook.office365.com (2603:10a6:10:540::23) with Microsoft SMTP Server (version=TLS1_3, cipher=TLS_AES_256_GCM_SHA384) id 15.20.9253.15 via Frontend Transport; Sat, 25 Oct 2025 03:25:56 +0000 X-MS-Exchange-Authentication-Results: spf=pass (sender IP is 195.60.68.100) smtp.mailfrom=axis.com; dkim=none (message not signed) header.d=none;dmarc=pass action=none header.from=axis.com; Received-SPF: Pass (protection.outlook.com: domain of axis.com designates 195.60.68.100 as permitted sender) receiver=protection.outlook.com; client-ip=195.60.68.100; helo=mail.axis.com; pr=C Received: from mail.axis.com (195.60.68.100) by DB1PEPF000509E6.mail.protection.outlook.com (10.167.242.56) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.20.9253.7 via Frontend Transport; Sat, 25 Oct 2025 03:25:55 +0000 Received: from SE-MAIL21W.axis.com (10.20.40.16) by se-mail01w.axis.com (10.20.40.7) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.2507.61; Sat, 25 Oct 2025 05:25:55 +0200 Received: from se-mail01w.axis.com (10.20.40.7) by SE-MAIL21W.axis.com (10.20.40.16) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.2507.61; Sat, 25 Oct 2025 05:25:55 +0200 Received: from se-intmail01x.se.axis.com (10.4.0.28) by se-mail01w.axis.com (10.20.40.7) with Microsoft SMTP Server id 15.1.2507.61 via Frontend Transport; Sat, 25 Oct 2025 05:25:55 +0200 Received: from pc56063-2339.se.axis.com (pc56063-2339.se.axis.com [10.92.3.2]) by se-intmail01x.se.axis.com (Postfix) with ESMTP id 307396318 for ; Sat, 25 Oct 2025 05:25:55 +0200 (CEST) Received: by pc56063-2339.se.axis.com (Postfix, from userid 14323) id E4F161200DD; Sat, 25 Oct 2025 05:25:53 +0200 (CEST) From: Peter Kjellerstedt To: Subject: [PATCHv2 2/2] knotty, teamcity, tinfoil: Only allow one process progress bar at once Date: Sat, 25 Oct 2025 05:25:50 +0200 Message-ID: <20251025032550.2730352-2-pkj@axis.com> X-Mailer: git-send-email 2.43.0 In-Reply-To: <20251025032550.2730352-1-pkj@axis.com> References: <20251025032550.2730352-1-pkj@axis.com> MIME-Version: 1.0 X-EOPAttributedMessage: 0 X-MS-PublicTrafficType: Email X-MS-TrafficTypeDiagnostic: DB1PEPF000509E6:EE_|DBAPR02MB6294:EE_ X-MS-Office365-Filtering-Correlation-Id: 0a59a26f-ef72-409c-d5df-08de13763579 X-MS-Exchange-SenderADCheck: 1 X-MS-Exchange-AntiSpam-Relay: 0 X-Microsoft-Antispam: BCL:0;ARA:13230040|1800799024|82310400026|36860700013|376014; X-Microsoft-Antispam-Message-Info: RacWUMqFT12CqJe3NCKdoQ5U6eDy2Kn6Nsn1H/4cjI1+n7nnTJok9jqDvxAr/49xo/5rDRwRdGj10FSZIizS7EVwoP8r4kLw27DuuCI+2akDU8zeG0AZn2Z1yjYfXQ8vJvlauWghO622wYCQcE3oSe9YX+R+BzYm2qufviuGbGEzTAUjfM0G+1eYoYdH/eN2NWJ4C8b7lULsIXwzkMKLNnzvufJvdnO38C9uh+lvAy1y9rKC0Vs5EVohe06oxR4/tOpxMyQ65s45P2adB8jpvh3SPopqG9Y3stOngxqQUqHTGQlNwPsRy9nsno4Yqz/IUh5d5U26IaAPCmrzt49E3BOyCB9zsDWdXLALRENFhnaKidXop6RzH9UPxat8m65Skdf6UJUVptbrXGvuxwrKCScOjZqabQkcN30WpfezJvmzjWRVjQ41/NsaDiuicYEekXk34ipwZB3IYU8ZNMHPQb/p6/9IRYuFy8Vswwh21FV84F2ipYPzsWBBrCUK7j9hYS8y8NsGPpS6apQlfItTgwaSPSAgNcTjAWYZ8t4HVwv35uK11I/sC87ZZAcyDbREaxbDp9keswuua3q030k5Vf4iMQZtR1CmmwNHJq7f2sjN/ZwF7C8JSXqNL6/XnpWb1AhdrzfBx6qEE1gqe8mjQRZKkOcXaVwXfPicqeODEZpSmM0C5C9Ki/9euLBFJzQzbzJ5gagtv8VwTb/4kyUEuwUh76hbrRl1Kj0/LsysRO8hP2S9p/sxi9hZ++LT9NiBeWd2yNgiKxlKErWaIwxoSz1v4UihGItsbYBIkKVL5KM8lqiKqelMTUgtb7kTa0cWsWsL2rwypRID8Pn3SOLHJcwbm95bLyjQNXmKFoQxzrODXySXBg6bc0S09r0M1KfTjWo1nOJJeF6YR2li1ra9oTG3U2zFgQ8/WRrbsAKFHgpioHjsG6905gHwPJ1CaxAidq4x75K+4wBHZxAjhW/2wXnzul35p0KbVde//PBzKz7l1k9039otYPcA20PIHU7Ipgg94CK6JRd0KBTQWpM9TyKL9ToOdbK7UZIaLeq/RpYOdRD3FaciUbIyQOaObomIzzH2gB3vwxMXpAMTuFESa9SuPSMMZkytlNJTWVqP/lnb+4lapjrAyK35Koq3JDmFqEhmmf2JwiG8YMjT+ZeK/KENQvRrQuR22NnFrzDDnj+L3wyRs2NJY5G+nLGfWXn7fJSYY+zC50s0Hnb8CGKnkuQjKUVXpLhmxHcIFOGxM2GkUxNCwbKwkE9Xdu6QOFUSMs3hWzu0seDUTxcec9LjlZhc81w+DqQr7MK5QHl9oFG25YAQVWiJXJcH/W63eJ62JhXGIy5YccaWJNfVt4h82T/1UQcYCGNFA2iAJzw2jD+83hfplmI1oU7zOQjHPrEpevdBFRAIav35PP4l9J7nLN+1vYJ3+ZWyTY7VpaJDh1xPouDAAgxQXXV0pZix2HGBvE+rNsBfTmv5wbcT9ARAuq3J2BxQ80VNfM3ls0VLLcRczE7TgneiCzo85M0CYkTu9DlKxnVwi7ZOPCtY3xs46kT/zaTdl4XxDqCmR1e7+Io= X-Forefront-Antispam-Report: CIP:195.60.68.100;CTRY:SE;LANG:en;SCL:1;SRV:;IPV:NLI;SFV:NSPM;H:mail.axis.com;PTR:InfoDomainNonexistent;CAT:NONE;SFS:(13230040)(1800799024)(82310400026)(36860700013)(376014);DIR:OUT;SFP:1101; X-OriginatorOrg: axis.com X-MS-Exchange-CrossTenant-OriginalArrivalTime: 25 Oct 2025 03:25:55.6915 (UTC) X-MS-Exchange-CrossTenant-Network-Message-Id: 0a59a26f-ef72-409c-d5df-08de13763579 X-MS-Exchange-CrossTenant-Id: 78703d3c-b907-432f-b066-88f7af9ca3af X-MS-Exchange-CrossTenant-OriginalAttributedTenantConnectingIp: TenantId=78703d3c-b907-432f-b066-88f7af9ca3af;Ip=[195.60.68.100];Helo=[mail.axis.com] X-MS-Exchange-CrossTenant-AuthSource: DB1PEPF000509E6.eurprd03.prod.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Anonymous X-MS-Exchange-CrossTenant-FromEntityHeader: HybridOnPrem X-MS-Exchange-Transport-CrossTenantHeadersStamped: DBAPR02MB6294 List-Id: X-Webhook-Received: from li982-79.members.linode.com [45.33.32.79] by aws-us-west-2-korg-lkml-1.web.codeaurora.org with HTTPS for ; Sat, 25 Oct 2025 03:26:04 -0000 X-Groupsio-URL: https://lists.openembedded.org/g/bitbake-devel/message/18214 In case a process progress bar (e.g., "Initialising tasks") is active when a new one (e.g., "Checking sstate mirror object availability") is started, then finish the first one before starting the second. Also ignore ProcessProgress and ProcessFinished events that are not for the currently active progress bar. This also adds an id to BBProgress (initialized to the initial msg), which is not affected by calls to setmessage(). Signed-off-by: Peter Kjellerstedt --- PATCHv2: Corrected a typo (parseprogress,finish -> parseprogress.finish) bitbake/lib/bb/tinfoil.py | 10 +++++----- bitbake/lib/bb/ui/knotty.py | 12 +++++++----- bitbake/lib/bb/ui/teamcity.py | 14 +++++++++++--- 3 files changed, 23 insertions(+), 13 deletions(-) diff --git a/bitbake/lib/bb/tinfoil.py b/bitbake/lib/bb/tinfoil.py index e7fbcbca0a..d9e985c612 100644 --- a/bitbake/lib/bb/tinfoil.py +++ b/bitbake/lib/bb/tinfoil.py @@ -91,23 +91,23 @@ def wait_for(f): if isinstance(event, bb.event.ProcessStarted): if self.quiet > 1: continue + if parseprogress: + parseprogress.finish() parseprogress = bb.ui.knotty.new_progress(event.processname, event.total) parseprogress.start(False) continue if isinstance(event, bb.event.ProcessProgress): if self.quiet > 1: continue - if parseprogress: + if parseprogress and parseprogress.id == event.processname: parseprogress.update(event.progress) - else: - bb.warn("Got ProcessProgress event for something that never started?") continue if isinstance(event, bb.event.ProcessFinished): if self.quiet > 1: continue - if parseprogress: + if parseprogress and parseprogress.id == event.processname: parseprogress.finish() - parseprogress = None + parseprogress = None continue if isinstance(event, bb.command.CommandCompleted): result = True diff --git a/bitbake/lib/bb/ui/knotty.py b/bitbake/lib/bb/ui/knotty.py index 6f03bf2faa..4bcf6bd12f 100644 --- a/bitbake/lib/bb/ui/knotty.py +++ b/bitbake/lib/bb/ui/knotty.py @@ -39,6 +39,7 @@ interactive = sys.stdout.isatty() class BBProgress(progressbar.ProgressBar): def __init__(self, msg, maxval, widgets=None, extrapos=-1, resize_handler=None): + self.id = msg self.msg = msg self.extrapos = extrapos if not widgets: @@ -84,6 +85,7 @@ class NonInteractiveProgress(object): fobj = sys.stdout def __init__(self, msg, maxval): + self.id = msg self.msg = msg self.maxval = maxval self.finished = False @@ -886,23 +888,23 @@ def main(server, eventHandler, params, tf = TerminalFilter): if params.options.quiet > 1: continue termfilter.clearFooter() + if parseprogress: + parseprogress.finish() parseprogress = new_progress(event.processname, event.total) parseprogress.start(False) continue if isinstance(event, bb.event.ProcessProgress): if params.options.quiet > 1: continue - if parseprogress: + if parseprogress and parseprogress.id == event.processname: parseprogress.update(event.progress) - else: - bb.warn("Got ProcessProgress event for someting that never started?") continue if isinstance(event, bb.event.ProcessFinished): if params.options.quiet > 1: continue - if parseprogress: + if parseprogress and parseprogress.id == event.processname: parseprogress.finish() - parseprogress = None + parseprogress = None continue # ignore diff --git a/bitbake/lib/bb/ui/teamcity.py b/bitbake/lib/bb/ui/teamcity.py index 7eeaab8d63..3177f4aaf4 100644 --- a/bitbake/lib/bb/ui/teamcity.py +++ b/bitbake/lib/bb/ui/teamcity.py @@ -200,6 +200,7 @@ def main(server, eventHandler, params): logger.error("XMLRPC Fault getting commandline: {0}".format(x)) return 1 + active_process = None active_process_total = None is_tasks_running = False @@ -300,16 +301,23 @@ def main(server, eventHandler, params): if isinstance(event, bb.event.ProcessStarted): if event.processname in ["Initialising tasks", "Checking sstate mirror object availability"]: + if active_process: + ui.progress(active_process, 100) + ui.block_end() + active_process = event.processname active_process_total = event.total ui.block_start(event.processname) if isinstance(event, bb.event.ProcessFinished): if event.processname in ["Initialising tasks", "Checking sstate mirror object availability"]: - ui.progress(event.processname, 100) - ui.block_end() + if active_process and active_process == event.processname: + ui.progress(event.processname, 100) + ui.block_end() + active_process = None if isinstance(event, bb.event.ProcessProgress): if event.processname in ["Initialising tasks", "Checking sstate mirror object availability"] and active_process_total != 0: - ui.progress(event.processname, event.progress * 100 / active_process_total) + if active_process and active_process == event.processname: + ui.progress(event.processname, event.progress * 100 / active_process_total) if isinstance(event, bb.event.CacheLoadStarted): ui.block_start("Loading cache") if isinstance(event, bb.event.CacheLoadProgress):