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

Unified Diff: chrome/browser/android/foreign_session_helper.h

Issue 19874002: [Android] Expose foreign session sync related funtionalities through JNI. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: fixed patchest 1 comments Created 7 years, 5 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 side-by-side diff with in-line comments
Download patch
Index: chrome/browser/android/foreign_session_helper.h
diff --git a/chrome/browser/android/foreign_session_helper.h b/chrome/browser/android/foreign_session_helper.h
new file mode 100644
index 0000000000000000000000000000000000000000..1a0b5221ac539debe8153101ac4c16ca69b6a6c6
--- /dev/null
+++ b/chrome/browser/android/foreign_session_helper.h
@@ -0,0 +1,59 @@
+// Copyright 2013 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_ANDROID_FOREIGN_SESSION_HELPER_H_
+#define CHROME_BROWSER_ANDROID_FOREIGN_SESSION_HELPER_H_
+
+#include <jni.h>
+
+#include "base/android/scoped_java_ref.h"
+#include "base/basictypes.h"
+#include "chrome/browser/profiles/profile.h"
+#include "chrome/browser/ui/webui/session_favicon_source.h"
+#include "content/public/browser/notification_observer.h"
+#include "content/public/browser/notification_registrar.h"
+
+using base::android::ScopedJavaLocalRef;
+
+class SessionWindow;
+
+namespace browser_sync {
+class SessionModelAssociator;
+class SyncedSession;
+} // namespace browser_sync
+
+class ForeignSessionHelper : public content::NotificationObserver {
+ public:
+ static bool RegisterForeignSessionHelper(JNIEnv* env);
Ted C 2013/07/26 22:29:47 the ordering of the methods should be as close as
Kibeom Kim (inactive) 2013/07/26 23:32:52 Done.
+
+ explicit ForeignSessionHelper(Profile* profile);
+ void Destroy(JNIEnv* env, jobject obj);
+ jboolean IsTabSyncEnabled(JNIEnv* env, jobject obj);
+ void SetOnForeignSessionCallback(JNIEnv* env, jobject obj, jobject callback);
+ virtual void Observe(int type, const content::NotificationSource& source,
Ted C 2013/07/26 22:29:47 I usually see all the overridden methods separated
Ted C 2013/07/26 22:29:47 if all the params don't fit on one line, then each
Kibeom Kim (inactive) 2013/07/26 23:32:52 Done.
Kibeom Kim (inactive) 2013/07/26 23:32:52 Done.
+ const content::NotificationDetails& details) OVERRIDE;
+ jboolean GetForeignSessions(JNIEnv* env, jobject obj, jobject result);
+ jboolean OpenForeignSessionTab(JNIEnv* env, jobject obj, jstring session_tag,
+ jint tab_id);
+ void SetForeignSessionCollapsed(JNIEnv* env, jobject obj, jstring session_tag,
+ jboolean is_collapsed);
+ void DeleteForeignSession(JNIEnv* env, jobject obj, jstring session_tag);
+
+ private:
+ Profile* profile_; // weak
+ base::android::ScopedJavaGlobalRef<jobject> callback_;
+ content::NotificationRegistrar registrar_;
+ browser_sync::SessionModelAssociator* GetSessionModelAssociator();
Ted C 2013/07/26 22:29:47 private methods above variables.
Kibeom Kim (inactive) 2013/07/26 23:32:52 Done.
+
+ void CopyTabsToJava(JNIEnv* env, const SessionWindow* window,
+ ScopedJavaLocalRef<jobject>& j_window);
+ void CopyWindowsToJava(JNIEnv* env,
+ const browser_sync::SyncedSession* session,
+ ScopedJavaLocalRef<jobject>& j_session);
+ virtual ~ForeignSessionHelper() {}
Kibeom Kim (inactive) 2013/07/26 18:35:44 clang build complains having {} here. I'll move {}
Kibeom Kim (inactive) 2013/07/26 23:32:52 Done.
+
+ DISALLOW_COPY_AND_ASSIGN(ForeignSessionHelper);
+};
+
+#endif // CHROME_BROWSER_ANDROID_FOREIGN_SESSION_HELPER_H_

Powered by Google App Engine
This is Rietveld 408576698