|  | # 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_fuchsia) { | 
|  | import("//build/config/fuchsia/config.gni") | 
|  | } | 
|  |  | 
|  | if (build_with_chromium) { | 
|  | import("//media/media_options.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() { | 
|  | # 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 | 
|  |  | 
|  | # Enables additional build targets that rely on | 
|  | # //third_party/google_benchmarks. | 
|  | rtc_enable_google_benchmarks = true | 
|  |  | 
|  | # 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 | 
|  |  | 
|  | # 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 | 
|  |  | 
|  | # 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 = "" | 
|  |  | 
|  | # 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 false to skip building examples. | 
|  | rtc_build_examples = true | 
|  |  | 
|  | # Set this to false to skip building tools. | 
|  | rtc_build_tools = true | 
|  |  | 
|  | # Set this to false to skip building code that requires X11. | 
|  | rtc_use_x11 = ozone_platform_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 | 
|  |  | 
|  | # Enable to use the Mozilla internal settings. | 
|  | build_with_mozilla = 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 (current_cpu == "arm" || current_cpu == "arm64") { | 
|  | rtc_prefer_fixed_point = true | 
|  | } | 
|  |  | 
|  | # Determines whether NEON code will be built. | 
|  | rtc_build_with_neon = | 
|  | (current_cpu == "arm" && arm_use_neon) || current_cpu == "arm64" | 
|  |  | 
|  | # Enable this to build OpenH264 encoder/FFmpeg decoder. When building WebRTC | 
|  | # as part of Chromium, this is delegated to `media_use_openh264`. When | 
|  | # building WebRTC as a standalone library, 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. | 
|  | if (build_with_chromium) { | 
|  | rtc_use_h264 = media_use_openh264 | 
|  | } else { | 
|  | rtc_use_h264 = | 
|  | proprietary_codecs && !is_android && !is_ios && !(is_win && !is_clang) | 
|  | } | 
|  |  | 
|  | # Use system OpenH264 | 
|  | rtc_system_openh264 = false | 
|  |  | 
|  | # Enable to use H265 | 
|  | if (build_with_chromium) { | 
|  | rtc_use_h265 = enable_hevc_parser_and_hw_decoder | 
|  | } else { | 
|  | rtc_use_h265 = proprietary_codecs | 
|  | } | 
|  |  | 
|  | # 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. | 
|  | rtc_ios_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 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 = is_win | 
|  |  | 
|  | # Includes the dav1d decoder in the internal decoder factory when set to true. | 
|  | rtc_include_dav1d_in_internal_decoder_factory = true | 
|  |  | 
|  | # When enabled, a run-time check will make sure that all field trial keys have | 
|  | # been registered in accordance with the field trial policy, see | 
|  | # g3doc/field-trials.md. The value can be set to the following: | 
|  | # | 
|  | #  "dcheck": RTC_DCHECKs that the field trial has been registered. RTC_DCHECK | 
|  | #            must be enabled separately. | 
|  | # | 
|  | #  "warn": RTC_LOGs a message with LS_WARNING severity if the field trial | 
|  | #          hasn't been registered. | 
|  | rtc_strict_field_trials = "" | 
|  |  | 
|  | # If different from "", symbols exported with RTC_OBJC_EXPORT will be prefixed | 
|  | # with this string. | 
|  | # See the definition of RTC_OBJC_TYPE_PREFIX in the code. | 
|  | rtc_objc_prefix = "" | 
|  |  | 
|  | # Embedders can define dependencies needed by WebRTC. Dependencies can be | 
|  | # configs or targets. This can be defined in their `.gn` file. | 
|  | # | 
|  | # In practise, this is use by Chromium: Targets from | 
|  | # `//third_party/webrtc_overrides` are depending on Chrome's `//base`, but | 
|  | # WebRTC does not declare its public dependencies. See webrtc:8603. Instead | 
|  | # WebRTC is using a global common dependencies. | 
|  | rtc_common_public_deps = []  # no-presubmit-check TODO(webrtc:8603) | 
|  |  | 
|  | # When true, include the Perfetto library. | 
|  | rtc_use_perfetto = false | 
|  |  | 
|  | # When true allows exports from deprecated namespaces. | 
|  | # This will be set to false on Jun 23 2025. See bugs.webrtc.org/42232595 | 
|  | # for details. | 
|  | rtc_allow_deprecated_namespaces = true | 
|  | } | 
|  |  | 
|  | 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 = !build_with_mozilla | 
|  | rtc_build_opus = !build_with_mozilla | 
|  | rtc_build_ssl = !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 | 
|  |  | 
|  | # 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) { | 
|  | 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 | 
|  |  | 
|  | # Enables an experimental rust version of base64 for building and testing. | 
|  | rtc_rusty_base64 = true | 
|  | } | 
|  |  | 
|  | 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) | 
|  | } | 
|  |  | 
|  | # 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_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) { | 
|  | if (filter_include(default_compiler_configs, | 
|  | [ "//build/config/compiler:enable_arc" ]) == []) { | 
|  | rtc_common_configs += [ "//build/config/compiler:enable_arc" ] | 
|  | } | 
|  | } | 
|  |  | 
|  | if (build_with_chromium) { | 
|  | rtc_use_perfetto = true | 
|  | } | 
|  |  | 
|  | # 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 | 
|  | public_deps = rtc_common_public_deps  # no-presubmit-check TODO(webrtc:8603) | 
|  | suppressed_configs = [] | 
|  | } | 
|  |  | 
|  | set_defaults("rtc_library") { | 
|  | configs = rtc_add_configs | 
|  | public_deps = rtc_common_public_deps  # no-presubmit-check TODO(webrtc:8603) | 
|  | suppressed_configs = [] | 
|  | } | 
|  |  | 
|  | set_defaults("rtc_source_set") { | 
|  | configs = rtc_add_configs | 
|  | public_deps = rtc_common_public_deps  # no-presubmit-check TODO(webrtc:8603) | 
|  | suppressed_configs = [] | 
|  | } | 
|  |  | 
|  | set_defaults("rtc_static_library") { | 
|  | configs = rtc_add_configs | 
|  | public_deps = rtc_common_public_deps  # no-presubmit-check TODO(webrtc:8603) | 
|  | suppressed_configs = [] | 
|  | } | 
|  |  | 
|  | set_defaults("rtc_executable") { | 
|  | configs = rtc_add_configs | 
|  | public_deps = rtc_common_public_deps  # no-presubmit-check TODO(webrtc:8603) | 
|  | suppressed_configs = [] | 
|  | } | 
|  |  | 
|  | set_defaults("rtc_shared_library") { | 
|  | configs = rtc_add_configs | 
|  | public_deps = rtc_common_public_deps  # no-presubmit-check TODO(webrtc:8603) | 
|  | 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 echo detector implementation. | 
|  | "default_echo_detector", | 
|  |  | 
|  | # Implementations of the utilities exposed through `Environment`. | 
|  | # Most webrtc classes must use propagated `Environment`. Only few top-level | 
|  | # classes are allowed to create `Environment` from individual utilities. | 
|  | "environment_construction", | 
|  |  | 
|  | # 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) { | 
|  | use_default_launcher = false | 
|  | android_manifest = webrtc_root + "test/android/AndroidManifest.xml" | 
|  | use_raw_android_executable = false | 
|  | min_sdk_version = 21 | 
|  | target_sdk_version = 24 | 
|  | deps += [ | 
|  | "//build/android/gtest_apk:native_test_instrumentation_test_runner_java", | 
|  | webrtc_root + "sdk/android:native_test_jni_onload", | 
|  | webrtc_root + "sdk/android:base_java", | 
|  | webrtc_root + "test:native_test_java", | 
|  | webrtc_root + "test:native_test_support", | 
|  | "//third_party/jni_zero:jni_zero_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" | 
|  | } | 
|  | } | 
|  |  | 
|  | assert( | 
|  | !defined(absl_deps), | 
|  | "`absl_deps` has been deprecated, add your Abseil dependencies to the `deps` variable.") | 
|  |  | 
|  | # Abseil dependencies need to be converted to //third_party/abseil-cpp:absl when build_with_chromium=true | 
|  | if (build_with_chromium && defined(deps)) { | 
|  | absl_dependencies = | 
|  | filter_labels_include(deps, [ "//third_party/abseil-cpp/*" ]) | 
|  | if (absl_dependencies != []) { | 
|  | filtered_deps = | 
|  | filter_labels_exclude(deps, [ "//third_party/abseil-cpp/*" ]) | 
|  | deps = [] | 
|  | deps = filtered_deps | 
|  | deps += [ "//third_party/abseil-cpp:absl" ] | 
|  | } | 
|  | } | 
|  |  | 
|  | # 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 | 
|  | } | 
|  |  | 
|  | if (defined(invoker.sources)) { | 
|  | nonheader_sources = filter_include(invoker.sources, [ "*.cc" ]) | 
|  | assert(nonheader_sources == [], | 
|  | "rtc_source_set shall not contain cc files") | 
|  | } | 
|  |  | 
|  | # 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 | 
|  | } | 
|  |  | 
|  | assert( | 
|  | !defined(absl_deps), | 
|  | "`absl_deps` has been deprecated, add your Abseil dependencies to the `deps` variable.") | 
|  |  | 
|  | # Abseil dependencies need to be converted to //third_party/abseil-cpp:absl when build_with_chromium=true | 
|  | if (build_with_chromium && defined(deps)) { | 
|  | absl_dependencies = | 
|  | filter_labels_include(deps, [ "//third_party/abseil-cpp/*" ]) | 
|  | if (absl_dependencies != []) { | 
|  | filtered_deps = | 
|  | filter_labels_exclude(deps, [ "//third_party/abseil-cpp/*" ]) | 
|  | deps = [] | 
|  | deps = filtered_deps | 
|  | deps += [ "//third_party/abseil-cpp:absl" ] | 
|  | } | 
|  | } | 
|  | } | 
|  | } | 
|  |  | 
|  | 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 | 
|  | } | 
|  |  | 
|  | assert( | 
|  | !defined(absl_deps), | 
|  | "`absl_deps` has been deprecated, add your Abseil dependencies to the `deps` variable.") | 
|  |  | 
|  | # Abseil dependencies need to be converted to //third_party/abseil-cpp:absl when build_with_chromium=true | 
|  | if (build_with_chromium && defined(deps)) { | 
|  | absl_dependencies = | 
|  | filter_labels_include(deps, [ "//third_party/abseil-cpp/*" ]) | 
|  | if (absl_dependencies != []) { | 
|  | filtered_deps = | 
|  | filter_labels_exclude(deps, [ "//third_party/abseil-cpp/*" ]) | 
|  | deps = [] | 
|  | deps = filtered_deps | 
|  | deps += [ "//third_party/abseil-cpp:absl" ] | 
|  | } | 
|  | } | 
|  | } | 
|  | } | 
|  |  | 
|  | # 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 | 
|  | } | 
|  |  | 
|  | assert( | 
|  | !defined(absl_deps), | 
|  | "`absl_deps` has been deprecated, add your Abseil dependencies to the `deps` variable.") | 
|  |  | 
|  | # Abseil dependencies need to be converted to //third_party/abseil-cpp:absl when build_with_chromium=true | 
|  | if (build_with_chromium && defined(deps)) { | 
|  | absl_dependencies = | 
|  | filter_labels_include(deps, [ "//third_party/abseil-cpp/*" ]) | 
|  | if (absl_dependencies != []) { | 
|  | filtered_deps = | 
|  | filter_labels_exclude(deps, [ "//third_party/abseil-cpp/*" ]) | 
|  | deps = [] | 
|  | deps = filtered_deps | 
|  | deps += [ "//third_party/abseil-cpp:absl" ] | 
|  | } | 
|  | } | 
|  | } | 
|  | } | 
|  |  | 
|  | 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", | 
|  | ] | 
|  | } | 
|  |  | 
|  | # Convert abseil dependencies to //third_party/abseil-cpp:absl_full when | 
|  | # build_with_chromium=true so that webrtc targets won't need exceptions to | 
|  | # depend on individual absl targets. | 
|  | # Note that //third_party/abseil-cpp:absl_full build target includes flags, | 
|  | # but //third_party/abseil-cpp:absl target - doesn't. That allows webrtc | 
|  | # executables, but not libraries to use absl flags. | 
|  | if (build_with_chromium && defined(deps)) { | 
|  | absl_dependencies = | 
|  | filter_labels_include(deps, [ "//third_party/abseil-cpp/*" ]) | 
|  | if (absl_dependencies != []) { | 
|  | filtered_deps = | 
|  | filter_labels_exclude(deps, [ "//third_party/abseil-cpp/*" ]) | 
|  | deps = [] | 
|  | deps = filtered_deps | 
|  | deps += [ "//third_party/abseil-cpp:absl_full" ] | 
|  | } | 
|  | } | 
|  | } | 
|  | } | 
|  |  | 
|  | 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" | 
|  | privacy_manifest_path = "$target_gen_dir/$target_name/PrivacyInfo.xcprivacy" | 
|  |  | 
|  | 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_privacy_manifest_$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_privacy_manifest_$this_target_name", | 
|  | ":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" | 
|  |  | 
|  | # The path to the privacy manifest file differs between Mac and iOS. | 
|  | # https://developer.apple.com/documentation/bundleresources/privacy_manifest_files/adding_a_privacy_manifest_to_your_app_or_third-party_sdk | 
|  | privacy_manifest_out_path = "Versions/A/Resources/PrivacyInfo.xcprivacy" | 
|  | } else { | 
|  | headers_dir = "Headers" | 
|  | privacy_manifest_out_path = "PrivacyInfo.xcprivacy" | 
|  | } | 
|  |  | 
|  | 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" ] | 
|  | } | 
|  |  | 
|  | action("create_privacy_manifest_$target_name") { | 
|  | script = "//tools_webrtc/apple/generate_privacy_manifest.py" | 
|  |  | 
|  | args = [ | 
|  | "--output", | 
|  | rebase_path(privacy_manifest_path), | 
|  | ] | 
|  |  | 
|  | outputs = [ privacy_manifest_path ] | 
|  | } | 
|  |  | 
|  | copy("copy_privacy_manifest_$target_name") { | 
|  | sources = [ privacy_manifest_path ] | 
|  | outputs = | 
|  | [ "$root_out_dir/$output_name.framework/$privacy_manifest_out_path" ] | 
|  |  | 
|  | deps = [ ":create_privacy_manifest_$target_name" ] | 
|  | } | 
|  | } | 
|  | } | 
|  |  | 
|  | if (is_android) { | 
|  | template("rtc_android_library") { | 
|  | android_library(target_name) { | 
|  | forward_variables_from(invoker, | 
|  | "*", | 
|  | [ | 
|  | "configs", | 
|  | "public_configs", | 
|  | "suppressed_configs", | 
|  | "visibility", | 
|  | ]) | 
|  |  | 
|  | # Add any arguments defined by the invoker. | 
|  | if (defined(invoker.errorprone_args)) { | 
|  | errorprone_args = invoker.errorprone_args | 
|  | } | 
|  |  | 
|  | not_needed([ "android_manifest" ]) | 
|  | } | 
|  | } | 
|  |  | 
|  | template("rtc_android_apk") { | 
|  | android_apk(target_name) { | 
|  | forward_variables_from(invoker, | 
|  | "*", | 
|  | [ | 
|  | "configs", | 
|  | "public_configs", | 
|  | "suppressed_configs", | 
|  | "visibility", | 
|  | ]) | 
|  | } | 
|  | } | 
|  |  | 
|  | template("rtc_instrumentation_test_apk") { | 
|  | instrumentation_test_apk(target_name) { | 
|  | forward_variables_from(invoker, | 
|  | "*", | 
|  | [ | 
|  | "configs", | 
|  | "public_configs", | 
|  | "suppressed_configs", | 
|  | "visibility", | 
|  | ]) | 
|  | deps += [ "//third_party/jni_zero:jni_zero_java" ] | 
|  | } | 
|  | } | 
|  | } |