blob: 9750d4d507470f9776427d9ee016dbd7ef9e90f4 [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")
11import("//build/config/sanitizers/sanitizers.gni")
Tomas Popela318da512018-11-13 06:32:23 +010012import("//build/config/sysroot.gni")
ehmaldonado0d729b32017-02-10 01:38:23 -080013import("//build/config/ui.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(
26 "More info about component builds at: " + "https://chromium.googlesource.com/chromium/src/+/master/docs/component_build.md")
27 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
mbonadei9aa3f0a2017-01-24 06:58:22 -080038declare_args() {
Mirko Bonadei028248c2018-10-10 12:19:02 +020039 # Setting this to true will make RTC_EXPORT (see rtc_base/system/rtc_export.h)
40 # expand to code that will manage symbols visibility.
41 rtc_enable_symbol_export = false
42
Mirko Bonadei31b0b452018-08-22 10:37:11 +020043 # Setting this to true will define WEBRTC_EXCLUDE_FIELD_TRIAL_DEFAULT which
Mirko Bonadei70400902018-08-21 15:44:28 +020044 # will tell the pre-processor to remove the default definition of symbols
45 # needed to use field_trial. In that case a new implementation needs to be
46 # provided.
Mirko Bonadei31b0b452018-08-22 10:37:11 +020047 if (build_with_chromium) {
48 # When WebRTC is built as part of Chromium it should exclude the default
49 # implementation of field_trial unless it is building for NACL or
50 # Chromecast.
51 rtc_exclude_field_trial_default = !is_nacl && !is_chromecast
52 } else {
53 rtc_exclude_field_trial_default = false
54 }
Mirko Bonadei70400902018-08-21 15:44:28 +020055
Mirko Bonadei906add42018-09-05 16:03:16 +020056 # Setting this to true will define WEBRTC_EXCLUDE_METRICS_DEFAULT which
57 # will tell the pre-processor to remove the default definition of symbols
58 # needed to use metrics. In that case a new implementation needs to be
59 # provided.
60 rtc_exclude_metrics_default = build_with_chromium
61
Benjamin Wrightd6f86e82018-05-08 13:12:25 -070062 # Setting this to false will require the API user to pass in their own
63 # SSLCertificateVerifier to verify the certificates presented from a
64 # TLS-TURN server. In return disabling this saves around 100kb in the binary.
65 rtc_builtin_ssl_root_certificates = true
66
Karl Wibergeb254b42017-11-01 15:08:12 +010067 # Include the iLBC audio codec?
68 rtc_include_ilbc = true
69
mbonadei9aa3f0a2017-01-24 06:58:22 -080070 # Disable this to avoid building the Opus audio codec.
71 rtc_include_opus = true
72
minyue2e03c662017-02-01 17:31:11 -080073 # Enable this if the Opus version upon which WebRTC is built supports direct
74 # encoding of 120 ms packets.
minyue-webrtc516711c2017-07-27 17:45:49 +020075 rtc_opus_support_120ms_ptime = true
minyue2e03c662017-02-01 17:31:11 -080076
mbonadei9aa3f0a2017-01-24 06:58:22 -080077 # Enable this to let the Opus audio codec change complexity on the fly.
78 rtc_opus_variable_complexity = false
79
mbonadei9aa3f0a2017-01-24 06:58:22 -080080 # Used to specify an external Jsoncpp include path when not compiling the
81 # library that comes with WebRTC (i.e. rtc_build_json == 0).
82 rtc_jsoncpp_root = "//third_party/jsoncpp/source/include"
83
84 # Used to specify an external OpenSSL include path when not compiling the
85 # library that comes with WebRTC (i.e. rtc_build_ssl == 0).
86 rtc_ssl_root = ""
87
88 # Selects fixed-point code where possible.
89 rtc_prefer_fixed_point = false
90
mbonadei9aa3f0a2017-01-24 06:58:22 -080091 # Enable when an external authentication mechanism is used for performing
92 # packet authentication for RTP packets instead of libsrtp.
93 rtc_enable_external_auth = build_with_chromium
94
95 # Selects whether debug dumps for the audio processing module
96 # should be generated.
97 apm_debug_dump = false
98
Per Åhgrencc73ed32020-04-26 23:56:17 +020099 # Selects whether the audio processing module should be excluded.
100 rtc_exclude_audio_processing_module = false
101
mbonadei9aa3f0a2017-01-24 06:58:22 -0800102 # Set this to true to enable BWE test logging.
103 rtc_enable_bwe_test_logging = false
104
Joachim Bauch93e91342017-12-07 01:25:53 +0100105 # Set this to false to skip building examples.
106 rtc_build_examples = true
107
108 # Set this to false to skip building tools.
109 rtc_build_tools = true
110
Joachim Bauch75f18fc2017-12-20 21:25:47 +0100111 # Set this to false to skip building code that requires X11.
112 rtc_use_x11 = use_x11
113
Tomas Popela318da512018-11-13 06:32:23 +0100114 # Set this to use PipeWire on the Wayland display server.
Tomas Popela762543f2018-12-12 14:37:51 +0100115 # By default it's only enabled on desktop Linux (excludes ChromeOS) and
116 # only when using the sysroot as PipeWire is not available in older and
117 # supported Ubuntu and Debian distributions.
118 rtc_use_pipewire = is_desktop_linux && use_sysroot
119
120 # Set this to link PipeWire directly instead of using the dlopen.
121 rtc_link_pipewire = false
Tomas Popela318da512018-11-13 06:32:23 +0100122
mbonadei9aa3f0a2017-01-24 06:58:22 -0800123 # Enable to use the Mozilla internal settings.
124 build_with_mozilla = false
125
henrika883d00f2018-03-16 10:09:49 +0100126 # Enable use of Android AAudio which requires Android SDK 26 or above and
127 # NDK r16 or above.
128 rtc_enable_android_aaudio = false
129
mbonadei9aa3f0a2017-01-24 06:58:22 -0800130 # Set to "func", "block", "edge" for coverage generation.
131 # At unit test runtime set UBSAN_OPTIONS="coverage=1".
132 # It is recommend to set include_examples=0.
133 # Use llvm's sancov -html-report for human readable reports.
134 # See http://clang.llvm.org/docs/SanitizerCoverage.html .
135 rtc_sanitize_coverage = ""
136
mbonadei9aa3f0a2017-01-24 06:58:22 -0800137 if (current_cpu == "arm" || current_cpu == "arm64") {
138 rtc_prefer_fixed_point = true
139 }
140
mbonadei9aa3f0a2017-01-24 06:58:22 -0800141 # Determines whether NEON code will be built.
142 rtc_build_with_neon =
143 (current_cpu == "arm" && arm_use_neon) || current_cpu == "arm64"
144
145 # Enable this to build OpenH264 encoder/FFmpeg decoder. This is supported on
146 # all platforms except Android and iOS. Because FFmpeg can be built
147 # with/without H.264 support, |ffmpeg_branding| has to separately be set to a
148 # value that includes H.264, for example "Chrome". If FFmpeg is built without
Sergey Silkinfe288eb2018-06-25 16:22:38 +0200149 # H.264, compilation succeeds but |H264DecoderImpl| fails to initialize.
mbonadei9aa3f0a2017-01-24 06:58:22 -0800150 # CHECK THE OPENH264, FFMPEG AND H.264 LICENSES/PATENTS BEFORE BUILDING.
151 # http://www.openh264.org, https://www.ffmpeg.org/
Mirko Bonadeiee0a85c2019-01-15 10:47:18 +0100152 #
153 # Enabling H264 when building with MSVC is currently not supported, see
154 # bugs.webrtc.org/9213#c13 for more info.
155 rtc_use_h264 =
156 proprietary_codecs && !is_android && !is_ios && !(is_win && !is_clang)
mbonadei9aa3f0a2017-01-24 06:58:22 -0800157
mbonadei9aa3f0a2017-01-24 06:58:22 -0800158 # By default, use normal platform audio support or dummy audio, but don't
159 # use file-based audio playout and record.
160 rtc_use_dummy_audio_file_devices = false
161
henrika7be78832017-06-13 17:34:16 +0200162 # When set to true, replace the audio output with a sinus tone at 440Hz.
163 # The ADM will ask for audio data from WebRTC but instead of reading real
164 # audio samples from NetEQ, a sinus tone will be generated and replace the
165 # real audio samples.
166 rtc_audio_device_plays_sinus_tone = false
167
Anders Carlsson358f2e02018-06-04 10:24:37 +0200168 if (is_ios) {
169 # Build broadcast extension in AppRTCMobile for iOS. This results in the
170 # binary only running on iOS 11+, which is why it is disabled by default.
171 rtc_apprtcmobile_broadcast_extension = false
172 }
Anders Carlsson7bca8ca2018-08-30 09:30:29 +0200173
174 # Determines whether Metal is available on iOS/macOS.
175 rtc_use_metal_rendering = is_mac || (is_ios && current_cpu == "arm64")
Jiawei Ou08745302019-02-12 11:36:13 -0800176
177 # When set to false, builtin audio encoder/decoder factories and all the
178 # audio codecs they depend on will not be included in libwebrtc.{a|lib}
179 # (they will still be included in libjingle_peerconnection_so.so and
180 # WebRTC.framework)
181 rtc_include_builtin_audio_codecs = true
182
183 # When set to false, builtin video encoder/decoder factories and all the
184 # video codecs they depends on will not be included in libwebrtc.{a|lib}
185 # (they will still be included in libjingle_peerconnection_so.so and
186 # WebRTC.framework)
187 rtc_include_builtin_video_codecs = true
Mirko Bonadei20574f42019-03-28 07:50:07 +0100188
189 # When set to true and in a standalone build, it will undefine UNICODE and
190 # _UNICODE (which are always defined globally by the Chromium Windows
191 # toolchain).
192 # This is only needed for testing purposes, WebRTC wants to be sure it
193 # doesn't assume /DUNICODE and /D_UNICODE but that it explicitly uses
194 # wide character functions.
195 rtc_win_undef_unicode = false
Dan Minor9c686132018-01-15 10:20:00 -0500196}
mbonadei9aa3f0a2017-01-24 06:58:22 -0800197
Dan Minor9c686132018-01-15 10:20:00 -0500198if (!build_with_mozilla) {
199 import("//testing/test.gni")
mbonadei9aa3f0a2017-01-24 06:58:22 -0800200}
201
202# A second declare_args block, so that declarations within it can
203# depend on the possibly overridden variables in the first
204# declare_args block.
205declare_args() {
Dan Minor9c686132018-01-15 10:20:00 -0500206 # Enables the use of protocol buffers for debug recordings.
207 rtc_enable_protobuf = !build_with_mozilla
208
209 # Set this to disable building with support for SCTP data channels.
210 rtc_enable_sctp = !build_with_mozilla
211
212 # Disable these to not build components which can be externally provided.
213 rtc_build_json = !build_with_mozilla
214 rtc_build_libsrtp = !build_with_mozilla
215 rtc_build_libvpx = !build_with_mozilla
216 rtc_libvpx_build_vp9 = !build_with_mozilla
Dan Minor9c686132018-01-15 10:20:00 -0500217 rtc_build_opus = !build_with_mozilla
218 rtc_build_ssl = !build_with_mozilla
219 rtc_build_usrsctp = !build_with_mozilla
220
221 # Enable libevent task queues on platforms that support it.
Mirko Bonadei775c02e2019-06-19 19:05:00 +0200222 if (is_win || is_mac || is_ios || is_nacl || is_fuchsia ||
223 target_cpu == "wasm") {
Dan Minor9c686132018-01-15 10:20:00 -0500224 rtc_enable_libevent = false
225 rtc_build_libevent = false
226 } else {
227 rtc_enable_libevent = true
228 rtc_build_libevent = !build_with_mozilla
229 }
230
Dan Minor9c686132018-01-15 10:20:00 -0500231 # Build sources requiring GTK. NOTICE: This is not present in Chrome OS
232 # build environments, even if available for Chromium builds.
233 rtc_use_gtk = !build_with_chromium && !build_with_mozilla
234
mbonadei9aa3f0a2017-01-24 06:58:22 -0800235 # Excluded in Chromium since its prerequisites don't require Pulse Audio.
236 rtc_include_pulse_audio = !build_with_chromium
237
238 # Chromium uses its own IO handling, so the internal ADM is only built for
239 # standalone WebRTC.
240 rtc_include_internal_audio_device = !build_with_chromium
241
242 # Include tests in standalone checkout.
Dan Minor9c686132018-01-15 10:20:00 -0500243 rtc_include_tests = !build_with_chromium && !build_with_mozilla
Oleh Prypin240b8932019-06-07 13:27:07 +0200244
245 # Set this to false to skip building code that also requires X11 extensions
246 # such as Xdamage, Xfixes.
247 rtc_use_x11_extensions = rtc_use_x11
Artem Titov6a4a1462019-11-26 16:24:46 +0100248
249 # Set this to true to fully remove logging from WebRTC.
250 rtc_disable_logging = false
Doudou Kisabaka2dec4962019-11-28 14:24:31 +0100251
252 # Set this to true to disable trace events.
253 rtc_disable_trace_events = false
Artem Titov9dc209a2019-11-28 17:09:30 +0100254
255 # Set this to true to disable detailed error message and logging for
256 # RTC_CHECKs.
257 rtc_disable_check_msg = false
Ying Wangef3998f2019-12-09 13:06:53 +0100258
259 # Set this to true to disable webrtc metrics.
Mirko Bonadei3c4fda22019-12-10 15:02:53 +0100260 rtc_disable_metrics = false
sazaaa42ecd2020-04-01 15:24:40 +0200261
262 # Set this to true to exclude the transient suppressor in the audio processing
263 # module from the build.
264 rtc_exclude_transient_suppressor = false
mbonadei9aa3f0a2017-01-24 06:58:22 -0800265}
266
267# Make it possible to provide custom locations for some libraries (move these
268# up into declare_args should we need to actually use them for the GN build).
269rtc_libvpx_dir = "//third_party/libvpx"
mbonadei9aa3f0a2017-01-24 06:58:22 -0800270rtc_opus_dir = "//third_party/opus"
271
272# Desktop capturer is supported only on Windows, OSX and Linux.
Oleh Prypin240b8932019-06-07 13:27:07 +0200273rtc_desktop_capture_supported =
274 (is_win && current_os != "winuwp") || is_mac ||
275 (is_linux && (rtc_use_x11_extensions || rtc_use_pipewire))
mbonadei9aa3f0a2017-01-24 06:58:22 -0800276
277###############################################################################
278# Templates
279#
280
Mirko Bonadei92ea95e2017-09-15 06:47:31 +0200281# Points to // in webrtc stand-alone or to //third_party/webrtc/ in
mbonadei9aa3f0a2017-01-24 06:58:22 -0800282# chromium.
283# We need absolute paths for all configs in templates as they are shared in
284# different subdirectories.
285webrtc_root = get_path_info(".", "abspath")
286
287# Global configuration that should be applied to all WebRTC targets.
288# You normally shouldn't need to include this in your target as it's
289# automatically included when using the rtc_* templates.
290# It sets defines, include paths and compilation warnings accordingly,
291# both for WebRTC stand-alone builds and for the scenario when WebRTC
292# native code is built as part of Chromium.
Will Harrisfc173d02018-08-29 13:56:00 -0700293rtc_common_configs = [
294 webrtc_root + ":common_config",
295 "//build/config/compiler:no_size_t_to_int_warning",
296]
mbonadei9aa3f0a2017-01-24 06:58:22 -0800297
kthelgasonc0977102017-04-24 00:57:16 -0700298if (is_mac || is_ios) {
299 rtc_common_configs += [ "//build/config/compiler:enable_arc" ]
300}
301
mbonadei9aa3f0a2017-01-24 06:58:22 -0800302# Global public configuration that should be applied to all WebRTC targets. You
303# normally shouldn't need to include this in your target as it's automatically
304# included when using the rtc_* templates. It set the defines, include paths and
305# compilation warnings that should be propagated to dependents of the targets
306# depending on the target having this config.
307rtc_common_inherited_config = webrtc_root + ":common_inherited_config"
308
309# Common configs to remove or add in all rtc targets.
310rtc_remove_configs = []
Mirko Bonadeifc52b912019-03-01 10:32:56 +0100311if (!build_with_chromium && is_clang) {
312 rtc_remove_configs += [ "//build/config/clang:find_bad_constructs" ]
313}
mbonadei9aa3f0a2017-01-24 06:58:22 -0800314rtc_add_configs = rtc_common_configs
Mirko Bonadei96ede162018-09-06 13:45:44 +0200315rtc_prod_configs = [ webrtc_root + ":rtc_prod_config" ]
Mirko Bonadei32ce18c2018-09-18 13:15:54 +0200316rtc_library_impl_config = [ webrtc_root + ":library_impl_config" ]
mbonadei9aa3f0a2017-01-24 06:58:22 -0800317
318set_defaults("rtc_test") {
319 configs = rtc_add_configs
320 suppressed_configs = []
321}
322
Mirko Bonadei86d053c2019-10-17 21:32:04 +0200323set_defaults("rtc_library") {
324 configs = rtc_add_configs
325 suppressed_configs = []
326}
327
mbonadei9aa3f0a2017-01-24 06:58:22 -0800328set_defaults("rtc_source_set") {
329 configs = rtc_add_configs
330 suppressed_configs = []
331}
332
Mirko Bonadei86d053c2019-10-17 21:32:04 +0200333set_defaults("rtc_static_library") {
mbonadei9aa3f0a2017-01-24 06:58:22 -0800334 configs = rtc_add_configs
335 suppressed_configs = []
336}
337
Mirko Bonadei86d053c2019-10-17 21:32:04 +0200338set_defaults("rtc_executable") {
mbonadei9aa3f0a2017-01-24 06:58:22 -0800339 configs = rtc_add_configs
340 suppressed_configs = []
341}
342
343set_defaults("rtc_shared_library") {
344 configs = rtc_add_configs
345 suppressed_configs = []
346}
347
Per Kjellandera7f2d842018-01-10 15:54:53 +0000348webrtc_default_visibility = [ webrtc_root + "/*" ]
349if (build_with_chromium) {
350 # Allow Chromium's WebRTC overrides targets to bypass the regular
351 # visibility restrictions.
352 webrtc_default_visibility += [ webrtc_root + "/../webrtc_overrides/*" ]
353}
354
Karl Wibergbb23c832018-04-22 19:55:00 +0200355# ---- Poisons ----
356#
357# The general idea is that some targets declare that they contain some
358# kind of poison, which makes it impossible for other targets to
359# depend on them (even transitively) unless they declare themselves
360# immune to that particular type of poison.
361#
362# Targets that *contain* poison of type foo should contain the line
363#
364# poisonous = [ "foo" ]
365#
366# and targets that *are immune but arent't themselves poisonous*
367# should contain
368#
369# allow_poison = [ "foo" ]
370#
371# This useful in cases where we have some large target or set of
372# targets and want to ensure that most other targets do not
373# transitively depend on them. For example, almost no high-level
374# target should depend on the audio codecs, since we want WebRTC users
375# to be able to inject any subset of them and actually end up with a
376# binary that doesn't include the codecs they didn't inject.
377#
378# Test-only targets (`testonly` set to true) and non-public targets
379# (`visibility` not containing "*") are automatically immune to all
380# types of poison.
381#
382# Here's the complete list of all types of poison. It must be kept in
383# 1:1 correspondence with the set of //:poison_* targets.
384#
385all_poison_types = [
386 # Encoders and decoders for specific audio codecs such as Opus and iSAC.
387 "audio_codecs",
Anders Carlsson1f433e42018-04-24 16:39:05 +0200388
Danil Chapovalov41300af2019-07-10 12:44:43 +0200389 # Default task queue implementation.
390 "default_task_queue",
Sam Zackrisson492fdf42019-10-25 10:45:58 +0200391
392 # JSON parsing should not be needed in the "slim and modular" WebRTC.
393 "rtc_json",
394
395 # Software video codecs (VP8 and VP9 through libvpx).
396 "software_video_codecs",
Karl Wibergbb23c832018-04-22 19:55:00 +0200397]
398
Mirko Bonadei9a89a492018-05-29 14:22:32 +0000399absl_include_config = "//third_party/abseil-cpp:absl_include_config"
400absl_define_config = "//third_party/abseil-cpp:absl_define_config"
401
Mirko Bonadei2ab97f62019-07-18 13:44:12 +0200402# Abseil Flags are testonly, so this config will only be applied to WebRTC targets
403# that are testonly.
404absl_flags_config = webrtc_root + ":absl_flags_configs"
405
mbonadei9aa3f0a2017-01-24 06:58:22 -0800406template("rtc_test") {
407 test(target_name) {
408 forward_variables_from(invoker,
409 "*",
410 [
411 "configs",
412 "public_configs",
413 "suppressed_configs",
Karl Wiberg138d4ac2017-10-16 11:16:19 +0200414 "visibility",
mbonadei9aa3f0a2017-01-24 06:58:22 -0800415 ])
Mirko Bonadeidd411942017-11-21 15:35:27 +0100416
417 # Always override to public because when target_os is Android the `test`
418 # template can override it to [ "*" ] and we want to avoid conditional
419 # visibility.
Mirko Bonadei21558812017-11-21 12:47:34 +0100420 visibility = [ "*" ]
mbonadei9aa3f0a2017-01-24 06:58:22 -0800421 configs += invoker.configs
422 configs -= rtc_remove_configs
423 configs -= invoker.suppressed_configs
Mirko Bonadei9a89a492018-05-29 14:22:32 +0000424 public_configs = [
425 rtc_common_inherited_config,
426 absl_include_config,
427 absl_define_config,
Mirko Bonadei2ab97f62019-07-18 13:44:12 +0200428 absl_flags_config,
Mirko Bonadei9a89a492018-05-29 14:22:32 +0000429 ]
mbonadei9aa3f0a2017-01-24 06:58:22 -0800430 if (defined(invoker.public_configs)) {
431 public_configs += invoker.public_configs
432 }
sakald7fdb802017-05-26 01:51:53 -0700433 if (!build_with_chromium && is_android) {
Jianjun Zhu037f3e42017-08-15 21:48:37 +0800434 android_manifest = webrtc_root + "test/android/AndroidManifest.xml"
Oleh Prypina79abd42019-06-25 23:19:17 +0200435 min_sdk_version = 16
Jianjun Zhu037f3e42017-08-15 21:48:37 +0800436 deps += [ webrtc_root + "test:native_test_java" ]
sakald7fdb802017-05-26 01:51:53 -0700437 }
mbonadei9aa3f0a2017-01-24 06:58:22 -0800438 }
439}
440
441template("rtc_source_set") {
442 source_set(target_name) {
443 forward_variables_from(invoker,
444 "*",
445 [
446 "configs",
447 "public_configs",
448 "suppressed_configs",
Karl Wiberg138d4ac2017-10-16 11:16:19 +0200449 "visibility",
mbonadei9aa3f0a2017-01-24 06:58:22 -0800450 ])
Karl Wiberg138d4ac2017-10-16 11:16:19 +0200451 forward_variables_from(invoker, [ "visibility" ])
Per Kjellandera7f2d842018-01-10 15:54:53 +0000452 if (!defined(visibility)) {
453 visibility = webrtc_default_visibility
454 }
Karl Wibergbb23c832018-04-22 19:55:00 +0200455
456 # What's your poison?
457 if (defined(testonly) && testonly) {
458 assert(!defined(poisonous))
459 assert(!defined(allow_poison))
460 } else {
461 if (!defined(poisonous)) {
462 poisonous = []
463 }
464 if (!defined(allow_poison)) {
465 allow_poison = []
466 }
467 if (!defined(assert_no_deps)) {
468 assert_no_deps = []
469 }
470 if (!defined(deps)) {
471 deps = []
472 }
473 foreach(p, poisonous) {
474 deps += [ webrtc_root + ":poison_" + p ]
475 }
476 foreach(poison_type, all_poison_types) {
477 allow_dep = true
478 foreach(v, visibility) {
479 if (v == "*") {
480 allow_dep = false
481 }
482 }
483 foreach(p, allow_poison + poisonous) {
484 if (p == poison_type) {
485 allow_dep = true
486 }
487 }
488 if (!allow_dep) {
489 assert_no_deps += [ webrtc_root + ":poison_" + poison_type ]
490 }
491 }
492 }
493
Mirko Bonadei92dd35d2019-11-15 16:08:41 +0100494 # Chromium should only depend on the WebRTC component in order to
495 # avoid to statically link WebRTC in a component build.
496 if (build_with_chromium) {
497 publicly_visible = false
498 foreach(v, visibility) {
499 if (v == "*") {
500 publicly_visible = true
501 }
502 }
503 if (publicly_visible) {
504 visibility = []
505 visibility = webrtc_default_visibility
506 }
507 }
508
Mirko Bonadei96ede162018-09-06 13:45:44 +0200509 if (!defined(testonly) || !testonly) {
510 configs += rtc_prod_configs
511 }
512
mbonadei9aa3f0a2017-01-24 06:58:22 -0800513 configs += invoker.configs
Mirko Bonadei32ce18c2018-09-18 13:15:54 +0200514 configs += rtc_library_impl_config
mbonadei9aa3f0a2017-01-24 06:58:22 -0800515 configs -= rtc_remove_configs
516 configs -= invoker.suppressed_configs
Mirko Bonadei9a89a492018-05-29 14:22:32 +0000517 public_configs = [
518 rtc_common_inherited_config,
519 absl_include_config,
520 absl_define_config,
521 ]
Mirko Bonadei2ab97f62019-07-18 13:44:12 +0200522 if (defined(testonly) && testonly) {
523 public_configs += [ absl_flags_config ]
524 }
mbonadei9aa3f0a2017-01-24 06:58:22 -0800525 if (defined(invoker.public_configs)) {
526 public_configs += invoker.public_configs
527 }
528 }
529}
530
mbonadei9aa3f0a2017-01-24 06:58:22 -0800531template("rtc_static_library") {
532 static_library(target_name) {
533 forward_variables_from(invoker,
534 "*",
535 [
536 "configs",
537 "public_configs",
538 "suppressed_configs",
Karl Wiberg138d4ac2017-10-16 11:16:19 +0200539 "visibility",
mbonadei9aa3f0a2017-01-24 06:58:22 -0800540 ])
Karl Wiberg138d4ac2017-10-16 11:16:19 +0200541 forward_variables_from(invoker, [ "visibility" ])
Per Kjellandera7f2d842018-01-10 15:54:53 +0000542 if (!defined(visibility)) {
543 visibility = webrtc_default_visibility
544 }
Karl Wibergbb23c832018-04-22 19:55:00 +0200545
546 # What's your poison?
547 if (defined(testonly) && testonly) {
548 assert(!defined(poisonous))
549 assert(!defined(allow_poison))
550 } else {
551 if (!defined(poisonous)) {
552 poisonous = []
553 }
554 if (!defined(allow_poison)) {
555 allow_poison = []
556 }
557 if (!defined(assert_no_deps)) {
558 assert_no_deps = []
559 }
560 if (!defined(deps)) {
561 deps = []
562 }
563 foreach(p, poisonous) {
564 deps += [ webrtc_root + ":poison_" + p ]
565 }
566 foreach(poison_type, all_poison_types) {
567 allow_dep = true
568 foreach(v, visibility) {
569 if (v == "*") {
570 allow_dep = false
571 }
572 }
573 foreach(p, allow_poison + poisonous) {
574 if (p == poison_type) {
575 allow_dep = true
576 }
577 }
578 if (!allow_dep) {
579 assert_no_deps += [ webrtc_root + ":poison_" + poison_type ]
580 }
581 }
582 }
583
Mirko Bonadei96ede162018-09-06 13:45:44 +0200584 if (!defined(testonly) || !testonly) {
585 configs += rtc_prod_configs
586 }
587
mbonadei9aa3f0a2017-01-24 06:58:22 -0800588 configs += invoker.configs
Mirko Bonadei32ce18c2018-09-18 13:15:54 +0200589 configs += rtc_library_impl_config
mbonadei9aa3f0a2017-01-24 06:58:22 -0800590 configs -= rtc_remove_configs
591 configs -= invoker.suppressed_configs
Mirko Bonadei9a89a492018-05-29 14:22:32 +0000592 public_configs = [
593 rtc_common_inherited_config,
594 absl_include_config,
595 absl_define_config,
596 ]
Mirko Bonadei2ab97f62019-07-18 13:44:12 +0200597 if (defined(testonly) && testonly) {
598 public_configs += [ absl_flags_config ]
599 }
mbonadei9aa3f0a2017-01-24 06:58:22 -0800600 if (defined(invoker.public_configs)) {
601 public_configs += invoker.public_configs
602 }
603 }
604}
605
Mirko Bonadei86d053c2019-10-17 21:32:04 +0200606# This template automatically switches the target type between source_set
607# and static_library.
608#
609# This should be the default target type for all the WebRTC targets with
610# one exception. Do not use this template for header only targets, in that case
611# rtc_source_set must be used in order to avoid build errors (e.g. libtool
612# complains if the output .a file is empty).
613#
614# How does it work:
615# Since all files in a source_set are linked into a final binary, while files
616# in a static library are only linked in if at least one symbol in them is
617# referenced, in component builds source_sets are easy to deal with because
618# all their object files are passed to the linker to create a shared library.
619# In release builds instead, static_libraries are preferred since they allow
620# the linker to discard dead code.
621# For the same reason, testonly targets will always be expanded to
622# source_set in order to be sure that tests are present in the test binary.
623template("rtc_library") {
624 if (is_component_build || (defined(invoker.testonly) && invoker.testonly)) {
625 target_type = "source_set"
626 } else {
627 target_type = "static_library"
628 }
629 target(target_type, target_name) {
630 forward_variables_from(invoker,
631 "*",
632 [
633 "configs",
634 "public_configs",
635 "suppressed_configs",
636 "visibility",
637 ])
638 forward_variables_from(invoker, [ "visibility" ])
639 if (!defined(visibility)) {
640 visibility = webrtc_default_visibility
641 }
642
643 # What's your poison?
644 if (defined(testonly) && testonly) {
645 assert(!defined(poisonous))
646 assert(!defined(allow_poison))
647 } else {
648 if (!defined(poisonous)) {
649 poisonous = []
650 }
651 if (!defined(allow_poison)) {
652 allow_poison = []
653 }
654 if (!defined(assert_no_deps)) {
655 assert_no_deps = []
656 }
657 if (!defined(deps)) {
658 deps = []
659 }
660 foreach(p, poisonous) {
661 deps += [ webrtc_root + ":poison_" + p ]
662 }
663 foreach(poison_type, all_poison_types) {
664 allow_dep = true
665 foreach(v, visibility) {
666 if (v == "*") {
667 allow_dep = false
668 }
669 }
670 foreach(p, allow_poison + poisonous) {
671 if (p == poison_type) {
672 allow_dep = true
673 }
674 }
675 if (!allow_dep) {
676 assert_no_deps += [ webrtc_root + ":poison_" + poison_type ]
677 }
678 }
679 }
680
Mirko Bonadei92dd35d2019-11-15 16:08:41 +0100681 # Chromium should only depend on the WebRTC component in order to
682 # avoid to statically link WebRTC in a component build.
683 if (build_with_chromium) {
684 publicly_visible = false
685 foreach(v, visibility) {
686 if (v == "*") {
687 publicly_visible = true
688 }
689 }
690 if (publicly_visible) {
691 visibility = []
692 visibility = webrtc_default_visibility
693 }
694 }
695
Mirko Bonadei86d053c2019-10-17 21:32:04 +0200696 if (!defined(testonly) || !testonly) {
697 configs += rtc_prod_configs
698 }
699
700 configs += invoker.configs
701 configs += rtc_library_impl_config
702 configs -= rtc_remove_configs
703 configs -= invoker.suppressed_configs
704 public_configs = [
705 rtc_common_inherited_config,
706 absl_include_config,
707 absl_define_config,
708 ]
709 if (defined(testonly) && testonly) {
710 public_configs += [ absl_flags_config ]
711 }
712 if (defined(invoker.public_configs)) {
713 public_configs += invoker.public_configs
714 }
715 }
716}
717
718template("rtc_executable") {
719 executable(target_name) {
720 forward_variables_from(invoker,
721 "*",
722 [
723 "deps",
724 "configs",
725 "public_configs",
726 "suppressed_configs",
727 "visibility",
728 ])
729 forward_variables_from(invoker, [ "visibility" ])
730 if (!defined(visibility)) {
731 visibility = webrtc_default_visibility
732 }
733 configs += invoker.configs
734 configs -= rtc_remove_configs
735 configs -= invoker.suppressed_configs
736 deps = invoker.deps
737
738 public_configs = [
739 rtc_common_inherited_config,
740 absl_include_config,
741 absl_define_config,
742 ]
743 if (defined(testonly) && testonly) {
744 public_configs += [ absl_flags_config ]
745 }
746 if (defined(invoker.public_configs)) {
747 public_configs += invoker.public_configs
748 }
749 if (is_win) {
750 deps += [
751 # Give executables the default manifest on Windows (a no-op elsewhere).
752 "//build/win:default_exe_manifest",
753 ]
754 }
755 }
756}
757
mbonadei9aa3f0a2017-01-24 06:58:22 -0800758template("rtc_shared_library") {
759 shared_library(target_name) {
760 forward_variables_from(invoker,
761 "*",
762 [
763 "configs",
764 "public_configs",
765 "suppressed_configs",
Karl Wiberg138d4ac2017-10-16 11:16:19 +0200766 "visibility",
mbonadei9aa3f0a2017-01-24 06:58:22 -0800767 ])
Karl Wiberg138d4ac2017-10-16 11:16:19 +0200768 forward_variables_from(invoker, [ "visibility" ])
Per Kjellandera7f2d842018-01-10 15:54:53 +0000769 if (!defined(visibility)) {
770 visibility = webrtc_default_visibility
771 }
Karl Wibergbb23c832018-04-22 19:55:00 +0200772
773 # What's your poison?
774 if (defined(testonly) && testonly) {
775 assert(!defined(poisonous))
776 assert(!defined(allow_poison))
777 } else {
778 if (!defined(poisonous)) {
779 poisonous = []
780 }
781 if (!defined(allow_poison)) {
782 allow_poison = []
783 }
784 if (!defined(assert_no_deps)) {
785 assert_no_deps = []
786 }
787 if (!defined(deps)) {
788 deps = []
789 }
790 foreach(p, poisonous) {
791 deps += [ webrtc_root + ":poison_" + p ]
792 }
793 foreach(poison_type, all_poison_types) {
794 allow_dep = true
795 foreach(v, visibility) {
796 if (v == "*") {
797 allow_dep = false
798 }
799 }
800 foreach(p, allow_poison + poisonous) {
801 if (p == poison_type) {
802 allow_dep = true
803 }
804 }
805 if (!allow_dep) {
806 assert_no_deps += [ webrtc_root + ":poison_" + poison_type ]
807 }
808 }
809 }
810
mbonadei9aa3f0a2017-01-24 06:58:22 -0800811 configs += invoker.configs
812 configs -= rtc_remove_configs
813 configs -= invoker.suppressed_configs
Mirko Bonadei9a89a492018-05-29 14:22:32 +0000814 public_configs = [
815 rtc_common_inherited_config,
816 absl_include_config,
817 absl_define_config,
818 ]
Mirko Bonadei2ab97f62019-07-18 13:44:12 +0200819 if (defined(testonly) && testonly) {
820 public_configs += [ absl_flags_config ]
821 }
mbonadei9aa3f0a2017-01-24 06:58:22 -0800822 if (defined(invoker.public_configs)) {
823 public_configs += invoker.public_configs
824 }
825 }
826}
kthelgason4065a572017-02-14 04:58:56 -0800827
828if (is_ios) {
829 set_defaults("rtc_ios_xctest_test") {
830 configs = rtc_add_configs
831 suppressed_configs = []
832 }
833
834 template("rtc_ios_xctest_test") {
835 ios_xctest_test(target_name) {
836 forward_variables_from(invoker,
837 "*",
838 [
839 "configs",
840 "public_configs",
841 "suppressed_configs",
Karl Wiberg138d4ac2017-10-16 11:16:19 +0200842 "visibility",
kthelgason4065a572017-02-14 04:58:56 -0800843 ])
Karl Wiberg138d4ac2017-10-16 11:16:19 +0200844 forward_variables_from(invoker, [ "visibility" ])
Per Kjellandera7f2d842018-01-10 15:54:53 +0000845 if (!defined(visibility)) {
846 visibility = webrtc_default_visibility
847 }
kthelgason4065a572017-02-14 04:58:56 -0800848 configs += invoker.configs
849 configs -= rtc_remove_configs
850 configs -= invoker.suppressed_configs
851 public_configs = [ rtc_common_inherited_config ]
852 if (defined(invoker.public_configs)) {
853 public_configs += invoker.public_configs
854 }
855 }
856 }
Anders Carlssondc6b4772018-01-15 13:31:03 +0100857
Joel Sutherlandd2fb1bf2018-10-02 16:08:25 -0400858 # TODO: Generate module.modulemap file to enable use in Swift
859 # projects. See "mac_framework_bundle_with_umbrella_header".
Anders Carlssondc6b4772018-01-15 13:31:03 +0100860 template("ios_framework_bundle_with_umbrella_header") {
861 forward_variables_from(invoker, [ "output_name" ])
862 umbrella_header_path =
863 "$target_gen_dir/$output_name.framework/Headers/$output_name.h"
864
865 ios_framework_bundle(target_name) {
866 forward_variables_from(invoker, "*", [])
867
868 deps += [ ":copy_umbrella_header_$target_name" ]
869 }
870
871 action("umbrella_header_$target_name") {
872 forward_variables_from(invoker, [ "public_headers" ])
873
874 script = "//tools_webrtc/ios/generate_umbrella_header.py"
875
Mirko Bonadeiccbe95f2020-01-21 12:10:10 +0100876 outputs = [ umbrella_header_path ]
Anders Carlssondc6b4772018-01-15 13:31:03 +0100877 args = [
878 "--out",
879 rebase_path(umbrella_header_path, root_build_dir),
880 "--sources",
Anders Carlsson7bca8ca2018-08-30 09:30:29 +0200881 ] + public_headers
Anders Carlssondc6b4772018-01-15 13:31:03 +0100882 }
883
884 copy("copy_umbrella_header_$target_name") {
Mirko Bonadeiccbe95f2020-01-21 12:10:10 +0100885 sources = [ umbrella_header_path ]
886 outputs =
887 [ "$root_out_dir/$output_name.framework/Headers/$output_name.h" ]
Anders Carlssondc6b4772018-01-15 13:31:03 +0100888
Mirko Bonadeiccbe95f2020-01-21 12:10:10 +0100889 deps = [ ":umbrella_header_$target_name" ]
Anders Carlssondc6b4772018-01-15 13:31:03 +0100890 }
891 }
892
893 set_defaults("ios_framework_bundle_with_umbrella_header") {
894 configs = default_shared_library_configs
895 }
kthelgason4065a572017-02-14 04:58:56 -0800896}
Mirko Bonadeifbb3b7d2017-11-07 15:36:33 +0000897
Anders Carlsson37bbf792018-09-05 16:29:27 +0200898if (is_mac) {
899 template("mac_framework_bundle_with_umbrella_header") {
900 forward_variables_from(invoker, [ "output_name" ])
Anders Carlsson95c56ee2018-09-06 15:48:17 +0200901 this_target_name = target_name
902 umbrella_header_path = "$target_gen_dir/umbrella_header/$output_name.h"
Joel Sutherlandd2fb1bf2018-10-02 16:08:25 -0400903 modulemap_path = "$target_gen_dir/Modules/module.modulemap"
Anders Carlsson37bbf792018-09-05 16:29:27 +0200904
905 mac_framework_bundle(target_name) {
Thomas Anderson6fde78c2019-01-23 10:40:29 -0800906 forward_variables_from(invoker, "*", [ "configs" ])
907 if (defined(invoker.configs)) {
908 configs += invoker.configs
909 }
Anders Carlsson37bbf792018-09-05 16:29:27 +0200910
911 framework_version = "A"
Joel Sutherlandd2fb1bf2018-10-02 16:08:25 -0400912 framework_contents = [
913 "Headers",
914 "Modules",
915 "Resources",
916 ]
Anders Carlsson37bbf792018-09-05 16:29:27 +0200917
918 ldflags = [
919 "-all_load",
920 "-install_name",
921 "@rpath/$output_name.framework/$output_name",
922 ]
923
924 deps += [
Anders Carlsson95c56ee2018-09-06 15:48:17 +0200925 ":copy_framework_headers_$this_target_name",
Joel Sutherlandd2fb1bf2018-10-02 16:08:25 -0400926 ":copy_modulemap_$this_target_name",
Anders Carlsson95c56ee2018-09-06 15:48:17 +0200927 ":copy_umbrella_header_$this_target_name",
Joel Sutherlandd2fb1bf2018-10-02 16:08:25 -0400928 ":modulemap_$this_target_name",
Anders Carlsson95c56ee2018-09-06 15:48:17 +0200929 ":umbrella_header_$this_target_name",
Anders Carlsson37bbf792018-09-05 16:29:27 +0200930 ]
931 }
932
Anders Carlsson95c56ee2018-09-06 15:48:17 +0200933 bundle_data("copy_framework_headers_$this_target_name") {
Anders Carlsson37bbf792018-09-05 16:29:27 +0200934 forward_variables_from(invoker, [ "sources" ])
935
Mirko Bonadeiccbe95f2020-01-21 12:10:10 +0100936 outputs = [ "{{bundle_contents_dir}}/Headers/{{source_file_part}}" ]
Anders Carlsson37bbf792018-09-05 16:29:27 +0200937 }
938
Joel Sutherlandd2fb1bf2018-10-02 16:08:25 -0400939 action("modulemap_$this_target_name") {
940 script = "//tools_webrtc/ios/generate_modulemap.py"
941 args = [
942 "--out",
943 rebase_path(modulemap_path, root_build_dir),
944 "--name",
945 output_name,
946 ]
Mirko Bonadeiccbe95f2020-01-21 12:10:10 +0100947 outputs = [ modulemap_path ]
Joel Sutherlandd2fb1bf2018-10-02 16:08:25 -0400948 }
949
950 bundle_data("copy_modulemap_$this_target_name") {
Mirko Bonadeiccbe95f2020-01-21 12:10:10 +0100951 sources = [ modulemap_path ]
952 outputs = [ "{{bundle_contents_dir}}/Modules/module.modulemap" ]
953 deps = [ ":modulemap_$this_target_name" ]
Joel Sutherlandd2fb1bf2018-10-02 16:08:25 -0400954 }
955
Anders Carlsson95c56ee2018-09-06 15:48:17 +0200956 action("umbrella_header_$this_target_name") {
Anders Carlsson37bbf792018-09-05 16:29:27 +0200957 forward_variables_from(invoker, [ "sources" ])
958
959 script = "//tools_webrtc/ios/generate_umbrella_header.py"
960
Mirko Bonadeiccbe95f2020-01-21 12:10:10 +0100961 outputs = [ umbrella_header_path ]
Anders Carlsson37bbf792018-09-05 16:29:27 +0200962 args = [
963 "--out",
964 rebase_path(umbrella_header_path, root_build_dir),
965 "--sources",
966 ] + sources
967 }
968
Anders Carlsson95c56ee2018-09-06 15:48:17 +0200969 bundle_data("copy_umbrella_header_$this_target_name") {
Mirko Bonadeiccbe95f2020-01-21 12:10:10 +0100970 sources = [ umbrella_header_path ]
971 outputs = [ "{{bundle_contents_dir}}/Headers/$output_name.h" ]
Anders Carlsson37bbf792018-09-05 16:29:27 +0200972
Mirko Bonadeiccbe95f2020-01-21 12:10:10 +0100973 deps = [ ":umbrella_header_$this_target_name" ]
Anders Carlsson37bbf792018-09-05 16:29:27 +0200974 }
975 }
976}
977
Mirko Bonadeifbb3b7d2017-11-07 15:36:33 +0000978if (is_android) {
979 template("rtc_android_library") {
980 android_library(target_name) {
981 forward_variables_from(invoker,
982 "*",
983 [
984 "configs",
985 "public_configs",
986 "suppressed_configs",
987 "visibility",
988 ])
989
Oleh Prypin05aee742018-11-23 17:29:44 +0100990 errorprone_args = []
Sami Kalliomäkie7fac682018-03-20 16:32:49 +0100991
Mirko Bonadeifbb3b7d2017-11-07 15:36:33 +0000992 # Treat warnings as errors.
Oleh Prypin05aee742018-11-23 17:29:44 +0100993 errorprone_args += [ "-Werror" ]
Sami Kalliomäkie7fac682018-03-20 16:32:49 +0100994
Sami Kalliomäki68d58602019-01-24 12:56:12 +0100995 # WebRTC supports API level 16 while Chromium only supports 19.
996 # (the manifest defines minimum supported SDK version)
Oleh Prypin4cbb4ef2019-06-18 17:09:51 +0200997 if (defined(invoker.min_sdk_version)) {
998 min_sdk_version = invoker.min_sdk_version
Sami Kalliomäki68d58602019-01-24 12:56:12 +0100999 } else {
Oleh Prypin4cbb4ef2019-06-18 17:09:51 +02001000 min_sdk_version = 16
Sami Kalliomäki68d58602019-01-24 12:56:12 +01001001 }
1002
Sami Kalliomäkie7fac682018-03-20 16:32:49 +01001003 # Add any arguments defined by the invoker.
Oleh Prypin05aee742018-11-23 17:29:44 +01001004 if (defined(invoker.errorprone_args)) {
1005 errorprone_args += invoker.errorprone_args
Sami Kalliomäkie7fac682018-03-20 16:32:49 +01001006 }
Mirko Bonadeifbb3b7d2017-11-07 15:36:33 +00001007
Sami Kalliomäkidc526512018-03-27 17:07:27 +02001008 if (!defined(deps)) {
1009 deps = []
1010 }
Sami Kalliomäkidc526512018-03-27 17:07:27 +02001011
Mirko Bonadeifbb3b7d2017-11-07 15:36:33 +00001012 no_build_hooks = true
1013 }
1014 }
1015
1016 template("rtc_android_apk") {
1017 android_apk(target_name) {
1018 forward_variables_from(invoker,
1019 "*",
1020 [
1021 "configs",
1022 "public_configs",
1023 "suppressed_configs",
1024 "visibility",
1025 ])
1026
1027 # Treat warnings as errors.
Yves Gerey2f385d22019-11-20 12:10:08 +01001028 errorprone_args = []
1029 errorprone_args += [ "-Werror" ]
Sami Kalliomäkidc526512018-03-27 17:07:27 +02001030
1031 if (!defined(deps)) {
1032 deps = []
1033 }
Sami Kalliomäkidc526512018-03-27 17:07:27 +02001034
Mirko Bonadeifbb3b7d2017-11-07 15:36:33 +00001035 no_build_hooks = true
1036 }
1037 }
1038
1039 template("rtc_instrumentation_test_apk") {
1040 instrumentation_test_apk(target_name) {
1041 forward_variables_from(invoker,
1042 "*",
1043 [
1044 "configs",
1045 "public_configs",
1046 "suppressed_configs",
1047 "visibility",
1048 ])
1049
1050 # Treat warnings as errors.
Yves Gerey2f385d22019-11-20 12:10:08 +01001051 errorprone_args = []
1052 errorprone_args += [ "-Werror" ]
Sami Kalliomäkidc526512018-03-27 17:07:27 +02001053
1054 if (!defined(deps)) {
1055 deps = []
1056 }
Sami Kalliomäkidc526512018-03-27 17:07:27 +02001057
Mirko Bonadeifbb3b7d2017-11-07 15:36:33 +00001058 no_build_hooks = true
1059 }
1060 }
1061}