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

Side by Side Diff: chrome/browser/android/background_sync_launcher_android.cc

Issue 1324173002: [Background Sync] Use GcmNetworkManager to start the browser for sync events. (Closed) Base URL: https://chromium.googlesource.com/chromium/src@bgsync-fix-background5
Patch Set: Addressing comments from PS#25 Created 5 years, 2 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
OLDNEW
1 // Copyright 2015 The Chromium Authors. All rights reserved. 1 // Copyright 2015 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/background_sync_launcher_android.h" 5 #include "chrome/browser/android/background_sync_launcher_android.h"
6 6
7 #include "content/public/browser/browser_thread.h" 7 #include "content/public/browser/browser_thread.h"
8 #include "jni/BackgroundSyncLauncher_jni.h" 8 #include "jni/BackgroundSyncLauncher_jni.h"
9 9
10 namespace content { 10 using content::BrowserThread;
11 11
12 namespace { 12 namespace {
13 base::LazyInstance<BackgroundSyncLauncherAndroid> g_background_sync_launcher = 13 base::LazyInstance<BackgroundSyncLauncherAndroid> g_background_sync_launcher =
14 LAZY_INSTANCE_INITIALIZER; 14 LAZY_INSTANCE_INITIALIZER;
15 } 15 }
16 16
17 // static 17 // static
18 BackgroundSyncLauncherAndroid* BackgroundSyncLauncherAndroid::Get() { 18 BackgroundSyncLauncherAndroid* BackgroundSyncLauncherAndroid::Get() {
19 DCHECK_CURRENTLY_ON(BrowserThread::UI); 19 DCHECK_CURRENTLY_ON(BrowserThread::UI);
20 20
21 return g_background_sync_launcher.Pointer(); 21 return g_background_sync_launcher.Pointer();
22 } 22 }
23 23
24 // static 24 // static
25 void BackgroundSyncLauncherAndroid::LaunchBrowserWhenNextOnline( 25 void BackgroundSyncLauncherAndroid::LaunchBrowserWhenNextOnline(
26 const BackgroundSyncManager* registrant, 26 const content::BackgroundSyncManager* registrant,
27 bool launch_when_next_online) { 27 bool launch_when_next_online) {
28 DCHECK_CURRENTLY_ON(BrowserThread::UI); 28 DCHECK_CURRENTLY_ON(BrowserThread::UI);
29 29
30 Get()->LaunchBrowserWhenNextOnlineImpl(registrant, launch_when_next_online); 30 Get()->LaunchBrowserWhenNextOnlineImpl(registrant, launch_when_next_online);
31 } 31 }
32 32
33 void BackgroundSyncLauncherAndroid::LaunchBrowserWhenNextOnlineImpl( 33 void BackgroundSyncLauncherAndroid::LaunchBrowserWhenNextOnlineImpl(
34 const BackgroundSyncManager* registrant, 34 const content::BackgroundSyncManager* registrant,
35 bool launch_when_next_online) { 35 bool launch_when_next_online) {
36 DCHECK_CURRENTLY_ON(BrowserThread::UI); 36 DCHECK_CURRENTLY_ON(BrowserThread::UI);
37 37
38 bool was_launching = !launch_when_next_online_registrants_.empty(); 38 bool was_launching = !launch_when_next_online_registrants_.empty();
39 39
40 if (launch_when_next_online) 40 if (launch_when_next_online)
41 launch_when_next_online_registrants_.insert(registrant); 41 launch_when_next_online_registrants_.insert(registrant);
42 else 42 else
43 launch_when_next_online_registrants_.erase(registrant); 43 launch_when_next_online_registrants_.erase(registrant);
44 44
45 bool now_launching = !launch_when_next_online_registrants_.empty(); 45 bool now_launching = !launch_when_next_online_registrants_.empty();
46 if (was_launching != now_launching) { 46 if (was_launching != now_launching) {
47 JNIEnv* env = base::android::AttachCurrentThread(); 47 JNIEnv* env = base::android::AttachCurrentThread();
48 Java_BackgroundSyncLauncher_setLaunchWhenNextOnline( 48 Java_BackgroundSyncLauncher_launchBrowserWhenNextOnlineIfStopped(
49 env, java_launcher_.obj(), base::android::GetApplicationContext(), 49 env, java_launcher_.obj(), base::android::GetApplicationContext(),
50 now_launching); 50 now_launching);
51 } 51 }
52 } 52 }
53 53
54 // static 54 // static
55 bool BackgroundSyncLauncherAndroid::RegisterLauncher(JNIEnv* env) { 55 bool BackgroundSyncLauncherAndroid::RegisterLauncher(JNIEnv* env) {
56 return RegisterNativesImpl(env); 56 return RegisterNativesImpl(env);
57 } 57 }
58 58
59 BackgroundSyncLauncherAndroid::BackgroundSyncLauncherAndroid() { 59 BackgroundSyncLauncherAndroid::BackgroundSyncLauncherAndroid() {
60 DCHECK_CURRENTLY_ON(BrowserThread::UI); 60 DCHECK_CURRENTLY_ON(BrowserThread::UI);
61 61
62 JNIEnv* env = base::android::AttachCurrentThread(); 62 JNIEnv* env = base::android::AttachCurrentThread();
63 java_launcher_.Reset(Java_BackgroundSyncLauncher_create( 63 java_launcher_.Reset(Java_BackgroundSyncLauncher_create(
64 env, base::android::GetApplicationContext())); 64 env, base::android::GetApplicationContext()));
65 } 65 }
66 66
67 BackgroundSyncLauncherAndroid::~BackgroundSyncLauncherAndroid() { 67 BackgroundSyncLauncherAndroid::~BackgroundSyncLauncherAndroid() {
68 DCHECK_CURRENTLY_ON(BrowserThread::UI); 68 DCHECK_CURRENTLY_ON(BrowserThread::UI);
69 69
70 JNIEnv* env = base::android::AttachCurrentThread(); 70 JNIEnv* env = base::android::AttachCurrentThread();
71 Java_BackgroundSyncLauncher_destroy(env, java_launcher_.obj()); 71 Java_BackgroundSyncLauncher_destroy(env, java_launcher_.obj());
72 } 72 }
73
74 } // namespace content
OLDNEW
« no previous file with comments | « chrome/browser/android/background_sync_launcher_android.h ('k') | chrome/browser/android/chrome_jni_registrar.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698