Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 946d8152 authored by Alex Vakulenko's avatar Alex Vakulenko Committed by Gerrit Code Review
Browse files

Merge "libbinderwrapper: Add BinderWrapper::GetOrCreateInstance()"

parents 5b7563a0 08c9891c
Loading
Loading
Loading
Loading
+5 −0
Original line number Diff line number Diff line
@@ -30,6 +30,7 @@ class BBinder;
class IBinder;

// Wraps libbinder to make it testable.
// NOTE: Static methods of this class are not thread-safe.
class BinderWrapper {
 public:
  virtual ~BinderWrapper() {}
@@ -50,6 +51,10 @@ class BinderWrapper {
  // InitForTesting().
  static BinderWrapper* Get();

  // Returns the singleton instance if it was previously created by Create() or
  // set by InitForTesting(), or creates a new one by calling Create().
  static BinderWrapper* GetOrCreateInstance();

  // Gets the binder for communicating with the service identified by
  // |service_name|, returning null immediately if it doesn't exist.
  virtual sp<IBinder> GetService(const std::string& service_name) = 0;
+7 −0
Original line number Diff line number Diff line
@@ -50,4 +50,11 @@ BinderWrapper* BinderWrapper::Get() {
  return instance_;
}

// static
BinderWrapper* BinderWrapper::GetOrCreateInstance() {
  if (!instance_)
    instance_ = new RealBinderWrapper();
  return instance_;
}

}  // namespace android