Index: chrome/browser/spellchecker/spellchecker_session_bridge_android.h |
diff --git a/chrome/browser/spellchecker/spellchecker_session_bridge_android.h b/chrome/browser/spellchecker/spellchecker_session_bridge_android.h |
new file mode 100644 |
index 0000000000000000000000000000000000000000..99f07a123ee894620339a61e09c1daabbb6007ef |
--- /dev/null |
+++ b/chrome/browser/spellchecker/spellchecker_session_bridge_android.h |
@@ -0,0 +1,66 @@ |
+// Copyright 2015 The Chromium Authors. All rights reserved. |
+// Use of this source code is governed by a BSD-style license that can be |
+// found in the LICENSE file. |
+ |
+#ifndef CHROME_BROWSER_SPELLCHECKER_SPELLCHECKER_SESSION_BRIDGE_ANDROID_H_ |
+#define CHROME_BROWSER_SPELLCHECKER_SPELLCHECKER_SESSION_BRIDGE_ANDROID_H_ |
+ |
+#include "base/android/jni_android.h" |
newt (away)
2015/08/13 20:40:32
I still don't think these jni_*.h includes are nee
dylanking
2015/08/14 02:57:03
Ah, I see. Changed, thanks!
|
+#include "base/android/jni_array.h" |
+#include "base/android/jni_string.h" |
+#include "base/android/scoped_java_ref.h" |
+#include "base/strings/string16.h" |
+ |
+// Owned by the SpellCheckMessageFilterPlatform. This class is used to |
+// interface between the android message filter and the Java class of the |
+// same name. This class is sent text to be spellchecked from |
+// the message filter, then sends that text to the Java side via JNI to be |
+// spellchecked, and finally processes those results and sends them to the |
+// renderer. |
+class SpellCheckerSessionBridge { |
+ public: |
+ explicit SpellCheckerSessionBridge(int render_process_id); |
+ ~SpellCheckerSessionBridge(); |
+ static bool RegisterJNI(JNIEnv* env); |
+ |
+ // Receives text to be checked from the message filter and sends it to Java |
+ // to be spellchecked. |
+ void RequestTextCheck(int route_id, |
+ int identifier, |
+ const base::string16& text); |
+ |
+ // Receives information from Java side about the typos in a given string |
+ // of text, processes these and sends them to the renderer. |
+ void ProcessSpellCheckResults(JNIEnv* env, |
+ jobject jobj, |
+ jintArray offset_array, |
+ jintArray length_array); |
+ |
+ private: |
+ struct SpellingRequest { |
newt (away)
2015/08/13 20:40:32
Since this class is used only internally, it'd be
dylanking
2015/08/14 02:57:03
I believe I need to define it here since SpellChec
|
+ SpellingRequest(int route_id, int identifier, const base::string16& text); |
+ SpellingRequest() {} |
newt (away)
2015/08/13 20:40:32
probably don't need this method either (once you s
dylanking
2015/08/14 02:57:03
Gotcha.
|
+ ~SpellingRequest() {} |
+ |
+ void set_route_id(int r_id) { route_id = r_id; } |
newt (away)
2015/08/13 20:40:31
I'd probably just remove these methods. Since this
dylanking
2015/08/14 02:57:03
Right, meant to delete those earlier. Fixed.
|
+ void set_identifier(int id) { identifier = id; } |
+ void set_text(base::string16 new_text) { text = new_text; } |
+ |
+ int route_id; |
+ int identifier; |
+ base::string16 text; |
+ }; |
+ |
+ int render_process_id_; |
+ bool is_active_request_; |
newt (away)
2015/08/13 20:40:32
Instead of using a bool to remember whether active
dylanking
2015/08/14 02:57:03
rouslan@ has advised me to use composed objects ra
please use gerrit instead
2015/08/14 17:06:23
I think this is a good use case for scoped pointer
|
+ bool is_pending_request_; |
+ |
+ SpellingRequest active_spelling_request_; |
+ SpellingRequest pending_spelling_request_; |
+ |
+ base::android::ScopedJavaGlobalRef<jobject> java_object_; |
+ |
+ DISALLOW_COPY_AND_ASSIGN(SpellCheckerSessionBridge); |
+}; |
+ |
+#endif // CHROME_BROWSER_SPELLCHECKER_SPELLCHECKER_SESSION_BRIDGE_ANDROID_H_ |