| Index: chrome/browser/android/offline_pages/background_scheduler_bridge.cc
|
| diff --git a/chrome/browser/android/offline_pages/background_scheduler_bridge.cc b/chrome/browser/android/offline_pages/background_scheduler_bridge.cc
|
| new file mode 100644
|
| index 0000000000000000000000000000000000000000..455c8b9452490308926da9c91fd774a9eff55638
|
| --- /dev/null
|
| +++ b/chrome/browser/android/offline_pages/background_scheduler_bridge.cc
|
| @@ -0,0 +1,65 @@
|
| +// Copyright 2016 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.
|
| +
|
| +#include "base/android/scoped_java_ref.h"
|
| +#include "chrome/browser/android/offline_pages/background_scheduler_bridge.h"
|
| +#include "chrome/browser/profiles/profile.h"
|
| +#include "chrome/browser/profiles/profile_android.h"
|
| +#include "jni/BackgroundSchedulerBridge_jni.h"
|
| +
|
| +using base::android::ScopedJavaGlobalRef;
|
| +
|
| +namespace offline_pages {
|
| +namespace android {
|
| +
|
| +namespace {
|
| +
|
| +// C++ callback that delegates to Java callback.
|
| +void ProcessingDoneCallback(
|
| + const ScopedJavaGlobalRef<jobject>& j_callback_obj, jboolean result) {
|
| + JNIEnv* env = base::android::AttachCurrentThread();
|
| + Java_ProcessingDoneCallback_onProcessingDone(
|
| + env, j_callback_obj.obj(), result);
|
| +}
|
| +
|
| +} // namespace
|
| +
|
| +// JNI call to start request processing.
|
| +static jboolean StartProcessing(
|
| + JNIEnv* env,
|
| + const JavaParamRef<jclass>& jcaller,
|
| + const JavaParamRef<jobject>& j_profile,
|
| + const JavaParamRef<jobject>& j_callback_obj) {
|
| + ScopedJavaGlobalRef<jobject> j_callback_ref;
|
| + j_callback_ref.Reset(env, j_callback_obj);
|
| + base::Bind(&ProcessingDoneCallback, j_callback_ref);
|
| + // TODO(dougarnett): lookup/create RequestCoordinator KeyedService
|
| + // and call StartProcessing on it with bound j_callback_obj.
|
| + return false;
|
| +}
|
| +
|
| +BackgroundSchedulerBridge::BackgroundSchedulerBridge() {
|
| +}
|
| +
|
| +BackgroundSchedulerBridge::~BackgroundSchedulerBridge() {
|
| +}
|
| +
|
| +void BackgroundSchedulerBridge::Schedule(
|
| + const TriggerCondition& trigger_condition) {
|
| + JNIEnv* env = base::android::AttachCurrentThread();
|
| + // TODO(dougarnett): pass trigger_condition.
|
| + Java_BackgroundSchedulerBridge_schedule(env);
|
| +}
|
| +
|
| +void BackgroundSchedulerBridge::Unschedule() {
|
| + JNIEnv* env = base::android::AttachCurrentThread();
|
| + Java_BackgroundSchedulerBridge_unschedule(env);
|
| +}
|
| +
|
| +bool RegisterBackgroundSchedulerBridge(JNIEnv* env) {
|
| + return RegisterNativesImpl(env);
|
| +}
|
| +
|
| +} // namespace android
|
| +} // namespace offline_pages
|
|
|