
This cl/ fixes another race condition with the recent additions to NetworkMonitorAutoDetect (getAllNetworksFromCache). The getAllNetworksFromCache-feature uses the by the Android team preferred way of enumerating networks, i.e to register network listeners. Th recent fix to add IsAdapterAvailable, https://webrtc-review.googlesource.com/c/src/+/257400 contained a bug in that the adapter_type_by_name_ map was not reset either on disconnect or Start/Stop. This cl/ addresses that including unit test. It also de-obfuscates NetworkMonitor so that it always calls NotifyOfActiveNetworkList on startMonitoring even if list.size() == 0. This should not matter but makes code easier to understand. Bug: webrtc:13741 Change-Id: I438b877eebf769a8b2e7292b697ef1c0a349b24f Reviewed-on: https://webrtc-review.googlesource.com/c/src/+/258721 Reviewed-by: Harald Alvestrand <hta@webrtc.org> Commit-Queue: Jonas Oreland <jonaso@webrtc.org> Cr-Commit-Position: refs/heads/main@{#36530}
This directory holds a Java implementation of the webrtc::PeerConnection API, as well as the JNI glue C++ code that lets the Java implementation reuse the C++ implementation of the same API. To build the Java API and related tests, make sure you have a WebRTC checkout with Android specific parts. This can be used for linux development as well by configuring gn appropriately, as it is a superset of the webrtc checkout: fetch --nohooks webrtc_android gclient sync You also must generate GN projects with: --args='target_os="android" target_cpu="arm"' More information on getting the code, compiling and running the AppRTCMobile app can be found at: https://webrtc.org/native-code/android/ To use the Java API, start by looking at the public interface of org.webrtc.PeerConnection{,Factory} and the org.webrtc.PeerConnectionTest. To understand the implementation of the API, see the native code in src/jni/pc/.