Chromium Code Reviews| Index: webrtc/sdk/android/BUILD.gn |
| diff --git a/webrtc/sdk/android/BUILD.gn b/webrtc/sdk/android/BUILD.gn |
| index 9fcedf907b7a5ce823aba7d243ef468c458179b3..43cb4fd9db6612f17b51d869ffccb128041e473c 100644 |
| --- a/webrtc/sdk/android/BUILD.gn |
| +++ b/webrtc/sdk/android/BUILD.gn |
| @@ -23,29 +23,69 @@ config("libjingle_peerconnection_jni_warnings_config") { |
| } |
| rtc_static_library("libjingle_peerconnection_jni") { |
| + public_deps = [ |
| + ":webrtc_audio_jni", |
| + ":webrtc_base_jni", |
| + ":webrtc_jni_common", |
| + ":webrtc_video_jni", |
| + ] |
| +} |
| + |
| +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
|
| sources = [ |
| - "src/jni/androidhistogram_jni.cc", |
| "src/jni/androidmediacodeccommon.h", |
| + "src/jni/classreferenceholder.cc", |
| + "src/jni/classreferenceholder.h", |
| + "src/jni/jni_helpers.cc", |
| + "src/jni/jni_helpers.h", |
| + ] |
| + |
| + deps = [ |
| + "../../base:rtc_base", |
| + "../../base:rtc_base_approved", |
| + ] |
| + |
| + if (is_clang) { |
| + # Suppress warnings from the Chromium Clang plugin (bugs.webrtc.org/163). |
| + suppressed_configs += [ |
| + "//build/config/clang:extra_warnings", |
| + "//build/config/clang:find_bad_constructs", |
| + ] |
| + } |
| +} |
| + |
| +rtc_static_library("webrtc_audio_jni") { |
| + deps = [ |
| + ":webrtc_jni_common", |
| + "../../pc:webrtc_audio", |
| + "../../pc:webrtc_media", |
| + "../../voice_engine:voice_engine", |
| + ] |
| +} |
| + |
| +rtc_static_library("webrtc_null_audio_jni") { |
| + deps = [ |
| + ":webrtc_jni_common", |
| + "../../pc:webrtc_null_audio", |
| + "../../pc:webrtc_null_media", |
| + ] |
| +} |
| + |
| +rtc_static_library("webrtc_video_jni") { |
| + sources = [ |
| + "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
|
| "src/jni/androidmediadecoder_jni.cc", |
| "src/jni/androidmediadecoder_jni.h", |
| "src/jni/androidmediaencoder_jni.cc", |
| "src/jni/androidmediaencoder_jni.h", |
| - "src/jni/androidnetworkmonitor_jni.cc", |
| - "src/jni/androidnetworkmonitor_jni.h", |
| "src/jni/androidvideotracksource.cc", |
| "src/jni/androidvideotracksource.h", |
| - "src/jni/androidvideotracksource_jni.cc", |
| - "src/jni/classreferenceholder.cc", |
| - "src/jni/classreferenceholder.h", |
| - "src/jni/jni_helpers.cc", |
| - "src/jni/jni_helpers.h", |
| "src/jni/native_handle_impl.cc", |
| "src/jni/native_handle_impl.h", |
| - "src/jni/peerconnection_jni.cc", |
| - "src/jni/rtcstatscollectorcallbackwrapper.cc", |
| - "src/jni/rtcstatscollectorcallbackwrapper.h", |
| "src/jni/surfacetexturehelper_jni.cc", |
| "src/jni/surfacetexturehelper_jni.h", |
| + "src/jni/video_jni.cc", |
| + "src/jni/video_renderer_jni.cc", |
| ] |
| configs += [ ":libjingle_peerconnection_jni_warnings_config" ] |
| @@ -69,20 +109,19 @@ rtc_static_library("libjingle_peerconnection_jni") { |
| } |
| deps = [ |
| - "../..:webrtc_common", |
| + ":webrtc_jni_common", |
| "../../api:video_frame_api", |
| "../../api/video_codecs:video_codecs_api", |
| "../../base:rtc_base", |
| "../../base:rtc_base_approved", |
| "../../base:rtc_task_queue", |
| "../../common_video:common_video", |
| - "../../media:rtc_media", |
| - "../../media:rtc_media_base", |
| - "../../modules/utility:utility", |
| + "../../media:rtc_audio_video", |
| + "../../media:rtc_media_data_base", |
| "../../modules/video_coding:video_coding_utility", |
| + "../../pc:webrtc_media", |
| "../../system_wrappers:system_wrappers", |
| - "../../voice_engine:voice_engine", |
| - "//webrtc/pc:libjingle_peerconnection", |
| + "//webrtc:webrtc_common", |
| ] |
| if (rtc_build_libyuv) { |
| @@ -96,6 +135,85 @@ rtc_static_library("libjingle_peerconnection_jni") { |
| } |
| } |
| +rtc_static_library("webrtc_null_video_jni") { |
| + sources = [ |
| + "src/jni/null_video_jni.cc", |
| + ] |
| + |
| + deps = [ |
| + ":webrtc_jni_common", |
| + "../../pc:webrtc_null_media", |
| + ] |
| + |
| + if (is_clang) { |
| + # Suppress warnings from the Chromium Clang plugin (bugs.webrtc.org/163). |
| + suppressed_configs += [ |
| + "//build/config/clang:extra_warnings", |
| + "//build/config/clang:find_bad_constructs", |
| + ] |
| + } |
| +} |
| + |
| +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.
|
| + sources = [ |
| + "src/jni/androidnetworkmonitor_jni.cc", |
| + "src/jni/androidnetworkmonitor_jni.h", |
| + "src/jni/peerconnection_jni.cc", |
| + "src/jni/rtcstatscollectorcallbackwrapper.cc", |
| + "src/jni/rtcstatscollectorcallbackwrapper.h", |
| + ] |
| + |
| + configs += [ ":libjingle_peerconnection_jni_warnings_config" ] |
| + |
| + if (is_clang) { |
| + # Suppress warnings from the Chromium Clang plugin (bugs.webrtc.org/163). |
| + suppressed_configs += [ |
| + "//build/config/clang:extra_warnings", |
| + "//build/config/clang:find_bad_constructs", |
| + ] |
| + } |
| + |
| + # TODO(jschuh): Bug 1348: fix this warning. |
| + configs += [ "//build/config/compiler:no_size_t_to_int_warning" ] |
| + |
| + if (is_win) { |
| + cflags += [ |
| + "/wd4245", # conversion from "int" to "size_t", signed/unsigned mismatch. |
| + "/wd4389", # signed/unsigned mismatch. |
| + ] |
| + } |
| + |
| + deps = [ |
| + ":webrtc_jni_common", |
| + "../..:webrtc_common", |
| + "../../base:rtc_base", |
| + "../../base:rtc_base_approved", |
| + "../../base:rtc_task_queue", |
| + "../../media:rtc_data", |
| + "../../media:rtc_media_data_base", |
| + "../../modules/utility:utility", |
| + "../../pc:webrtc_base", |
| + "../../system_wrappers:system_wrappers", |
| + ] |
| +} |
| + |
| +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.
|
| + sources = [ |
| + "src/jni/androidmetrics_jni.cc", |
| + ] |
| + |
| + configs += [ ":libjingle_peerconnection_jni_warnings_config" ] |
| + |
| + deps = [ |
| + ":webrtc_base_jni", |
| + ":webrtc_jni_common", |
| + "../../pc:webrtc_base", |
| + "../../system_wrappers", |
| + "../../system_wrappers:field_trial_default", |
| + "../../system_wrappers:metrics_default", |
| + ] |
| +} |
| + |
| rtc_static_library("libjingle_peerconnection_metrics_default_jni") { |
| sources = [ |
| "src/jni/androidmetrics_jni.cc", |
| @@ -105,11 +223,31 @@ rtc_static_library("libjingle_peerconnection_metrics_default_jni") { |
| deps = [ |
| ":libjingle_peerconnection_jni", |
| + "../../pc:libjingle_peerconnection", |
| "../../system_wrappers", |
| - "//webrtc/pc:libjingle_peerconnection", |
| - "//webrtc/system_wrappers:field_trial_default", |
| - "//webrtc/system_wrappers:metrics_default", |
| + "../../system_wrappers:field_trial_default", |
| + "../../system_wrappers:metrics_default", |
| + ] |
| +} |
| + |
| +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
|
| + sources = [ |
| + "src/jni/jni_onload.cc", |
| ] |
| + |
| + suppressed_configs += [ "//build/config/android:hide_all_but_jni_onload" ] |
| + configs += [ "//build/config/android:hide_all_but_jni" ] |
| + |
| + deps = [ |
| + ":webrtc_base_jni", |
| + ":webrtc_base_metrics_default_jni", |
| + ":webrtc_jni_common", |
| + ":webrtc_null_audio_jni", |
| + ":webrtc_null_video_jni", |
| + "../../base:rtc_base", |
| + "../../pc:webrtc_base", |
| + ] |
| + output_extension = "so" |
| } |
| rtc_shared_library("libjingle_peerconnection_so") { |