OLD | NEW |
---|---|
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 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/renderer_host/ime_adapter_android.h" | 5 #include "content/browser/renderer_host/ime_adapter_android.h" |
6 | 6 |
7 #include <android/input.h> | 7 #include <android/input.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/android/scoped_java_ref.h" | 11 #include "base/android/scoped_java_ref.h" |
12 #include "base/strings/utf_string_conversions.h" | 12 #include "base/strings/utf_string_conversions.h" |
13 #include "base/time/time.h" | 13 #include "base/time/time.h" |
14 #include "content/browser/frame_host/render_frame_host_impl.h" | |
15 #include "content/browser/renderer_host/render_view_host_impl.h" | |
14 #include "content/browser/renderer_host/render_widget_host_impl.h" | 16 #include "content/browser/renderer_host/render_widget_host_impl.h" |
15 #include "content/browser/renderer_host/render_widget_host_view_android.h" | 17 #include "content/browser/renderer_host/render_widget_host_view_android.h" |
16 #include "content/common/view_messages.h" | 18 #include "content/common/view_messages.h" |
17 #include "content/public/browser/native_web_keyboard_event.h" | 19 #include "content/public/browser/native_web_keyboard_event.h" |
18 #include "jni/ImeAdapter_jni.h" | 20 #include "jni/ImeAdapter_jni.h" |
19 #include "third_party/WebKit/public/web/WebCompositionUnderline.h" | 21 #include "third_party/WebKit/public/web/WebCompositionUnderline.h" |
20 #include "third_party/WebKit/public/web/WebInputEvent.h" | 22 #include "third_party/WebKit/public/web/WebInputEvent.h" |
21 | 23 |
22 using base::android::AttachCurrentThread; | 24 using base::android::AttachCurrentThread; |
23 using base::android::ConvertJavaStringToUTF16; | 25 using base::android::ConvertJavaStringToUTF16; |
(...skipping 209 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
233 | 235 |
234 void ImeAdapterAndroid::SelectAll(JNIEnv* env, jobject) { | 236 void ImeAdapterAndroid::SelectAll(JNIEnv* env, jobject) { |
235 RenderWidgetHostImpl* rwhi = GetRenderWidgetHostImpl(); | 237 RenderWidgetHostImpl* rwhi = GetRenderWidgetHostImpl(); |
236 if (!rwhi) | 238 if (!rwhi) |
237 return; | 239 return; |
238 | 240 |
239 rwhi->SelectAll(); | 241 rwhi->SelectAll(); |
240 } | 242 } |
241 | 243 |
242 void ImeAdapterAndroid::Cut(JNIEnv* env, jobject) { | 244 void ImeAdapterAndroid::Cut(JNIEnv* env, jobject) { |
243 RenderWidgetHostImpl* rwhi = GetRenderWidgetHostImpl(); | 245 RenderFrameHost* rfh = GetRenderFrameHost(); |
244 if (!rwhi) | 246 if (rfh) |
245 return; | 247 rfh->Cut(); |
246 | |
247 rwhi->Cut(); | |
248 } | 248 } |
249 | 249 |
250 void ImeAdapterAndroid::Copy(JNIEnv* env, jobject) { | 250 void ImeAdapterAndroid::Copy(JNIEnv* env, jobject) { |
251 RenderWidgetHostImpl* rwhi = GetRenderWidgetHostImpl(); | 251 RenderFrameHost* rfh = GetRenderFrameHost(); |
252 if (!rwhi) | 252 if (rfh) |
253 return; | 253 rfh->Copy(); |
254 | |
255 rwhi->Copy(); | |
256 } | 254 } |
257 | 255 |
258 void ImeAdapterAndroid::Paste(JNIEnv* env, jobject) { | 256 void ImeAdapterAndroid::Paste(JNIEnv* env, jobject) { |
259 RenderWidgetHostImpl* rwhi = GetRenderWidgetHostImpl(); | 257 RenderFrameHost* rfh = GetRenderFrameHost(); |
260 if (!rwhi) | 258 if (rfh) |
261 return; | 259 rfh->Paste(); |
262 | |
263 rwhi->Paste(); | |
264 } | 260 } |
265 | 261 |
266 void ImeAdapterAndroid::ResetImeAdapter(JNIEnv* env, jobject) { | 262 void ImeAdapterAndroid::ResetImeAdapter(JNIEnv* env, jobject) { |
267 java_ime_adapter_.reset(); | 263 java_ime_adapter_.reset(); |
268 } | 264 } |
269 | 265 |
270 RenderWidgetHostImpl* ImeAdapterAndroid::GetRenderWidgetHostImpl() { | 266 RenderWidgetHostImpl* ImeAdapterAndroid::GetRenderWidgetHostImpl() { |
271 DCHECK(rwhva_); | 267 DCHECK(rwhva_); |
272 RenderWidgetHost* rwh = rwhva_->GetRenderWidgetHost(); | 268 RenderWidgetHost* rwh = rwhva_->GetRenderWidgetHost(); |
273 if (!rwh) | 269 if (!rwh) |
274 return NULL; | 270 return NULL; |
275 | 271 |
276 return RenderWidgetHostImpl::From(rwh); | 272 return RenderWidgetHostImpl::From(rwh); |
277 } | 273 } |
278 | 274 |
275 RenderFrameHost* ImeAdapterAndroid::GetRenderFrameHost() { | |
nasko
2014/03/05 21:50:47
nit: Shouldn't this be GetFocusedRenderFrameHost?
jam
2014/03/06 00:59:37
Done.
| |
276 RenderWidgetHostImpl* rwh = GetRenderWidgetHostImpl(); | |
277 if (!rwh) | |
278 return NULL; | |
279 if (!rwh->IsRenderView()) | |
280 return NULL; | |
281 RenderViewHost* rvh = RenderViewHost::From(rwh); | |
282 return rvh->GetFocusedFrame(); | |
283 } | |
284 | |
279 } // namespace content | 285 } // namespace content |
OLD | NEW |