[libcamera-devel] [RFC v1 2/7] py: Add Python logging category

Tomi Valkeinen tomi.valkeinen at ideasonboard.com
Mon Jun 27 14:14:23 CEST 2022


On 27/06/2022 11:18, Laurent Pinchart wrote:
> Hi Tomi,
> 
> On Mon, Jun 27, 2022 at 09:48:34AM +0300, Tomi Valkeinen wrote:
>> On 24/06/2022 12:50, Laurent Pinchart wrote:
>>> On Thu, Jun 23, 2022 at 05:47:31PM +0300, Tomi Valkeinen wrote:
>>>> Add Python logging category, and use it in handleRequestCompleted().
>>>>
>>>> Signed-off-by: Tomi Valkeinen <tomi.valkeinen at ideasonboard.com>
>>>> ---
>>>>    src/py/libcamera/py_main.cpp |  8 ++++++--
>>>>    src/py/libcamera/py_main.h   | 12 ++++++++++++
>>>>    2 files changed, 18 insertions(+), 2 deletions(-)
>>>>    create mode 100644 src/py/libcamera/py_main.h
>>>>
>>>> diff --git a/src/py/libcamera/py_main.cpp b/src/py/libcamera/py_main.cpp
>>>> index 505cc3dc..17b17f60 100644
>>>> --- a/src/py/libcamera/py_main.cpp
>>>> +++ b/src/py/libcamera/py_main.cpp
>>>> @@ -5,6 +5,8 @@
>>>>     * Python bindings
>>>>     */
>>>>    
>>>> +#include "py_main.h"
>>>> +
>>>>    #include <mutex>
>>>>    #include <stdexcept>
>>>>    #include <sys/eventfd.h>
>>>> @@ -23,6 +25,8 @@ namespace py = pybind11;
>>>>    
>>>>    using namespace libcamera;
>>>>    
>>>> +LOG_DEFINE_CATEGORY(Python)
>>>> +
>>>>    template<typename T>
>>>>    static py::object valueOrTuple(const ControlValue &cv)
>>>>    {
>>>> @@ -120,10 +124,10 @@ static void handleRequestCompleted(Request *req)
>>>>    	size_t s = write(gEventfd, &v, 8);
>>>>    	/*
>>>>    	 * We should never fail, and have no simple means to manage the error,
>>>> -	 * so let's use LOG(Fatal).
>>>> +	 * so let's use LOG(Python, Fatal).
>>>
>>> You could also write "so let's log a fatal error".
>>
>> Yep.
>>
>>>>    	 */
>>>>    	if (s != 8)
>>>> -		LOG(Fatal) << "Unable to write to eventfd";
>>>> +		LOG(Python, Fatal) << "Unable to write to eventfd";
>>>>    }
>>>>    
>>>>    void init_py_enums(py::module &m);
>>>> diff --git a/src/py/libcamera/py_main.h b/src/py/libcamera/py_main.h
>>>> new file mode 100644
>>>> index 00000000..1b543a55
>>>> --- /dev/null
>>>> +++ b/src/py/libcamera/py_main.h
>>>> @@ -0,0 +1,12 @@
>>>> +/* SPDX-License-Identifier: LGPL-2.1-or-later */
>>>> +/*
>>>> + * Copyright (C) 2022, Tomi Valkeinen <tomi.valkeinen at ideasonboard.com>
>>>> + */
>>>> +
>>>> +#pragma once
>>>> +
>>>> +#include <libcamera/base/log.h>
>>>> +
>>>> +using namespace libcamera;
>>>
>>> "using namespace" directives are discouraged in header files, as they
>>> will propagate to all compilation units. Could this be avoided ? With
>>> that fixed,
>>
>> LOG_DECLARE_CATEGORY() requires either using namespace or being inside
>> libcamera namespace.
>>
>> I guess I could move all the python bindings code to be inside libcamera
>> namespace.
> 
> You can also do
> 
> namespace libcamera {
> 
> LOG_DECLARE_CATEGORY(Python)
> 
> }

That's true. I'll change this as above, and maybe later move the whole 
bindings inside namespace libcamera. Or any concerns with that change?

  Tomi


More information about the libcamera-devel mailing list