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

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: Move the BackgroundSyncLauncher into /chrome 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
12 namespace chrome {
13 namespace android {
11 14
jkarlin 2015/10/14 18:30:28 top level namespace
iclelland 2015/10/14 19:31:24 Done.
12 namespace { 15 namespace {
13 base::LazyInstance<BackgroundSyncLauncherAndroid> g_background_sync_launcher = 16 base::LazyInstance<BackgroundSyncLauncherAndroid> g_background_sync_launcher =
14 LAZY_INSTANCE_INITIALIZER; 17 LAZY_INSTANCE_INITIALIZER;
15 } 18 }
16 19
17 // static 20 // static
18 BackgroundSyncLauncherAndroid* BackgroundSyncLauncherAndroid::Get() { 21 BackgroundSyncLauncherAndroid* BackgroundSyncLauncherAndroid::Get() {
19 DCHECK_CURRENTLY_ON(BrowserThread::UI); 22 DCHECK_CURRENTLY_ON(BrowserThread::UI);
20 23
21 return g_background_sync_launcher.Pointer(); 24 return g_background_sync_launcher.Pointer();
22 } 25 }
23 26
24 // static 27 // static
25 void BackgroundSyncLauncherAndroid::LaunchBrowserWhenNextOnline( 28 void BackgroundSyncLauncherAndroid::LaunchBrowserWhenNextOnline(
26 const BackgroundSyncManager* registrant, 29 const content::BackgroundSyncManager* registrant,
27 bool launch_when_next_online) { 30 bool launch_when_next_online) {
28 DCHECK_CURRENTLY_ON(BrowserThread::UI); 31 DCHECK_CURRENTLY_ON(BrowserThread::UI);
29 32
30 Get()->LaunchBrowserWhenNextOnlineImpl(registrant, launch_when_next_online); 33 Get()->LaunchBrowserWhenNextOnlineImpl(registrant, launch_when_next_online);
31 } 34 }
32 35
33 void BackgroundSyncLauncherAndroid::LaunchBrowserWhenNextOnlineImpl( 36 void BackgroundSyncLauncherAndroid::LaunchBrowserWhenNextOnlineImpl(
34 const BackgroundSyncManager* registrant, 37 const content::BackgroundSyncManager* registrant,
35 bool launch_when_next_online) { 38 bool launch_when_next_online) {
36 DCHECK_CURRENTLY_ON(BrowserThread::UI); 39 DCHECK_CURRENTLY_ON(BrowserThread::UI);
37 40
38 bool was_launching = !launch_when_next_online_registrants_.empty(); 41 bool was_launching = !launch_when_next_online_registrants_.empty();
39 42
40 if (launch_when_next_online) 43 if (launch_when_next_online)
41 launch_when_next_online_registrants_.insert(registrant); 44 launch_when_next_online_registrants_.insert(registrant);
42 else 45 else
43 launch_when_next_online_registrants_.erase(registrant); 46 launch_when_next_online_registrants_.erase(registrant);
44 47
45 bool now_launching = !launch_when_next_online_registrants_.empty(); 48 bool now_launching = !launch_when_next_online_registrants_.empty();
46 if (was_launching != now_launching) { 49 if (was_launching != now_launching) {
47 JNIEnv* env = base::android::AttachCurrentThread(); 50 JNIEnv* env = base::android::AttachCurrentThread();
48 Java_BackgroundSyncLauncher_setLaunchWhenNextOnline( 51 Java_BackgroundSyncLauncher_launchBrowserWhenNextOnlineIfStopped(
49 env, java_launcher_.obj(), base::android::GetApplicationContext(), 52 env, java_launcher_.obj(), base::android::GetApplicationContext(),
50 now_launching); 53 now_launching);
51 } 54 }
52 } 55 }
53 56
54 // static 57 // static
55 bool BackgroundSyncLauncherAndroid::RegisterLauncher(JNIEnv* env) { 58 bool BackgroundSyncLauncherAndroid::RegisterLauncher(JNIEnv* env) {
56 return RegisterNativesImpl(env); 59 return RegisterNativesImpl(env);
57 } 60 }
58 61
59 BackgroundSyncLauncherAndroid::BackgroundSyncLauncherAndroid() { 62 BackgroundSyncLauncherAndroid::BackgroundSyncLauncherAndroid() {
60 DCHECK_CURRENTLY_ON(BrowserThread::UI); 63 DCHECK_CURRENTLY_ON(BrowserThread::UI);
61 64
62 JNIEnv* env = base::android::AttachCurrentThread(); 65 JNIEnv* env = base::android::AttachCurrentThread();
63 java_launcher_.Reset(Java_BackgroundSyncLauncher_create( 66 java_launcher_.Reset(Java_BackgroundSyncLauncher_create(
64 env, base::android::GetApplicationContext())); 67 env, base::android::GetApplicationContext()));
65 } 68 }
66 69
67 BackgroundSyncLauncherAndroid::~BackgroundSyncLauncherAndroid() { 70 BackgroundSyncLauncherAndroid::~BackgroundSyncLauncherAndroid() {
68 DCHECK_CURRENTLY_ON(BrowserThread::UI); 71 DCHECK_CURRENTLY_ON(BrowserThread::UI);
69 72
70 JNIEnv* env = base::android::AttachCurrentThread(); 73 JNIEnv* env = base::android::AttachCurrentThread();
71 Java_BackgroundSyncLauncher_destroy(env, java_launcher_.obj()); 74 Java_BackgroundSyncLauncher_destroy(env, java_launcher_.obj());
72 } 75 }
73 76
74 } // namespace content 77 } // namespace android
78 } // namespace chrome
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698