From 9e3c08db40b8916968b9f30096c7be3f00ce9647 Mon Sep 17 00:00:00 2001 From: Daniel Baumann Date: Sun, 21 Apr 2024 13:44:51 +0200 Subject: Adding upstream version 1:115.7.0. Signed-off-by: Daniel Baumann --- third_party/libwebrtc/webrtc.gni | 1203 ++++++++++++++++++++++++++++++++++++++ 1 file changed, 1203 insertions(+) create mode 100644 third_party/libwebrtc/webrtc.gni (limited to 'third_party/libwebrtc/webrtc.gni') diff --git a/third_party/libwebrtc/webrtc.gni b/third_party/libwebrtc/webrtc.gni new file mode 100644 index 0000000000..92beecc5e4 --- /dev/null +++ b/third_party/libwebrtc/webrtc.gni @@ -0,0 +1,1203 @@ +# Copyright (c) 2014 The WebRTC project authors. All Rights Reserved. +# +# Use of this source code is governed by a BSD-style license +# that can be found in the LICENSE file in the root of the source +# tree. An additional intellectual property rights grant can be found +# in the file PATENTS. All contributing project authors may +# be found in the AUTHORS file in the root of the source tree. +import("//build/config/arm.gni") +import("//build/config/features.gni") +import("//build/config/mips.gni") +import("//build/config/ozone.gni") +import("//build/config/sanitizers/sanitizers.gni") +import("//build/config/sysroot.gni") +import("//build_overrides/build.gni") + +if (!build_with_chromium && is_component_build) { + print("The Gn argument `is_component_build` is currently " + + "ignored for WebRTC builds.") + print("Component builds are supported by Chromium and the argument " + + "`is_component_build` makes it possible to create shared libraries " + + "instead of static libraries.") + print("If an app depends on WebRTC it makes sense to just depend on the " + + "WebRTC static library, so there is no difference between " + + "`is_component_build=true` and `is_component_build=false`.") + print( + "More info about component builds at: " + "https://chromium.googlesource.com/chromium/src/+/main/docs/component_build.md") + assert(!is_component_build, "Component builds are not supported in WebRTC.") +} + +if (is_ios) { + import("//build/config/ios/rules.gni") +} + +if (is_mac) { + import("//build/config/mac/rules.gni") +} + +if (is_android) { + import("//build/config/android/config.gni") + import("//build/config/android/rules.gni") +} + +if (is_fuchsia) { + import("//build/config/fuchsia/config.gni") +} + +# This declare_args is separated from the next one because args declared +# in this one, can be read from the next one (args defined in the same +# declare_args cannot be referenced in that scope). +declare_args() { + # Enable to use the Mozilla internal settings. + build_with_mozilla = true +} + +declare_args() { + # Setting this to true will make RTC_EXPORT (see rtc_base/system/rtc_export.h) + # expand to code that will manage symbols visibility. + rtc_enable_symbol_export = false +} + +declare_args() { + # Setting this to true, will make RTC_DLOG() expand to log statements instead + # of being removed by the preprocessor. + # This is useful for example to be able to get RTC_DLOGs on a release build. + rtc_dlog_always_on = false + + # Setting this to true will make RTC_OBJC_EXPORT expand to code that will + # manage symbols visibility. By default, Obj-C/Obj-C++ symbols are exported + # if C++ symbols are but setting this arg to true while keeping + # rtc_enable_symbol_export=false will only export RTC_OBJC_EXPORT + # annotated symbols. + rtc_enable_objc_symbol_export = rtc_enable_symbol_export + + # Setting this to true will define WEBRTC_EXCLUDE_FIELD_TRIAL_DEFAULT which + # will tell the pre-processor to remove the default definition of symbols + # needed to use field_trial. In that case a new implementation needs to be + # provided. + if (build_with_chromium) { + # When WebRTC is built as part of Chromium it should exclude the default + # implementation of field_trial unless it is building for NACL or + # Chromecast. + rtc_exclude_field_trial_default = !is_nacl && !is_castos && !is_cast_android + } else { + rtc_exclude_field_trial_default = false + } + + # Setting this to true will define WEBRTC_EXCLUDE_METRICS_DEFAULT which + # will tell the pre-processor to remove the default definition of symbols + # needed to use metrics. In that case a new implementation needs to be + # provided. + rtc_exclude_metrics_default = build_with_chromium + + # Setting this to true will define WEBRTC_EXCLUDE_SYSTEM_TIME which + # will tell the pre-processor to remove the default definition of the + # SystemTimeNanos() which is defined in rtc_base/system_time.cc. In + # that case a new implementation needs to be provided. + rtc_exclude_system_time = build_with_chromium || build_with_mozilla + + # Setting this to false will require the API user to pass in their own + # SSLCertificateVerifier to verify the certificates presented from a + # TLS-TURN server. In return disabling this saves around 100kb in the binary. + rtc_builtin_ssl_root_certificates = true + + # Include the iLBC audio codec? + rtc_include_ilbc = true + + # Disable this to avoid building the Opus audio codec. + rtc_include_opus = true + + # Enable this if the Opus version upon which WebRTC is built supports direct + # encoding of 120 ms packets. + rtc_opus_support_120ms_ptime = true + + # Enable this to let the Opus audio codec change complexity on the fly. + rtc_opus_variable_complexity = false + + # Used to specify an external Jsoncpp include path when not compiling the + # library that comes with WebRTC (i.e. rtc_build_json == 0). + rtc_jsoncpp_root = "//third_party/jsoncpp/source/include" + + # Used to specify an external OpenSSL include path when not compiling the + # library that comes with WebRTC (i.e. rtc_build_ssl == 0). + rtc_ssl_root = "unused" + + # Enable when an external authentication mechanism is used for performing + # packet authentication for RTP packets instead of libsrtp. + rtc_enable_external_auth = build_with_chromium + + # Selects whether debug dumps for the audio processing module + # should be generated. + apm_debug_dump = false + + # Selects whether the audio processing module should be excluded. + rtc_exclude_audio_processing_module = false + + # Set this to true to enable BWE test logging. + rtc_enable_bwe_test_logging = false + + # Set this to false to skip building examples. + rtc_build_examples = false + + # Set this to false to skip building tools. + rtc_build_tools = false + + # Set this to false to skip building code that requires X11. + rtc_use_x11 = use_x11 + + # Set this to use PipeWire on the Wayland display server. + # By default it's only enabled on desktop Linux (excludes ChromeOS) and + # only when using the sysroot as PipeWire is not available in older and + # supported Ubuntu and Debian distributions. + rtc_use_pipewire = is_linux && use_sysroot + + # Set this to link PipeWire and required libraries directly instead of using the dlopen. + rtc_link_pipewire = false + + # Experimental: enable use of Android AAudio which requires Android SDK 26 or above + # and NDK r16 or above. + rtc_enable_android_aaudio = false + + # Set to "func", "block", "edge" for coverage generation. + # At unit test runtime set UBSAN_OPTIONS="coverage=1". + # It is recommend to set include_examples=0. + # Use llvm's sancov -html-report for human readable reports. + # See http://clang.llvm.org/docs/SanitizerCoverage.html . + rtc_sanitize_coverage = "" + + # Selects fixed-point code where possible. + rtc_prefer_fixed_point = false + if (target_cpu == "arm" || target_cpu == "arm64") { + rtc_prefer_fixed_point = true + } + + # Determines whether NEON code will be built. + rtc_build_with_neon = + (target_cpu == "arm" && arm_use_neon) || target_cpu == "arm64" + + # Enable this to build OpenH264 encoder/FFmpeg decoder. This is supported on + # all platforms except Android and iOS. Because FFmpeg can be built + # with/without H.264 support, `ffmpeg_branding` has to separately be set to a + # value that includes H.264, for example "Chrome". If FFmpeg is built without + # H.264, compilation succeeds but `H264DecoderImpl` fails to initialize. + # CHECK THE OPENH264, FFMPEG AND H.264 LICENSES/PATENTS BEFORE BUILDING. + # http://www.openh264.org, https://www.ffmpeg.org/ + # + # Enabling H264 when building with MSVC is currently not supported, see + # bugs.webrtc.org/9213#c13 for more info. + rtc_use_h264 = + proprietary_codecs && !is_android && !is_ios && !(is_win && !is_clang) + + # Enable this flag to make webrtc::Mutex be implemented by absl::Mutex. + rtc_use_absl_mutex = false + + # By default, use normal platform audio support or dummy audio, but don't + # use file-based audio playout and record. + rtc_use_dummy_audio_file_devices = false + + # When set to true, replace the audio output with a sinus tone at 440Hz. + # The ADM will ask for audio data from WebRTC but instead of reading real + # audio samples from NetEQ, a sinus tone will be generated and replace the + # real audio samples. + rtc_audio_device_plays_sinus_tone = false + + if (is_ios) { + # Build broadcast extension in AppRTCMobile for iOS. This results in the + # binary only running on iOS 11+, which is why it is disabled by default. + rtc_apprtcmobile_broadcast_extension = false + } + + # Determines whether OpenGL is available on iOS/macOS. + rtc_ios_macos_use_opengl_rendering = + !(is_ios && target_environment == "catalyst") + + # When set to false, builtin audio encoder/decoder factories and all the + # audio codecs they depend on will not be included in libwebrtc.{a|lib} + # (they will still be included in libjingle_peerconnection_so.so and + # WebRTC.framework) + rtc_include_builtin_audio_codecs = true + + # When set to false, builtin video encoder/decoder factories and all the + # video codecs they depends on will not be included in libwebrtc.{a|lib} + # (they will still be included in libjingle_peerconnection_so.so and + # WebRTC.framework) + rtc_include_builtin_video_codecs = !build_with_mozilla # See Bug 1820869. + + # When set to true and in a standalone build, it will undefine UNICODE and + # _UNICODE (which are always defined globally by the Chromium Windows + # toolchain). + # This is only needed for testing purposes, WebRTC wants to be sure it + # doesn't assume /DUNICODE and /D_UNICODE but that it explicitly uses + # wide character functions. + rtc_win_undef_unicode = false + + # When set to true, a capturer implementation that uses the + # Windows.Graphics.Capture APIs will be available for use. This introduces a + # dependency on the Win 10 SDK v10.0.17763.0. + rtc_enable_win_wgc = false + + # Includes the dav1d decoder in the internal decoder factory when set to true. + rtc_include_dav1d_in_internal_decoder_factory = true + + # When set to true, a run-time check will make sure that all field trial keys + # have been registered in accordance with the field trial policy. The check + # will only run with builds that have RTC_DCHECKs enabled. + rtc_strict_field_trials = false +} + +if (!build_with_mozilla) { + import("//testing/test.gni") +} + +# A second declare_args block, so that declarations within it can +# depend on the possibly overridden variables in the first +# declare_args block. +declare_args() { + # Enables the use of protocol buffers for debug recordings. + rtc_enable_protobuf = !build_with_mozilla + + # Set this to disable building with support for SCTP data channels. + rtc_enable_sctp = !build_with_mozilla + + # Disable these to not build components which can be externally provided. + rtc_build_json = !build_with_mozilla + rtc_build_libsrtp = !build_with_mozilla + rtc_build_libvpx = !build_with_mozilla + rtc_libvpx_build_vp9 = true + rtc_build_opus = !build_with_mozilla + rtc_build_ssl = !build_with_mozilla + + # Enable libevent task queues on platforms that support it. + if (is_win || is_mac || is_ios || is_nacl || is_fuchsia || + target_cpu == "wasm") { + rtc_enable_libevent = false + rtc_build_libevent = false + } else { + rtc_enable_libevent = true + rtc_build_libevent = !build_with_mozilla + } + + # Excluded in Chromium since its prerequisites don't require Pulse Audio. + rtc_include_pulse_audio = !build_with_chromium + + # Chromium uses its own IO handling, so the internal ADM is only built for + # standalone WebRTC. + rtc_include_internal_audio_device = !build_with_chromium && !build_with_mozilla + + # Set this to true to enable the avx2 support in webrtc. + # TODO: Make sure that AVX2 works also for non-clang compilers. + if (is_clang == true && (target_cpu == "x86" || target_cpu == "x64")) { + rtc_enable_avx2 = true + } else { + rtc_enable_avx2 = false + } + + # Set this to true to build the unit tests. + # Disabled when building with Chromium or Mozilla. + rtc_include_tests = !build_with_chromium && !build_with_mozilla + + # Set this to false to skip building code that also requires X11 extensions + # such as Xdamage, Xfixes. + rtc_use_x11_extensions = rtc_use_x11 + + # Set this to true to fully remove logging from WebRTC. + rtc_disable_logging = false + + # Set this to true to disable trace events. + rtc_disable_trace_events = false + + # Set this to true to disable detailed error message and logging for + # RTC_CHECKs. + rtc_disable_check_msg = false + + # Set this to true to disable webrtc metrics. + rtc_disable_metrics = false + + # Set this to true to exclude the transient suppressor in the audio processing + # module from the build. + rtc_exclude_transient_suppressor = false +} + +declare_args() { + # Enable the dcsctp backend for DataChannels and related unittests + rtc_build_dcsctp = !build_with_mozilla && rtc_enable_sctp + + # Enable gRPC used for negotiation in multiprocess tests + rtc_enable_grpc = rtc_enable_protobuf && (is_linux || is_mac) +} + +# Enable liboam only on non-mozilla builds. +enable_libaom = !build_with_mozilla + +# Make it possible to provide custom locations for some libraries (move these +# up into declare_args should we need to actually use them for the GN build). +rtc_libvpx_dir = "//third_party/libvpx" +rtc_opus_dir = "//third_party/opus" + +# Desktop capturer is supported only on Windows, OSX and Linux. +rtc_desktop_capture_supported = + (is_win && current_os != "winuwp") || is_mac || is_bsd || + ((is_linux || is_chromeos) && (rtc_use_x11_extensions || rtc_use_pipewire)) + +############################################################################### +# Templates +# + +# Points to // in webrtc stand-alone or to //third_party/webrtc/ in +# chromium. +# We need absolute paths for all configs in templates as they are shared in +# different subdirectories. +webrtc_root = get_path_info(".", "abspath") + +# Global configuration that should be applied to all WebRTC targets. +# You normally shouldn't need to include this in your target as it's +# automatically included when using the rtc_* templates. +# It sets defines, include paths and compilation warnings accordingly, +# both for WebRTC stand-alone builds and for the scenario when WebRTC +# native code is built as part of Chromium. +rtc_common_configs = [ webrtc_root + ":common_config" ] + +if (is_mac || is_ios) { + rtc_common_configs += [ "//build/config/compiler:enable_arc" ] +} + +# Global public configuration that should be applied to all WebRTC targets. You +# normally shouldn't need to include this in your target as it's automatically +# included when using the rtc_* templates. It set the defines, include paths and +# compilation warnings that should be propagated to dependents of the targets +# depending on the target having this config. +rtc_common_inherited_config = webrtc_root + ":common_inherited_config" + +# Common configs to remove or add in all rtc targets. +rtc_remove_configs = [] +if (!build_with_chromium && is_clang) { + rtc_remove_configs += [ "//build/config/clang:find_bad_constructs" ] +} +rtc_add_configs = rtc_common_configs +rtc_prod_configs = [ webrtc_root + ":rtc_prod_config" ] +rtc_library_impl_config = [ webrtc_root + ":library_impl_config" ] + +set_defaults("rtc_test") { + configs = rtc_add_configs + suppressed_configs = [] +} + +set_defaults("rtc_library") { + configs = rtc_add_configs + suppressed_configs = [] + absl_deps = [] +} + +set_defaults("rtc_source_set") { + configs = rtc_add_configs + suppressed_configs = [] + absl_deps = [] +} + +set_defaults("rtc_static_library") { + configs = rtc_add_configs + suppressed_configs = [] + absl_deps = [] +} + +set_defaults("rtc_executable") { + configs = rtc_add_configs + suppressed_configs = [] +} + +set_defaults("rtc_shared_library") { + configs = rtc_add_configs + suppressed_configs = [] +} + +webrtc_default_visibility = [ webrtc_root + "/*" ] +if (build_with_chromium) { + # Allow Chromium's WebRTC overrides targets to bypass the regular + # visibility restrictions. + webrtc_default_visibility += [ webrtc_root + "/../webrtc_overrides/*" ] +} + +# ---- Poisons ---- +# +# The general idea is that some targets declare that they contain some +# kind of poison, which makes it impossible for other targets to +# depend on them (even transitively) unless they declare themselves +# immune to that particular type of poison. +# +# Targets that *contain* poison of type foo should contain the line +# +# poisonous = [ "foo" ] +# +# and targets that *are immune but arent't themselves poisonous* +# should contain +# +# allow_poison = [ "foo" ] +# +# This useful in cases where we have some large target or set of +# targets and want to ensure that most other targets do not +# transitively depend on them. For example, almost no high-level +# target should depend on the audio codecs, since we want WebRTC users +# to be able to inject any subset of them and actually end up with a +# binary that doesn't include the codecs they didn't inject. +# +# Test-only targets (`testonly` set to true) and non-public targets +# (`visibility` not containing "*") are automatically immune to all +# types of poison. +# +# Here's the complete list of all types of poison. It must be kept in +# 1:1 correspondence with the set of //:poison_* targets. +# +all_poison_types = [ + # Encoders and decoders for specific audio codecs such as Opus and iSAC. + "audio_codecs", + + # Default task queue implementation. + "default_task_queue", + + # Default echo detector implementation. + "default_echo_detector", + + # JSON parsing should not be needed in the "slim and modular" WebRTC. + "rtc_json", + + # Software video codecs (VP8 and VP9 through libvpx). + "software_video_codecs", +] + +absl_include_config = "//third_party/abseil-cpp:absl_include_config" +absl_define_config = "//third_party/abseil-cpp:absl_define_config" + +# Abseil Flags are testonly, so this config will only be applied to WebRTC targets +# that are testonly. +absl_flags_config = webrtc_root + ":absl_flags_configs" + +# WebRTC wrapper of Chromium's test() template. This template just adds some +# WebRTC only configuration in order to avoid to duplicate it for every WebRTC +# target. +# The parameter `is_xctest` is different from the one in the Chromium's test() +# template (and it is not forwarded to it). In rtc_test(), the argument +# `is_xctest` is used to avoid to take dependencies that are not needed +# in case the test is a real XCTest (using the XCTest framework). +template("rtc_test") { + test(target_name) { + forward_variables_from(invoker, + "*", + [ + "configs", + "is_xctest", + "public_configs", + "suppressed_configs", + "visibility", + ]) + + # Always override to public because when target_os is Android the `test` + # template can override it to [ "*" ] and we want to avoid conditional + # visibility. + visibility = [ "*" ] + configs += invoker.configs + configs -= rtc_remove_configs + configs -= invoker.suppressed_configs + public_configs = [ + rtc_common_inherited_config, + absl_include_config, + absl_define_config, + absl_flags_config, + ] + if (defined(invoker.public_configs)) { + public_configs += invoker.public_configs + } + if (!build_with_chromium && is_android) { + android_manifest = webrtc_root + "test/android/AndroidManifest.xml" + use_raw_android_executable = false + min_sdk_version = 21 + target_sdk_version = 23 + deps += [ + "//build/android/gtest_apk:native_test_instrumentation_test_runner_java", + webrtc_root + "test:native_test_java", + ] + } + + # Build //test:google_test_runner_objc when the test is not a real XCTest. + if (is_ios && rtc_include_tests) { + if (!defined(invoker.is_xctest) || !invoker.is_xctest) { + xctest_module_target = "//test:google_test_runner_objc" + } + } + + # If absl_deps is [], no action is needed. If not [], then it needs to be + # converted to //third_party/abseil-cpp:absl when build_with_chromium=true + # otherwise it just needs to be added to deps. + if (defined(absl_deps) && absl_deps != []) { + if (!defined(deps)) { + deps = [] + } + if (build_with_chromium) { + deps += [ "//third_party/abseil-cpp:absl" ] + } else { + deps += absl_deps + } + } + + # TODO(crbug.com/webrtc/13556): Adding the .app folder in the runtime_deps + # shoulnd't be necessary. this code should be removed and the same solution + # as Chromium should be used. + if (is_ios) { + if (!defined(invoker.data)) { + data = [] + } + data += [ "${root_out_dir}/${target_name}.app" ] + } + } +} + +template("rtc_source_set") { + source_set(target_name) { + forward_variables_from(invoker, + "*", + [ + "configs", + "public_configs", + "suppressed_configs", + "visibility", + ]) + forward_variables_from(invoker, [ "visibility" ]) + if (!defined(visibility)) { + visibility = webrtc_default_visibility + } + + # What's your poison? + if (defined(testonly) && testonly) { + assert(!defined(poisonous)) + assert(!defined(allow_poison)) + } else { + if (!defined(poisonous)) { + poisonous = [] + } + if (!defined(allow_poison)) { + allow_poison = [] + } + if (!defined(assert_no_deps)) { + assert_no_deps = [] + } + if (!defined(deps)) { + deps = [] + } + foreach(p, poisonous) { + deps += [ webrtc_root + ":poison_" + p ] + } + foreach(poison_type, all_poison_types) { + allow_dep = true + foreach(v, visibility) { + if (v == "*") { + allow_dep = false + } + } + foreach(p, allow_poison + poisonous) { + if (p == poison_type) { + allow_dep = true + } + } + if (!allow_dep) { + assert_no_deps += [ webrtc_root + ":poison_" + poison_type ] + } + } + } + + # Chromium should only depend on the WebRTC component in order to + # avoid to statically link WebRTC in a component build. + if (build_with_chromium) { + publicly_visible = false + foreach(v, visibility) { + if (v == "*") { + publicly_visible = true + } + } + if (publicly_visible) { + visibility = [] + visibility = webrtc_default_visibility + } + } + + if (!defined(testonly) || !testonly) { + configs += rtc_prod_configs + } + + configs += invoker.configs + configs += rtc_library_impl_config + configs -= rtc_remove_configs + configs -= invoker.suppressed_configs + public_configs = [ + rtc_common_inherited_config, + absl_include_config, + absl_define_config, + ] + if (defined(testonly) && testonly) { + public_configs += [ absl_flags_config ] + } + if (defined(invoker.public_configs)) { + public_configs += invoker.public_configs + } + + # If absl_deps is [], no action is needed. If not [], then it needs to be + # converted to //third_party/abseil-cpp:absl when build_with_chromium=true + # otherwise it just needs to be added to deps. + if (absl_deps != []) { + if (!defined(deps)) { + deps = [] + } + if (build_with_chromium) { + deps += [ "//third_party/abseil-cpp:absl" ] + } else { + deps += absl_deps + } + } + } +} + +template("rtc_static_library") { + static_library(target_name) { + forward_variables_from(invoker, + "*", + [ + "configs", + "public_configs", + "suppressed_configs", + "visibility", + ]) + forward_variables_from(invoker, [ "visibility" ]) + if (!defined(visibility)) { + visibility = webrtc_default_visibility + } + + # What's your poison? + if (defined(testonly) && testonly) { + assert(!defined(poisonous)) + assert(!defined(allow_poison)) + } else { + if (!defined(poisonous)) { + poisonous = [] + } + if (!defined(allow_poison)) { + allow_poison = [] + } + if (!defined(assert_no_deps)) { + assert_no_deps = [] + } + if (!defined(deps)) { + deps = [] + } + foreach(p, poisonous) { + deps += [ webrtc_root + ":poison_" + p ] + } + foreach(poison_type, all_poison_types) { + allow_dep = true + foreach(v, visibility) { + if (v == "*") { + allow_dep = false + } + } + foreach(p, allow_poison + poisonous) { + if (p == poison_type) { + allow_dep = true + } + } + if (!allow_dep) { + assert_no_deps += [ webrtc_root + ":poison_" + poison_type ] + } + } + } + + if (!defined(testonly) || !testonly) { + configs += rtc_prod_configs + } + + configs += invoker.configs + configs += rtc_library_impl_config + configs -= rtc_remove_configs + configs -= invoker.suppressed_configs + public_configs = [ + rtc_common_inherited_config, + absl_include_config, + absl_define_config, + ] + if (defined(testonly) && testonly) { + public_configs += [ absl_flags_config ] + } + if (defined(invoker.public_configs)) { + public_configs += invoker.public_configs + } + + # If absl_deps is [], no action is needed. If not [], then it needs to be + # converted to //third_party/abseil-cpp:absl when build_with_chromium=true + # otherwise it just needs to be added to deps. + if (absl_deps != []) { + if (!defined(deps)) { + deps = [] + } + if (build_with_chromium) { + deps += [ "//third_party/abseil-cpp:absl" ] + } else { + deps += absl_deps + } + } + } +} + +# This template automatically switches the target type between source_set +# and static_library. +# +# This should be the default target type for all the WebRTC targets. +# +# How does it work: +# Since all files in a source_set are linked into a final binary, while files +# in a static library are only linked in if at least one symbol in them is +# referenced, in component builds source_sets are easy to deal with because +# all their object files are passed to the linker to create a shared library. +# In release builds instead, static_libraries are preferred since they allow +# the linker to discard dead code. +# For the same reason, testonly targets will always be expanded to +# source_set in order to be sure that tests are present in the test binary. +template("rtc_library") { + header_only = true + if (defined(invoker.sources)) { + non_header_sources = filter_exclude(invoker.sources, + [ + "*.h", + "*.hh", + "*.inc", + ]) + if (non_header_sources != []) { + header_only = false + } + } + + # Header only libraries should use source_set as a static_library with no + # source files will cause issues with macOS libtool. + if (header_only || is_component_build || + (defined(invoker.testonly) && invoker.testonly)) { + target_type = "source_set" + } else { + target_type = "static_library" + } + target(target_type, target_name) { + forward_variables_from(invoker, + "*", + [ + "configs", + "public_configs", + "suppressed_configs", + "visibility", + ]) + forward_variables_from(invoker, [ "visibility" ]) + if (!defined(visibility)) { + visibility = webrtc_default_visibility + } + + # What's your poison? + if (defined(testonly) && testonly) { + assert(!defined(poisonous)) + assert(!defined(allow_poison)) + } else { + if (!defined(poisonous)) { + poisonous = [] + } + if (!defined(allow_poison)) { + allow_poison = [] + } + if (!defined(assert_no_deps)) { + assert_no_deps = [] + } + if (!defined(deps)) { + deps = [] + } + foreach(p, poisonous) { + deps += [ webrtc_root + ":poison_" + p ] + } + foreach(poison_type, all_poison_types) { + allow_dep = true + foreach(v, visibility) { + if (v == "*") { + allow_dep = false + } + } + foreach(p, allow_poison + poisonous) { + if (p == poison_type) { + allow_dep = true + } + } + if (!allow_dep) { + assert_no_deps += [ webrtc_root + ":poison_" + poison_type ] + } + } + } + + # Chromium should only depend on the WebRTC component in order to + # avoid to statically link WebRTC in a component build. + if (build_with_chromium) { + publicly_visible = false + foreach(v, visibility) { + if (v == "*") { + publicly_visible = true + } + } + if (publicly_visible) { + visibility = [] + visibility = webrtc_default_visibility + } + } + + if (!defined(testonly) || !testonly) { + configs += rtc_prod_configs + } + + configs += invoker.configs + configs += rtc_library_impl_config + configs -= rtc_remove_configs + configs -= invoker.suppressed_configs + public_configs = [ + rtc_common_inherited_config, + absl_include_config, + absl_define_config, + ] + if (defined(testonly) && testonly) { + public_configs += [ absl_flags_config ] + } + if (defined(invoker.public_configs)) { + public_configs += invoker.public_configs + } + + # If absl_deps is [], no action is needed. If not [], then it needs to be + # converted to //third_party/abseil-cpp:absl when build_with_chromium=true + # otherwise it just needs to be added to deps. + if (absl_deps != []) { + if (!defined(deps)) { + deps = [] + } + if (build_with_chromium) { + deps += [ "//third_party/abseil-cpp:absl" ] + } else { + deps += absl_deps + } + } + } +} + +template("rtc_executable") { + executable(target_name) { + forward_variables_from(invoker, + "*", + [ + "deps", + "configs", + "public_configs", + "suppressed_configs", + "visibility", + ]) + forward_variables_from(invoker, [ "visibility" ]) + if (!defined(visibility)) { + visibility = webrtc_default_visibility + } + configs += invoker.configs + configs -= rtc_remove_configs + configs -= invoker.suppressed_configs + deps = invoker.deps + + public_configs = [ + rtc_common_inherited_config, + absl_include_config, + absl_define_config, + ] + if (defined(testonly) && testonly) { + public_configs += [ absl_flags_config ] + } + if (defined(invoker.public_configs)) { + public_configs += invoker.public_configs + } + if (is_win) { + deps += [ + # Give executables the default manifest on Windows (a no-op elsewhere). + "//build/win:default_exe_manifest", + ] + } + } +} + +template("rtc_shared_library") { + shared_library(target_name) { + forward_variables_from(invoker, + "*", + [ + "configs", + "public_configs", + "suppressed_configs", + "visibility", + ]) + forward_variables_from(invoker, [ "visibility" ]) + if (!defined(visibility)) { + visibility = webrtc_default_visibility + } + + # What's your poison? + if (defined(testonly) && testonly) { + assert(!defined(poisonous)) + assert(!defined(allow_poison)) + } else { + if (!defined(poisonous)) { + poisonous = [] + } + if (!defined(allow_poison)) { + allow_poison = [] + } + if (!defined(assert_no_deps)) { + assert_no_deps = [] + } + if (!defined(deps)) { + deps = [] + } + foreach(p, poisonous) { + deps += [ webrtc_root + ":poison_" + p ] + } + foreach(poison_type, all_poison_types) { + allow_dep = true + foreach(v, visibility) { + if (v == "*") { + allow_dep = false + } + } + foreach(p, allow_poison + poisonous) { + if (p == poison_type) { + allow_dep = true + } + } + if (!allow_dep) { + assert_no_deps += [ webrtc_root + ":poison_" + poison_type ] + } + } + } + + configs += invoker.configs + configs -= rtc_remove_configs + configs -= invoker.suppressed_configs + public_configs = [ + rtc_common_inherited_config, + absl_include_config, + absl_define_config, + ] + if (defined(testonly) && testonly) { + public_configs += [ absl_flags_config ] + } + if (defined(invoker.public_configs)) { + public_configs += invoker.public_configs + } + } +} + +if (is_mac || is_ios) { + template("apple_framework_bundle_with_umbrella_header") { + forward_variables_from(invoker, [ "output_name" ]) + this_target_name = target_name + umbrella_header_path = + "$target_gen_dir/$output_name.framework/WebRTC/$output_name.h" + modulemap_path = "$target_gen_dir/Modules/module.modulemap" + + action_foreach("create_bracket_include_headers_$target_name") { + script = "//tools_webrtc/apple/copy_framework_header.py" + sources = invoker.sources + output_name = invoker.output_name + outputs = [ + "$target_gen_dir/$output_name.framework/WebRTC/{{source_file_part}}", + ] + args = [ + "--input", + "{{source}}", + "--output", + rebase_path(target_gen_dir, root_build_dir) + + "/$output_name.framework/WebRTC/{{source_file_part}}", + ] + } + + if (is_mac) { + mac_framework_bundle(target_name) { + forward_variables_from(invoker, "*", [ "configs" ]) + if (defined(invoker.configs)) { + configs += invoker.configs + } + + framework_version = "A" + framework_contents = [ + "Headers", + "Modules", + "Resources", + ] + + ldflags = [ + "-all_load", + "-install_name", + "@rpath/$output_name.framework/$output_name", + ] + + deps += [ + ":copy_framework_headers_$this_target_name", + ":copy_modulemap_$this_target_name", + ":copy_umbrella_header_$this_target_name", + ":create_bracket_include_headers_$this_target_name", + ":modulemap_$this_target_name", + ":umbrella_header_$this_target_name", + ] + } + } + if (is_ios) { + ios_framework_bundle(target_name) { + forward_variables_from(invoker, + "*", + [ + "configs", + "public_headers", + ]) + if (defined(invoker.configs)) { + configs += invoker.configs + } + public_headers = get_target_outputs( + ":create_bracket_include_headers_$this_target_name") + + deps += [ + ":copy_umbrella_header_$this_target_name", + ":create_bracket_include_headers_$this_target_name", + ] + } + } + + if (is_mac || target_environment == "catalyst") { + # Catalyst frameworks use the same layout as regular Mac frameworks. + headers_dir = "Versions/A/Headers" + } else { + headers_dir = "Headers" + } + + bundle_data("copy_framework_headers_$this_target_name") { + sources = get_target_outputs( + ":create_bracket_include_headers_$this_target_name") + + outputs = [ "{{bundle_contents_dir}}/Headers/{{source_file_part}}" ] + deps = [ ":create_bracket_include_headers_$this_target_name" ] + } + + action("modulemap_$this_target_name") { + script = "//tools_webrtc/ios/generate_modulemap.py" + args = [ + "--out", + rebase_path(modulemap_path, root_build_dir), + "--name", + output_name, + ] + outputs = [ modulemap_path ] + } + + bundle_data("copy_modulemap_$this_target_name") { + sources = [ modulemap_path ] + outputs = [ "{{bundle_contents_dir}}/Modules/module.modulemap" ] + deps = [ ":modulemap_$this_target_name" ] + } + + action("umbrella_header_$this_target_name") { + sources = get_target_outputs( + ":create_bracket_include_headers_$this_target_name") + + script = "//tools_webrtc/ios/generate_umbrella_header.py" + + outputs = [ umbrella_header_path ] + args = [ + "--out", + rebase_path(umbrella_header_path, root_build_dir), + "--sources", + ] + sources + deps = [ ":create_bracket_include_headers_$this_target_name" ] + } + + copy("copy_umbrella_header_$target_name") { + sources = [ umbrella_header_path ] + outputs = + [ "$root_out_dir/$output_name.framework/$headers_dir/$output_name.h" ] + + deps = [ ":umbrella_header_$target_name" ] + } + } +} + +if (is_android && !build_with_mozilla) { + template("rtc_android_library") { + android_library(target_name) { + forward_variables_from(invoker, + "*", + [ + "configs", + "public_configs", + "suppressed_configs", + "visibility", + ]) + + errorprone_args = [] + + # Treat warnings as errors. + errorprone_args += [ "-Werror" ] + + # Add any arguments defined by the invoker. + if (defined(invoker.errorprone_args)) { + errorprone_args += invoker.errorprone_args + } + + if (!defined(deps)) { + deps = [] + } + + no_build_hooks = true + not_needed([ "android_manifest" ]) + } + } + + template("rtc_android_apk") { + android_apk(target_name) { + forward_variables_from(invoker, + "*", + [ + "configs", + "public_configs", + "suppressed_configs", + "visibility", + ]) + + # Treat warnings as errors. + errorprone_args = [] + errorprone_args += [ "-Werror" ] + + if (!defined(deps)) { + deps = [] + } + + no_build_hooks = true + } + } + + template("rtc_instrumentation_test_apk") { + instrumentation_test_apk(target_name) { + forward_variables_from(invoker, + "*", + [ + "configs", + "public_configs", + "suppressed_configs", + "visibility", + ]) + + # Treat warnings as errors. + errorprone_args = [] + errorprone_args += [ "-Werror" ] + + if (!defined(deps)) { + deps = [] + } + + no_build_hooks = true + } + } +} -- cgit v1.2.3