{"id":22870,"url":"https://patchwork.libcamera.org/api/1.1/covers/22870/?format=json","web_url":"https://patchwork.libcamera.org/cover/22870/","project":{"id":1,"url":"https://patchwork.libcamera.org/api/1.1/projects/1/?format=json","name":"libcamera","link_name":"libcamera","list_id":"libcamera_core","list_email":"libcamera-devel@lists.libcamera.org","web_url":"","scm_url":"","webscm_url":""},"msgid":"<20250225173531.2595922-1-pobrn@protonmail.com>","date":"2025-02-25T17:35:34","name":"[v4,0/8] libcamera: base: log: Misc. changes","submitter":{"id":133,"url":"https://patchwork.libcamera.org/api/1.1/people/133/?format=json","name":"Pőcze Barnabás","email":"pobrn@protonmail.com"},"mbox":"https://patchwork.libcamera.org/cover/22870/mbox/","series":[{"id":5022,"url":"https://patchwork.libcamera.org/api/1.1/series/5022/?format=json","web_url":"https://patchwork.libcamera.org/project/libcamera/list/?series=5022","date":"2025-02-25T17:35:34","name":"libcamera: base: log: Misc. changes","version":4,"mbox":"https://patchwork.libcamera.org/series/5022/mbox/"}],"comments":"https://patchwork.libcamera.org/api/covers/22870/comments/","headers":{"Return-Path":"<libcamera-devel-bounces@lists.libcamera.org>","X-Original-To":"parsemail@patchwork.libcamera.org","Delivered-To":"parsemail@patchwork.libcamera.org","Received":["from lancelot.ideasonboard.com (lancelot.ideasonboard.com\n\t[92.243.16.209])\n\tby patchwork.libcamera.org (Postfix) with ESMTPS id 6126FBF415\n\tfor <parsemail@patchwork.libcamera.org>;\n\tTue, 25 Feb 2025 17:35:41 +0000 (UTC)","from lancelot.ideasonboard.com (localhost [IPv6:::1])\n\tby lancelot.ideasonboard.com (Postfix) with ESMTP id 833C568723;\n\tTue, 25 Feb 2025 18:35:40 +0100 (CET)","from mail-4316.protonmail.ch (mail-4316.protonmail.ch\n\t[185.70.43.16])\n\tby lancelot.ideasonboard.com (Postfix) with ESMTPS id 8BFB9686D6\n\tfor <libcamera-devel@lists.libcamera.org>;\n\tTue, 25 Feb 2025 18:35:39 +0100 (CET)"],"Authentication-Results":"lancelot.ideasonboard.com;\n\tdkim=fail reason=\"signature verification failed\" (2048-bit key;\n\tunprotected) header.d=protonmail.com header.i=@protonmail.com\n\theader.b=\"moouRBnV\"; dkim-atps=neutral","DKIM-Signature":"v=1; a=rsa-sha256; c=relaxed/relaxed; d=protonmail.com;\n\ts=protonmail3; t=1740504939; x=1740764139;\n\tbh=jOpIDyyY/Zz6zK53gMf8IwyoAXvOkZ98ntCKOdrQpgw=;\n\th=Date:To:From:Subject:Message-ID:Feedback-ID:From:To:Cc:Date:\n\tSubject:Reply-To:Feedback-ID:Message-ID:BIMI-Selector:\n\tList-Unsubscribe:List-Unsubscribe-Post;\n\tb=moouRBnVubprbce18IwhtlY8QmRkqD0Rrz2nMkbYW6W3T9QHzwbvCh6pQeViKpAuM\n\tawMf5EBMsb6+vzyH1ktlLnn3t+oHMR/tTicTba3H/+j6knijjOPfj+QgcnMDph9SkV\n\tOxXSsajGe629CZHbkI6HJ3busWk4w9ghTKiSFH7luQ1OHMWfkjX99K59IRav6O+Al3\n\tszeZJ7cl17Zs6LU4ejNP597K1HLn+15kaUh04AWR7uwjAGzNLoM8pJrLDpM3D8Vkzn\n\tV2oFlWbJVAzWAPONRUEzjg7liyJRXl6brN7rPYtetCkFGmCbi1wue4n4iI1ALdyVN5\n\tlXHkt5Qy10d8g==","Date":"Tue, 25 Feb 2025 17:35:34 +0000","To":"libcamera-devel@lists.libcamera.org","From":"=?utf-8?q?Barnab=C3=A1s_P=C5=91cze?= <pobrn@protonmail.com>","Subject":"[PATCH v4 0/8] libcamera: base: log: Misc. changes","Message-ID":"<20250225173531.2595922-1-pobrn@protonmail.com>","Feedback-ID":"20568564:user:proton","X-Pm-Message-ID":"3acc45f0cc2746d47f456684135fdfc0ffb30de0","MIME-Version":"1.0","Content-Type":"text/plain; charset=utf-8","Content-Transfer-Encoding":"quoted-printable","X-BeenThere":"libcamera-devel@lists.libcamera.org","X-Mailman-Version":"2.1.29","Precedence":"list","List-Id":"<libcamera-devel.lists.libcamera.org>","List-Unsubscribe":"<https://lists.libcamera.org/options/libcamera-devel>,\n\t<mailto:libcamera-devel-request@lists.libcamera.org?subject=unsubscribe>","List-Archive":"<https://lists.libcamera.org/pipermail/libcamera-devel/>","List-Post":"<mailto:libcamera-devel@lists.libcamera.org>","List-Help":"<mailto:libcamera-devel-request@lists.libcamera.org?subject=help>","List-Subscribe":"<https://lists.libcamera.org/listinfo/libcamera-devel>,\n\t<mailto:libcamera-devel-request@lists.libcamera.org?subject=subscribe>","Errors-To":"libcamera-devel-bounces@lists.libcamera.org","Sender":"\"libcamera-devel\" <libcamera-devel-bounces@lists.libcamera.org>"},"content":"A collection of misc. changes I made while I was looking\nat https://bugs.libcamera.org/show_bug.cgi?id=243 .\n\nChanges in v4:\n  * rebase on master branch\n  * use camel case\n\nChanges in v3:\n  * drop https://patchwork.libcamera.org/patch/22716/\n  * store `LogCategory`s in `std::vector` of `std::unique_ptr`\n  * rewrite commit message of https://patchwork.libcamera.org/patch/22717/\n\nChanges in v2:\n  * remove `LogMessage` move constructor\n  * split function moving into separate patch\n  * do not pass the default value of 10 to `std::from_chars()`\n  * store `LogCategory`s in `std::list` instead of vector\n    of owning raw pointers\n\nv3: https://patchwork.libcamera.org/project/libcamera/list/?series=5007\nv2: https://patchwork.libcamera.org/project/libcamera/list/?series=4982\nv1: https://patchwork.libcamera.org/project/libcamera/list/?series=4960\n\nBarnabás Pőcze (8):\n  libcamera: base: log: Remove move constructor\n  libcamera: base: log: Use `std::from_chars()`\n  libcamera: base: log: Remove `LogMessage::init()`\n  libcamera: base: log: Make `LogCategory::severity_` atomic\n  libcamera: base: log: Use `std::string_view` to avoid some copies\n  libcamera: base: log: Pass dynamic prefix through\n  libcamera: base: log: Protect log categories with lock\n  libcamera: base: log: Avoid manual `LogCategory` deletion\n\n include/libcamera/base/log.h |  23 +++---\n src/libcamera/base/log.cpp   | 134 +++++++++++------------------------\n 2 files changed, 55 insertions(+), 102 deletions(-)\n\n--\n2.48.1"}