OLD | NEW |
---|---|
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 Loading... | |
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 } |
OLD | NEW |