diff options
author | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-27 16:51:28 +0000 |
---|---|---|
committer | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-27 16:51:28 +0000 |
commit | 940b4d1848e8c70ab7642901a68594e8016caffc (patch) | |
tree | eb72f344ee6c3d9b80a7ecc079ea79e9fba8676d /bridges/Library_cpp_uno.mk | |
parent | Initial commit. (diff) | |
download | libreoffice-940b4d1848e8c70ab7642901a68594e8016caffc.tar.xz libreoffice-940b4d1848e8c70ab7642901a68594e8016caffc.zip |
Adding upstream version 1:7.0.4.upstream/1%7.0.4upstream
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'bridges/Library_cpp_uno.mk')
-rw-r--r-- | bridges/Library_cpp_uno.mk | 278 |
1 files changed, 278 insertions, 0 deletions
diff --git a/bridges/Library_cpp_uno.mk b/bridges/Library_cpp_uno.mk new file mode 100644 index 000000000..c392fa4c6 --- /dev/null +++ b/bridges/Library_cpp_uno.mk @@ -0,0 +1,278 @@ +# -*- Mode: makefile-gmake; tab-width: 4; indent-tabs-mode: t -*- +# +# This file is part of the LibreOffice project. +# +# This Source Code Form is subject to the terms of the Mozilla Public +# License, v. 2.0. If a copy of the MPL was not distributed with this +# file, You can obtain one at http://mozilla.org/MPL/2.0/. +# + +$(eval $(call gb_Library_Library,$(gb_CPPU_ENV)_uno)) + +ifeq ($(CPUNAME),ARM) + +ifneq ($(filter ANDROID DRAGONFLY FREEBSD LINUX NETBSD OPENBSD,$(OS)),) +bridges_SELECTED_BRIDGE := gcc3_linux_arm +bridge_noopt_objects := cpp2uno except uno2cpp +# HACK +$(call gb_LinkTarget_get_target,$(call gb_Library_get_linktarget,gcc3_uno)) : \ + $(call gb_CustomTarget_get_workdir,bridges/source/cpp_uno/gcc3_linux_arm)/armhelper.objectlist +$(call gb_LinkTarget_get_target,$(call gb_Library_get_linktarget,gcc3_uno)) : \ + EXTRAOBJECTLISTS += $(call gb_CustomTarget_get_workdir,bridges/source/cpp_uno/gcc3_linux_arm)/armhelper.objectlist +endif + +else ifeq ($(CPUNAME),AARCH64) + +ifneq ($(filter ANDROID DRAGONFLY FREEBSD LINUX MACOSX NETBSD OPENBSD,$(OS)),) +bridges_SELECTED_BRIDGE := gcc3_linux_aarch64 +bridge_asm_objects := vtableslotcall +bridge_exception_objects := abi cpp2uno uno2cpp + +$(eval $(call gb_Library_add_exception_objects,$(gb_CPPU_ENV)_uno, \ + bridges/source/cpp_uno/$(bridges_SELECTED_BRIDGE)/callvirtualfunction, \ + $(if $(HAVE_GCC_STACK_CLASH_PROTECTION),-fno-stack-clash-protection) \ +)) + +else ifeq ($(OS),iOS) +bridges_SELECTED_BRIDGE := gcc3_ios +bridge_noopt_objects := cpp2uno except uno2cpp +bridge_asm_objects := ios64_helper + +endif + +else ifeq ($(CPUNAME),AXP) + +ifneq ($(filter DRAGONFLY FREEBSD LINUX NETBSD OPENBSD,$(OS)),) +bridges_SELECTED_BRIDGE := gcc3_linux_alpha +bridge_exception_objects := cpp2uno except uno2cpp +endif + +else ifeq ($(CPUNAME),HPPA) + +ifneq ($(filter DRAGONFLY FREEBSD LINUX NETBSD OPENBSD,$(OS)),) +bridges_SELECTED_BRIDGE := gcc3_linux_hppa +bridge_noopt_objects := call cpp2uno except uno2cpp +endif + +else ifeq ($(CPUNAME),IA64) + +ifneq ($(filter DRAGONFLY FREEBSD LINUX NETBSD OPENBSD,$(OS)),) +bridges_SELECTED_BRIDGE := gcc3_linux_ia64 +bridge_asm_objects := call +bridge_exception_objects := except +bridge_noopt_objects := cpp2uno uno2cpp +endif + +else ifeq ($(CPUNAME),INTEL) + +ifneq ($(filter ANDROID DRAGONFLY FREEBSD LINUX NETBSD OPENBSD HAIKU,$(OS)),) +bridges_SELECTED_BRIDGE := gcc3_linux_intel +bridge_asm_objects := call +bridge_exception_objects := cpp2uno except uno2cpp +bridge_noncallexception_objects := callvirtualmethod +else ifeq ($(OS),SOLARIS) +bridges_SELECTED_BRIDGE := gcc3_solaris_intel +bridge_exception_objects := cpp2uno except uno2cpp +bridge_noncallexception_objects := callvirtualmethod +else ifeq ($(COM),MSC) +bridges_SELECTED_BRIDGE := msvc_win32_intel +bridge_exception_objects := cpp2uno uno2cpp +bridge_noopt_objects := except +endif + +else ifeq ($(CPUNAME),M68K) + +ifneq ($(filter DRAGONFLY FREEBSD LINUX NETBSD OPENBSD,$(OS)),) +bridges_SELECTED_BRIDGE := gcc3_linux_m68k +bridge_noopt_objects := cpp2uno except uno2cpp +endif + +else ifeq ($(CPUNAME),GODSON) + +ifneq ($(filter LINUX,$(OS)),) +bridges_SELECTED_BRIDGE := gcc3_linux_mips +bridge_noopt_objects := cpp2uno uno2cpp +bridge_exception_objects := except +endif + +else ifeq ($(CPUNAME),GODSON64) + +ifneq ($(filter LINUX,$(OS)),) +bridges_SELECTED_BRIDGE := gcc3_linux_mips64 +bridge_asm_objects := call +bridge_noopt_objects := cpp2uno uno2cpp +bridge_exception_objects := except +endif + +else ifeq ($(CPUNAME),POWERPC) + +ifneq ($(filter DRAGONFLY FREEBSD LINUX NETBSD OPENBSD,$(OS)),) +bridges_SELECTED_BRIDGE := gcc3_linux_powerpc +bridge_noopt_objects := uno2cpp +bridge_exception_objects := cpp2uno except +else ifeq ($(OS),AIX) +bridges_SELECTED_BRIDGE := gcc3_aix_powerpc +bridge_exception_objects := except +bridge_cxx_objects := cpp2uno uno2cpp +endif + +else ifeq ($(CPUNAME),POWERPC64) + +ifneq ($(filter DRAGONFLY FREEBSD LINUX NETBSD OPENBSD,$(OS)),) +bridges_SELECTED_BRIDGE := gcc3_linux_powerpc64 +bridge_noopt_objects := cpp2uno uno2cpp +bridge_exception_objects := except +endif + +else ifeq ($(CPUNAME),S390) + +ifneq ($(filter DRAGONFLY FREEBSD LINUX NETBSD OPENBSD,$(OS)),) +bridges_SELECTED_BRIDGE := gcc3_linux_s390 +bridge_exception_objects := cpp2uno except uno2cpp +endif + +else ifeq ($(CPUNAME),S390X) + +ifneq ($(filter DRAGONFLY FREEBSD LINUX NETBSD OPENBSD,$(OS)),) +bridges_SELECTED_BRIDGE := gcc3_linux_s390x +bridge_exception_objects := cpp2uno except uno2cpp +endif + +else ifeq ($(CPUNAME),SPARC) + +ifneq ($(filter DRAGONFLY FREEBSD LINUX NETBSD OPENBSD,$(OS)),) +bridges_SELECTED_BRIDGE := gcc3_linux_sparc +bridge_asm_objects := call +bridge_noopt_objects := except +bridge_exception_objects := cpp2uno uno2cpp +else ifeq ($(OS),SOLARIS) +bridges_SELECTED_BRIDGE := gcc3_solaris_sparc +bridge_noopt_objects := cpp2uno uno2cpp +bridge_exception_objects := except +endif + +else ifeq ($(OS)-$(CPUNAME),LINUX-SPARC64) + +bridges_SELECTED_BRIDGE := gcc3_linux_sparc64 +bridge_asm_objects := call +bridge_noopt_objects := cpp2uno uno2cpp +bridge_exception_objects := except + +else ifeq ($(CPUNAME),X86_64) + +ifneq ($(filter ANDROID DRAGONFLY FREEBSD LINUX NETBSD OPENBSD HAIKU,$(OS)),) +bridges_SELECTED_BRIDGE := gcc3_linux_x86-64 +bridge_asm_objects := call +bridge_noncallexception_noopt_objects := callvirtualmethod +bridge_exception_objects := abi cpp2uno except rtti uno2cpp +else ifneq ($(filter MACOSX iOS,$(OS)),) +bridges_SELECTED_BRIDGE := gcc3_macosx_x86-64 +bridge_exception_objects := abi call cpp2uno except uno2cpp +bridge_noncallexception_noopt_objects := callvirtualmethod +else ifeq ($(COM),MSC) +bridges_SELECTED_BRIDGE := msvc_win32_x86-64 +bridge_exception_objects := cpp2uno uno2cpp +bridge_noopt_objects := except +bridge_asm_objects := call +endif + +endif + +$(eval $(call gb_Library_use_internal_comprehensive_api,$(gb_CPPU_ENV)_uno,\ + udkapi \ +)) + +ifeq ($(OS),MACOSX) +ifeq ($(CPUNAME),AARCH64) +$(eval $(call gb_Library_use_internal_comprehensive_api,$(gb_CPPU_ENV)_uno,\ + offapi \ +)) +endif +endif + +$(eval $(call gb_Library_set_include,$(gb_CPPU_ENV)_uno,\ + -I$(SRCDIR)/bridges/inc \ + $$(INCLUDE) \ +)) + +ifeq ($(HAVE_POSIX_FALLOCATE),YES) +$(eval $(call gb_Library_add_defs,$(gb_CPPU_ENV)_uno,\ + -DHAVE_POSIX_FALLOCATE \ +)) +endif + +# In case someone enabled the non-standard -fomit-frame-pointer which does not +# work with the .cxx sources of this library. +# LTO causes crashes when enabled for this library +# In case the compiler supports AVX this code segfaults so specifically turn +# it off. +ifeq ($(COM),GCC) +$(eval $(call gb_Library_add_cxxflags,gcc3_uno,\ + $(if $(filter armeabi-v7a,$(ANDROID_APP_ABI)),-I$(ANDROID_BINUTILS_PREBUILT_ROOT)/lib/gcc/arm-linux-androideabi/4.9.x/include) \ + -fno-omit-frame-pointer \ + -fno-strict-aliasing \ + -fno-lto \ + $(if $(filter TRUE,$(HAVE_GCC_AVX)),-mno-avx) \ +)) + +ifeq ($(filter ANDROID WNT DRAGONFLY FREEBSD NETBSD OPENBSD MACOSX iOS HAIKU,$(OS)),) +$(eval $(call gb_Library_add_libs,gcc3_uno,\ + -ldl \ +)) +endif +endif + +ifeq ($(COM),GCC) +ifneq ($(COM_IS_CLANG),TRUE) +bridges_NON_CALL_EXCEPTIONS_FLAGS := -fnon-call-exceptions +endif +endif + +$(eval $(call gb_Library_use_libraries,$(gb_CPPU_ENV)_uno,\ + cppu \ + sal \ +)) + +$(foreach obj,$(bridge_exception_objects),\ + $(eval $(call gb_Library_add_exception_objects,$(gb_CPPU_ENV)_uno,\ + bridges/source/cpp_uno/$(bridges_SELECTED_BRIDGE)/$(obj))) \ +) +$(foreach obj,$(bridge_noncallexception_objects),\ + $(eval $(call gb_Library_add_exception_objects,$(gb_CPPU_ENV)_uno,\ + bridges/source/cpp_uno/$(bridges_SELECTED_BRIDGE)/$(obj) \ + , $(bridges_NON_CALL_EXCEPTIONS_FLAGS) )) \ +) +$(foreach obj,$(bridge_noopt_objects),\ + $(eval $(call gb_Library_add_exception_objects,$(gb_CPPU_ENV)_uno,\ + bridges/source/cpp_uno/$(bridges_SELECTED_BRIDGE)/$(obj) \ + , $(gb_COMPILERNOOPTFLAGS))) \ + ) +$(foreach obj,$(bridge_noncallexception_noopt_objects),\ + $(eval $(call gb_Library_add_exception_objects,$(gb_CPPU_ENV)_uno,\ + bridges/source/cpp_uno/$(bridges_SELECTED_BRIDGE)/$(obj) \ + , $(gb_COMPILERNOOPTFLAGS) $(bridges_NON_CALL_EXCEPTIONS_FLAGS) )) \ + ) +$(foreach obj,$(bridge_cxx_objects),\ + $(eval $(call gb_Library_add_cxxobjects,$(gb_CPPU_ENV)_uno,\ + bridges/source/cpp_uno/$(bridges_SELECTED_BRIDGE)/$(obj))) \ + ) +$(foreach obj,$(bridge_asm_objects),\ + $(eval $(call gb_Library_add_asmobjects,$(gb_CPPU_ENV)_uno,\ + bridges/source/cpp_uno/$(bridges_SELECTED_BRIDGE)/$(obj))) \ + ) + +$(eval $(call gb_Library_add_exception_objects,$(gb_CPPU_ENV)_uno,\ + bridges/source/cpp_uno/shared/bridge \ + bridges/source/cpp_uno/shared/component \ + bridges/source/cpp_uno/shared/types \ + bridges/source/cpp_uno/shared/unointerfaceproxy \ + bridges/source/cpp_uno/shared/vtablefactory \ + bridges/source/cpp_uno/shared/vtables \ + )) + +$(eval $(call gb_Library_add_cxxobjects,$(gb_CPPU_ENV)_uno,\ + bridges/source/cpp_uno/shared/cppinterfaceproxy \ + , $(gb_COMPILERNOOPTFLAGS) $(gb_LinkTarget_EXCEPTIONFLAGS) \ + )) + +# vim: set noet sw=4 ts=4: |