| OLD | NEW |
| 1 /* | 1 /* |
| 2 * Copyright 2017 The WebRTC project authors. All Rights Reserved. | 2 * Copyright 2017 The WebRTC project authors. All Rights Reserved. |
| 3 * | 3 * |
| 4 * Use of this source code is governed by a BSD-style license | 4 * Use of this source code is governed by a BSD-style license |
| 5 * that can be found in the LICENSE file in the root of the source | 5 * that can be found in the LICENSE file in the root of the source |
| 6 * tree. An additional intellectual property rights grant can be found | 6 * tree. An additional intellectual property rights grant can be found |
| 7 * in the file PATENTS. All contributing project authors may | 7 * in the file PATENTS. All contributing project authors may |
| 8 * be found in the AUTHORS file in the root of the source tree. | 8 * be found in the AUTHORS file in the root of the source tree. |
| 9 */ | 9 */ |
| 10 | 10 |
| 11 #include "webrtc/sdk/android/src/jni/pc/java_native_conversion.h" | 11 #include "webrtc/sdk/android/src/jni/pc/java_native_conversion.h" |
| 12 | 12 |
| 13 #include <string> | 13 #include <string> |
| 14 | 14 |
| 15 #include "webrtc/pc/webrtcsdp.h" | 15 #include "webrtc/pc/webrtcsdp.h" |
| 16 #include "webrtc/sdk/android/src/jni/classreferenceholder.h" | 16 #include "webrtc/sdk/android/src/jni/classreferenceholder.h" |
| 17 | 17 |
| 18 namespace webrtc_jni { | 18 namespace webrtc { |
| 19 namespace jni { |
| 19 | 20 |
| 20 webrtc::DataChannelInit JavaToNativeDataChannelInit(JNIEnv* jni, | 21 DataChannelInit JavaToNativeDataChannelInit(JNIEnv* jni, jobject j_init) { |
| 21 jobject j_init) { | 22 DataChannelInit init; |
| 22 webrtc::DataChannelInit init; | |
| 23 | 23 |
| 24 jclass j_init_class = FindClass(jni, "org/webrtc/DataChannel$Init"); | 24 jclass j_init_class = FindClass(jni, "org/webrtc/DataChannel$Init"); |
| 25 jfieldID ordered_id = GetFieldID(jni, j_init_class, "ordered", "Z"); | 25 jfieldID ordered_id = GetFieldID(jni, j_init_class, "ordered", "Z"); |
| 26 jfieldID max_retransmit_time_id = | 26 jfieldID max_retransmit_time_id = |
| 27 GetFieldID(jni, j_init_class, "maxRetransmitTimeMs", "I"); | 27 GetFieldID(jni, j_init_class, "maxRetransmitTimeMs", "I"); |
| 28 jfieldID max_retransmits_id = | 28 jfieldID max_retransmits_id = |
| 29 GetFieldID(jni, j_init_class, "maxRetransmits", "I"); | 29 GetFieldID(jni, j_init_class, "maxRetransmits", "I"); |
| 30 jfieldID protocol_id = | 30 jfieldID protocol_id = |
| 31 GetFieldID(jni, j_init_class, "protocol", "Ljava/lang/String;"); | 31 GetFieldID(jni, j_init_class, "protocol", "Ljava/lang/String;"); |
| 32 jfieldID negotiated_id = GetFieldID(jni, j_init_class, "negotiated", "Z"); | 32 jfieldID negotiated_id = GetFieldID(jni, j_init_class, "negotiated", "Z"); |
| (...skipping 53 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 86 jclass j_candidate_class = GetObjectClass(jni, j_candidate); | 86 jclass j_candidate_class = GetObjectClass(jni, j_candidate); |
| 87 jfieldID j_sdp_mid_id = | 87 jfieldID j_sdp_mid_id = |
| 88 GetFieldID(jni, j_candidate_class, "sdpMid", "Ljava/lang/String;"); | 88 GetFieldID(jni, j_candidate_class, "sdpMid", "Ljava/lang/String;"); |
| 89 std::string sdp_mid = | 89 std::string sdp_mid = |
| 90 JavaToStdString(jni, GetStringField(jni, j_candidate, j_sdp_mid_id)); | 90 JavaToStdString(jni, GetStringField(jni, j_candidate, j_sdp_mid_id)); |
| 91 jfieldID j_sdp_id = | 91 jfieldID j_sdp_id = |
| 92 GetFieldID(jni, j_candidate_class, "sdp", "Ljava/lang/String;"); | 92 GetFieldID(jni, j_candidate_class, "sdp", "Ljava/lang/String;"); |
| 93 std::string sdp = | 93 std::string sdp = |
| 94 JavaToStdString(jni, GetStringField(jni, j_candidate, j_sdp_id)); | 94 JavaToStdString(jni, GetStringField(jni, j_candidate, j_sdp_id)); |
| 95 cricket::Candidate candidate; | 95 cricket::Candidate candidate; |
| 96 if (!webrtc::SdpDeserializeCandidate(sdp_mid, sdp, &candidate, NULL)) { | 96 if (!SdpDeserializeCandidate(sdp_mid, sdp, &candidate, NULL)) { |
| 97 LOG(LS_ERROR) << "SdpDescrializeCandidate failed with sdp " << sdp; | 97 LOG(LS_ERROR) << "SdpDescrializeCandidate failed with sdp " << sdp; |
| 98 } | 98 } |
| 99 return candidate; | 99 return candidate; |
| 100 } | 100 } |
| 101 | 101 |
| 102 jobject NativeToJavaCandidate(JNIEnv* jni, | 102 jobject NativeToJavaCandidate(JNIEnv* jni, |
| 103 jclass* candidate_class, | 103 jclass* candidate_class, |
| 104 const cricket::Candidate& candidate) { | 104 const cricket::Candidate& candidate) { |
| 105 std::string sdp = webrtc::SdpSerializeCandidate(candidate); | 105 std::string sdp = SdpSerializeCandidate(candidate); |
| 106 RTC_CHECK(!sdp.empty()) << "got an empty ICE candidate"; | 106 RTC_CHECK(!sdp.empty()) << "got an empty ICE candidate"; |
| 107 jmethodID ctor = GetMethodID(jni, *candidate_class, "<init>", | 107 jmethodID ctor = GetMethodID(jni, *candidate_class, "<init>", |
| 108 "(Ljava/lang/String;ILjava/lang/String;)V"); | 108 "(Ljava/lang/String;ILjava/lang/String;)V"); |
| 109 jstring j_mid = JavaStringFromStdString(jni, candidate.transport_name()); | 109 jstring j_mid = JavaStringFromStdString(jni, candidate.transport_name()); |
| 110 jstring j_sdp = JavaStringFromStdString(jni, sdp); | 110 jstring j_sdp = JavaStringFromStdString(jni, sdp); |
| 111 // sdp_mline_index is not used, pass an invalid value -1. | 111 // sdp_mline_index is not used, pass an invalid value -1. |
| 112 jobject j_candidate = | 112 jobject j_candidate = |
| 113 jni->NewObject(*candidate_class, ctor, j_mid, -1, j_sdp); | 113 jni->NewObject(*candidate_class, ctor, j_mid, -1, j_sdp); |
| 114 CHECK_EXCEPTION(jni) << "error during Java Candidate NewObject"; | 114 CHECK_EXCEPTION(jni) << "error during Java Candidate NewObject"; |
| 115 return j_candidate; | 115 return j_candidate; |
| 116 } | 116 } |
| 117 | 117 |
| 118 jobjectArray NativeToJavaCandidateArray( | 118 jobjectArray NativeToJavaCandidateArray( |
| 119 JNIEnv* jni, | 119 JNIEnv* jni, |
| 120 const std::vector<cricket::Candidate>& candidates) { | 120 const std::vector<cricket::Candidate>& candidates) { |
| 121 jclass candidate_class = FindClass(jni, "org/webrtc/IceCandidate"); | 121 jclass candidate_class = FindClass(jni, "org/webrtc/IceCandidate"); |
| 122 jobjectArray java_candidates = | 122 jobjectArray java_candidates = |
| 123 jni->NewObjectArray(candidates.size(), candidate_class, NULL); | 123 jni->NewObjectArray(candidates.size(), candidate_class, NULL); |
| 124 int i = 0; | 124 int i = 0; |
| 125 for (const cricket::Candidate& candidate : candidates) { | 125 for (const cricket::Candidate& candidate : candidates) { |
| 126 jobject j_candidate = | 126 jobject j_candidate = |
| 127 NativeToJavaCandidate(jni, &candidate_class, candidate); | 127 NativeToJavaCandidate(jni, &candidate_class, candidate); |
| 128 jni->SetObjectArrayElement(java_candidates, i++, j_candidate); | 128 jni->SetObjectArrayElement(java_candidates, i++, j_candidate); |
| 129 } | 129 } |
| 130 return java_candidates; | 130 return java_candidates; |
| 131 } | 131 } |
| 132 | 132 |
| 133 webrtc::SessionDescriptionInterface* JavaToNativeSessionDescription( | 133 SessionDescriptionInterface* JavaToNativeSessionDescription(JNIEnv* jni, |
| 134 JNIEnv* jni, | 134 jobject j_sdp) { |
| 135 jobject j_sdp) { | |
| 136 jfieldID j_type_id = GetFieldID(jni, GetObjectClass(jni, j_sdp), "type", | 135 jfieldID j_type_id = GetFieldID(jni, GetObjectClass(jni, j_sdp), "type", |
| 137 "Lorg/webrtc/SessionDescription$Type;"); | 136 "Lorg/webrtc/SessionDescription$Type;"); |
| 138 jobject j_type = GetObjectField(jni, j_sdp, j_type_id); | 137 jobject j_type = GetObjectField(jni, j_sdp, j_type_id); |
| 139 jmethodID j_canonical_form_id = | 138 jmethodID j_canonical_form_id = |
| 140 GetMethodID(jni, GetObjectClass(jni, j_type), "canonicalForm", | 139 GetMethodID(jni, GetObjectClass(jni, j_type), "canonicalForm", |
| 141 "()Ljava/lang/String;"); | 140 "()Ljava/lang/String;"); |
| 142 jstring j_type_string = | 141 jstring j_type_string = |
| 143 (jstring)jni->CallObjectMethod(j_type, j_canonical_form_id); | 142 (jstring)jni->CallObjectMethod(j_type, j_canonical_form_id); |
| 144 CHECK_EXCEPTION(jni) << "error during CallObjectMethod"; | 143 CHECK_EXCEPTION(jni) << "error during CallObjectMethod"; |
| 145 std::string std_type = JavaToStdString(jni, j_type_string); | 144 std::string std_type = JavaToStdString(jni, j_type_string); |
| 146 | 145 |
| 147 jfieldID j_description_id = GetFieldID(jni, GetObjectClass(jni, j_sdp), | 146 jfieldID j_description_id = GetFieldID(jni, GetObjectClass(jni, j_sdp), |
| 148 "description", "Ljava/lang/String;"); | 147 "description", "Ljava/lang/String;"); |
| 149 jstring j_description = (jstring)GetObjectField(jni, j_sdp, j_description_id); | 148 jstring j_description = (jstring)GetObjectField(jni, j_sdp, j_description_id); |
| 150 std::string std_description = JavaToStdString(jni, j_description); | 149 std::string std_description = JavaToStdString(jni, j_description); |
| 151 | 150 |
| 152 return webrtc::CreateSessionDescription(std_type, std_description, NULL); | 151 return CreateSessionDescription(std_type, std_description, NULL); |
| 153 } | 152 } |
| 154 | 153 |
| 155 jobject NativeToJavaSessionDescription( | 154 jobject NativeToJavaSessionDescription( |
| 156 JNIEnv* jni, | 155 JNIEnv* jni, |
| 157 const webrtc::SessionDescriptionInterface* desc) { | 156 const SessionDescriptionInterface* desc) { |
| 158 std::string sdp; | 157 std::string sdp; |
| 159 RTC_CHECK(desc->ToString(&sdp)) << "got so far: " << sdp; | 158 RTC_CHECK(desc->ToString(&sdp)) << "got so far: " << sdp; |
| 160 jstring j_description = JavaStringFromStdString(jni, sdp); | 159 jstring j_description = JavaStringFromStdString(jni, sdp); |
| 161 | 160 |
| 162 jclass j_type_class = FindClass(jni, "org/webrtc/SessionDescription$Type"); | 161 jclass j_type_class = FindClass(jni, "org/webrtc/SessionDescription$Type"); |
| 163 jmethodID j_type_from_canonical = GetStaticMethodID( | 162 jmethodID j_type_from_canonical = GetStaticMethodID( |
| 164 jni, j_type_class, "fromCanonicalForm", | 163 jni, j_type_class, "fromCanonicalForm", |
| 165 "(Ljava/lang/String;)Lorg/webrtc/SessionDescription$Type;"); | 164 "(Ljava/lang/String;)Lorg/webrtc/SessionDescription$Type;"); |
| 166 jstring j_type_string = JavaStringFromStdString(jni, desc->type()); | 165 jstring j_type_string = JavaStringFromStdString(jni, desc->type()); |
| 167 jobject j_type = jni->CallStaticObjectMethod( | 166 jobject j_type = jni->CallStaticObjectMethod( |
| 168 j_type_class, j_type_from_canonical, j_type_string); | 167 j_type_class, j_type_from_canonical, j_type_string); |
| 169 CHECK_EXCEPTION(jni) << "error during CallObjectMethod"; | 168 CHECK_EXCEPTION(jni) << "error during CallObjectMethod"; |
| 170 | 169 |
| 171 jclass j_sdp_class = FindClass(jni, "org/webrtc/SessionDescription"); | 170 jclass j_sdp_class = FindClass(jni, "org/webrtc/SessionDescription"); |
| 172 jmethodID j_sdp_ctor = | 171 jmethodID j_sdp_ctor = |
| 173 GetMethodID(jni, j_sdp_class, "<init>", | 172 GetMethodID(jni, j_sdp_class, "<init>", |
| 174 "(Lorg/webrtc/SessionDescription$Type;Ljava/lang/String;)V"); | 173 "(Lorg/webrtc/SessionDescription$Type;Ljava/lang/String;)V"); |
| 175 jobject j_sdp = | 174 jobject j_sdp = |
| 176 jni->NewObject(j_sdp_class, j_sdp_ctor, j_type, j_description); | 175 jni->NewObject(j_sdp_class, j_sdp_ctor, j_type, j_description); |
| 177 CHECK_EXCEPTION(jni) << "error during NewObject"; | 176 CHECK_EXCEPTION(jni) << "error during NewObject"; |
| 178 return j_sdp; | 177 return j_sdp; |
| 179 } | 178 } |
| 180 | 179 |
| 181 webrtc::PeerConnectionFactoryInterface::Options | 180 PeerConnectionFactoryInterface::Options |
| 182 JavaToNativePeerConnectionFactoryOptions(JNIEnv* jni, jobject options) { | 181 JavaToNativePeerConnectionFactoryOptions(JNIEnv* jni, jobject options) { |
| 183 jclass options_class = jni->GetObjectClass(options); | 182 jclass options_class = jni->GetObjectClass(options); |
| 184 jfieldID network_ignore_mask_field = | 183 jfieldID network_ignore_mask_field = |
| 185 jni->GetFieldID(options_class, "networkIgnoreMask", "I"); | 184 jni->GetFieldID(options_class, "networkIgnoreMask", "I"); |
| 186 int network_ignore_mask = | 185 int network_ignore_mask = |
| 187 jni->GetIntField(options, network_ignore_mask_field); | 186 jni->GetIntField(options, network_ignore_mask_field); |
| 188 | 187 |
| 189 jfieldID disable_encryption_field = | 188 jfieldID disable_encryption_field = |
| 190 jni->GetFieldID(options_class, "disableEncryption", "Z"); | 189 jni->GetFieldID(options_class, "disableEncryption", "Z"); |
| 191 bool disable_encryption = | 190 bool disable_encryption = |
| 192 jni->GetBooleanField(options, disable_encryption_field); | 191 jni->GetBooleanField(options, disable_encryption_field); |
| 193 | 192 |
| 194 jfieldID disable_network_monitor_field = | 193 jfieldID disable_network_monitor_field = |
| 195 jni->GetFieldID(options_class, "disableNetworkMonitor", "Z"); | 194 jni->GetFieldID(options_class, "disableNetworkMonitor", "Z"); |
| 196 bool disable_network_monitor = | 195 bool disable_network_monitor = |
| 197 jni->GetBooleanField(options, disable_network_monitor_field); | 196 jni->GetBooleanField(options, disable_network_monitor_field); |
| 198 | 197 |
| 199 webrtc::PeerConnectionFactoryInterface::Options native_options; | 198 PeerConnectionFactoryInterface::Options native_options; |
| 200 | 199 |
| 201 // This doesn't necessarily match the c++ version of this struct; feel free | 200 // This doesn't necessarily match the c++ version of this struct; feel free |
| 202 // to add more parameters as necessary. | 201 // to add more parameters as necessary. |
| 203 native_options.network_ignore_mask = network_ignore_mask; | 202 native_options.network_ignore_mask = network_ignore_mask; |
| 204 native_options.disable_encryption = disable_encryption; | 203 native_options.disable_encryption = disable_encryption; |
| 205 native_options.disable_network_monitor = disable_network_monitor; | 204 native_options.disable_network_monitor = disable_network_monitor; |
| 206 return native_options; | 205 return native_options; |
| 207 } | 206 } |
| 208 | 207 |
| 209 webrtc::PeerConnectionInterface::IceTransportsType | 208 PeerConnectionInterface::IceTransportsType JavaToNativeIceTransportsType( |
| 210 JavaToNativeIceTransportsType(JNIEnv* jni, jobject j_ice_transports_type) { | 209 JNIEnv* jni, |
| 210 jobject j_ice_transports_type) { |
| 211 std::string enum_name = | 211 std::string enum_name = |
| 212 GetJavaEnumName(jni, "org/webrtc/PeerConnection$IceTransportsType", | 212 GetJavaEnumName(jni, "org/webrtc/PeerConnection$IceTransportsType", |
| 213 j_ice_transports_type); | 213 j_ice_transports_type); |
| 214 | 214 |
| 215 if (enum_name == "ALL") | 215 if (enum_name == "ALL") |
| 216 return webrtc::PeerConnectionInterface::kAll; | 216 return PeerConnectionInterface::kAll; |
| 217 | 217 |
| 218 if (enum_name == "RELAY") | 218 if (enum_name == "RELAY") |
| 219 return webrtc::PeerConnectionInterface::kRelay; | 219 return PeerConnectionInterface::kRelay; |
| 220 | 220 |
| 221 if (enum_name == "NOHOST") | 221 if (enum_name == "NOHOST") |
| 222 return webrtc::PeerConnectionInterface::kNoHost; | 222 return PeerConnectionInterface::kNoHost; |
| 223 | 223 |
| 224 if (enum_name == "NONE") | 224 if (enum_name == "NONE") |
| 225 return webrtc::PeerConnectionInterface::kNone; | 225 return PeerConnectionInterface::kNone; |
| 226 | 226 |
| 227 RTC_CHECK(false) << "Unexpected IceTransportsType enum_name " << enum_name; | 227 RTC_CHECK(false) << "Unexpected IceTransportsType enum_name " << enum_name; |
| 228 return webrtc::PeerConnectionInterface::kAll; | 228 return PeerConnectionInterface::kAll; |
| 229 } | 229 } |
| 230 | 230 |
| 231 webrtc::PeerConnectionInterface::BundlePolicy JavaToNativeBundlePolicy( | 231 PeerConnectionInterface::BundlePolicy JavaToNativeBundlePolicy( |
| 232 JNIEnv* jni, | 232 JNIEnv* jni, |
| 233 jobject j_bundle_policy) { | 233 jobject j_bundle_policy) { |
| 234 std::string enum_name = GetJavaEnumName( | 234 std::string enum_name = GetJavaEnumName( |
| 235 jni, "org/webrtc/PeerConnection$BundlePolicy", j_bundle_policy); | 235 jni, "org/webrtc/PeerConnection$BundlePolicy", j_bundle_policy); |
| 236 | 236 |
| 237 if (enum_name == "BALANCED") | 237 if (enum_name == "BALANCED") |
| 238 return webrtc::PeerConnectionInterface::kBundlePolicyBalanced; | 238 return PeerConnectionInterface::kBundlePolicyBalanced; |
| 239 | 239 |
| 240 if (enum_name == "MAXBUNDLE") | 240 if (enum_name == "MAXBUNDLE") |
| 241 return webrtc::PeerConnectionInterface::kBundlePolicyMaxBundle; | 241 return PeerConnectionInterface::kBundlePolicyMaxBundle; |
| 242 | 242 |
| 243 if (enum_name == "MAXCOMPAT") | 243 if (enum_name == "MAXCOMPAT") |
| 244 return webrtc::PeerConnectionInterface::kBundlePolicyMaxCompat; | 244 return PeerConnectionInterface::kBundlePolicyMaxCompat; |
| 245 | 245 |
| 246 RTC_CHECK(false) << "Unexpected BundlePolicy enum_name " << enum_name; | 246 RTC_CHECK(false) << "Unexpected BundlePolicy enum_name " << enum_name; |
| 247 return webrtc::PeerConnectionInterface::kBundlePolicyBalanced; | 247 return PeerConnectionInterface::kBundlePolicyBalanced; |
| 248 } | 248 } |
| 249 | 249 |
| 250 webrtc::PeerConnectionInterface::RtcpMuxPolicy JavaToNativeRtcpMuxPolicy( | 250 PeerConnectionInterface::RtcpMuxPolicy JavaToNativeRtcpMuxPolicy( |
| 251 JNIEnv* jni, | 251 JNIEnv* jni, |
| 252 jobject j_rtcp_mux_policy) { | 252 jobject j_rtcp_mux_policy) { |
| 253 std::string enum_name = GetJavaEnumName( | 253 std::string enum_name = GetJavaEnumName( |
| 254 jni, "org/webrtc/PeerConnection$RtcpMuxPolicy", j_rtcp_mux_policy); | 254 jni, "org/webrtc/PeerConnection$RtcpMuxPolicy", j_rtcp_mux_policy); |
| 255 | 255 |
| 256 if (enum_name == "NEGOTIATE") | 256 if (enum_name == "NEGOTIATE") |
| 257 return webrtc::PeerConnectionInterface::kRtcpMuxPolicyNegotiate; | 257 return PeerConnectionInterface::kRtcpMuxPolicyNegotiate; |
| 258 | 258 |
| 259 if (enum_name == "REQUIRE") | 259 if (enum_name == "REQUIRE") |
| 260 return webrtc::PeerConnectionInterface::kRtcpMuxPolicyRequire; | 260 return PeerConnectionInterface::kRtcpMuxPolicyRequire; |
| 261 | 261 |
| 262 RTC_CHECK(false) << "Unexpected RtcpMuxPolicy enum_name " << enum_name; | 262 RTC_CHECK(false) << "Unexpected RtcpMuxPolicy enum_name " << enum_name; |
| 263 return webrtc::PeerConnectionInterface::kRtcpMuxPolicyNegotiate; | 263 return PeerConnectionInterface::kRtcpMuxPolicyNegotiate; |
| 264 } | 264 } |
| 265 | 265 |
| 266 webrtc::PeerConnectionInterface::TcpCandidatePolicy | 266 PeerConnectionInterface::TcpCandidatePolicy JavaToNativeTcpCandidatePolicy( |
| 267 JavaToNativeTcpCandidatePolicy(JNIEnv* jni, jobject j_tcp_candidate_policy) { | 267 JNIEnv* jni, |
| 268 jobject j_tcp_candidate_policy) { |
| 268 std::string enum_name = | 269 std::string enum_name = |
| 269 GetJavaEnumName(jni, "org/webrtc/PeerConnection$TcpCandidatePolicy", | 270 GetJavaEnumName(jni, "org/webrtc/PeerConnection$TcpCandidatePolicy", |
| 270 j_tcp_candidate_policy); | 271 j_tcp_candidate_policy); |
| 271 | 272 |
| 272 if (enum_name == "ENABLED") | 273 if (enum_name == "ENABLED") |
| 273 return webrtc::PeerConnectionInterface::kTcpCandidatePolicyEnabled; | 274 return PeerConnectionInterface::kTcpCandidatePolicyEnabled; |
| 274 | 275 |
| 275 if (enum_name == "DISABLED") | 276 if (enum_name == "DISABLED") |
| 276 return webrtc::PeerConnectionInterface::kTcpCandidatePolicyDisabled; | 277 return PeerConnectionInterface::kTcpCandidatePolicyDisabled; |
| 277 | 278 |
| 278 RTC_CHECK(false) << "Unexpected TcpCandidatePolicy enum_name " << enum_name; | 279 RTC_CHECK(false) << "Unexpected TcpCandidatePolicy enum_name " << enum_name; |
| 279 return webrtc::PeerConnectionInterface::kTcpCandidatePolicyEnabled; | 280 return PeerConnectionInterface::kTcpCandidatePolicyEnabled; |
| 280 } | 281 } |
| 281 | 282 |
| 282 webrtc::PeerConnectionInterface::CandidateNetworkPolicy | 283 PeerConnectionInterface::CandidateNetworkPolicy |
| 283 JavaToNativeCandidateNetworkPolicy(JNIEnv* jni, | 284 JavaToNativeCandidateNetworkPolicy(JNIEnv* jni, |
| 284 jobject j_candidate_network_policy) { | 285 jobject j_candidate_network_policy) { |
| 285 std::string enum_name = | 286 std::string enum_name = |
| 286 GetJavaEnumName(jni, "org/webrtc/PeerConnection$CandidateNetworkPolicy", | 287 GetJavaEnumName(jni, "org/webrtc/PeerConnection$CandidateNetworkPolicy", |
| 287 j_candidate_network_policy); | 288 j_candidate_network_policy); |
| 288 | 289 |
| 289 if (enum_name == "ALL") | 290 if (enum_name == "ALL") |
| 290 return webrtc::PeerConnectionInterface::kCandidateNetworkPolicyAll; | 291 return PeerConnectionInterface::kCandidateNetworkPolicyAll; |
| 291 | 292 |
| 292 if (enum_name == "LOW_COST") | 293 if (enum_name == "LOW_COST") |
| 293 return webrtc::PeerConnectionInterface::kCandidateNetworkPolicyLowCost; | 294 return PeerConnectionInterface::kCandidateNetworkPolicyLowCost; |
| 294 | 295 |
| 295 RTC_CHECK(false) << "Unexpected CandidateNetworkPolicy enum_name " | 296 RTC_CHECK(false) << "Unexpected CandidateNetworkPolicy enum_name " |
| 296 << enum_name; | 297 << enum_name; |
| 297 return webrtc::PeerConnectionInterface::kCandidateNetworkPolicyAll; | 298 return PeerConnectionInterface::kCandidateNetworkPolicyAll; |
| 298 } | 299 } |
| 299 | 300 |
| 300 rtc::KeyType JavaToNativeKeyType(JNIEnv* jni, jobject j_key_type) { | 301 rtc::KeyType JavaToNativeKeyType(JNIEnv* jni, jobject j_key_type) { |
| 301 std::string enum_name = | 302 std::string enum_name = |
| 302 GetJavaEnumName(jni, "org/webrtc/PeerConnection$KeyType", j_key_type); | 303 GetJavaEnumName(jni, "org/webrtc/PeerConnection$KeyType", j_key_type); |
| 303 | 304 |
| 304 if (enum_name == "RSA") | 305 if (enum_name == "RSA") |
| 305 return rtc::KT_RSA; | 306 return rtc::KT_RSA; |
| 306 if (enum_name == "ECDSA") | 307 if (enum_name == "ECDSA") |
| 307 return rtc::KT_ECDSA; | 308 return rtc::KT_ECDSA; |
| 308 | 309 |
| 309 RTC_CHECK(false) << "Unexpected KeyType enum_name " << enum_name; | 310 RTC_CHECK(false) << "Unexpected KeyType enum_name " << enum_name; |
| 310 return rtc::KT_ECDSA; | 311 return rtc::KT_ECDSA; |
| 311 } | 312 } |
| 312 | 313 |
| 313 webrtc::PeerConnectionInterface::ContinualGatheringPolicy | 314 PeerConnectionInterface::ContinualGatheringPolicy |
| 314 JavaToNativeContinualGatheringPolicy(JNIEnv* jni, jobject j_gathering_policy) { | 315 JavaToNativeContinualGatheringPolicy(JNIEnv* jni, jobject j_gathering_policy) { |
| 315 std::string enum_name = | 316 std::string enum_name = |
| 316 GetJavaEnumName(jni, "org/webrtc/PeerConnection$ContinualGatheringPolicy", | 317 GetJavaEnumName(jni, "org/webrtc/PeerConnection$ContinualGatheringPolicy", |
| 317 j_gathering_policy); | 318 j_gathering_policy); |
| 318 if (enum_name == "GATHER_ONCE") | 319 if (enum_name == "GATHER_ONCE") |
| 319 return webrtc::PeerConnectionInterface::GATHER_ONCE; | 320 return PeerConnectionInterface::GATHER_ONCE; |
| 320 | 321 |
| 321 if (enum_name == "GATHER_CONTINUALLY") | 322 if (enum_name == "GATHER_CONTINUALLY") |
| 322 return webrtc::PeerConnectionInterface::GATHER_CONTINUALLY; | 323 return PeerConnectionInterface::GATHER_CONTINUALLY; |
| 323 | 324 |
| 324 RTC_CHECK(false) << "Unexpected ContinualGatheringPolicy enum name " | 325 RTC_CHECK(false) << "Unexpected ContinualGatheringPolicy enum name " |
| 325 << enum_name; | 326 << enum_name; |
| 326 return webrtc::PeerConnectionInterface::GATHER_ONCE; | 327 return PeerConnectionInterface::GATHER_ONCE; |
| 327 } | 328 } |
| 328 | 329 |
| 329 webrtc::PeerConnectionInterface::TlsCertPolicy JavaToNativeTlsCertPolicy( | 330 PeerConnectionInterface::TlsCertPolicy JavaToNativeTlsCertPolicy( |
| 330 JNIEnv* jni, | 331 JNIEnv* jni, |
| 331 jobject j_ice_server_tls_cert_policy) { | 332 jobject j_ice_server_tls_cert_policy) { |
| 332 std::string enum_name = | 333 std::string enum_name = |
| 333 GetJavaEnumName(jni, "org/webrtc/PeerConnection$TlsCertPolicy", | 334 GetJavaEnumName(jni, "org/webrtc/PeerConnection$TlsCertPolicy", |
| 334 j_ice_server_tls_cert_policy); | 335 j_ice_server_tls_cert_policy); |
| 335 | 336 |
| 336 if (enum_name == "TLS_CERT_POLICY_SECURE") | 337 if (enum_name == "TLS_CERT_POLICY_SECURE") |
| 337 return webrtc::PeerConnectionInterface::kTlsCertPolicySecure; | 338 return PeerConnectionInterface::kTlsCertPolicySecure; |
| 338 | 339 |
| 339 if (enum_name == "TLS_CERT_POLICY_INSECURE_NO_CHECK") | 340 if (enum_name == "TLS_CERT_POLICY_INSECURE_NO_CHECK") |
| 340 return webrtc::PeerConnectionInterface::kTlsCertPolicyInsecureNoCheck; | 341 return PeerConnectionInterface::kTlsCertPolicyInsecureNoCheck; |
| 341 | 342 |
| 342 RTC_CHECK(false) << "Unexpected TlsCertPolicy enum_name " << enum_name; | 343 RTC_CHECK(false) << "Unexpected TlsCertPolicy enum_name " << enum_name; |
| 343 return webrtc::PeerConnectionInterface::kTlsCertPolicySecure; | 344 return PeerConnectionInterface::kTlsCertPolicySecure; |
| 344 } | 345 } |
| 345 | 346 |
| 346 void JavaToNativeIceServers( | 347 void JavaToNativeIceServers(JNIEnv* jni, |
| 347 JNIEnv* jni, | 348 jobject j_ice_servers, |
| 348 jobject j_ice_servers, | 349 PeerConnectionInterface::IceServers* ice_servers) { |
| 349 webrtc::PeerConnectionInterface::IceServers* ice_servers) { | |
| 350 for (jobject j_ice_server : Iterable(jni, j_ice_servers)) { | 350 for (jobject j_ice_server : Iterable(jni, j_ice_servers)) { |
| 351 jclass j_ice_server_class = GetObjectClass(jni, j_ice_server); | 351 jclass j_ice_server_class = GetObjectClass(jni, j_ice_server); |
| 352 jfieldID j_ice_server_uri_id = | 352 jfieldID j_ice_server_uri_id = |
| 353 GetFieldID(jni, j_ice_server_class, "uri", "Ljava/lang/String;"); | 353 GetFieldID(jni, j_ice_server_class, "uri", "Ljava/lang/String;"); |
| 354 jfieldID j_ice_server_username_id = | 354 jfieldID j_ice_server_username_id = |
| 355 GetFieldID(jni, j_ice_server_class, "username", "Ljava/lang/String;"); | 355 GetFieldID(jni, j_ice_server_class, "username", "Ljava/lang/String;"); |
| 356 jfieldID j_ice_server_password_id = | 356 jfieldID j_ice_server_password_id = |
| 357 GetFieldID(jni, j_ice_server_class, "password", "Ljava/lang/String;"); | 357 GetFieldID(jni, j_ice_server_class, "password", "Ljava/lang/String;"); |
| 358 jfieldID j_ice_server_tls_cert_policy_id = | 358 jfieldID j_ice_server_tls_cert_policy_id = |
| 359 GetFieldID(jni, j_ice_server_class, "tlsCertPolicy", | 359 GetFieldID(jni, j_ice_server_class, "tlsCertPolicy", |
| 360 "Lorg/webrtc/PeerConnection$TlsCertPolicy;"); | 360 "Lorg/webrtc/PeerConnection$TlsCertPolicy;"); |
| 361 jobject j_ice_server_tls_cert_policy = | 361 jobject j_ice_server_tls_cert_policy = |
| 362 GetObjectField(jni, j_ice_server, j_ice_server_tls_cert_policy_id); | 362 GetObjectField(jni, j_ice_server, j_ice_server_tls_cert_policy_id); |
| 363 jfieldID j_ice_server_hostname_id = | 363 jfieldID j_ice_server_hostname_id = |
| 364 GetFieldID(jni, j_ice_server_class, "hostname", "Ljava/lang/String;"); | 364 GetFieldID(jni, j_ice_server_class, "hostname", "Ljava/lang/String;"); |
| 365 jstring uri = reinterpret_cast<jstring>( | 365 jstring uri = reinterpret_cast<jstring>( |
| 366 GetObjectField(jni, j_ice_server, j_ice_server_uri_id)); | 366 GetObjectField(jni, j_ice_server, j_ice_server_uri_id)); |
| 367 jstring username = reinterpret_cast<jstring>( | 367 jstring username = reinterpret_cast<jstring>( |
| 368 GetObjectField(jni, j_ice_server, j_ice_server_username_id)); | 368 GetObjectField(jni, j_ice_server, j_ice_server_username_id)); |
| 369 jstring password = reinterpret_cast<jstring>( | 369 jstring password = reinterpret_cast<jstring>( |
| 370 GetObjectField(jni, j_ice_server, j_ice_server_password_id)); | 370 GetObjectField(jni, j_ice_server, j_ice_server_password_id)); |
| 371 webrtc::PeerConnectionInterface::TlsCertPolicy tls_cert_policy = | 371 PeerConnectionInterface::TlsCertPolicy tls_cert_policy = |
| 372 JavaToNativeTlsCertPolicy(jni, j_ice_server_tls_cert_policy); | 372 JavaToNativeTlsCertPolicy(jni, j_ice_server_tls_cert_policy); |
| 373 jstring hostname = reinterpret_cast<jstring>( | 373 jstring hostname = reinterpret_cast<jstring>( |
| 374 GetObjectField(jni, j_ice_server, j_ice_server_hostname_id)); | 374 GetObjectField(jni, j_ice_server, j_ice_server_hostname_id)); |
| 375 webrtc::PeerConnectionInterface::IceServer server; | 375 PeerConnectionInterface::IceServer server; |
| 376 server.uri = JavaToStdString(jni, uri); | 376 server.uri = JavaToStdString(jni, uri); |
| 377 server.username = JavaToStdString(jni, username); | 377 server.username = JavaToStdString(jni, username); |
| 378 server.password = JavaToStdString(jni, password); | 378 server.password = JavaToStdString(jni, password); |
| 379 server.tls_cert_policy = tls_cert_policy; | 379 server.tls_cert_policy = tls_cert_policy; |
| 380 server.hostname = JavaToStdString(jni, hostname); | 380 server.hostname = JavaToStdString(jni, hostname); |
| 381 ice_servers->push_back(server); | 381 ice_servers->push_back(server); |
| 382 } | 382 } |
| 383 } | 383 } |
| 384 | 384 |
| 385 void JavaToNativeRTCConfiguration( | 385 void JavaToNativeRTCConfiguration( |
| 386 JNIEnv* jni, | 386 JNIEnv* jni, |
| 387 jobject j_rtc_config, | 387 jobject j_rtc_config, |
| 388 webrtc::PeerConnectionInterface::RTCConfiguration* rtc_config) { | 388 PeerConnectionInterface::RTCConfiguration* rtc_config) { |
| 389 jclass j_rtc_config_class = GetObjectClass(jni, j_rtc_config); | 389 jclass j_rtc_config_class = GetObjectClass(jni, j_rtc_config); |
| 390 | 390 |
| 391 jfieldID j_ice_transports_type_id = | 391 jfieldID j_ice_transports_type_id = |
| 392 GetFieldID(jni, j_rtc_config_class, "iceTransportsType", | 392 GetFieldID(jni, j_rtc_config_class, "iceTransportsType", |
| 393 "Lorg/webrtc/PeerConnection$IceTransportsType;"); | 393 "Lorg/webrtc/PeerConnection$IceTransportsType;"); |
| 394 jobject j_ice_transports_type = | 394 jobject j_ice_transports_type = |
| 395 GetObjectField(jni, j_rtc_config, j_ice_transports_type_id); | 395 GetObjectField(jni, j_rtc_config, j_ice_transports_type_id); |
| 396 | 396 |
| 397 jfieldID j_bundle_policy_id = | 397 jfieldID j_bundle_policy_id = |
| 398 GetFieldID(jni, j_rtc_config_class, "bundlePolicy", | 398 GetFieldID(jni, j_rtc_config_class, "bundlePolicy", |
| (...skipping 110 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 509 jni, j_rtc_config, j_ice_regather_interval_range_id); | 509 jni, j_rtc_config, j_ice_regather_interval_range_id); |
| 510 if (!IsNull(jni, j_ice_regather_interval_range)) { | 510 if (!IsNull(jni, j_ice_regather_interval_range)) { |
| 511 int min = jni->CallIntMethod(j_ice_regather_interval_range, get_min_id); | 511 int min = jni->CallIntMethod(j_ice_regather_interval_range, get_min_id); |
| 512 int max = jni->CallIntMethod(j_ice_regather_interval_range, get_max_id); | 512 int max = jni->CallIntMethod(j_ice_regather_interval_range, get_max_id); |
| 513 rtc_config->ice_regather_interval_range.emplace(min, max); | 513 rtc_config->ice_regather_interval_range.emplace(min, max); |
| 514 } | 514 } |
| 515 } | 515 } |
| 516 | 516 |
| 517 void JavaToNativeRtpParameters(JNIEnv* jni, | 517 void JavaToNativeRtpParameters(JNIEnv* jni, |
| 518 jobject j_parameters, | 518 jobject j_parameters, |
| 519 webrtc::RtpParameters* parameters) { | 519 RtpParameters* parameters) { |
| 520 RTC_CHECK(parameters != nullptr); | 520 RTC_CHECK(parameters != nullptr); |
| 521 jclass parameters_class = jni->FindClass("org/webrtc/RtpParameters"); | 521 jclass parameters_class = jni->FindClass("org/webrtc/RtpParameters"); |
| 522 jfieldID encodings_id = | 522 jfieldID encodings_id = |
| 523 GetFieldID(jni, parameters_class, "encodings", "Ljava/util/LinkedList;"); | 523 GetFieldID(jni, parameters_class, "encodings", "Ljava/util/LinkedList;"); |
| 524 jfieldID codecs_id = | 524 jfieldID codecs_id = |
| 525 GetFieldID(jni, parameters_class, "codecs", "Ljava/util/LinkedList;"); | 525 GetFieldID(jni, parameters_class, "codecs", "Ljava/util/LinkedList;"); |
| 526 | 526 |
| 527 // Convert encodings. | 527 // Convert encodings. |
| 528 jobject j_encodings = GetObjectField(jni, j_parameters, encodings_id); | 528 jobject j_encodings = GetObjectField(jni, j_parameters, encodings_id); |
| 529 jclass j_encoding_parameters_class = | 529 jclass j_encoding_parameters_class = |
| 530 jni->FindClass("org/webrtc/RtpParameters$Encoding"); | 530 jni->FindClass("org/webrtc/RtpParameters$Encoding"); |
| 531 jfieldID active_id = | 531 jfieldID active_id = |
| 532 GetFieldID(jni, j_encoding_parameters_class, "active", "Z"); | 532 GetFieldID(jni, j_encoding_parameters_class, "active", "Z"); |
| 533 jfieldID bitrate_id = GetFieldID(jni, j_encoding_parameters_class, | 533 jfieldID bitrate_id = GetFieldID(jni, j_encoding_parameters_class, |
| 534 "maxBitrateBps", "Ljava/lang/Integer;"); | 534 "maxBitrateBps", "Ljava/lang/Integer;"); |
| 535 jfieldID ssrc_id = | 535 jfieldID ssrc_id = |
| 536 GetFieldID(jni, j_encoding_parameters_class, "ssrc", "Ljava/lang/Long;"); | 536 GetFieldID(jni, j_encoding_parameters_class, "ssrc", "Ljava/lang/Long;"); |
| 537 jclass j_integer_class = jni->FindClass("java/lang/Integer"); | 537 jclass j_integer_class = jni->FindClass("java/lang/Integer"); |
| 538 jclass j_long_class = jni->FindClass("java/lang/Long"); | 538 jclass j_long_class = jni->FindClass("java/lang/Long"); |
| 539 jmethodID int_value_id = GetMethodID(jni, j_integer_class, "intValue", "()I"); | 539 jmethodID int_value_id = GetMethodID(jni, j_integer_class, "intValue", "()I"); |
| 540 jmethodID long_value_id = GetMethodID(jni, j_long_class, "longValue", "()J"); | 540 jmethodID long_value_id = GetMethodID(jni, j_long_class, "longValue", "()J"); |
| 541 | 541 |
| 542 for (jobject j_encoding_parameters : Iterable(jni, j_encodings)) { | 542 for (jobject j_encoding_parameters : Iterable(jni, j_encodings)) { |
| 543 webrtc::RtpEncodingParameters encoding; | 543 RtpEncodingParameters encoding; |
| 544 encoding.active = GetBooleanField(jni, j_encoding_parameters, active_id); | 544 encoding.active = GetBooleanField(jni, j_encoding_parameters, active_id); |
| 545 jobject j_bitrate = | 545 jobject j_bitrate = |
| 546 GetNullableObjectField(jni, j_encoding_parameters, bitrate_id); | 546 GetNullableObjectField(jni, j_encoding_parameters, bitrate_id); |
| 547 if (!IsNull(jni, j_bitrate)) { | 547 if (!IsNull(jni, j_bitrate)) { |
| 548 int bitrate_value = jni->CallIntMethod(j_bitrate, int_value_id); | 548 int bitrate_value = jni->CallIntMethod(j_bitrate, int_value_id); |
| 549 CHECK_EXCEPTION(jni) << "error during CallIntMethod"; | 549 CHECK_EXCEPTION(jni) << "error during CallIntMethod"; |
| 550 encoding.max_bitrate_bps = rtc::Optional<int>(bitrate_value); | 550 encoding.max_bitrate_bps = rtc::Optional<int>(bitrate_value); |
| 551 } | 551 } |
| 552 jobject j_ssrc = | 552 jobject j_ssrc = |
| 553 GetNullableObjectField(jni, j_encoding_parameters, ssrc_id); | 553 GetNullableObjectField(jni, j_encoding_parameters, ssrc_id); |
| (...skipping 11 matching lines...) Expand all Loading... |
| 565 jfieldID payload_type_id = GetFieldID(jni, codec_class, "payloadType", "I"); | 565 jfieldID payload_type_id = GetFieldID(jni, codec_class, "payloadType", "I"); |
| 566 jfieldID name_id = GetFieldID(jni, codec_class, "name", "Ljava/lang/String;"); | 566 jfieldID name_id = GetFieldID(jni, codec_class, "name", "Ljava/lang/String;"); |
| 567 jfieldID kind_id = GetFieldID(jni, codec_class, "kind", | 567 jfieldID kind_id = GetFieldID(jni, codec_class, "kind", |
| 568 "Lorg/webrtc/MediaStreamTrack$MediaType;"); | 568 "Lorg/webrtc/MediaStreamTrack$MediaType;"); |
| 569 jfieldID clock_rate_id = | 569 jfieldID clock_rate_id = |
| 570 GetFieldID(jni, codec_class, "clockRate", "Ljava/lang/Integer;"); | 570 GetFieldID(jni, codec_class, "clockRate", "Ljava/lang/Integer;"); |
| 571 jfieldID num_channels_id = | 571 jfieldID num_channels_id = |
| 572 GetFieldID(jni, codec_class, "numChannels", "Ljava/lang/Integer;"); | 572 GetFieldID(jni, codec_class, "numChannels", "Ljava/lang/Integer;"); |
| 573 | 573 |
| 574 for (jobject j_codec : Iterable(jni, j_codecs)) { | 574 for (jobject j_codec : Iterable(jni, j_codecs)) { |
| 575 webrtc::RtpCodecParameters codec; | 575 RtpCodecParameters codec; |
| 576 codec.payload_type = GetIntField(jni, j_codec, payload_type_id); | 576 codec.payload_type = GetIntField(jni, j_codec, payload_type_id); |
| 577 codec.name = JavaToStdString(jni, GetStringField(jni, j_codec, name_id)); | 577 codec.name = JavaToStdString(jni, GetStringField(jni, j_codec, name_id)); |
| 578 codec.kind = | 578 codec.kind = |
| 579 JavaToNativeMediaType(jni, GetObjectField(jni, j_codec, kind_id)); | 579 JavaToNativeMediaType(jni, GetObjectField(jni, j_codec, kind_id)); |
| 580 jobject j_clock_rate = GetNullableObjectField(jni, j_codec, clock_rate_id); | 580 jobject j_clock_rate = GetNullableObjectField(jni, j_codec, clock_rate_id); |
| 581 if (!IsNull(jni, j_clock_rate)) { | 581 if (!IsNull(jni, j_clock_rate)) { |
| 582 int clock_rate_value = jni->CallIntMethod(j_clock_rate, int_value_id); | 582 int clock_rate_value = jni->CallIntMethod(j_clock_rate, int_value_id); |
| 583 CHECK_EXCEPTION(jni) << "error during CallIntMethod"; | 583 CHECK_EXCEPTION(jni) << "error during CallIntMethod"; |
| 584 codec.clock_rate = rtc::Optional<int>(clock_rate_value); | 584 codec.clock_rate = rtc::Optional<int>(clock_rate_value); |
| 585 } | 585 } |
| 586 jobject j_num_channels = | 586 jobject j_num_channels = |
| 587 GetNullableObjectField(jni, j_codec, num_channels_id); | 587 GetNullableObjectField(jni, j_codec, num_channels_id); |
| 588 if (!IsNull(jni, j_num_channels)) { | 588 if (!IsNull(jni, j_num_channels)) { |
| 589 int num_channels_value = jni->CallIntMethod(j_num_channels, int_value_id); | 589 int num_channels_value = jni->CallIntMethod(j_num_channels, int_value_id); |
| 590 CHECK_EXCEPTION(jni) << "error during CallIntMethod"; | 590 CHECK_EXCEPTION(jni) << "error during CallIntMethod"; |
| 591 codec.num_channels = rtc::Optional<int>(num_channels_value); | 591 codec.num_channels = rtc::Optional<int>(num_channels_value); |
| 592 } | 592 } |
| 593 parameters->codecs.push_back(codec); | 593 parameters->codecs.push_back(codec); |
| 594 } | 594 } |
| 595 } | 595 } |
| 596 | 596 |
| 597 jobject NativeToJavaRtpParameters(JNIEnv* jni, | 597 jobject NativeToJavaRtpParameters(JNIEnv* jni, |
| 598 const webrtc::RtpParameters& parameters) { | 598 const RtpParameters& parameters) { |
| 599 jclass parameters_class = jni->FindClass("org/webrtc/RtpParameters"); | 599 jclass parameters_class = jni->FindClass("org/webrtc/RtpParameters"); |
| 600 jmethodID parameters_ctor = | 600 jmethodID parameters_ctor = |
| 601 GetMethodID(jni, parameters_class, "<init>", "()V"); | 601 GetMethodID(jni, parameters_class, "<init>", "()V"); |
| 602 jobject j_parameters = jni->NewObject(parameters_class, parameters_ctor); | 602 jobject j_parameters = jni->NewObject(parameters_class, parameters_ctor); |
| 603 CHECK_EXCEPTION(jni) << "error during NewObject"; | 603 CHECK_EXCEPTION(jni) << "error during NewObject"; |
| 604 | 604 |
| 605 // Add encodings. | 605 // Add encodings. |
| 606 jclass encoding_class = jni->FindClass("org/webrtc/RtpParameters$Encoding"); | 606 jclass encoding_class = jni->FindClass("org/webrtc/RtpParameters$Encoding"); |
| 607 jmethodID encoding_ctor = GetMethodID(jni, encoding_class, "<init>", "()V"); | 607 jmethodID encoding_ctor = GetMethodID(jni, encoding_class, "<init>", "()V"); |
| 608 jfieldID encodings_id = | 608 jfieldID encodings_id = |
| 609 GetFieldID(jni, parameters_class, "encodings", "Ljava/util/LinkedList;"); | 609 GetFieldID(jni, parameters_class, "encodings", "Ljava/util/LinkedList;"); |
| 610 jobject j_encodings = GetObjectField(jni, j_parameters, encodings_id); | 610 jobject j_encodings = GetObjectField(jni, j_parameters, encodings_id); |
| 611 jmethodID encodings_add = GetMethodID(jni, GetObjectClass(jni, j_encodings), | 611 jmethodID encodings_add = GetMethodID(jni, GetObjectClass(jni, j_encodings), |
| 612 "add", "(Ljava/lang/Object;)Z"); | 612 "add", "(Ljava/lang/Object;)Z"); |
| 613 jfieldID active_id = GetFieldID(jni, encoding_class, "active", "Z"); | 613 jfieldID active_id = GetFieldID(jni, encoding_class, "active", "Z"); |
| 614 jfieldID bitrate_id = | 614 jfieldID bitrate_id = |
| 615 GetFieldID(jni, encoding_class, "maxBitrateBps", "Ljava/lang/Integer;"); | 615 GetFieldID(jni, encoding_class, "maxBitrateBps", "Ljava/lang/Integer;"); |
| 616 jfieldID ssrc_id = | 616 jfieldID ssrc_id = |
| 617 GetFieldID(jni, encoding_class, "ssrc", "Ljava/lang/Long;"); | 617 GetFieldID(jni, encoding_class, "ssrc", "Ljava/lang/Long;"); |
| 618 | 618 |
| 619 jclass integer_class = jni->FindClass("java/lang/Integer"); | 619 jclass integer_class = jni->FindClass("java/lang/Integer"); |
| 620 jclass long_class = jni->FindClass("java/lang/Long"); | 620 jclass long_class = jni->FindClass("java/lang/Long"); |
| 621 jmethodID integer_ctor = GetMethodID(jni, integer_class, "<init>", "(I)V"); | 621 jmethodID integer_ctor = GetMethodID(jni, integer_class, "<init>", "(I)V"); |
| 622 jmethodID long_ctor = GetMethodID(jni, long_class, "<init>", "(J)V"); | 622 jmethodID long_ctor = GetMethodID(jni, long_class, "<init>", "(J)V"); |
| 623 | 623 |
| 624 for (const webrtc::RtpEncodingParameters& encoding : parameters.encodings) { | 624 for (const RtpEncodingParameters& encoding : parameters.encodings) { |
| 625 jobject j_encoding_parameters = | 625 jobject j_encoding_parameters = |
| 626 jni->NewObject(encoding_class, encoding_ctor); | 626 jni->NewObject(encoding_class, encoding_ctor); |
| 627 CHECK_EXCEPTION(jni) << "error during NewObject"; | 627 CHECK_EXCEPTION(jni) << "error during NewObject"; |
| 628 jni->SetBooleanField(j_encoding_parameters, active_id, encoding.active); | 628 jni->SetBooleanField(j_encoding_parameters, active_id, encoding.active); |
| 629 CHECK_EXCEPTION(jni) << "error during SetBooleanField"; | 629 CHECK_EXCEPTION(jni) << "error during SetBooleanField"; |
| 630 if (encoding.max_bitrate_bps) { | 630 if (encoding.max_bitrate_bps) { |
| 631 jobject j_bitrate_value = jni->NewObject(integer_class, integer_ctor, | 631 jobject j_bitrate_value = jni->NewObject(integer_class, integer_ctor, |
| 632 *(encoding.max_bitrate_bps)); | 632 *(encoding.max_bitrate_bps)); |
| 633 CHECK_EXCEPTION(jni) << "error during NewObject"; | 633 CHECK_EXCEPTION(jni) << "error during NewObject"; |
| 634 jni->SetObjectField(j_encoding_parameters, bitrate_id, j_bitrate_value); | 634 jni->SetObjectField(j_encoding_parameters, bitrate_id, j_bitrate_value); |
| (...skipping 22 matching lines...) Expand all Loading... |
| 657 "(Ljava/lang/Object;)Z"); | 657 "(Ljava/lang/Object;)Z"); |
| 658 jfieldID payload_type_id = GetFieldID(jni, codec_class, "payloadType", "I"); | 658 jfieldID payload_type_id = GetFieldID(jni, codec_class, "payloadType", "I"); |
| 659 jfieldID name_id = GetFieldID(jni, codec_class, "name", "Ljava/lang/String;"); | 659 jfieldID name_id = GetFieldID(jni, codec_class, "name", "Ljava/lang/String;"); |
| 660 jfieldID kind_id = GetFieldID(jni, codec_class, "kind", | 660 jfieldID kind_id = GetFieldID(jni, codec_class, "kind", |
| 661 "Lorg/webrtc/MediaStreamTrack$MediaType;"); | 661 "Lorg/webrtc/MediaStreamTrack$MediaType;"); |
| 662 jfieldID clock_rate_id = | 662 jfieldID clock_rate_id = |
| 663 GetFieldID(jni, codec_class, "clockRate", "Ljava/lang/Integer;"); | 663 GetFieldID(jni, codec_class, "clockRate", "Ljava/lang/Integer;"); |
| 664 jfieldID num_channels_id = | 664 jfieldID num_channels_id = |
| 665 GetFieldID(jni, codec_class, "numChannels", "Ljava/lang/Integer;"); | 665 GetFieldID(jni, codec_class, "numChannels", "Ljava/lang/Integer;"); |
| 666 | 666 |
| 667 for (const webrtc::RtpCodecParameters& codec : parameters.codecs) { | 667 for (const RtpCodecParameters& codec : parameters.codecs) { |
| 668 jobject j_codec = jni->NewObject(codec_class, codec_ctor); | 668 jobject j_codec = jni->NewObject(codec_class, codec_ctor); |
| 669 CHECK_EXCEPTION(jni) << "error during NewObject"; | 669 CHECK_EXCEPTION(jni) << "error during NewObject"; |
| 670 jni->SetIntField(j_codec, payload_type_id, codec.payload_type); | 670 jni->SetIntField(j_codec, payload_type_id, codec.payload_type); |
| 671 CHECK_EXCEPTION(jni) << "error during SetIntField"; | 671 CHECK_EXCEPTION(jni) << "error during SetIntField"; |
| 672 jni->SetObjectField(j_codec, name_id, | 672 jni->SetObjectField(j_codec, name_id, |
| 673 JavaStringFromStdString(jni, codec.name)); | 673 JavaStringFromStdString(jni, codec.name)); |
| 674 CHECK_EXCEPTION(jni) << "error during SetObjectField"; | 674 CHECK_EXCEPTION(jni) << "error during SetObjectField"; |
| 675 jni->SetObjectField(j_codec, kind_id, | 675 jni->SetObjectField(j_codec, kind_id, |
| 676 NativeToJavaMediaType(jni, codec.kind)); | 676 NativeToJavaMediaType(jni, codec.kind)); |
| 677 CHECK_EXCEPTION(jni) << "error during SetObjectField"; | 677 CHECK_EXCEPTION(jni) << "error during SetObjectField"; |
| (...skipping 12 matching lines...) Expand all Loading... |
| 690 CHECK_EXCEPTION(jni) << "error during SetObjectField"; | 690 CHECK_EXCEPTION(jni) << "error during SetObjectField"; |
| 691 } | 691 } |
| 692 jboolean added = jni->CallBooleanMethod(j_codecs, codecs_add, j_codec); | 692 jboolean added = jni->CallBooleanMethod(j_codecs, codecs_add, j_codec); |
| 693 CHECK_EXCEPTION(jni) << "error during CallBooleanMethod"; | 693 CHECK_EXCEPTION(jni) << "error during CallBooleanMethod"; |
| 694 RTC_CHECK(added); | 694 RTC_CHECK(added); |
| 695 } | 695 } |
| 696 | 696 |
| 697 return j_parameters; | 697 return j_parameters; |
| 698 } | 698 } |
| 699 | 699 |
| 700 } // namespace webrtc_jni | 700 } // namespace jni |
| 701 } // namespace webrtc |
| OLD | NEW |