blob: de1c5e97b7cce4510d5688d0aecd1a95acb25ad5 [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.
8
9import("//build/config/arm.gni")
10import("//build/config/features.gni")
11import("//build/config/mips.gni")
12import("//build/config/sanitizers/sanitizers.gni")
ehmaldonado0d729b32017-02-10 01:38:23 -080013import("//build/config/ui.gni")
mbonadei9aa3f0a2017-01-24 06:58:22 -080014import("//build_overrides/build.gni")
15import("//testing/test.gni")
mbonadei96606272017-03-03 19:41:59 -080016
17if (!build_with_chromium && is_component_build) {
18 print("The Gn argument `is_component_build` is currently " +
19 "ignored for WebRTC builds.")
20 print("Component builds are supported by Chromium and the argument " +
21 "`is_component_build` makes it possible to create shared libraries " +
22 "instead of static libraries.")
23 print("If an app depends on WebRTC it makes sense to just depend on the " +
24 "WebRTC static library, so there is no difference between " +
25 "`is_component_build=true` and `is_component_build=false`.")
26 print(
27 "More info about component builds at: " + "https://chromium.googlesource.com/chromium/src/+/master/docs/component_build.md")
28 assert(!is_component_build, "Component builds are not supported in WebRTC.")
29}
30
kthelgason4065a572017-02-14 04:58:56 -080031if (is_ios) {
32 import("//build/config/ios/rules.gni")
33}
mbonadei9aa3f0a2017-01-24 06:58:22 -080034
35declare_args() {
36 # Disable this to avoid building the Opus audio codec.
37 rtc_include_opus = true
38
minyue2e03c662017-02-01 17:31:11 -080039 # Enable this if the Opus version upon which WebRTC is built supports direct
40 # encoding of 120 ms packets.
minyue-webrtc516711c2017-07-27 17:45:49 +020041 rtc_opus_support_120ms_ptime = true
minyue2e03c662017-02-01 17:31:11 -080042
mbonadei9aa3f0a2017-01-24 06:58:22 -080043 # Enable this to let the Opus audio codec change complexity on the fly.
44 rtc_opus_variable_complexity = false
45
mbonadei9aa3f0a2017-01-24 06:58:22 -080046 # Used to specify an external Jsoncpp include path when not compiling the
47 # library that comes with WebRTC (i.e. rtc_build_json == 0).
48 rtc_jsoncpp_root = "//third_party/jsoncpp/source/include"
49
50 # Used to specify an external OpenSSL include path when not compiling the
51 # library that comes with WebRTC (i.e. rtc_build_ssl == 0).
52 rtc_ssl_root = ""
53
54 # Selects fixed-point code where possible.
55 rtc_prefer_fixed_point = false
56
57 # Enables the use of protocol buffers for debug recordings.
58 rtc_enable_protobuf = true
59
60 # Disable the code for the intelligibility enhancer by default.
61 rtc_enable_intelligibility_enhancer = false
62
63 # Enable when an external authentication mechanism is used for performing
64 # packet authentication for RTP packets instead of libsrtp.
65 rtc_enable_external_auth = build_with_chromium
66
67 # Selects whether debug dumps for the audio processing module
68 # should be generated.
69 apm_debug_dump = false
70
71 # Set this to true to enable BWE test logging.
72 rtc_enable_bwe_test_logging = false
73
74 # Set this to disable building with support for SCTP data channels.
75 rtc_enable_sctp = true
76
77 # Disable these to not build components which can be externally provided.
mbonadei9aa3f0a2017-01-24 06:58:22 -080078 rtc_build_json = true
mbonadei9aa3f0a2017-01-24 06:58:22 -080079 rtc_build_libsrtp = true
80 rtc_build_libvpx = true
81 rtc_libvpx_build_vp9 = true
82 rtc_build_libyuv = true
83 rtc_build_openmax_dl = true
84 rtc_build_opus = true
85 rtc_build_ssl = true
86 rtc_build_usrsctp = true
87
88 # Enable to use the Mozilla internal settings.
89 build_with_mozilla = false
90
91 rtc_enable_android_opensl = false
92
93 # Link-Time Optimizations.
94 # Executes code generation at link-time instead of compile-time.
95 # https://gcc.gnu.org/wiki/LinkTimeOptimization
96 rtc_use_lto = false
97
98 # Set to "func", "block", "edge" for coverage generation.
99 # At unit test runtime set UBSAN_OPTIONS="coverage=1".
100 # It is recommend to set include_examples=0.
101 # Use llvm's sancov -html-report for human readable reports.
102 # See http://clang.llvm.org/docs/SanitizerCoverage.html .
103 rtc_sanitize_coverage = ""
104
perkj650fdae2017-08-25 05:00:11 -0700105 # Links a default implementation of task queues to targets
106 # that depend on the target rtc_task_queue. Set to false to
107 # use an external implementation.
108 rtc_link_task_queue_impl = true
109
mbonadei9aa3f0a2017-01-24 06:58:22 -0800110 # Enable libevent task queues on platforms that support it.
perkj650fdae2017-08-25 05:00:11 -0700111 # rtc_link_task_queue_impl must be set to true for this to
112 # have an effect.
mbonadei9aa3f0a2017-01-24 06:58:22 -0800113 if (is_win || is_mac || is_ios || is_nacl) {
114 rtc_enable_libevent = false
115 rtc_build_libevent = false
116 } else {
117 rtc_enable_libevent = true
118 rtc_build_libevent = true
119 }
120
121 if (current_cpu == "arm" || current_cpu == "arm64") {
122 rtc_prefer_fixed_point = true
123 }
124
125 if (!is_ios && (current_cpu != "arm" || arm_version >= 7) &&
126 current_cpu != "mips64el") {
127 rtc_use_openmax_dl = true
128 } else {
129 rtc_use_openmax_dl = false
130 }
131
132 # Determines whether NEON code will be built.
133 rtc_build_with_neon =
134 (current_cpu == "arm" && arm_use_neon) || current_cpu == "arm64"
135
136 # Enable this to build OpenH264 encoder/FFmpeg decoder. This is supported on
137 # all platforms except Android and iOS. Because FFmpeg can be built
138 # with/without H.264 support, |ffmpeg_branding| has to separately be set to a
139 # value that includes H.264, for example "Chrome". If FFmpeg is built without
140 # H.264, compilation succeeds but |H264DecoderImpl| fails to initialize. See
141 # also: |rtc_initialize_ffmpeg|.
142 # CHECK THE OPENH264, FFMPEG AND H.264 LICENSES/PATENTS BEFORE BUILDING.
143 # http://www.openh264.org, https://www.ffmpeg.org/
144 rtc_use_h264 = proprietary_codecs && !is_android && !is_ios
145
146 # Determines whether QUIC code will be built.
147 rtc_use_quic = false
148
149 # By default, use normal platform audio support or dummy audio, but don't
150 # use file-based audio playout and record.
151 rtc_use_dummy_audio_file_devices = false
152
henrika7be78832017-06-13 17:34:16 +0200153 # When set to true, replace the audio output with a sinus tone at 440Hz.
154 # The ADM will ask for audio data from WebRTC but instead of reading real
155 # audio samples from NetEQ, a sinus tone will be generated and replace the
156 # real audio samples.
157 rtc_audio_device_plays_sinus_tone = false
158
mbonadei9aa3f0a2017-01-24 06:58:22 -0800159 # When set to true, test targets will declare the files needed to run memcheck
160 # as data dependencies. This is to enable memcheck execution on swarming bots.
161 rtc_use_memcheck = false
162
163 # FFmpeg must be initialized for |H264DecoderImpl| to work. This can be done
164 # by WebRTC during |H264DecoderImpl::InitDecode| or externally. FFmpeg must
165 # only be initialized once. Projects that initialize FFmpeg externally, such
166 # as Chromium, must turn this flag off so that WebRTC does not also
167 # initialize.
168 rtc_initialize_ffmpeg = !build_with_chromium
169
170 # Build sources requiring GTK. NOTICE: This is not present in Chrome OS
171 # build environments, even if available for Chromium builds.
172 rtc_use_gtk = !build_with_chromium
173}
174
175# A second declare_args block, so that declarations within it can
176# depend on the possibly overridden variables in the first
177# declare_args block.
178declare_args() {
179 # Include the iLBC audio codec?
180 rtc_include_ilbc = !(build_with_chromium || build_with_mozilla)
181
182 rtc_restrict_logging = build_with_chromium
183
184 # Excluded in Chromium since its prerequisites don't require Pulse Audio.
185 rtc_include_pulse_audio = !build_with_chromium
186
187 # Chromium uses its own IO handling, so the internal ADM is only built for
188 # standalone WebRTC.
189 rtc_include_internal_audio_device = !build_with_chromium
190
191 # Include tests in standalone checkout.
192 rtc_include_tests = !build_with_chromium
193}
194
195# Make it possible to provide custom locations for some libraries (move these
196# up into declare_args should we need to actually use them for the GN build).
197rtc_libvpx_dir = "//third_party/libvpx"
198rtc_libyuv_dir = "//third_party/libyuv"
199rtc_opus_dir = "//third_party/opus"
200
201# Desktop capturer is supported only on Windows, OSX and Linux.
ehmaldonado0d729b32017-02-10 01:38:23 -0800202rtc_desktop_capture_supported = is_win || is_mac || (is_linux && use_x11)
mbonadei9aa3f0a2017-01-24 06:58:22 -0800203
204###############################################################################
205# Templates
206#
207
Mirko Bonadei92ea95e2017-09-15 06:47:31 +0200208# Points to // in webrtc stand-alone or to //third_party/webrtc/ in
mbonadei9aa3f0a2017-01-24 06:58:22 -0800209# chromium.
210# We need absolute paths for all configs in templates as they are shared in
211# different subdirectories.
212webrtc_root = get_path_info(".", "abspath")
213
214# Global configuration that should be applied to all WebRTC targets.
215# You normally shouldn't need to include this in your target as it's
216# automatically included when using the rtc_* templates.
217# It sets defines, include paths and compilation warnings accordingly,
218# both for WebRTC stand-alone builds and for the scenario when WebRTC
219# native code is built as part of Chromium.
220rtc_common_configs = [ webrtc_root + ":common_config" ]
221
kthelgasonc0977102017-04-24 00:57:16 -0700222if (is_mac || is_ios) {
223 rtc_common_configs += [ "//build/config/compiler:enable_arc" ]
224}
225
mbonadei9aa3f0a2017-01-24 06:58:22 -0800226# Global public configuration that should be applied to all WebRTC targets. You
227# normally shouldn't need to include this in your target as it's automatically
228# included when using the rtc_* templates. It set the defines, include paths and
229# compilation warnings that should be propagated to dependents of the targets
230# depending on the target having this config.
231rtc_common_inherited_config = webrtc_root + ":common_inherited_config"
232
233# Common configs to remove or add in all rtc targets.
234rtc_remove_configs = []
235rtc_add_configs = rtc_common_configs
236
237set_defaults("rtc_test") {
238 configs = rtc_add_configs
239 suppressed_configs = []
240}
241
242set_defaults("rtc_source_set") {
243 configs = rtc_add_configs
244 suppressed_configs = []
245}
246
247set_defaults("rtc_executable") {
248 configs = rtc_add_configs
249 suppressed_configs = []
250}
251
252set_defaults("rtc_static_library") {
253 configs = rtc_add_configs
254 suppressed_configs = []
255}
256
257set_defaults("rtc_shared_library") {
258 configs = rtc_add_configs
259 suppressed_configs = []
260}
261
262template("rtc_test") {
263 test(target_name) {
264 forward_variables_from(invoker,
265 "*",
266 [
267 "configs",
268 "public_configs",
269 "suppressed_configs",
Karl Wiberg138d4ac2017-10-16 11:16:19 +0200270 "visibility",
mbonadei9aa3f0a2017-01-24 06:58:22 -0800271 ])
Karl Wiberg138d4ac2017-10-16 11:16:19 +0200272 forward_variables_from(invoker, [ "visibility" ])
mbonadei9aa3f0a2017-01-24 06:58:22 -0800273 configs += invoker.configs
274 configs -= rtc_remove_configs
275 configs -= invoker.suppressed_configs
276 public_configs = [ rtc_common_inherited_config ]
277 if (defined(invoker.public_configs)) {
278 public_configs += invoker.public_configs
279 }
sakald7fdb802017-05-26 01:51:53 -0700280 if (!build_with_chromium && is_android) {
Jianjun Zhu037f3e42017-08-15 21:48:37 +0800281 android_manifest = webrtc_root + "test/android/AndroidManifest.xml"
282 deps += [ webrtc_root + "test:native_test_java" ]
sakald7fdb802017-05-26 01:51:53 -0700283 }
mbonadei9aa3f0a2017-01-24 06:58:22 -0800284 }
285}
286
287template("rtc_source_set") {
288 source_set(target_name) {
289 forward_variables_from(invoker,
290 "*",
291 [
292 "configs",
293 "public_configs",
294 "suppressed_configs",
Karl Wiberg138d4ac2017-10-16 11:16:19 +0200295 "visibility",
mbonadei9aa3f0a2017-01-24 06:58:22 -0800296 ])
Karl Wiberg138d4ac2017-10-16 11:16:19 +0200297 forward_variables_from(invoker, [ "visibility" ])
mbonadei9aa3f0a2017-01-24 06:58:22 -0800298 configs += invoker.configs
299 configs -= rtc_remove_configs
300 configs -= invoker.suppressed_configs
301 public_configs = [ rtc_common_inherited_config ]
302 if (defined(invoker.public_configs)) {
303 public_configs += invoker.public_configs
304 }
305 }
306}
307
308template("rtc_executable") {
309 executable(target_name) {
310 forward_variables_from(invoker,
311 "*",
312 [
313 "deps",
314 "configs",
315 "public_configs",
316 "suppressed_configs",
Karl Wiberg138d4ac2017-10-16 11:16:19 +0200317 "visibility",
mbonadei9aa3f0a2017-01-24 06:58:22 -0800318 ])
Karl Wiberg138d4ac2017-10-16 11:16:19 +0200319 forward_variables_from(invoker, [ "visibility" ])
mbonadei9aa3f0a2017-01-24 06:58:22 -0800320 configs += invoker.configs
321 configs -= rtc_remove_configs
322 configs -= invoker.suppressed_configs
323 deps = [
thomasanderson7f52f082017-05-18 23:51:46 -0700324 "//build/config:exe_and_shlib_deps",
mbonadei9aa3f0a2017-01-24 06:58:22 -0800325 ]
326 deps += invoker.deps
perkj650fdae2017-08-25 05:00:11 -0700327
mbonadei9aa3f0a2017-01-24 06:58:22 -0800328 public_configs = [ rtc_common_inherited_config ]
329 if (defined(invoker.public_configs)) {
330 public_configs += invoker.public_configs
331 }
332 }
333}
334
335template("rtc_static_library") {
336 static_library(target_name) {
337 forward_variables_from(invoker,
338 "*",
339 [
340 "configs",
341 "public_configs",
342 "suppressed_configs",
Karl Wiberg138d4ac2017-10-16 11:16:19 +0200343 "visibility",
mbonadei9aa3f0a2017-01-24 06:58:22 -0800344 ])
Karl Wiberg138d4ac2017-10-16 11:16:19 +0200345 forward_variables_from(invoker, [ "visibility" ])
mbonadei9aa3f0a2017-01-24 06:58:22 -0800346 configs += invoker.configs
347 configs -= rtc_remove_configs
348 configs -= invoker.suppressed_configs
349 public_configs = [ rtc_common_inherited_config ]
350 if (defined(invoker.public_configs)) {
351 public_configs += invoker.public_configs
352 }
353 }
354}
355
356template("rtc_shared_library") {
357 shared_library(target_name) {
358 forward_variables_from(invoker,
359 "*",
360 [
361 "configs",
362 "public_configs",
363 "suppressed_configs",
Karl Wiberg138d4ac2017-10-16 11:16:19 +0200364 "visibility",
mbonadei9aa3f0a2017-01-24 06:58:22 -0800365 ])
Karl Wiberg138d4ac2017-10-16 11:16:19 +0200366 forward_variables_from(invoker, [ "visibility" ])
mbonadei9aa3f0a2017-01-24 06:58:22 -0800367 configs += invoker.configs
368 configs -= rtc_remove_configs
369 configs -= invoker.suppressed_configs
370 public_configs = [ rtc_common_inherited_config ]
371 if (defined(invoker.public_configs)) {
372 public_configs += invoker.public_configs
373 }
374 }
375}
kthelgason4065a572017-02-14 04:58:56 -0800376
377if (is_ios) {
378 set_defaults("rtc_ios_xctest_test") {
379 configs = rtc_add_configs
380 suppressed_configs = []
381 }
382
383 template("rtc_ios_xctest_test") {
384 ios_xctest_test(target_name) {
385 forward_variables_from(invoker,
386 "*",
387 [
388 "configs",
389 "public_configs",
390 "suppressed_configs",
Karl Wiberg138d4ac2017-10-16 11:16:19 +0200391 "visibility",
kthelgason4065a572017-02-14 04:58:56 -0800392 ])
Karl Wiberg138d4ac2017-10-16 11:16:19 +0200393 forward_variables_from(invoker, [ "visibility" ])
kthelgason4065a572017-02-14 04:58:56 -0800394 configs += invoker.configs
395 configs -= rtc_remove_configs
396 configs -= invoker.suppressed_configs
397 public_configs = [ rtc_common_inherited_config ]
398 if (defined(invoker.public_configs)) {
399 public_configs += invoker.public_configs
400 }
401 }
402 }
403}