1 // Copyright (c) 2012 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.
5 #ifndef BASE_MAC_SCOPED_MACH_PORT_H_
6 #define BASE_MAC_SCOPED_MACH_PORT_H_
10 #include "base/base_export.h"
11 #include "base/scoped_generic.h"
18 struct BASE_EXPORT SendRightTraits
{
19 static mach_port_t
InvalidValue() {
20 return MACH_PORT_NULL
;
23 BASE_EXPORT
static void Free(mach_port_t port
);
26 struct BASE_EXPORT ReceiveRightTraits
{
27 static mach_port_t
InvalidValue() {
28 return MACH_PORT_NULL
;
31 BASE_EXPORT
static void Free(mach_port_t port
);
34 struct PortSetTraits
{
35 static mach_port_t
InvalidValue() {
36 return MACH_PORT_NULL
;
39 BASE_EXPORT
static void Free(mach_port_t port
);
42 } // namespace internal
44 // A scoper for handling a Mach port that names a send right. Send rights are
45 // reference counted, and this takes ownership of the right on construction
46 // and then removes a reference to the right on destruction. If the reference
47 // is the last one on the right, the right is deallocated.
48 class BASE_EXPORT ScopedMachSendRight
:
49 public base::ScopedGeneric
<mach_port_t
, internal::SendRightTraits
> {
51 explicit ScopedMachSendRight(mach_port_t port
= traits_type::InvalidValue())
52 : ScopedGeneric(port
) {}
54 operator mach_port_t() const { return get(); }
57 // A scoper for handling a Mach port's receive right. There is only one
58 // receive right per port. This takes ownership of the receive right on
59 // construction and then destroys the right on destruction, turning all
60 // outstanding send rights into dead names.
61 class BASE_EXPORT ScopedMachReceiveRight
:
62 public base::ScopedGeneric
<mach_port_t
, internal::ReceiveRightTraits
> {
64 explicit ScopedMachReceiveRight(
65 mach_port_t port
= traits_type::InvalidValue()) : ScopedGeneric(port
) {}
67 operator mach_port_t() const { return get(); }
70 // A scoper for handling a Mach port set. A port set can have only one
71 // reference. This takes ownership of that single reference on construction and
72 // destroys the port set on destruction. Destroying a port set does not destroy
73 // the receive rights that are members of the port set.
74 class BASE_EXPORT ScopedMachPortSet
:
75 public ScopedGeneric
<mach_port_t
, internal::PortSetTraits
> {
77 explicit ScopedMachPortSet(mach_port_t port
= traits_type::InvalidValue())
78 : ScopedGeneric(port
) {}
80 operator mach_port_t() const { return get(); }
86 #endif // BASE_MAC_SCOPED_MACH_PORT_H_