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

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

Issue 2854123003: Build WebRTC with data channel only. (Closed)
Patch Set: Fix the issues. Make it ready for another round of review. Add a test. Created 3 years, 7 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("libjingle_peerconnection_jni") {
26 public_deps = [
27 ":webrtc_audio_jni",
28 ":webrtc_base_jni",
29 ":webrtc_jni_common",
30 ":webrtc_video_jni",
31 ]
32 }
33
34 rtc_static_library("webrtc_jni_common") {
sakal 2017/05/23 09:33:18 nit: Why do this targets begin with webrtc_, isn't
Zhi Huang 2017/05/23 18:49:45 I just tried to match the naming of the targets in
35 sources = [
36 "src/jni/androidmediacodeccommon.h",
37 "src/jni/classreferenceholder.cc",
38 "src/jni/classreferenceholder.h",
39 "src/jni/jni_helpers.cc",
40 "src/jni/jni_helpers.h",
41 ]
42
43 deps = [
44 "../../base:rtc_base",
45 "../../base:rtc_base_approved",
46 ]
47
48 if (is_clang) {
49 # Suppress warnings from the Chromium Clang plugin (bugs.webrtc.org/163).
50 suppressed_configs += [
51 "//build/config/clang:extra_warnings",
52 "//build/config/clang:find_bad_constructs",
53 ]
54 }
55 }
56
57 rtc_static_library("webrtc_audio_jni") {
58 deps = [
59 ":webrtc_jni_common",
60 "../../pc:webrtc_audio",
61 "../../pc:webrtc_media",
62 "../../voice_engine:voice_engine",
63 ]
64 }
65
66 rtc_static_library("webrtc_null_audio_jni") {
67 deps = [
68 ":webrtc_jni_common",
69 "../../pc:webrtc_null_audio",
70 "../../pc:webrtc_null_media",
71 ]
72 }
73
74 rtc_static_library("webrtc_video_jni") {
26 sources = [ 75 sources = [
27 "src/jni/androidhistogram_jni.cc", 76 "src/jni/androidhistogram_jni.cc",
sakal 2017/05/23 09:33:19 Maybe we should move these files to separate subfo
Zhi Huang 2017/05/23 18:49:45 Do you mean move these files to a new directory (l
28 "src/jni/androidmediacodeccommon.h",
29 "src/jni/androidmediadecoder_jni.cc", 77 "src/jni/androidmediadecoder_jni.cc",
30 "src/jni/androidmediadecoder_jni.h", 78 "src/jni/androidmediadecoder_jni.h",
31 "src/jni/androidmediaencoder_jni.cc", 79 "src/jni/androidmediaencoder_jni.cc",
32 "src/jni/androidmediaencoder_jni.h", 80 "src/jni/androidmediaencoder_jni.h",
33 "src/jni/androidnetworkmonitor_jni.cc",
34 "src/jni/androidnetworkmonitor_jni.h",
35 "src/jni/androidvideotracksource.cc", 81 "src/jni/androidvideotracksource.cc",
36 "src/jni/androidvideotracksource.h", 82 "src/jni/androidvideotracksource.h",
37 "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 ] 89 ]
50 90
51 configs += [ ":libjingle_peerconnection_jni_warnings_config" ] 91 configs += [ ":libjingle_peerconnection_jni_warnings_config" ]
52 92
53 if (is_clang) { 93 if (is_clang) {
54 # Suppress warnings from the Chromium Clang plugin (bugs.webrtc.org/163). 94 # Suppress warnings from the Chromium Clang plugin (bugs.webrtc.org/163).
55 suppressed_configs += [ 95 suppressed_configs += [
56 "//build/config/clang:extra_warnings", 96 "//build/config/clang:extra_warnings",
57 "//build/config/clang:find_bad_constructs", 97 "//build/config/clang:find_bad_constructs",
58 ] 98 ]
59 } 99 }
60 100
61 # TODO(jschuh): Bug 1348: fix this warning. 101 # TODO(jschuh): Bug 1348: fix this warning.
62 configs += [ "//build/config/compiler:no_size_t_to_int_warning" ] 102 configs += [ "//build/config/compiler:no_size_t_to_int_warning" ]
63 103
64 if (is_win) { 104 if (is_win) {
65 cflags += [ 105 cflags += [
66 "/wd4245", # conversion from "int" to "size_t", signed/unsigned mismatch. 106 "/wd4245", # conversion from "int" to "size_t", signed/unsigned mismatch.
67 "/wd4389", # signed/unsigned mismatch. 107 "/wd4389", # signed/unsigned mismatch.
68 ] 108 ]
69 } 109 }
70 110
71 deps = [ 111 deps = [
72 "../..:webrtc_common", 112 ":webrtc_jni_common",
73 "../../api:video_frame_api", 113 "../../api:video_frame_api",
74 "../../api/video_codecs:video_codecs_api", 114 "../../api/video_codecs:video_codecs_api",
75 "../../base:rtc_base", 115 "../../base:rtc_base",
76 "../../base:rtc_base_approved", 116 "../../base:rtc_base_approved",
77 "../../base:rtc_task_queue", 117 "../../base:rtc_task_queue",
78 "../../common_video:common_video", 118 "../../common_video:common_video",
79 "../../media:rtc_media", 119 "../../media:rtc_audio_video",
80 "../../media:rtc_media_base", 120 "../../media:rtc_media_data_base",
81 "../../modules/utility:utility",
82 "../../modules/video_coding:video_coding_utility", 121 "../../modules/video_coding:video_coding_utility",
122 "../../pc:webrtc_media",
83 "../../system_wrappers:system_wrappers", 123 "../../system_wrappers:system_wrappers",
84 "../../voice_engine:voice_engine", 124 "//webrtc:webrtc_common",
85 "//webrtc/pc:libjingle_peerconnection",
86 ] 125 ]
87 126
88 if (rtc_build_libyuv) { 127 if (rtc_build_libyuv) {
89 deps += [ "$rtc_libyuv_dir" ] 128 deps += [ "$rtc_libyuv_dir" ]
90 public_deps = [ 129 public_deps = [
91 "$rtc_libyuv_dir", 130 "$rtc_libyuv_dir",
92 ] 131 ]
93 } else { 132 } else {
94 # Need to add a directory normally exported by libyuv. 133 # Need to add a directory normally exported by libyuv.
95 include_dirs = [ "$rtc_libyuv_dir/include" ] 134 include_dirs = [ "$rtc_libyuv_dir/include" ]
96 } 135 }
97 } 136 }
98 137
138 rtc_static_library("webrtc_null_video_jni") {
139 sources = [
140 "src/jni/null_video_jni.cc",
141 ]
142
143 deps = [
144 ":webrtc_jni_common",
145 "../../pc:webrtc_null_media",
146 ]
147
148 if (is_clang) {
149 # Suppress warnings from the Chromium Clang plugin (bugs.webrtc.org/163).
150 suppressed_configs += [
151 "//build/config/clang:extra_warnings",
152 "//build/config/clang:find_bad_constructs",
153 ]
154 }
155 }
156
157 rtc_static_library("webrtc_base_jni") {
sakal 2017/05/23 09:33:18 nit: Perhaps webrtc_peerconnection_jni
Zhi Huang 2017/05/23 18:49:45 Done.
158 sources = [
159 "src/jni/androidnetworkmonitor_jni.cc",
160 "src/jni/androidnetworkmonitor_jni.h",
161 "src/jni/peerconnection_jni.cc",
162 "src/jni/rtcstatscollectorcallbackwrapper.cc",
163 "src/jni/rtcstatscollectorcallbackwrapper.h",
164 ]
165
166 configs += [ ":libjingle_peerconnection_jni_warnings_config" ]
167
168 if (is_clang) {
169 # Suppress warnings from the Chromium Clang plugin (bugs.webrtc.org/163).
170 suppressed_configs += [
171 "//build/config/clang:extra_warnings",
172 "//build/config/clang:find_bad_constructs",
173 ]
174 }
175
176 # TODO(jschuh): Bug 1348: fix this warning.
177 configs += [ "//build/config/compiler:no_size_t_to_int_warning" ]
178
179 if (is_win) {
180 cflags += [
181 "/wd4245", # conversion from "int" to "size_t", signed/unsigned mismatch.
182 "/wd4389", # signed/unsigned mismatch.
183 ]
184 }
185
186 deps = [
187 ":webrtc_jni_common",
188 "../..:webrtc_common",
189 "../../base:rtc_base",
190 "../../base:rtc_base_approved",
191 "../../base:rtc_task_queue",
192 "../../media:rtc_data",
193 "../../media:rtc_media_data_base",
194 "../../modules/utility:utility",
195 "../../pc:webrtc_base",
196 "../../system_wrappers:system_wrappers",
197 ]
198 }
199
200 rtc_static_library("webrtc_base_metrics_default_jni") {
sakal 2017/05/23 09:33:19 Can this be renamed to webrtc_metrics_jni?
Zhi Huang 2017/05/23 18:49:45 Done.
201 sources = [
202 "src/jni/androidmetrics_jni.cc",
203 ]
204
205 configs += [ ":libjingle_peerconnection_jni_warnings_config" ]
206
207 deps = [
208 ":webrtc_base_jni",
209 ":webrtc_jni_common",
210 "../../pc:webrtc_base",
211 "../../system_wrappers",
212 "../../system_wrappers:field_trial_default",
213 "../../system_wrappers:metrics_default",
214 ]
215 }
216
99 rtc_static_library("libjingle_peerconnection_metrics_default_jni") { 217 rtc_static_library("libjingle_peerconnection_metrics_default_jni") {
100 sources = [ 218 sources = [
101 "src/jni/androidmetrics_jni.cc", 219 "src/jni/androidmetrics_jni.cc",
102 ] 220 ]
103 221
104 configs += [ ":libjingle_peerconnection_jni_warnings_config" ] 222 configs += [ ":libjingle_peerconnection_jni_warnings_config" ]
105 223
106 deps = [ 224 deps = [
107 ":libjingle_peerconnection_jni", 225 ":libjingle_peerconnection_jni",
226 "../../pc:libjingle_peerconnection",
108 "../../system_wrappers", 227 "../../system_wrappers",
109 "//webrtc/pc:libjingle_peerconnection", 228 "../../system_wrappers:field_trial_default",
110 "//webrtc/system_wrappers:field_trial_default", 229 "../../system_wrappers:metrics_default",
111 "//webrtc/system_wrappers:metrics_default",
112 ] 230 ]
113 } 231 }
114 232
233 rtc_shared_library("libjingle_peerconnection_datachannelonly_so") {
sakal 2017/05/23 09:33:18 Is this target necessary, can't clients create it
Zhi Huang 2017/05/23 18:49:45 You're right. The idea is letting the clients crea
234 sources = [
235 "src/jni/jni_onload.cc",
236 ]
237
238 suppressed_configs += [ "//build/config/android:hide_all_but_jni_onload" ]
239 configs += [ "//build/config/android:hide_all_but_jni" ]
240
241 deps = [
242 ":webrtc_base_jni",
243 ":webrtc_base_metrics_default_jni",
244 ":webrtc_jni_common",
245 ":webrtc_null_audio_jni",
246 ":webrtc_null_video_jni",
247 "../../base:rtc_base",
248 "../../pc:webrtc_base",
249 ]
250 output_extension = "so"
251 }
252
115 rtc_shared_library("libjingle_peerconnection_so") { 253 rtc_shared_library("libjingle_peerconnection_so") {
116 sources = [ 254 sources = [
117 "src/jni/jni_onload.cc", 255 "src/jni/jni_onload.cc",
118 ] 256 ]
119 257
120 suppressed_configs += [ "//build/config/android:hide_all_but_jni_onload" ] 258 suppressed_configs += [ "//build/config/android:hide_all_but_jni_onload" ]
121 configs += [ "//build/config/android:hide_all_but_jni" ] 259 configs += [ "//build/config/android:hide_all_but_jni" ]
122 260
123 deps = [ 261 deps = [
124 ":libjingle_peerconnection_jni", 262 ":libjingle_peerconnection_jni",
(...skipping 127 matching lines...) Expand 10 before | Expand all | Expand 10 after
252 "//third_party/android_support_test_runner:runner_java", 390 "//third_party/android_support_test_runner:runner_java",
253 "//third_party/junit", 391 "//third_party/junit",
254 "//webrtc/base:base_java", 392 "//webrtc/base:base_java",
255 "//webrtc/sdk/android:libjingle_peerconnection_java", 393 "//webrtc/sdk/android:libjingle_peerconnection_java",
256 "//webrtc/sdk/android:libjingle_peerconnection_metrics_default_java", 394 "//webrtc/sdk/android:libjingle_peerconnection_metrics_default_java",
257 ] 395 ]
258 396
259 shared_libraries = [ "//webrtc/sdk/android:libjingle_peerconnection_so" ] 397 shared_libraries = [ "//webrtc/sdk/android:libjingle_peerconnection_so" ]
260 } 398 }
261 } 399 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698