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
3 // found in the LICENSE file.
4 
5 #ifndef MOJO_PUBLIC_CPP_BINDINGS_ASSOCIATED_GROUP_H_
6 #define MOJO_PUBLIC_CPP_BINDINGS_ASSOCIATED_GROUP_H_
7 
8 #include "base/callback.h"
9 #include "base/component_export.h"
10 #include "base/memory/ref_counted.h"
11 #include "mojo/public/cpp/bindings/scoped_interface_endpoint_handle.h"
12 
13 namespace mojo {
14 
15 class AssociatedGroupController;
16 
17 // AssociatedGroup refers to all the interface endpoints running at one end of a
18 // message pipe.
19 // It is thread safe and cheap to make copies.
COMPONENT_EXPORT(MOJO_CPP_BINDINGS_BASE)20 class COMPONENT_EXPORT(MOJO_CPP_BINDINGS_BASE) AssociatedGroup {
21  public:
22   AssociatedGroup();
23 
24   explicit AssociatedGroup(scoped_refptr<AssociatedGroupController> controller);
25 
26   explicit AssociatedGroup(const ScopedInterfaceEndpointHandle& handle);
27 
28   AssociatedGroup(const AssociatedGroup& other);
29 
30   ~AssociatedGroup();
31 
32   AssociatedGroup& operator=(const AssociatedGroup& other);
33 
34   // The return value of this getter if this object is initialized with a
35   // ScopedInterfaceEndpointHandle:
36   //   - If the handle is invalid, the return value will always be null.
37   //   - If the handle is valid and non-pending, the return value will be
38   //     non-null and remain unchanged even if the handle is later reset.
39   //   - If the handle is pending asssociation, the return value will initially
40   //     be null, change to non-null when/if the handle is associated, and
41   //     remain unchanged ever since.
42   AssociatedGroupController* GetController();
43 
44  private:
45   base::Callback<AssociatedGroupController*()> controller_getter_;
46   scoped_refptr<AssociatedGroupController> controller_;
47 };
48 
49 }  // namespace mojo
50 
51 #endif  // MOJO_PUBLIC_CPP_BINDINGS_ASSOCIATED_GROUP_H_
52