Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(382)

Side by Side Diff: webrtc/sdk/android/BUILD.gn

Issue 2939203002: Support building WebRTC without audio and video for Android (Closed)
Patch Set: Rebase. Created 3 years, 6 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
1 # Copyright (c) 2016 The WebRTC project authors. All Rights Reserved. 1 # Copyright (c) 2016 The WebRTC project authors. All Rights Reserved.
2 # 2 #
3 # Use of this source code is governed by a BSD-style license 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 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 5 # tree. An additional intellectual property rights grant can be found
6 # in the file PATENTS. All contributing project authors may 6 # in the file PATENTS. All contributing project authors may
7 # be found in the AUTHORS file in the root of the source tree. 7 # be found in the AUTHORS file in the root of the source tree.
8 8
9 import("//webrtc/webrtc.gni") 9 import("//webrtc/webrtc.gni")
10 import("//build/config/android/config.gni") 10 import("//build/config/android/config.gni")
11 import("//build/config/android/rules.gni") 11 import("//build/config/android/rules.gni")
12 12
13 config("libjingle_peerconnection_jni_warnings_config") { 13 config("libjingle_peerconnection_jni_warnings_config") {
14 # The warnings below are enabled by default. Since GN orders compiler flags 14 # The warnings below are enabled by default. Since GN orders compiler flags
15 # for a target before flags from configs, the only way to disable such 15 # for a target before flags from configs, the only way to disable such
16 # warnings is by having them in a separate config, loaded from the target. 16 # warnings is by having them in a separate config, loaded from the target.
17 if (!is_win) { 17 if (!is_win) {
18 cflags = [ 18 cflags = [
19 "-Wno-sign-compare", 19 "-Wno-sign-compare",
20 "-Wno-unused-variable", 20 "-Wno-unused-variable",
21 ] 21 ]
22 } 22 }
23 } 23 }
24 24
25 rtc_static_library("libjingle_peerconnection_jni") { 25 rtc_static_library("base_jni") {
Taylor Brandstetter 2017/06/16 22:19:08 May want to make these rtc_source_sets
Zhi Huang 2017/06/17 01:46:43 Done.
26 sources = [
27 "src/jni/androidmediacodeccommon.h",
28 "src/jni/classreferenceholder.cc",
29 "src/jni/classreferenceholder.h",
30 "src/jni/jni_helpers.cc",
31 "src/jni/jni_helpers.h",
32 "src/jni/ownedfactoryandthreads.cc",
33 "src/jni/ownedfactoryandthreads.h",
34 ]
35
36 deps = [
37 "//webrtc/api:libjingle_peerconnection_api",
38 "//webrtc/base:rtc_base",
39 "//webrtc/base:rtc_base_approved",
40 ]
41
42 if (is_clang) {
43 # Suppress warnings from the Chromium Clang plugin (bugs.webrtc.org/163).
44 suppressed_configs += [
45 "//build/config/clang:extra_warnings",
46 "//build/config/clang:find_bad_constructs",
47 ]
48 }
49 }
50
51 rtc_static_library("audio_jni") {
52 deps = [
53 ":base_jni",
54 "//webrtc/voice_engine:voice_engine",
55 ]
56 }
57
58 rtc_static_library("null_audio_jni") {
59 sources = [
60 "src/jni/null_audio_jni.cc",
61 ]
62
63 deps = [
64 "//webrtc/api:audio_mixer_api",
65 "//webrtc/api:libjingle_peerconnection_api",
66 "//webrtc/base:rtc_base",
67 "//webrtc/base:rtc_base_approved",
68 "//webrtc/call:call_interfaces",
69 "//webrtc/logging:rtc_event_log_api",
70 ]
71 }
72
73 rtc_static_library("video_jni") {
26 sources = [ 74 sources = [
27 "src/jni/androidhistogram_jni.cc", 75 "src/jni/androidhistogram_jni.cc",
28 "src/jni/androidmediacodeccommon.h",
29 "src/jni/androidmediadecoder_jni.cc", 76 "src/jni/androidmediadecoder_jni.cc",
30 "src/jni/androidmediadecoder_jni.h", 77 "src/jni/androidmediadecoder_jni.h",
31 "src/jni/androidmediaencoder_jni.cc", 78 "src/jni/androidmediaencoder_jni.cc",
32 "src/jni/androidmediaencoder_jni.h", 79 "src/jni/androidmediaencoder_jni.h",
33 "src/jni/androidnetworkmonitor_jni.cc",
34 "src/jni/androidnetworkmonitor_jni.h",
35 "src/jni/androidvideotracksource.cc", 80 "src/jni/androidvideotracksource.cc",
36 "src/jni/androidvideotracksource.h", 81 "src/jni/androidvideotracksource.h",
37 "src/jni/androidvideotracksource_jni.cc", 82 "src/jni/androidvideotracksource_jni.cc",
38 "src/jni/classreferenceholder.cc",
39 "src/jni/classreferenceholder.h",
40 "src/jni/jni_helpers.cc",
41 "src/jni/jni_helpers.h",
42 "src/jni/native_handle_impl.cc", 83 "src/jni/native_handle_impl.cc",
43 "src/jni/native_handle_impl.h", 84 "src/jni/native_handle_impl.h",
44 "src/jni/peerconnection_jni.cc",
45 "src/jni/rtcstatscollectorcallbackwrapper.cc",
46 "src/jni/rtcstatscollectorcallbackwrapper.h",
47 "src/jni/surfacetexturehelper_jni.cc", 85 "src/jni/surfacetexturehelper_jni.cc",
48 "src/jni/surfacetexturehelper_jni.h", 86 "src/jni/surfacetexturehelper_jni.h",
87 "src/jni/video_jni.cc",
88 "src/jni/video_renderer_jni.cc",
49 "src/jni/wrapped_native_i420_buffer.cc", 89 "src/jni/wrapped_native_i420_buffer.cc",
50 "src/jni/wrapped_native_i420_buffer.h", 90 "src/jni/wrapped_native_i420_buffer.h",
51 ] 91 ]
52 92
53 configs += [ ":libjingle_peerconnection_jni_warnings_config" ] 93 configs += [ ":libjingle_peerconnection_jni_warnings_config" ]
54 94
55 if (is_clang) { 95 if (is_clang) {
56 # Suppress warnings from the Chromium Clang plugin (bugs.webrtc.org/163). 96 # Suppress warnings from the Chromium Clang plugin (bugs.webrtc.org/163).
57 suppressed_configs += [ 97 suppressed_configs += [
58 "//build/config/clang:extra_warnings", 98 "//build/config/clang:extra_warnings",
59 "//build/config/clang:find_bad_constructs", 99 "//build/config/clang:find_bad_constructs",
60 ] 100 ]
61 } 101 }
62 102
63 # TODO(jschuh): Bug 1348: fix this warning. 103 # TODO(jschuh): Bug 1348: fix this warning.
64 configs += [ "//build/config/compiler:no_size_t_to_int_warning" ] 104 configs += [ "//build/config/compiler:no_size_t_to_int_warning" ]
65 105
66 if (is_win) { 106 if (is_win) {
67 cflags += [ 107 cflags += [
68 "/wd4245", # conversion from "int" to "size_t", signed/unsigned mismatch. 108 "/wd4245", # conversion from "int" to "size_t", signed/unsigned mismatch.
69 "/wd4389", # signed/unsigned mismatch. 109 "/wd4389", # signed/unsigned mismatch.
70 ] 110 ]
71 } 111 }
72 112
73 deps = [ 113 deps = [
74 "../..:webrtc_common", 114 ":base_jni",
75 "../../api:video_frame_api", 115 "//webrtc:webrtc_common",
76 "../../api/video_codecs:video_codecs_api", 116 "//webrtc/api:libjingle_peerconnection_api",
77 "../../base:rtc_base", 117 "//webrtc/api:video_frame_api",
78 "../../base:rtc_base_approved", 118 "//webrtc/api/video_codecs:video_codecs_api",
79 "../../base:rtc_task_queue", 119 "//webrtc/base:rtc_base",
80 "../../base:sequenced_task_checker", 120 "//webrtc/base:rtc_base_approved",
81 "../../base:weak_ptr", 121 "//webrtc/base:rtc_task_queue",
82 "../../common_video:common_video", 122 "//webrtc/base:sequenced_task_checker",
83 "../../media:rtc_media", 123 "//webrtc/base:weak_ptr",
84 "../../media:rtc_media_base", 124 "//webrtc/common_video:common_video",
85 "../../modules/utility:utility", 125 "//webrtc/media:rtc_audio_video",
86 "../../modules/video_coding:video_coding_utility", 126 "//webrtc/media:rtc_media_base",
87 "../../system_wrappers:system_wrappers", 127 "//webrtc/modules/utility:utility",
88 "../../voice_engine:voice_engine", 128 "//webrtc/modules/video_coding:video_coding_utility",
89 "//webrtc/pc:libjingle_peerconnection", 129 "//webrtc/system_wrappers:system_wrappers",
90 ] 130 ]
91 131
92 if (rtc_build_libyuv) { 132 if (rtc_build_libyuv) {
93 deps += [ "$rtc_libyuv_dir" ] 133 deps += [ "$rtc_libyuv_dir" ]
94 public_deps = [ 134 public_deps = [
95 "$rtc_libyuv_dir", 135 "$rtc_libyuv_dir",
96 ] 136 ]
97 } else { 137 } else {
98 # Need to add a directory normally exported by libyuv. 138 # Need to add a directory normally exported by libyuv.
99 include_dirs = [ "$rtc_libyuv_dir/include" ] 139 include_dirs = [ "$rtc_libyuv_dir/include" ]
100 } 140 }
101 } 141 }
102 142
143 rtc_static_library("null_video_jni") {
144 sources = [
145 "src/jni/null_video_jni.cc",
146 ]
147
148 deps = [
149 ":base_jni",
150 "//webrtc/base:rtc_base_approved",
151 ]
152
153 if (is_clang) {
154 # Suppress warnings from the Chromium Clang plugin (bugs.webrtc.org/163).
155 suppressed_configs += [
156 "//build/config/clang:extra_warnings",
157 "//build/config/clang:find_bad_constructs",
158 ]
159 }
160 }
161
162 rtc_static_library("peerconnection_jni") {
163 sources = [
164 "src/jni/androidnetworkmonitor_jni.cc",
165 "src/jni/androidnetworkmonitor_jni.h",
166 "src/jni/peerconnection_jni.cc",
167 "src/jni/rtcstatscollectorcallbackwrapper.cc",
168 "src/jni/rtcstatscollectorcallbackwrapper.h",
169 ]
170
171 configs += [ ":libjingle_peerconnection_jni_warnings_config" ]
172
173 if (is_clang) {
174 # Suppress warnings from the Chromium Clang plugin (bugs.webrtc.org/163).
175 suppressed_configs += [
176 "//build/config/clang:extra_warnings",
177 "//build/config/clang:find_bad_constructs",
178 ]
179 }
180
181 # TODO(jschuh): Bug 1348: fix this warning.
182 configs += [ "//build/config/compiler:no_size_t_to_int_warning" ]
183
184 if (is_win) {
185 cflags += [
186 "/wd4245", # conversion from "int" to "size_t", signed/unsigned mismatch.
187 "/wd4389", # signed/unsigned mismatch.
188 ]
189 }
190
191 deps = [
192 ":base_jni",
193 "../..:webrtc_common",
194 "//webrtc/base:rtc_base",
195 "//webrtc/base:rtc_base_approved",
196 "//webrtc/base:rtc_task_queue",
197 "//webrtc/media:rtc_data",
198 "//webrtc/media:rtc_media_base",
199 "//webrtc/modules/utility:utility",
200 "//webrtc/pc:peerconnection",
201 "//webrtc/system_wrappers:system_wrappers",
202 ]
203 }
204
205 rtc_static_library("libjingle_peerconnection_jni") {
206 public_deps = [
207 ":audio_jni",
208 ":base_jni",
209 ":peerconnection_jni",
210 ":video_jni",
211 "//webrtc/pc:create_pc_factory",
212 ]
213 }
214
215 rtc_static_library("metrics_jni") {
Taylor Brandstetter 2017/06/16 22:19:08 Do we need the two "metrics_jni" targets? It seems
Zhi Huang 2017/06/17 01:46:43 Done.
216 sources = [
217 "src/jni/androidmetrics_jni.cc",
218 ]
219
220 configs += [ ":libjingle_peerconnection_jni_warnings_config" ]
221
222 deps = [
223 ":base_jni",
224 ":peerconnection_jni",
225 "//webrtc/pc:peerconnection",
226 "//webrtc/system_wrappers",
227 "//webrtc/system_wrappers:field_trial_default",
228 "//webrtc/system_wrappers:metrics_default",
229 ]
230 }
231
103 rtc_static_library("libjingle_peerconnection_metrics_default_jni") { 232 rtc_static_library("libjingle_peerconnection_metrics_default_jni") {
104 sources = [ 233 sources = [
105 "src/jni/androidmetrics_jni.cc", 234 "src/jni/androidmetrics_jni.cc",
106 ] 235 ]
107 236
108 configs += [ ":libjingle_peerconnection_jni_warnings_config" ] 237 configs += [ ":libjingle_peerconnection_jni_warnings_config" ]
109 238
110 deps = [ 239 deps = [
111 ":libjingle_peerconnection_jni", 240 ":libjingle_peerconnection_jni",
112 "../../system_wrappers",
113 "//webrtc/pc:libjingle_peerconnection", 241 "//webrtc/pc:libjingle_peerconnection",
242 "//webrtc/system_wrappers",
114 "//webrtc/system_wrappers:field_trial_default", 243 "//webrtc/system_wrappers:field_trial_default",
115 "//webrtc/system_wrappers:metrics_default", 244 "//webrtc/system_wrappers:metrics_default",
116 ] 245 ]
117 } 246 }
118 247
248 # The modular build targets can be used to build WebRTC with different
249 # functionalities. The users can choose either the real implemenation or the
250 # null implementation of the audio/video modules based on their requirments.
251 #
252 # For example, to build WebRTC with datachannel support only, we would need the
253 # the peerconnection and the null implementation of the audio and video module.
254 # rtc_shared_library("libjingle_peerconnection_datachannelonly_so") {
255 # sources = [
256 # "src/jni/jni_onload.cc",
257 # ]
258 #
259 # suppressed_configs += [ "//build/config/android:hide_all_but_jni_onload" ]
260 # configs += [ "//build/config/android:hide_all_but_jni" ]
261 #
262 # deps = [
263 # ":base_jni",
264 # ":metrics_jni",
265 # ":null_audio_jni",
266 # ":null_video_jni",
267 # ":peerconnection_jni",
268 # "//webrtc/base:rtc_base",
269 # "//webrtc/base:rtc_base_approved",
270 # "//webrtc/pc:peerconnection",
271 # ]
272 # output_extension = "so"
273 # }
Taylor Brandstetter 2017/06/16 22:19:08 May want to mention that this is still under devel
Zhi Huang 2017/06/17 01:46:43 I'll try to remove the limitation.
274
119 rtc_shared_library("libjingle_peerconnection_so") { 275 rtc_shared_library("libjingle_peerconnection_so") {
120 sources = [ 276 sources = [
121 "src/jni/jni_onload.cc", 277 "src/jni/jni_onload.cc",
122 ] 278 ]
123 279
124 suppressed_configs += [ "//build/config/android:hide_all_but_jni_onload" ] 280 suppressed_configs += [ "//build/config/android:hide_all_but_jni_onload" ]
125 configs += [ "//build/config/android:hide_all_but_jni" ] 281 configs += [ "//build/config/android:hide_all_but_jni" ]
126 282
127 deps = [ 283 deps = [
128 ":libjingle_peerconnection_jni", 284 ":libjingle_peerconnection_jni",
129 ":libjingle_peerconnection_metrics_default_jni", 285 ":libjingle_peerconnection_metrics_default_jni",
130 "../../base:rtc_base", 286 "//webrtc/base:rtc_base",
131 "//webrtc/pc:libjingle_peerconnection", 287 "//webrtc/pc:libjingle_peerconnection",
132 ] 288 ]
133 output_extension = "so" 289 output_extension = "so"
134 } 290 }
135 291
136 dist_jar("libwebrtc") { 292 dist_jar("libwebrtc") {
137 _target_dir_name = get_label_info(":$target_name", "dir") 293 _target_dir_name = get_label_info(":$target_name", "dir")
138 output = "${root_out_dir}/lib.java${_target_dir_name}/${target_name}.jar" 294 output = "${root_out_dir}/lib.java${_target_dir_name}/${target_name}.jar"
139 direct_deps_only = true 295 direct_deps_only = true
140 use_interface_jars = false 296 use_interface_jars = false
(...skipping 132 matching lines...) Expand 10 before | Expand all | Expand 10 after
273 "//third_party/android_support_test_runner:runner_java", 429 "//third_party/android_support_test_runner:runner_java",
274 "//third_party/junit", 430 "//third_party/junit",
275 "//webrtc/base:base_java", 431 "//webrtc/base:base_java",
276 "//webrtc/sdk/android:libjingle_peerconnection_java", 432 "//webrtc/sdk/android:libjingle_peerconnection_java",
277 "//webrtc/sdk/android:libjingle_peerconnection_metrics_default_java", 433 "//webrtc/sdk/android:libjingle_peerconnection_metrics_default_java",
278 ] 434 ]
279 435
280 shared_libraries = [ "//webrtc/sdk/android:libjingle_peerconnection_so" ] 436 shared_libraries = [ "//webrtc/sdk/android:libjingle_peerconnection_so" ]
281 } 437 }
282 } 438 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698