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

Side by Side Diff: net/base/net_string_util_icu_alternatives_android.cc

Issue 449253002: Fix Java object leaks in net_string_util_icu_alternatives_android.cc. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Oops Created 6 years, 4 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 | Annotate | Revision Log
« no previous file with comments | « no previous file | no next file » | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright 2014 The Chromium Authors. All rights reserved. 1 // Copyright 2014 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #include "net/base/net_string_util_icu_alternatives_android.h" 5 #include "net/base/net_string_util_icu_alternatives_android.h"
6 6
7 #include "base/android/jni_android.h" 7 #include "base/android/jni_android.h"
8 #include "base/android/jni_string.h" 8 #include "base/android/jni_string.h"
9 #include "base/strings/string16.h" 9 #include "base/strings/string16.h"
10 #include "base/strings/string_piece.h" 10 #include "base/strings/string_piece.h"
11 #include "jni/NetStringUtil_jni.h" 11 #include "jni/NetStringUtil_jni.h"
12 #include "net/base/net_string_util.h" 12 #include "net/base/net_string_util.h"
13 13
14 namespace net { 14 namespace net {
15 15
16 namespace { 16 namespace {
17 17
18 // Attempts to convert |text| encoded in |charset| to a jstring (Java unicode 18 // Attempts to convert |text| encoded in |charset| to a jstring (Java unicode
19 // string). Returns the result jstring, or NULL on failure. 19 // string). Returns the result jstring, or NULL on failure.
20 ScopedJavaLocalRef<jstring> ConvertToJstring(const std::string& text, 20 ScopedJavaLocalRef<jstring> ConvertToJstring(const std::string& text,
21 const char* charset) { 21 const char* charset) {
22 JNIEnv* env = base::android::AttachCurrentThread(); 22 JNIEnv* env = base::android::AttachCurrentThread();
23 jobject java_byte_buffer = 23 ScopedJavaLocalRef<jobject> java_byte_buffer(
24 env->NewDirectByteBuffer(const_cast<char*>(text.data()), text.length()); 24 env,
25 env->NewDirectByteBuffer(const_cast<char*>(text.data()), text.length()));
25 base::android::ScopedJavaLocalRef<jstring> java_charset = 26 base::android::ScopedJavaLocalRef<jstring> java_charset =
26 base::android::ConvertUTF8ToJavaString(env, base::StringPiece(charset)); 27 base::android::ConvertUTF8ToJavaString(env, base::StringPiece(charset));
27 ScopedJavaLocalRef<jstring> java_result = 28 ScopedJavaLocalRef<jstring> java_result =
28 android::Java_NetStringUtil_convertToUnicode(env, java_byte_buffer, 29 android::Java_NetStringUtil_convertToUnicode(env, java_byte_buffer.obj(),
29 java_charset.obj()); 30 java_charset.obj());
30 return java_result; 31 return java_result;
31 } 32 }
32 33
33 // Attempts to convert |text| encoded in |charset| to a jstring (Java unicode 34 // Attempts to convert |text| encoded in |charset| to a jstring (Java unicode
34 // string) and then normalizes the string. Returns the result jstring, or NULL 35 // string) and then normalizes the string. Returns the result jstring, or NULL
35 // on failure. 36 // on failure.
36 ScopedJavaLocalRef<jstring> ConvertToNormalizedJstring( 37 ScopedJavaLocalRef<jstring> ConvertToNormalizedJstring(
37 const std::string& text, const char* charset) { 38 const std::string& text, const char* charset) {
38 JNIEnv* env = base::android::AttachCurrentThread(); 39 JNIEnv* env = base::android::AttachCurrentThread();
39 jobject java_byte_buffer = 40 ScopedJavaLocalRef<jobject> java_byte_buffer(
40 env->NewDirectByteBuffer(const_cast<char*>(text.data()), text.length()); 41 env,
42 env->NewDirectByteBuffer(const_cast<char*>(text.data()), text.length()));
41 base::android::ScopedJavaLocalRef<jstring> java_charset = 43 base::android::ScopedJavaLocalRef<jstring> java_charset =
42 base::android::ConvertUTF8ToJavaString(env, base::StringPiece(charset)); 44 base::android::ConvertUTF8ToJavaString(env, base::StringPiece(charset));
43 ScopedJavaLocalRef<jstring> java_result = 45 ScopedJavaLocalRef<jstring> java_result =
44 android::Java_NetStringUtil_convertToUnicodeAndNormalize( 46 android::Java_NetStringUtil_convertToUnicodeAndNormalize(
45 env, java_byte_buffer, java_charset.obj()); 47 env, java_byte_buffer.obj(), java_charset.obj());
46 return java_result; 48 return java_result;
47 } 49 }
48 50
49 // Converts |text| encoded in |charset| to a jstring (Java unicode string). 51 // Converts |text| encoded in |charset| to a jstring (Java unicode string).
50 // Any characters that can not be converted are replaced with U+FFFD. 52 // Any characters that can not be converted are replaced with U+FFFD.
51 ScopedJavaLocalRef<jstring> ConvertToJstringWithSubstitutions( 53 ScopedJavaLocalRef<jstring> ConvertToJstringWithSubstitutions(
52 const std::string& text, const char* charset) { 54 const std::string& text, const char* charset) {
53 JNIEnv* env = base::android::AttachCurrentThread(); 55 JNIEnv* env = base::android::AttachCurrentThread();
54 jobject java_byte_buffer = 56 ScopedJavaLocalRef<jobject> java_byte_buffer(
55 env->NewDirectByteBuffer(const_cast<char*>(text.data()), text.length()); 57 env,
58 env->NewDirectByteBuffer(const_cast<char*>(text.data()), text.length()));
56 base::android::ScopedJavaLocalRef<jstring> java_charset = 59 base::android::ScopedJavaLocalRef<jstring> java_charset =
57 base::android::ConvertUTF8ToJavaString(env, base::StringPiece(charset)); 60 base::android::ConvertUTF8ToJavaString(env, base::StringPiece(charset));
58 ScopedJavaLocalRef<jstring> java_result = 61 ScopedJavaLocalRef<jstring> java_result =
59 android::Java_NetStringUtil_convertToUnicodeWithSubstitutions( 62 android::Java_NetStringUtil_convertToUnicodeWithSubstitutions(
60 env, java_byte_buffer, java_charset.obj()); 63 env, java_byte_buffer.obj(), java_charset.obj());
61 return java_result; 64 return java_result;
62 } 65 }
63 66
64 } // namespace 67 } // namespace
65 68
66 const char* const kCharsetLatin1 = "ISO-8859-1"; 69 const char* const kCharsetLatin1 = "ISO-8859-1";
67 70
68 bool ConvertToUtf8(const std::string& text, const char* charset, 71 bool ConvertToUtf8(const std::string& text, const char* charset,
69 std::string* output) { 72 std::string* output) {
70 output->clear(); 73 output->clear();
(...skipping 35 matching lines...) Expand 10 before | Expand all | Expand 10 after
106 return false; 109 return false;
107 *output = base::android::ConvertJavaStringToUTF16(java_result); 110 *output = base::android::ConvertJavaStringToUTF16(java_result);
108 return true; 111 return true;
109 } 112 }
110 113
111 bool RegisterNetStringUtils(JNIEnv* env) { 114 bool RegisterNetStringUtils(JNIEnv* env) {
112 return android::RegisterNativesImpl(env); 115 return android::RegisterNativesImpl(env);
113 } 116 }
114 117
115 } // namespace net 118 } // namespace net
OLDNEW
« no previous file with comments | « no previous file | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698