OLD | NEW |
1 // Copyright (c) 2013 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2013 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 "content/browser/android/date_time_chooser_android.h" | 5 #include "content/browser/android/date_time_chooser_android.h" |
6 | 6 |
7 #include <stddef.h> | 7 #include <stddef.h> |
8 | 8 |
9 #include "base/android/jni_android.h" | 9 #include "base/android/jni_android.h" |
10 #include "base/android/jni_string.h" | 10 #include "base/android/jni_string.h" |
11 #include "base/i18n/char_iterator.h" | 11 #include "base/i18n/char_iterator.h" |
| 12 #include "base/i18n/unicodestring.h" |
12 #include "content/common/date_time_suggestion.h" | 13 #include "content/common/date_time_suggestion.h" |
13 #include "content/common/view_messages.h" | 14 #include "content/common/view_messages.h" |
14 #include "content/public/browser/render_view_host.h" | 15 #include "content/public/browser/render_view_host.h" |
15 #include "jni/DateTimeChooserAndroid_jni.h" | 16 #include "jni/DateTimeChooserAndroid_jni.h" |
16 #include "third_party/icu/source/common/unicode/uchar.h" | 17 #include "third_party/icu/source/common/unicode/uchar.h" |
17 #include "third_party/icu/source/common/unicode/unistr.h" | 18 #include "third_party/icu/source/common/unicode/unistr.h" |
18 #include "ui/android/window_android.h" | 19 #include "ui/android/window_android.h" |
19 | 20 |
20 using base::android::AttachCurrentThread; | 21 using base::android::AttachCurrentThread; |
21 using base::android::ConvertJavaStringToUTF16; | 22 using base::android::ConvertJavaStringToUTF16; |
22 using base::android::ConvertUTF8ToJavaString; | 23 using base::android::ConvertUTF8ToJavaString; |
23 using base::android::ConvertUTF16ToJavaString; | 24 using base::android::ConvertUTF16ToJavaString; |
24 using base::android::JavaRef; | 25 using base::android::JavaRef; |
25 using base::android::ScopedJavaLocalRef; | 26 using base::android::ScopedJavaLocalRef; |
26 | 27 |
27 namespace { | 28 namespace { |
28 | 29 |
29 base::string16 SanitizeSuggestionString(const base::string16& string) { | 30 base::string16 SanitizeSuggestionString(const base::string16& string) { |
30 base::string16 trimmed = string.substr(0, 255); | 31 base::string16 trimmed = string.substr(0, 255); |
31 icu::UnicodeString sanitized; | 32 icu::UnicodeString sanitized; |
32 base::i18n::UTF16CharIterator sanitized_iterator(&trimmed); | 33 base::i18n::UTF16CharIterator sanitized_iterator(&trimmed); |
33 while (!sanitized_iterator.end()) { | 34 while (!sanitized_iterator.end()) { |
34 UChar c = sanitized_iterator.get(); | 35 UChar c = sanitized_iterator.get(); |
35 if (u_isprint(c)) | 36 if (u_isprint(c)) |
36 sanitized.append(c); | 37 sanitized.append(c); |
37 sanitized_iterator.Advance(); | 38 sanitized_iterator.Advance(); |
38 } | 39 } |
39 return base::string16(sanitized.getBuffer(), | 40 return base::i18n::UnicodeStringToString16(sanitized); |
40 static_cast<size_t>(sanitized.length())); | |
41 } | 41 } |
42 | 42 |
43 } // namespace | 43 } // namespace |
44 | 44 |
45 namespace content { | 45 namespace content { |
46 | 46 |
47 // DateTimeChooserAndroid implementation | 47 // DateTimeChooserAndroid implementation |
48 DateTimeChooserAndroid::DateTimeChooserAndroid() | 48 DateTimeChooserAndroid::DateTimeChooserAndroid() |
49 : host_(NULL) { | 49 : host_(NULL) { |
50 } | 50 } |
(...skipping 49 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
100 } | 100 } |
101 | 101 |
102 // ---------------------------------------------------------------------------- | 102 // ---------------------------------------------------------------------------- |
103 // Native JNI methods | 103 // Native JNI methods |
104 // ---------------------------------------------------------------------------- | 104 // ---------------------------------------------------------------------------- |
105 bool RegisterDateTimeChooserAndroid(JNIEnv* env) { | 105 bool RegisterDateTimeChooserAndroid(JNIEnv* env) { |
106 return RegisterNativesImpl(env); | 106 return RegisterNativesImpl(env); |
107 } | 107 } |
108 | 108 |
109 } // namespace content | 109 } // namespace content |
OLD | NEW |