mirror of
https://github.com/LadybirdBrowser/ladybird.git
synced 2025-05-27 13:32:52 +00:00
If no header includes the prototype of a function, then it cannot be used from outside the translation unit it was defined in. In that case, it should be marked as `static`, in order to avoid possible ODR problems, unnecessary exported symbols, and allow the compiler to better optimize those. If this warning triggers in a function defined in a header, `inline` needs to be added, otherwise if the header is included in more than one TU, it will fail to link with a duplicate definition error. The reason this diff got so big is that Lagom-only code wasn't built with this flag even in Serenity times.
23 lines
389 B
C++
23 lines
389 B
C++
/*
|
|
* Copyright (c) 2024, Andreas Kling <kling@serenityos.org>
|
|
*
|
|
* SPDX-License-Identifier: BSD-2-Clause
|
|
*/
|
|
|
|
#pragma once
|
|
|
|
#include <LibJS/Forward.h>
|
|
|
|
namespace Web::WebIDL {
|
|
|
|
extern bool g_enable_idl_tracing;
|
|
|
|
void log_trace_impl(JS::VM&, char const*);
|
|
|
|
inline void log_trace(JS::VM& vm, char const* function)
|
|
{
|
|
if (g_enable_idl_tracing)
|
|
log_trace_impl(vm, function);
|
|
}
|
|
|
|
}
|