blob: d2582c20cd5f180639c571567eb5197a8a3122a9 [file] [log] [blame]
// Copyright 2025 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef BASE_ANDROID_SCOPED_SERVICE_BINDING_BATCH_H_
#define BASE_ANDROID_SCOPED_SERVICE_BINDING_BATCH_H_
#include "base/android/scoped_java_ref.h"
#include "base/base_export.h"
namespace base::android {
// ScopedServiceBindingBatch is used to batch up service binding requests.
//
//
// This is a C++ wrapper for the ScopedServiceBindingBatch Java class. This
// class follows RAII to ensure that batch updates are started and stopped
// correctly.
//
// When a ScopedServiceBindingBatch is created, it begins a batch update on the
// process launcher thread. When the ScopedServiceBindingBatch is destroyed, it
// ends the batch update. ScopedServiceBindingBatch supports nested batch
// updates. If the batch update count drops to 0, the binding request queue is
// flushed.
//
// ScopedServiceBindingBatch must be created on the main thread to ensure that
// nested batch window does not partially overlap. The batch open/end events are
// dispatched to the process launcher thread and counter is
// incremented/decremented on the launcher thread.
//
// While it is in batch mode, BindService will queue up binding requests. When
// the batch is over, the queue is flushed.
class BASE_EXPORT ScopedServiceBindingBatch {
public:
ScopedServiceBindingBatch();
~ScopedServiceBindingBatch();
ScopedServiceBindingBatch(const ScopedServiceBindingBatch&) = delete;
ScopedServiceBindingBatch& operator=(const ScopedServiceBindingBatch&) =
delete;
private:
base::android::ScopedJavaGlobalRef<jobject> java_object_;
};
} // namespace base::android
#endif // BASE_ANDROID_SCOPED_SERVICE_BINDING_BATCH_H_