office-gobmx/include/osl
Stephan Bergmann 4bbe329ef0 Avoid -Werror,-Wcast-function-type-mismatch
...as seen when building LOWA (i.e., --disable-dynloading) with a recent Clang
with
<999d4f8407>
"Split -Wcast-function-type into a separate group (#86131)", where
-Wcast-function-type-mismatch generally warns about casts between incompatible
function types...

> cppuhelper/source/shlib.cxx:294:23: error: cast from 'void *(*)(void *, void *)' to 'ImplementationConstructorFn *' (aka 'css::uno::XInterface *(*)(css::uno::XComponentContext *, const css::uno::Sequence<css::uno::Any> &)') converts to incompatible function type [-Werror,-Wcast-function-type-mismatch]
>   294 |                     = reinterpret_cast<ImplementationConstructorFn *>(
>       |                       ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
>   295 |                         map[i].constructor_function);
>       |                         ~~~~~~~~~~~~~~~~~~~~~~~~~~~~

...but not for the special case of casting from/to void(*)(void).

(Using the correct function type

> css::uno::XInterface * (*)(css::uno::XComponentContext *, css::uno::Sequence<css::uno::Any> const &)

throughout would be even better, but doesn't easily fit into this C code that is
included in low-level places that don't know those UNO types and is shared
between LOWA and Android etc.)

Change-Id: Ic4dbabbff0f772b34cf692db968c3ad257c37cb2
Reviewed-on: https://gerrit.libreoffice.org/c/core/+/173463
Reviewed-by: Stephan Bergmann <stephan.bergmann@allotropia.de>
Tested-by: Jenkins
2024-09-17 21:01:48 +02:00
..
detail
test
conditn.h
conditn.hxx
diagnose.h
diagnose.hxx
doublecheckedlocking.h
endian.h
file.h
file.hxx
getglobalmutex.hxx
interlck.h
module.h
module.hxx
mutex.h
mutex.hxx
nlsupport.h
pipe.h
pipe.hxx
pipe_decl.hxx
process.h
profile.h
profile.hxx
security.h
security.hxx
security_decl.hxx
signal.h
socket.h
socket.hxx
socket_decl.hxx
thread.h
thread.hxx
time.h