blob: c4a62fc5489eccae382983151bbe5d45cdfc5258 [file] [log] [blame]
mbonadei9aa3f0a2017-01-24 06:58:22 -08001# Copyright (c) 2014 The WebRTC project authors. All Rights Reserved.
2#
3# Use of this source code is governed by a BSD-style license
4# that can be found in the LICENSE file in the root of the source
5# tree. An additional intellectual property rights grant can be found
6# in the file PATENTS. All contributing project authors may
7# be found in the AUTHORS file in the root of the source tree.
mbonadei9aa3f0a2017-01-24 06:58:22 -08008import("//build/config/arm.gni")
9import("//build/config/features.gni")
10import("//build/config/mips.gni")
Maksim Sisovef4d0b62021-09-20 09:02:01 +030011import("//build/config/ozone.gni")
mbonadei9aa3f0a2017-01-24 06:58:22 -080012import("//build/config/sanitizers/sanitizers.gni")
Tomas Popela318da512018-11-13 06:32:23 +010013import("//build/config/sysroot.gni")
mbonadei9aa3f0a2017-01-24 06:58:22 -080014import("//build_overrides/build.gni")
mbonadei96606272017-03-03 19:41:59 -080015
16if (!build_with_chromium && is_component_build) {
17 print("The Gn argument `is_component_build` is currently " +
18 "ignored for WebRTC builds.")
19 print("Component builds are supported by Chromium and the argument " +
20 "`is_component_build` makes it possible to create shared libraries " +
21 "instead of static libraries.")
22 print("If an app depends on WebRTC it makes sense to just depend on the " +
23 "WebRTC static library, so there is no difference between " +
24 "`is_component_build=true` and `is_component_build=false`.")
25 print(
Fanny Linderborg0d2dc1f2021-07-14 14:02:11 +000026 "More info about component builds at: " + "https://chromium.googlesource.com/chromium/src/+/main/docs/component_build.md")
mbonadei96606272017-03-03 19:41:59 -080027 assert(!is_component_build, "Component builds are not supported in WebRTC.")
28}
29
kthelgason4065a572017-02-14 04:58:56 -080030if (is_ios) {
31 import("//build/config/ios/rules.gni")
32}
mbonadei9aa3f0a2017-01-24 06:58:22 -080033
Anders Carlsson37bbf792018-09-05 16:29:27 +020034if (is_mac) {
35 import("//build/config/mac/rules.gni")
36}
37
Mirko Bonadei5f078452021-07-30 22:32:55 +020038# This declare_args is separated from the next one because args declared
39# in this one, can be read from the next one (args defined in the same
40# declare_args cannot be referenced in that scope).
mbonadei9aa3f0a2017-01-24 06:58:22 -080041declare_args() {
Mirko Bonadei028248c2018-10-10 12:19:02 +020042 # Setting this to true will make RTC_EXPORT (see rtc_base/system/rtc_export.h)
43 # expand to code that will manage symbols visibility.
44 rtc_enable_symbol_export = false
Mirko Bonadei5f078452021-07-30 22:32:55 +020045}
46
47declare_args() {
Mirko Bonadei339965f2021-10-12 13:23:44 +020048 # Setting this to true, will make RTC_DLOG() expand to log statements instead
Mirko Bonadei56ed4682021-10-12 08:55:42 +020049 # of being removed by the preprocessor.
50 # This is useful for example to be able to get RTC_DLOGs on a release build.
51 rtc_dlog_always_on = false
52
Mirko Bonadei5f078452021-07-30 22:32:55 +020053 # Setting this to true will make RTC_OBJC_EXPORT expand to code that will
54 # manage symbols visibility. By default, Obj-C/Obj-C++ symbols are exported
55 # if C++ symbols are but setting this arg to true while keeping
56 # rtc_enable_symbol_export=false will only export RTC_OBJC_EXPORT
57 # annotated symbols.
58 rtc_enable_objc_symbol_export = rtc_enable_symbol_export
Mirko Bonadei028248c2018-10-10 12:19:02 +020059
Mirko Bonadei31b0b452018-08-22 10:37:11 +020060 # Setting this to true will define WEBRTC_EXCLUDE_FIELD_TRIAL_DEFAULT which
Mirko Bonadei70400902018-08-21 15:44:28 +020061 # will tell the pre-processor to remove the default definition of symbols
62 # needed to use field_trial. In that case a new implementation needs to be
63 # provided.
Mirko Bonadei31b0b452018-08-22 10:37:11 +020064 if (build_with_chromium) {
65 # When WebRTC is built as part of Chromium it should exclude the default
66 # implementation of field_trial unless it is building for NACL or
67 # Chromecast.
68 rtc_exclude_field_trial_default = !is_nacl && !is_chromecast
69 } else {
70 rtc_exclude_field_trial_default = false
71 }
Mirko Bonadei70400902018-08-21 15:44:28 +020072
Mirko Bonadei906add42018-09-05 16:03:16 +020073 # Setting this to true will define WEBRTC_EXCLUDE_METRICS_DEFAULT which
74 # will tell the pre-processor to remove the default definition of symbols
75 # needed to use metrics. In that case a new implementation needs to be
76 # provided.
77 rtc_exclude_metrics_default = build_with_chromium
78
Johannes Kronda20c732021-02-19 16:39:41 +010079 # Setting this to true will define WEBRTC_EXCLUDE_SYSTEM_TIME which
80 # will tell the pre-processor to remove the default definition of the
81 # SystemTimeNanos() which is defined in rtc_base/system_time.cc. In
82 # that case a new implementation needs to be provided.
Johannes Kronbb52bdf2021-02-25 10:10:08 +010083 rtc_exclude_system_time = build_with_chromium
Johannes Kronda20c732021-02-19 16:39:41 +010084
Benjamin Wrightd6f86e82018-05-08 13:12:25 -070085 # Setting this to false will require the API user to pass in their own
86 # SSLCertificateVerifier to verify the certificates presented from a
87 # TLS-TURN server. In return disabling this saves around 100kb in the binary.
88 rtc_builtin_ssl_root_certificates = true
89
Karl Wibergeb254b42017-11-01 15:08:12 +010090 # Include the iLBC audio codec?
Olga Sharonova5fbd7582020-07-09 09:50:42 +000091 rtc_include_ilbc = true
Karl Wibergeb254b42017-11-01 15:08:12 +010092
mbonadei9aa3f0a2017-01-24 06:58:22 -080093 # Disable this to avoid building the Opus audio codec.
94 rtc_include_opus = true
95
minyue2e03c662017-02-01 17:31:11 -080096 # Enable this if the Opus version upon which WebRTC is built supports direct
97 # encoding of 120 ms packets.
minyue-webrtc516711c2017-07-27 17:45:49 +020098 rtc_opus_support_120ms_ptime = true
minyue2e03c662017-02-01 17:31:11 -080099
mbonadei9aa3f0a2017-01-24 06:58:22 -0800100 # Enable this to let the Opus audio codec change complexity on the fly.
101 rtc_opus_variable_complexity = false
102
mbonadei9aa3f0a2017-01-24 06:58:22 -0800103 # Used to specify an external Jsoncpp include path when not compiling the
104 # library that comes with WebRTC (i.e. rtc_build_json == 0).
105 rtc_jsoncpp_root = "//third_party/jsoncpp/source/include"
106
107 # Used to specify an external OpenSSL include path when not compiling the
108 # library that comes with WebRTC (i.e. rtc_build_ssl == 0).
109 rtc_ssl_root = ""
110
mbonadei9aa3f0a2017-01-24 06:58:22 -0800111 # Enable when an external authentication mechanism is used for performing
112 # packet authentication for RTP packets instead of libsrtp.
113 rtc_enable_external_auth = build_with_chromium
114
115 # Selects whether debug dumps for the audio processing module
116 # should be generated.
117 apm_debug_dump = false
118
Per Åhgrencc73ed32020-04-26 23:56:17 +0200119 # Selects whether the audio processing module should be excluded.
120 rtc_exclude_audio_processing_module = false
121
mbonadei9aa3f0a2017-01-24 06:58:22 -0800122 # Set this to true to enable BWE test logging.
123 rtc_enable_bwe_test_logging = false
124
Joachim Bauch93e91342017-12-07 01:25:53 +0100125 # Set this to false to skip building examples.
126 rtc_build_examples = true
127
128 # Set this to false to skip building tools.
129 rtc_build_tools = true
130
Joachim Bauch75f18fc2017-12-20 21:25:47 +0100131 # Set this to false to skip building code that requires X11.
Maksim Sisovef4d0b62021-09-20 09:02:01 +0300132 rtc_use_x11 = ozone_platform_x11
Joachim Bauch75f18fc2017-12-20 21:25:47 +0100133
Tomas Popela318da512018-11-13 06:32:23 +0100134 # Set this to use PipeWire on the Wayland display server.
Tomas Popela762543f2018-12-12 14:37:51 +0100135 # By default it's only enabled on desktop Linux (excludes ChromeOS) and
136 # only when using the sysroot as PipeWire is not available in older and
137 # supported Ubuntu and Debian distributions.
Artem Titov4d6a76d2021-09-03 10:07:20 +0000138 rtc_use_pipewire = is_linux && use_sysroot
Tomas Popela762543f2018-12-12 14:37:51 +0100139
Jan Gruliche1e05af2021-09-21 20:36:16 +0200140 # Set this to link PipeWire and required libraries directly instead of using the dlopen.
Tomas Popela762543f2018-12-12 14:37:51 +0100141 rtc_link_pipewire = false
Tomas Popela318da512018-11-13 06:32:23 +0100142
mbonadei9aa3f0a2017-01-24 06:58:22 -0800143 # Enable to use the Mozilla internal settings.
144 build_with_mozilla = false
145
Philipp Hanckee95ebda2020-09-17 16:13:20 +0200146 # Experimental: enable use of Android AAudio which requires Android SDK 26 or above
147 # and NDK r16 or above.
henrika883d00f2018-03-16 10:09:49 +0100148 rtc_enable_android_aaudio = false
149
mbonadei9aa3f0a2017-01-24 06:58:22 -0800150 # Set to "func", "block", "edge" for coverage generation.
151 # At unit test runtime set UBSAN_OPTIONS="coverage=1".
152 # It is recommend to set include_examples=0.
153 # Use llvm's sancov -html-report for human readable reports.
154 # See http://clang.llvm.org/docs/SanitizerCoverage.html .
155 rtc_sanitize_coverage = ""
156
Philipp Hanckeaeac9f82020-09-11 11:58:18 +0200157 # Selects fixed-point code where possible.
158 rtc_prefer_fixed_point = false
mbonadei9aa3f0a2017-01-24 06:58:22 -0800159 if (current_cpu == "arm" || current_cpu == "arm64") {
160 rtc_prefer_fixed_point = true
161 }
162
mbonadei9aa3f0a2017-01-24 06:58:22 -0800163 # Determines whether NEON code will be built.
164 rtc_build_with_neon =
165 (current_cpu == "arm" && arm_use_neon) || current_cpu == "arm64"
166
167 # Enable this to build OpenH264 encoder/FFmpeg decoder. This is supported on
168 # all platforms except Android and iOS. Because FFmpeg can be built
Artem Titov22a6b2d2021-07-27 16:25:56 +0200169 # with/without H.264 support, `ffmpeg_branding` has to separately be set to a
mbonadei9aa3f0a2017-01-24 06:58:22 -0800170 # value that includes H.264, for example "Chrome". If FFmpeg is built without
Artem Titov22a6b2d2021-07-27 16:25:56 +0200171 # H.264, compilation succeeds but `H264DecoderImpl` fails to initialize.
mbonadei9aa3f0a2017-01-24 06:58:22 -0800172 # CHECK THE OPENH264, FFMPEG AND H.264 LICENSES/PATENTS BEFORE BUILDING.
173 # http://www.openh264.org, https://www.ffmpeg.org/
Mirko Bonadeiee0a85c2019-01-15 10:47:18 +0100174 #
175 # Enabling H264 when building with MSVC is currently not supported, see
176 # bugs.webrtc.org/9213#c13 for more info.
177 rtc_use_h264 =
178 proprietary_codecs && !is_android && !is_ios && !(is_win && !is_clang)
mbonadei9aa3f0a2017-01-24 06:58:22 -0800179
Markus Handell8e75bd42020-06-05 11:47:40 +0200180 # Enable this flag to make webrtc::Mutex be implemented by absl::Mutex.
181 rtc_use_absl_mutex = false
182
mbonadei9aa3f0a2017-01-24 06:58:22 -0800183 # By default, use normal platform audio support or dummy audio, but don't
184 # use file-based audio playout and record.
185 rtc_use_dummy_audio_file_devices = false
186
henrika7be78832017-06-13 17:34:16 +0200187 # When set to true, replace the audio output with a sinus tone at 440Hz.
188 # The ADM will ask for audio data from WebRTC but instead of reading real
189 # audio samples from NetEQ, a sinus tone will be generated and replace the
190 # real audio samples.
191 rtc_audio_device_plays_sinus_tone = false
192
Anders Carlsson358f2e02018-06-04 10:24:37 +0200193 if (is_ios) {
194 # Build broadcast extension in AppRTCMobile for iOS. This results in the
195 # binary only running on iOS 11+, which is why it is disabled by default.
196 rtc_apprtcmobile_broadcast_extension = false
197 }
Anders Carlsson7bca8ca2018-08-30 09:30:29 +0200198
Jordan Rose53d3fc92021-07-06 12:16:41 -0700199 # Determines whether OpenGL is available on iOS/macOS.
200 rtc_ios_macos_use_opengl_rendering =
201 !(is_ios && target_environment == "catalyst")
202
Jiawei Ou08745302019-02-12 11:36:13 -0800203 # When set to false, builtin audio encoder/decoder factories and all the
204 # audio codecs they depend on will not be included in libwebrtc.{a|lib}
205 # (they will still be included in libjingle_peerconnection_so.so and
206 # WebRTC.framework)
207 rtc_include_builtin_audio_codecs = true
208
209 # When set to false, builtin video encoder/decoder factories and all the
210 # video codecs they depends on will not be included in libwebrtc.{a|lib}
211 # (they will still be included in libjingle_peerconnection_so.so and
212 # WebRTC.framework)
213 rtc_include_builtin_video_codecs = true
Mirko Bonadei20574f42019-03-28 07:50:07 +0100214
215 # When set to true and in a standalone build, it will undefine UNICODE and
216 # _UNICODE (which are always defined globally by the Chromium Windows
217 # toolchain).
218 # This is only needed for testing purposes, WebRTC wants to be sure it
219 # doesn't assume /DUNICODE and /D_UNICODE but that it explicitly uses
220 # wide character functions.
221 rtc_win_undef_unicode = false
Austin Orion25b0dee2020-10-01 13:47:54 -0700222
223 # When set to true, a capturer implementation that uses the
Austin Orion66241e42021-04-22 13:22:25 -0700224 # Windows.Graphics.Capture APIs will be available for use. This introduces a
225 # dependency on the Win 10 SDK v10.0.17763.0.
Austin Orion78f04d82021-04-23 12:37:26 -0700226 rtc_enable_win_wgc = is_win
philipelb09d8722021-11-23 11:00:24 +0100227
228 # Includes the dav1d decoder in the internal decoder factory when set to true.
229 rtc_include_dav1d_in_internal_decoder_factory = true
Dan Minor9c686132018-01-15 10:20:00 -0500230}
mbonadei9aa3f0a2017-01-24 06:58:22 -0800231
Dan Minor9c686132018-01-15 10:20:00 -0500232if (!build_with_mozilla) {
233 import("//testing/test.gni")
mbonadei9aa3f0a2017-01-24 06:58:22 -0800234}
235
236# A second declare_args block, so that declarations within it can
237# depend on the possibly overridden variables in the first
238# declare_args block.
239declare_args() {
Dan Minor9c686132018-01-15 10:20:00 -0500240 # Enables the use of protocol buffers for debug recordings.
241 rtc_enable_protobuf = !build_with_mozilla
242
243 # Set this to disable building with support for SCTP data channels.
244 rtc_enable_sctp = !build_with_mozilla
245
246 # Disable these to not build components which can be externally provided.
247 rtc_build_json = !build_with_mozilla
248 rtc_build_libsrtp = !build_with_mozilla
249 rtc_build_libvpx = !build_with_mozilla
250 rtc_libvpx_build_vp9 = !build_with_mozilla
Dan Minor9c686132018-01-15 10:20:00 -0500251 rtc_build_opus = !build_with_mozilla
252 rtc_build_ssl = !build_with_mozilla
Dan Minor9c686132018-01-15 10:20:00 -0500253
254 # Enable libevent task queues on platforms that support it.
Mirko Bonadei775c02e2019-06-19 19:05:00 +0200255 if (is_win || is_mac || is_ios || is_nacl || is_fuchsia ||
256 target_cpu == "wasm") {
Dan Minor9c686132018-01-15 10:20:00 -0500257 rtc_enable_libevent = false
258 rtc_build_libevent = false
259 } else {
260 rtc_enable_libevent = true
261 rtc_build_libevent = !build_with_mozilla
262 }
263
mbonadei9aa3f0a2017-01-24 06:58:22 -0800264 # Excluded in Chromium since its prerequisites don't require Pulse Audio.
265 rtc_include_pulse_audio = !build_with_chromium
266
267 # Chromium uses its own IO handling, so the internal ADM is only built for
268 # standalone WebRTC.
269 rtc_include_internal_audio_device = !build_with_chromium
270
Zhaoliang Ma72e43212020-08-17 17:13:41 +0800271 # Set this to true to enable the avx2 support in webrtc.
Per Åhgrena43178c2020-09-25 12:02:32 +0200272 # TODO: Make sure that AVX2 works also for non-clang compilers.
273 if (is_clang == true) {
274 rtc_enable_avx2 = true
275 } else {
276 rtc_enable_avx2 = false
277 }
Zhaoliang Ma72e43212020-08-17 17:13:41 +0800278
Philipp Hancke1a89bc82021-03-02 21:23:24 +0100279 # Set this to true to build the unit tests.
280 # Disabled when building with Chromium or Mozilla.
Dan Minor9c686132018-01-15 10:20:00 -0500281 rtc_include_tests = !build_with_chromium && !build_with_mozilla
Oleh Prypin240b8932019-06-07 13:27:07 +0200282
283 # Set this to false to skip building code that also requires X11 extensions
284 # such as Xdamage, Xfixes.
285 rtc_use_x11_extensions = rtc_use_x11
Artem Titov6a4a1462019-11-26 16:24:46 +0100286
287 # Set this to true to fully remove logging from WebRTC.
288 rtc_disable_logging = false
Doudou Kisabaka2dec4962019-11-28 14:24:31 +0100289
290 # Set this to true to disable trace events.
291 rtc_disable_trace_events = false
Artem Titov9dc209a2019-11-28 17:09:30 +0100292
293 # Set this to true to disable detailed error message and logging for
294 # RTC_CHECKs.
295 rtc_disable_check_msg = false
Ying Wangef3998f2019-12-09 13:06:53 +0100296
297 # Set this to true to disable webrtc metrics.
Mirko Bonadei3c4fda22019-12-10 15:02:53 +0100298 rtc_disable_metrics = false
sazaaa42ecd2020-04-01 15:24:40 +0200299
300 # Set this to true to exclude the transient suppressor in the audio processing
301 # module from the build.
302 rtc_exclude_transient_suppressor = false
mbonadei9aa3f0a2017-01-24 06:58:22 -0800303}
304
Florent Castellia80c3e52021-04-15 15:02:56 +0200305declare_args() {
Florent Castellia6983c62021-05-06 10:50:07 +0200306 # Enable the dcsctp backend for DataChannels and related unittests
307 rtc_build_dcsctp = !build_with_mozilla && rtc_enable_sctp
308
Florent Castellia80c3e52021-04-15 15:02:56 +0200309 # Enable the usrsctp backend for DataChannels and related unittests
310 rtc_build_usrsctp = !build_with_mozilla && rtc_enable_sctp
Florent Castelli023be3c2022-03-15 16:01:52 +0100311
312 # Enable gRPC used for negotiation in multiprocess tests
313 rtc_enable_grpc = rtc_enable_protobuf && (is_linux || is_mac)
Florent Castellia80c3e52021-04-15 15:02:56 +0200314}
315
mbonadei9aa3f0a2017-01-24 06:58:22 -0800316# Make it possible to provide custom locations for some libraries (move these
317# up into declare_args should we need to actually use them for the GN build).
318rtc_libvpx_dir = "//third_party/libvpx"
mbonadei9aa3f0a2017-01-24 06:58:22 -0800319rtc_opus_dir = "//third_party/opus"
320
321# Desktop capturer is supported only on Windows, OSX and Linux.
Oleh Prypin240b8932019-06-07 13:27:07 +0200322rtc_desktop_capture_supported =
323 (is_win && current_os != "winuwp") || is_mac ||
Hidehiko Abef264e702020-09-10 18:10:11 +0900324 ((is_linux || is_chromeos) && (rtc_use_x11_extensions || rtc_use_pipewire))
mbonadei9aa3f0a2017-01-24 06:58:22 -0800325
326###############################################################################
327# Templates
328#
329
Mirko Bonadei92ea95e2017-09-15 06:47:31 +0200330# Points to // in webrtc stand-alone or to //third_party/webrtc/ in
mbonadei9aa3f0a2017-01-24 06:58:22 -0800331# chromium.
332# We need absolute paths for all configs in templates as they are shared in
333# different subdirectories.
334webrtc_root = get_path_info(".", "abspath")
335
336# Global configuration that should be applied to all WebRTC targets.
337# You normally shouldn't need to include this in your target as it's
338# automatically included when using the rtc_* templates.
339# It sets defines, include paths and compilation warnings accordingly,
340# both for WebRTC stand-alone builds and for the scenario when WebRTC
341# native code is built as part of Chromium.
Mirko Bonadei5f078452021-07-30 22:32:55 +0200342rtc_common_configs = [ webrtc_root + ":common_config" ]
mbonadei9aa3f0a2017-01-24 06:58:22 -0800343
kthelgasonc0977102017-04-24 00:57:16 -0700344if (is_mac || is_ios) {
345 rtc_common_configs += [ "//build/config/compiler:enable_arc" ]
346}
347
mbonadei9aa3f0a2017-01-24 06:58:22 -0800348# Global public configuration that should be applied to all WebRTC targets. You
349# normally shouldn't need to include this in your target as it's automatically
350# included when using the rtc_* templates. It set the defines, include paths and
351# compilation warnings that should be propagated to dependents of the targets
352# depending on the target having this config.
353rtc_common_inherited_config = webrtc_root + ":common_inherited_config"
354
355# Common configs to remove or add in all rtc targets.
356rtc_remove_configs = []
Mirko Bonadeifc52b912019-03-01 10:32:56 +0100357if (!build_with_chromium && is_clang) {
358 rtc_remove_configs += [ "//build/config/clang:find_bad_constructs" ]
359}
mbonadei9aa3f0a2017-01-24 06:58:22 -0800360rtc_add_configs = rtc_common_configs
Mirko Bonadei96ede162018-09-06 13:45:44 +0200361rtc_prod_configs = [ webrtc_root + ":rtc_prod_config" ]
Mirko Bonadei32ce18c2018-09-18 13:15:54 +0200362rtc_library_impl_config = [ webrtc_root + ":library_impl_config" ]
mbonadei9aa3f0a2017-01-24 06:58:22 -0800363
364set_defaults("rtc_test") {
365 configs = rtc_add_configs
366 suppressed_configs = []
367}
368
Mirko Bonadei86d053c2019-10-17 21:32:04 +0200369set_defaults("rtc_library") {
370 configs = rtc_add_configs
371 suppressed_configs = []
Mirko Bonadei8b7cfa12020-06-03 21:23:41 +0200372 absl_deps = []
Mirko Bonadei86d053c2019-10-17 21:32:04 +0200373}
374
mbonadei9aa3f0a2017-01-24 06:58:22 -0800375set_defaults("rtc_source_set") {
376 configs = rtc_add_configs
377 suppressed_configs = []
Mirko Bonadei8b7cfa12020-06-03 21:23:41 +0200378 absl_deps = []
mbonadei9aa3f0a2017-01-24 06:58:22 -0800379}
380
Mirko Bonadei86d053c2019-10-17 21:32:04 +0200381set_defaults("rtc_static_library") {
mbonadei9aa3f0a2017-01-24 06:58:22 -0800382 configs = rtc_add_configs
383 suppressed_configs = []
Mirko Bonadei8b7cfa12020-06-03 21:23:41 +0200384 absl_deps = []
mbonadei9aa3f0a2017-01-24 06:58:22 -0800385}
386
Mirko Bonadei86d053c2019-10-17 21:32:04 +0200387set_defaults("rtc_executable") {
mbonadei9aa3f0a2017-01-24 06:58:22 -0800388 configs = rtc_add_configs
389 suppressed_configs = []
390}
391
392set_defaults("rtc_shared_library") {
393 configs = rtc_add_configs
394 suppressed_configs = []
395}
396
Per Kjellandera7f2d842018-01-10 15:54:53 +0000397webrtc_default_visibility = [ webrtc_root + "/*" ]
398if (build_with_chromium) {
399 # Allow Chromium's WebRTC overrides targets to bypass the regular
400 # visibility restrictions.
401 webrtc_default_visibility += [ webrtc_root + "/../webrtc_overrides/*" ]
402}
403
Karl Wibergbb23c832018-04-22 19:55:00 +0200404# ---- Poisons ----
405#
406# The general idea is that some targets declare that they contain some
407# kind of poison, which makes it impossible for other targets to
408# depend on them (even transitively) unless they declare themselves
409# immune to that particular type of poison.
410#
411# Targets that *contain* poison of type foo should contain the line
412#
413# poisonous = [ "foo" ]
414#
415# and targets that *are immune but arent't themselves poisonous*
416# should contain
417#
418# allow_poison = [ "foo" ]
419#
420# This useful in cases where we have some large target or set of
421# targets and want to ensure that most other targets do not
422# transitively depend on them. For example, almost no high-level
423# target should depend on the audio codecs, since we want WebRTC users
424# to be able to inject any subset of them and actually end up with a
425# binary that doesn't include the codecs they didn't inject.
426#
427# Test-only targets (`testonly` set to true) and non-public targets
428# (`visibility` not containing "*") are automatically immune to all
429# types of poison.
430#
431# Here's the complete list of all types of poison. It must be kept in
432# 1:1 correspondence with the set of //:poison_* targets.
433#
434all_poison_types = [
435 # Encoders and decoders for specific audio codecs such as Opus and iSAC.
436 "audio_codecs",
Anders Carlsson1f433e42018-04-24 16:39:05 +0200437
Danil Chapovalov41300af2019-07-10 12:44:43 +0200438 # Default task queue implementation.
439 "default_task_queue",
Sam Zackrisson492fdf42019-10-25 10:45:58 +0200440
Sam Zackrisson03cb7e52021-12-06 15:40:04 +0100441 # Default echo detector implementation.
442 "default_echo_detector",
443
Sam Zackrisson492fdf42019-10-25 10:45:58 +0200444 # JSON parsing should not be needed in the "slim and modular" WebRTC.
445 "rtc_json",
446
447 # Software video codecs (VP8 and VP9 through libvpx).
448 "software_video_codecs",
Karl Wibergbb23c832018-04-22 19:55:00 +0200449]
450
Mirko Bonadei9a89a492018-05-29 14:22:32 +0000451absl_include_config = "//third_party/abseil-cpp:absl_include_config"
452absl_define_config = "//third_party/abseil-cpp:absl_define_config"
453
Mirko Bonadei2ab97f62019-07-18 13:44:12 +0200454# Abseil Flags are testonly, so this config will only be applied to WebRTC targets
455# that are testonly.
456absl_flags_config = webrtc_root + ":absl_flags_configs"
457
Mirko Bonadeie99b6cc2020-11-25 16:41:37 +0100458# WebRTC wrapper of Chromium's test() template. This template just adds some
459# WebRTC only configuration in order to avoid to duplicate it for every WebRTC
460# target.
461# The parameter `is_xctest` is different from the one in the Chromium's test()
462# template (and it is not forwarded to it). In rtc_test(), the argument
463# `is_xctest` is used to avoid to take dependencies that are not needed
464# in case the test is a real XCTest (using the XCTest framework).
mbonadei9aa3f0a2017-01-24 06:58:22 -0800465template("rtc_test") {
466 test(target_name) {
467 forward_variables_from(invoker,
468 "*",
469 [
470 "configs",
Mirko Bonadeie99b6cc2020-11-25 16:41:37 +0100471 "is_xctest",
mbonadei9aa3f0a2017-01-24 06:58:22 -0800472 "public_configs",
473 "suppressed_configs",
Karl Wiberg138d4ac2017-10-16 11:16:19 +0200474 "visibility",
mbonadei9aa3f0a2017-01-24 06:58:22 -0800475 ])
Mirko Bonadeidd411942017-11-21 15:35:27 +0100476
477 # Always override to public because when target_os is Android the `test`
478 # template can override it to [ "*" ] and we want to avoid conditional
479 # visibility.
Mirko Bonadei21558812017-11-21 12:47:34 +0100480 visibility = [ "*" ]
mbonadei9aa3f0a2017-01-24 06:58:22 -0800481 configs += invoker.configs
482 configs -= rtc_remove_configs
483 configs -= invoker.suppressed_configs
Mirko Bonadei9a89a492018-05-29 14:22:32 +0000484 public_configs = [
485 rtc_common_inherited_config,
486 absl_include_config,
487 absl_define_config,
Mirko Bonadei2ab97f62019-07-18 13:44:12 +0200488 absl_flags_config,
Mirko Bonadei9a89a492018-05-29 14:22:32 +0000489 ]
mbonadei9aa3f0a2017-01-24 06:58:22 -0800490 if (defined(invoker.public_configs)) {
491 public_configs += invoker.public_configs
492 }
sakald7fdb802017-05-26 01:51:53 -0700493 if (!build_with_chromium && is_android) {
Jianjun Zhu037f3e42017-08-15 21:48:37 +0800494 android_manifest = webrtc_root + "test/android/AndroidManifest.xml"
Peter Kotwicz3ceb16e2021-04-14 18:53:11 -0400495 use_raw_android_executable = false
Jeremy Leconteb19cfee2020-06-25 22:57:49 +0200496 min_sdk_version = 21
Mirko Bonadeibd393b22020-07-10 23:00:41 +0200497 target_sdk_version = 23
Mirko Bonadei80939352021-04-12 19:03:37 +0200498 deps += [
499 "//build/android/gtest_apk:native_test_instrumentation_test_runner_java",
500 webrtc_root + "test:native_test_java",
501 ]
sakald7fdb802017-05-26 01:51:53 -0700502 }
Mirko Bonadeie99b6cc2020-11-25 16:41:37 +0100503
Jeremy Leconteb8ba8c92022-03-15 09:08:29 +0100504 # Build //base/test:google_test_runner when the test is not a real XCTest.
505 if (is_ios && rtc_include_tests) {
Mirko Bonadeie99b6cc2020-11-25 16:41:37 +0100506 if (!defined(invoker.is_xctest) || !invoker.is_xctest) {
507 xctest_module_target = "//base/test:google_test_runner"
508 }
509 }
Andrey Logvin78646002021-01-29 10:50:19 +0000510
511 # If absl_deps is [], no action is needed. If not [], then it needs to be
512 # converted to //third_party/abseil-cpp:absl when build_with_chromium=true
513 # otherwise it just needs to be added to deps.
514 if (defined(absl_deps) && absl_deps != []) {
515 if (!defined(deps)) {
516 deps = []
517 }
518 if (build_with_chromium) {
519 deps += [ "//third_party/abseil-cpp:absl" ]
520 } else {
521 deps += absl_deps
522 }
523 }
524
Mirko Bonadei1d77c3e2021-01-26 17:10:04 +0100525 if (using_sanitizer) {
526 if (is_linux) {
527 if (!defined(invoker.data)) {
528 data = []
529 }
530 data +=
531 [ "//third_party/llvm-build/Release+Asserts/lib/libstdc++.so.6" ]
532 }
533 }
Jeremy Leconteb8ba8c92022-03-15 09:08:29 +0100534
Jeremy Leconted15f3e12022-02-18 10:16:32 +0100535 # TODO(crbug.com/webrtc/13556): Adding the .app folder in the runtime_deps
536 # shoulnd't be necessary. this code should be removed and the same solution
537 # as Chromium should be used.
538 if (is_ios) {
539 if (!defined(invoker.data)) {
540 data = []
541 }
542 data += [ "${root_out_dir}/${target_name}.app" ]
543 }
mbonadei9aa3f0a2017-01-24 06:58:22 -0800544 }
545}
546
547template("rtc_source_set") {
548 source_set(target_name) {
549 forward_variables_from(invoker,
550 "*",
551 [
552 "configs",
553 "public_configs",
554 "suppressed_configs",
Karl Wiberg138d4ac2017-10-16 11:16:19 +0200555 "visibility",
mbonadei9aa3f0a2017-01-24 06:58:22 -0800556 ])
Karl Wiberg138d4ac2017-10-16 11:16:19 +0200557 forward_variables_from(invoker, [ "visibility" ])
Per Kjellandera7f2d842018-01-10 15:54:53 +0000558 if (!defined(visibility)) {
559 visibility = webrtc_default_visibility
560 }
Karl Wibergbb23c832018-04-22 19:55:00 +0200561
562 # What's your poison?
563 if (defined(testonly) && testonly) {
564 assert(!defined(poisonous))
565 assert(!defined(allow_poison))
566 } else {
567 if (!defined(poisonous)) {
568 poisonous = []
569 }
570 if (!defined(allow_poison)) {
571 allow_poison = []
572 }
573 if (!defined(assert_no_deps)) {
574 assert_no_deps = []
575 }
576 if (!defined(deps)) {
577 deps = []
578 }
579 foreach(p, poisonous) {
580 deps += [ webrtc_root + ":poison_" + p ]
581 }
582 foreach(poison_type, all_poison_types) {
583 allow_dep = true
584 foreach(v, visibility) {
585 if (v == "*") {
586 allow_dep = false
587 }
588 }
589 foreach(p, allow_poison + poisonous) {
590 if (p == poison_type) {
591 allow_dep = true
592 }
593 }
594 if (!allow_dep) {
595 assert_no_deps += [ webrtc_root + ":poison_" + poison_type ]
596 }
597 }
598 }
599
Mirko Bonadei92dd35d2019-11-15 16:08:41 +0100600 # Chromium should only depend on the WebRTC component in order to
601 # avoid to statically link WebRTC in a component build.
602 if (build_with_chromium) {
603 publicly_visible = false
604 foreach(v, visibility) {
605 if (v == "*") {
606 publicly_visible = true
607 }
608 }
609 if (publicly_visible) {
610 visibility = []
611 visibility = webrtc_default_visibility
612 }
613 }
614
Mirko Bonadei96ede162018-09-06 13:45:44 +0200615 if (!defined(testonly) || !testonly) {
616 configs += rtc_prod_configs
617 }
618
mbonadei9aa3f0a2017-01-24 06:58:22 -0800619 configs += invoker.configs
Mirko Bonadei32ce18c2018-09-18 13:15:54 +0200620 configs += rtc_library_impl_config
mbonadei9aa3f0a2017-01-24 06:58:22 -0800621 configs -= rtc_remove_configs
622 configs -= invoker.suppressed_configs
Mirko Bonadei9a89a492018-05-29 14:22:32 +0000623 public_configs = [
624 rtc_common_inherited_config,
625 absl_include_config,
626 absl_define_config,
627 ]
Mirko Bonadei2ab97f62019-07-18 13:44:12 +0200628 if (defined(testonly) && testonly) {
629 public_configs += [ absl_flags_config ]
630 }
mbonadei9aa3f0a2017-01-24 06:58:22 -0800631 if (defined(invoker.public_configs)) {
632 public_configs += invoker.public_configs
633 }
Mirko Bonadei8b7cfa12020-06-03 21:23:41 +0200634
Mirko Bonadei96115cf2020-06-23 23:39:56 +0200635 # If absl_deps is [], no action is needed. If not [], then it needs to be
636 # converted to //third_party/abseil-cpp:absl when build_with_chromium=true
Mirko Bonadei8b7cfa12020-06-03 21:23:41 +0200637 # otherwise it just needs to be added to deps.
638 if (absl_deps != []) {
Mirko Bonadei2dcf3482020-06-05 14:30:41 +0200639 if (!defined(deps)) {
640 deps = []
641 }
Mirko Bonadei08ce9862020-06-11 11:25:32 +0200642 if (build_with_chromium) {
643 deps += [ "//third_party/abseil-cpp:absl" ]
Mirko Bonadei8b7cfa12020-06-03 21:23:41 +0200644 } else {
645 deps += absl_deps
646 }
647 }
mbonadei9aa3f0a2017-01-24 06:58:22 -0800648 }
649}
650
mbonadei9aa3f0a2017-01-24 06:58:22 -0800651template("rtc_static_library") {
652 static_library(target_name) {
653 forward_variables_from(invoker,
654 "*",
655 [
656 "configs",
657 "public_configs",
658 "suppressed_configs",
Karl Wiberg138d4ac2017-10-16 11:16:19 +0200659 "visibility",
mbonadei9aa3f0a2017-01-24 06:58:22 -0800660 ])
Karl Wiberg138d4ac2017-10-16 11:16:19 +0200661 forward_variables_from(invoker, [ "visibility" ])
Per Kjellandera7f2d842018-01-10 15:54:53 +0000662 if (!defined(visibility)) {
663 visibility = webrtc_default_visibility
664 }
Karl Wibergbb23c832018-04-22 19:55:00 +0200665
666 # What's your poison?
667 if (defined(testonly) && testonly) {
668 assert(!defined(poisonous))
669 assert(!defined(allow_poison))
670 } else {
671 if (!defined(poisonous)) {
672 poisonous = []
673 }
674 if (!defined(allow_poison)) {
675 allow_poison = []
676 }
677 if (!defined(assert_no_deps)) {
678 assert_no_deps = []
679 }
680 if (!defined(deps)) {
681 deps = []
682 }
683 foreach(p, poisonous) {
684 deps += [ webrtc_root + ":poison_" + p ]
685 }
686 foreach(poison_type, all_poison_types) {
687 allow_dep = true
688 foreach(v, visibility) {
689 if (v == "*") {
690 allow_dep = false
691 }
692 }
693 foreach(p, allow_poison + poisonous) {
694 if (p == poison_type) {
695 allow_dep = true
696 }
697 }
698 if (!allow_dep) {
699 assert_no_deps += [ webrtc_root + ":poison_" + poison_type ]
700 }
701 }
702 }
703
Mirko Bonadei96ede162018-09-06 13:45:44 +0200704 if (!defined(testonly) || !testonly) {
705 configs += rtc_prod_configs
706 }
707
mbonadei9aa3f0a2017-01-24 06:58:22 -0800708 configs += invoker.configs
Mirko Bonadei32ce18c2018-09-18 13:15:54 +0200709 configs += rtc_library_impl_config
mbonadei9aa3f0a2017-01-24 06:58:22 -0800710 configs -= rtc_remove_configs
711 configs -= invoker.suppressed_configs
Mirko Bonadei9a89a492018-05-29 14:22:32 +0000712 public_configs = [
713 rtc_common_inherited_config,
714 absl_include_config,
715 absl_define_config,
716 ]
Mirko Bonadei2ab97f62019-07-18 13:44:12 +0200717 if (defined(testonly) && testonly) {
718 public_configs += [ absl_flags_config ]
719 }
mbonadei9aa3f0a2017-01-24 06:58:22 -0800720 if (defined(invoker.public_configs)) {
721 public_configs += invoker.public_configs
722 }
Mirko Bonadei8b7cfa12020-06-03 21:23:41 +0200723
Mirko Bonadei96115cf2020-06-23 23:39:56 +0200724 # If absl_deps is [], no action is needed. If not [], then it needs to be
725 # converted to //third_party/abseil-cpp:absl when build_with_chromium=true
Mirko Bonadei8b7cfa12020-06-03 21:23:41 +0200726 # otherwise it just needs to be added to deps.
727 if (absl_deps != []) {
Mirko Bonadei2dcf3482020-06-05 14:30:41 +0200728 if (!defined(deps)) {
729 deps = []
730 }
Mirko Bonadei08ce9862020-06-11 11:25:32 +0200731 if (build_with_chromium) {
732 deps += [ "//third_party/abseil-cpp:absl" ]
Mirko Bonadei8b7cfa12020-06-03 21:23:41 +0200733 } else {
734 deps += absl_deps
735 }
736 }
mbonadei9aa3f0a2017-01-24 06:58:22 -0800737 }
738}
739
Mirko Bonadei86d053c2019-10-17 21:32:04 +0200740# This template automatically switches the target type between source_set
741# and static_library.
742#
743# This should be the default target type for all the WebRTC targets with
744# one exception. Do not use this template for header only targets, in that case
745# rtc_source_set must be used in order to avoid build errors (e.g. libtool
746# complains if the output .a file is empty).
747#
748# How does it work:
749# Since all files in a source_set are linked into a final binary, while files
750# in a static library are only linked in if at least one symbol in them is
751# referenced, in component builds source_sets are easy to deal with because
752# all their object files are passed to the linker to create a shared library.
753# In release builds instead, static_libraries are preferred since they allow
754# the linker to discard dead code.
755# For the same reason, testonly targets will always be expanded to
756# source_set in order to be sure that tests are present in the test binary.
757template("rtc_library") {
758 if (is_component_build || (defined(invoker.testonly) && invoker.testonly)) {
759 target_type = "source_set"
760 } else {
761 target_type = "static_library"
762 }
763 target(target_type, target_name) {
764 forward_variables_from(invoker,
765 "*",
766 [
767 "configs",
768 "public_configs",
769 "suppressed_configs",
770 "visibility",
771 ])
772 forward_variables_from(invoker, [ "visibility" ])
773 if (!defined(visibility)) {
774 visibility = webrtc_default_visibility
775 }
776
777 # What's your poison?
778 if (defined(testonly) && testonly) {
779 assert(!defined(poisonous))
780 assert(!defined(allow_poison))
781 } else {
782 if (!defined(poisonous)) {
783 poisonous = []
784 }
785 if (!defined(allow_poison)) {
786 allow_poison = []
787 }
788 if (!defined(assert_no_deps)) {
789 assert_no_deps = []
790 }
791 if (!defined(deps)) {
792 deps = []
793 }
794 foreach(p, poisonous) {
795 deps += [ webrtc_root + ":poison_" + p ]
796 }
797 foreach(poison_type, all_poison_types) {
798 allow_dep = true
799 foreach(v, visibility) {
800 if (v == "*") {
801 allow_dep = false
802 }
803 }
804 foreach(p, allow_poison + poisonous) {
805 if (p == poison_type) {
806 allow_dep = true
807 }
808 }
809 if (!allow_dep) {
810 assert_no_deps += [ webrtc_root + ":poison_" + poison_type ]
811 }
812 }
813 }
814
Mirko Bonadei92dd35d2019-11-15 16:08:41 +0100815 # Chromium should only depend on the WebRTC component in order to
816 # avoid to statically link WebRTC in a component build.
817 if (build_with_chromium) {
818 publicly_visible = false
819 foreach(v, visibility) {
820 if (v == "*") {
821 publicly_visible = true
822 }
823 }
824 if (publicly_visible) {
825 visibility = []
826 visibility = webrtc_default_visibility
827 }
828 }
829
Mirko Bonadei86d053c2019-10-17 21:32:04 +0200830 if (!defined(testonly) || !testonly) {
831 configs += rtc_prod_configs
832 }
833
834 configs += invoker.configs
835 configs += rtc_library_impl_config
836 configs -= rtc_remove_configs
837 configs -= invoker.suppressed_configs
838 public_configs = [
839 rtc_common_inherited_config,
840 absl_include_config,
841 absl_define_config,
842 ]
843 if (defined(testonly) && testonly) {
844 public_configs += [ absl_flags_config ]
845 }
846 if (defined(invoker.public_configs)) {
847 public_configs += invoker.public_configs
848 }
Mirko Bonadei8b7cfa12020-06-03 21:23:41 +0200849
Mirko Bonadei96115cf2020-06-23 23:39:56 +0200850 # If absl_deps is [], no action is needed. If not [], then it needs to be
851 # converted to //third_party/abseil-cpp:absl when build_with_chromium=true
Mirko Bonadei8b7cfa12020-06-03 21:23:41 +0200852 # otherwise it just needs to be added to deps.
853 if (absl_deps != []) {
Mirko Bonadei2dcf3482020-06-05 14:30:41 +0200854 if (!defined(deps)) {
855 deps = []
856 }
Mirko Bonadei08ce9862020-06-11 11:25:32 +0200857 if (build_with_chromium) {
858 deps += [ "//third_party/abseil-cpp:absl" ]
Mirko Bonadei8b7cfa12020-06-03 21:23:41 +0200859 } else {
860 deps += absl_deps
861 }
862 }
Mirko Bonadei86d053c2019-10-17 21:32:04 +0200863 }
864}
865
866template("rtc_executable") {
867 executable(target_name) {
868 forward_variables_from(invoker,
869 "*",
870 [
871 "deps",
872 "configs",
873 "public_configs",
874 "suppressed_configs",
875 "visibility",
876 ])
877 forward_variables_from(invoker, [ "visibility" ])
878 if (!defined(visibility)) {
879 visibility = webrtc_default_visibility
880 }
881 configs += invoker.configs
882 configs -= rtc_remove_configs
883 configs -= invoker.suppressed_configs
884 deps = invoker.deps
885
886 public_configs = [
887 rtc_common_inherited_config,
888 absl_include_config,
889 absl_define_config,
890 ]
891 if (defined(testonly) && testonly) {
892 public_configs += [ absl_flags_config ]
893 }
894 if (defined(invoker.public_configs)) {
895 public_configs += invoker.public_configs
896 }
897 if (is_win) {
898 deps += [
899 # Give executables the default manifest on Windows (a no-op elsewhere).
900 "//build/win:default_exe_manifest",
901 ]
902 }
903 }
904}
905
mbonadei9aa3f0a2017-01-24 06:58:22 -0800906template("rtc_shared_library") {
907 shared_library(target_name) {
908 forward_variables_from(invoker,
909 "*",
910 [
911 "configs",
912 "public_configs",
913 "suppressed_configs",
Karl Wiberg138d4ac2017-10-16 11:16:19 +0200914 "visibility",
mbonadei9aa3f0a2017-01-24 06:58:22 -0800915 ])
Karl Wiberg138d4ac2017-10-16 11:16:19 +0200916 forward_variables_from(invoker, [ "visibility" ])
Per Kjellandera7f2d842018-01-10 15:54:53 +0000917 if (!defined(visibility)) {
918 visibility = webrtc_default_visibility
919 }
Karl Wibergbb23c832018-04-22 19:55:00 +0200920
921 # What's your poison?
922 if (defined(testonly) && testonly) {
923 assert(!defined(poisonous))
924 assert(!defined(allow_poison))
925 } else {
926 if (!defined(poisonous)) {
927 poisonous = []
928 }
929 if (!defined(allow_poison)) {
930 allow_poison = []
931 }
932 if (!defined(assert_no_deps)) {
933 assert_no_deps = []
934 }
935 if (!defined(deps)) {
936 deps = []
937 }
938 foreach(p, poisonous) {
939 deps += [ webrtc_root + ":poison_" + p ]
940 }
941 foreach(poison_type, all_poison_types) {
942 allow_dep = true
943 foreach(v, visibility) {
944 if (v == "*") {
945 allow_dep = false
946 }
947 }
948 foreach(p, allow_poison + poisonous) {
949 if (p == poison_type) {
950 allow_dep = true
951 }
952 }
953 if (!allow_dep) {
954 assert_no_deps += [ webrtc_root + ":poison_" + poison_type ]
955 }
956 }
957 }
958
mbonadei9aa3f0a2017-01-24 06:58:22 -0800959 configs += invoker.configs
960 configs -= rtc_remove_configs
961 configs -= invoker.suppressed_configs
Mirko Bonadei9a89a492018-05-29 14:22:32 +0000962 public_configs = [
963 rtc_common_inherited_config,
964 absl_include_config,
965 absl_define_config,
966 ]
Mirko Bonadei2ab97f62019-07-18 13:44:12 +0200967 if (defined(testonly) && testonly) {
968 public_configs += [ absl_flags_config ]
969 }
mbonadei9aa3f0a2017-01-24 06:58:22 -0800970 if (defined(invoker.public_configs)) {
971 public_configs += invoker.public_configs
972 }
973 }
974}
kthelgason4065a572017-02-14 04:58:56 -0800975
976if (is_ios) {
Joel Sutherlandd2fb1bf2018-10-02 16:08:25 -0400977 # TODO: Generate module.modulemap file to enable use in Swift
978 # projects. See "mac_framework_bundle_with_umbrella_header".
Anders Carlssondc6b4772018-01-15 13:31:03 +0100979 template("ios_framework_bundle_with_umbrella_header") {
980 forward_variables_from(invoker, [ "output_name" ])
Daniel.L (Byoungchan Lee)32026ed2020-10-17 07:49:28 +0900981 this_target_name = target_name
Anders Carlssondc6b4772018-01-15 13:31:03 +0100982 umbrella_header_path =
Daniel.L (Byoungchan Lee)32026ed2020-10-17 07:49:28 +0900983 "$target_gen_dir/$output_name.framework/WebRTC/$output_name.h"
984
985 action_foreach("create_bracket_include_headers_$target_name") {
986 script = "//tools_webrtc/apple/copy_framework_header.py"
987 sources = invoker.sources
988 output_name = invoker.output_name
989 outputs = [
990 "$target_gen_dir/$output_name.framework/WebRTC/{{source_file_part}}",
991 ]
992 args = [
993 "--input",
994 "{{source}}",
995 "--output",
996 rebase_path(target_gen_dir, root_build_dir) +
997 "/$output_name.framework/WebRTC/{{source_file_part}}",
998 ]
999 }
Anders Carlssondc6b4772018-01-15 13:31:03 +01001000
1001 ios_framework_bundle(target_name) {
Daniel.L (Byoungchan Lee)32026ed2020-10-17 07:49:28 +09001002 forward_variables_from(invoker, "*", [ "public_headers" ])
1003 public_headers = get_target_outputs(
1004 ":create_bracket_include_headers_$this_target_name")
1005 deps += [
1006 ":copy_umbrella_header_$target_name",
1007 ":create_bracket_include_headers_$target_name",
1008 ]
Anders Carlssondc6b4772018-01-15 13:31:03 +01001009 }
1010
1011 action("umbrella_header_$target_name") {
Daniel.L (Byoungchan Lee)32026ed2020-10-17 07:49:28 +09001012 public_headers = get_target_outputs(
1013 ":create_bracket_include_headers_$this_target_name")
Anders Carlssondc6b4772018-01-15 13:31:03 +01001014
1015 script = "//tools_webrtc/ios/generate_umbrella_header.py"
1016
Mirko Bonadeiccbe95f2020-01-21 12:10:10 +01001017 outputs = [ umbrella_header_path ]
Anders Carlssondc6b4772018-01-15 13:31:03 +01001018 args = [
1019 "--out",
1020 rebase_path(umbrella_header_path, root_build_dir),
1021 "--sources",
Anders Carlsson7bca8ca2018-08-30 09:30:29 +02001022 ] + public_headers
Daniel.L (Byoungchan Lee)32026ed2020-10-17 07:49:28 +09001023 deps = [ ":create_bracket_include_headers_$this_target_name" ]
Anders Carlssondc6b4772018-01-15 13:31:03 +01001024 }
1025
Jordan Rose53d3fc92021-07-06 12:16:41 -07001026 if (target_environment == "catalyst") {
1027 # Catalyst frameworks use the same layout as regular Mac frameworks.
1028 headers_dir = "Versions/A/Headers"
1029 } else {
1030 headers_dir = "Headers"
1031 }
Anders Carlssondc6b4772018-01-15 13:31:03 +01001032 copy("copy_umbrella_header_$target_name") {
Mirko Bonadeiccbe95f2020-01-21 12:10:10 +01001033 sources = [ umbrella_header_path ]
1034 outputs =
Jordan Rose53d3fc92021-07-06 12:16:41 -07001035 [ "$root_out_dir/$output_name.framework/$headers_dir/$output_name.h" ]
Anders Carlssondc6b4772018-01-15 13:31:03 +01001036
Mirko Bonadeiccbe95f2020-01-21 12:10:10 +01001037 deps = [ ":umbrella_header_$target_name" ]
Anders Carlssondc6b4772018-01-15 13:31:03 +01001038 }
1039 }
1040
1041 set_defaults("ios_framework_bundle_with_umbrella_header") {
1042 configs = default_shared_library_configs
1043 }
kthelgason4065a572017-02-14 04:58:56 -08001044}
Mirko Bonadeifbb3b7d2017-11-07 15:36:33 +00001045
Anders Carlsson37bbf792018-09-05 16:29:27 +02001046if (is_mac) {
1047 template("mac_framework_bundle_with_umbrella_header") {
1048 forward_variables_from(invoker, [ "output_name" ])
Anders Carlsson95c56ee2018-09-06 15:48:17 +02001049 this_target_name = target_name
1050 umbrella_header_path = "$target_gen_dir/umbrella_header/$output_name.h"
Joel Sutherlandd2fb1bf2018-10-02 16:08:25 -04001051 modulemap_path = "$target_gen_dir/Modules/module.modulemap"
Anders Carlsson37bbf792018-09-05 16:29:27 +02001052
1053 mac_framework_bundle(target_name) {
Thomas Anderson6fde78c2019-01-23 10:40:29 -08001054 forward_variables_from(invoker, "*", [ "configs" ])
1055 if (defined(invoker.configs)) {
1056 configs += invoker.configs
1057 }
Anders Carlsson37bbf792018-09-05 16:29:27 +02001058
1059 framework_version = "A"
Joel Sutherlandd2fb1bf2018-10-02 16:08:25 -04001060 framework_contents = [
1061 "Headers",
1062 "Modules",
1063 "Resources",
1064 ]
Anders Carlsson37bbf792018-09-05 16:29:27 +02001065
1066 ldflags = [
1067 "-all_load",
1068 "-install_name",
1069 "@rpath/$output_name.framework/$output_name",
1070 ]
1071
1072 deps += [
Anders Carlsson95c56ee2018-09-06 15:48:17 +02001073 ":copy_framework_headers_$this_target_name",
Joel Sutherlandd2fb1bf2018-10-02 16:08:25 -04001074 ":copy_modulemap_$this_target_name",
Anders Carlsson95c56ee2018-09-06 15:48:17 +02001075 ":copy_umbrella_header_$this_target_name",
Daniel.L (Byoungchan Lee)32026ed2020-10-17 07:49:28 +09001076 ":create_bracket_include_headers_$this_target_name",
Joel Sutherlandd2fb1bf2018-10-02 16:08:25 -04001077 ":modulemap_$this_target_name",
Anders Carlsson95c56ee2018-09-06 15:48:17 +02001078 ":umbrella_header_$this_target_name",
Anders Carlsson37bbf792018-09-05 16:29:27 +02001079 ]
1080 }
1081
Daniel.L (Byoungchan Lee)32026ed2020-10-17 07:49:28 +09001082 action_foreach("create_bracket_include_headers_$this_target_name") {
1083 script = "//tools_webrtc/apple/copy_framework_header.py"
1084 sources = invoker.sources
1085 output_name = invoker.output_name
1086 outputs = [
1087 "$target_gen_dir/$output_name.framework/WebRTC/{{source_file_part}}",
1088 ]
1089 args = [
1090 "--input",
1091 "{{source}}",
1092 "--output",
1093 rebase_path(target_gen_dir, root_build_dir) +
1094 "/$output_name.framework/WebRTC/{{source_file_part}}",
1095 ]
1096 }
1097
Anders Carlsson95c56ee2018-09-06 15:48:17 +02001098 bundle_data("copy_framework_headers_$this_target_name") {
Daniel.L (Byoungchan Lee)32026ed2020-10-17 07:49:28 +09001099 sources = get_target_outputs(
1100 ":create_bracket_include_headers_$this_target_name")
Anders Carlsson37bbf792018-09-05 16:29:27 +02001101
Mirko Bonadeiccbe95f2020-01-21 12:10:10 +01001102 outputs = [ "{{bundle_contents_dir}}/Headers/{{source_file_part}}" ]
Daniel.L (Byoungchan Lee)32026ed2020-10-17 07:49:28 +09001103 deps = [ ":create_bracket_include_headers_$this_target_name" ]
Anders Carlsson37bbf792018-09-05 16:29:27 +02001104 }
1105
Joel Sutherlandd2fb1bf2018-10-02 16:08:25 -04001106 action("modulemap_$this_target_name") {
1107 script = "//tools_webrtc/ios/generate_modulemap.py"
1108 args = [
1109 "--out",
1110 rebase_path(modulemap_path, root_build_dir),
1111 "--name",
1112 output_name,
1113 ]
Mirko Bonadeiccbe95f2020-01-21 12:10:10 +01001114 outputs = [ modulemap_path ]
Joel Sutherlandd2fb1bf2018-10-02 16:08:25 -04001115 }
1116
1117 bundle_data("copy_modulemap_$this_target_name") {
Mirko Bonadeiccbe95f2020-01-21 12:10:10 +01001118 sources = [ modulemap_path ]
1119 outputs = [ "{{bundle_contents_dir}}/Modules/module.modulemap" ]
1120 deps = [ ":modulemap_$this_target_name" ]
Joel Sutherlandd2fb1bf2018-10-02 16:08:25 -04001121 }
1122
Anders Carlsson95c56ee2018-09-06 15:48:17 +02001123 action("umbrella_header_$this_target_name") {
Daniel.L (Byoungchan Lee)32026ed2020-10-17 07:49:28 +09001124 sources = get_target_outputs(
1125 ":create_bracket_include_headers_$this_target_name")
Anders Carlsson37bbf792018-09-05 16:29:27 +02001126
1127 script = "//tools_webrtc/ios/generate_umbrella_header.py"
1128
Mirko Bonadeiccbe95f2020-01-21 12:10:10 +01001129 outputs = [ umbrella_header_path ]
Anders Carlsson37bbf792018-09-05 16:29:27 +02001130 args = [
1131 "--out",
1132 rebase_path(umbrella_header_path, root_build_dir),
1133 "--sources",
1134 ] + sources
Daniel.L (Byoungchan Lee)32026ed2020-10-17 07:49:28 +09001135 deps = [ ":create_bracket_include_headers_$this_target_name" ]
Anders Carlsson37bbf792018-09-05 16:29:27 +02001136 }
1137
Anders Carlsson95c56ee2018-09-06 15:48:17 +02001138 bundle_data("copy_umbrella_header_$this_target_name") {
Mirko Bonadeiccbe95f2020-01-21 12:10:10 +01001139 sources = [ umbrella_header_path ]
1140 outputs = [ "{{bundle_contents_dir}}/Headers/$output_name.h" ]
Anders Carlsson37bbf792018-09-05 16:29:27 +02001141
Mirko Bonadeiccbe95f2020-01-21 12:10:10 +01001142 deps = [ ":umbrella_header_$this_target_name" ]
Anders Carlsson37bbf792018-09-05 16:29:27 +02001143 }
1144 }
1145}
1146
Mirko Bonadeifbb3b7d2017-11-07 15:36:33 +00001147if (is_android) {
1148 template("rtc_android_library") {
1149 android_library(target_name) {
1150 forward_variables_from(invoker,
1151 "*",
1152 [
1153 "configs",
1154 "public_configs",
1155 "suppressed_configs",
1156 "visibility",
1157 ])
1158
Oleh Prypin05aee742018-11-23 17:29:44 +01001159 errorprone_args = []
Sami Kalliomäkie7fac682018-03-20 16:32:49 +01001160
Mirko Bonadeifbb3b7d2017-11-07 15:36:33 +00001161 # Treat warnings as errors.
Oleh Prypin05aee742018-11-23 17:29:44 +01001162 errorprone_args += [ "-Werror" ]
Sami Kalliomäkie7fac682018-03-20 16:32:49 +01001163
1164 # Add any arguments defined by the invoker.
Oleh Prypin05aee742018-11-23 17:29:44 +01001165 if (defined(invoker.errorprone_args)) {
1166 errorprone_args += invoker.errorprone_args
Sami Kalliomäkie7fac682018-03-20 16:32:49 +01001167 }
Mirko Bonadeifbb3b7d2017-11-07 15:36:33 +00001168
Sami Kalliomäkidc526512018-03-27 17:07:27 +02001169 if (!defined(deps)) {
1170 deps = []
1171 }
Sami Kalliomäkidc526512018-03-27 17:07:27 +02001172
Mirko Bonadeifbb3b7d2017-11-07 15:36:33 +00001173 no_build_hooks = true
Mirko Bonadei8b7cfa12020-06-03 21:23:41 +02001174 not_needed([ "android_manifest" ])
Mirko Bonadeifbb3b7d2017-11-07 15:36:33 +00001175 }
1176 }
1177
1178 template("rtc_android_apk") {
1179 android_apk(target_name) {
1180 forward_variables_from(invoker,
1181 "*",
1182 [
1183 "configs",
1184 "public_configs",
1185 "suppressed_configs",
1186 "visibility",
1187 ])
1188
1189 # Treat warnings as errors.
Yves Gerey2f385d22019-11-20 12:10:08 +01001190 errorprone_args = []
1191 errorprone_args += [ "-Werror" ]
Sami Kalliomäkidc526512018-03-27 17:07:27 +02001192
1193 if (!defined(deps)) {
1194 deps = []
1195 }
Sami Kalliomäkidc526512018-03-27 17:07:27 +02001196
Mirko Bonadeifbb3b7d2017-11-07 15:36:33 +00001197 no_build_hooks = true
1198 }
1199 }
1200
1201 template("rtc_instrumentation_test_apk") {
1202 instrumentation_test_apk(target_name) {
1203 forward_variables_from(invoker,
1204 "*",
1205 [
1206 "configs",
1207 "public_configs",
1208 "suppressed_configs",
1209 "visibility",
1210 ])
1211
1212 # Treat warnings as errors.
Yves Gerey2f385d22019-11-20 12:10:08 +01001213 errorprone_args = []
1214 errorprone_args += [ "-Werror" ]
Sami Kalliomäkidc526512018-03-27 17:07:27 +02001215
1216 if (!defined(deps)) {
1217 deps = []
1218 }
Sami Kalliomäkidc526512018-03-27 17:07:27 +02001219
Mirko Bonadeifbb3b7d2017-11-07 15:36:33 +00001220 no_build_hooks = true
1221 }
1222 }
1223}