blocxx
src
blocxx
RefCount.hpp
Go to the documentation of this file.
1
/*******************************************************************************
2
* Copyright (C) 2005, Vintela, Inc. All rights reserved.
3
* Copyright (C) 2006, Novell, Inc. All rights reserved.
4
*
5
* Redistribution and use in source and binary forms, with or without
6
* modification, are permitted provided that the following conditions are met:
7
*
8
* * Redistributions of source code must retain the above copyright notice,
9
* this list of conditions and the following disclaimer.
10
* * Redistributions in binary form must reproduce the above copyright
11
* notice, this list of conditions and the following disclaimer in the
12
* documentation and/or other materials provided with the distribution.
13
* * Neither the name of
14
* Vintela, Inc.,
15
* nor Novell, Inc.,
16
* nor the names of its contributors or employees may be used to
17
* endorse or promote products derived from this software without
18
* specific prior written permission.
19
*
20
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
21
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
22
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
23
* ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
24
* LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
25
* CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
26
* SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
27
* INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
28
* CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
29
* ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
30
* POSSIBILITY OF SUCH DAMAGE.
31
*******************************************************************************/
32
33
37
38
#ifndef BLOCXX_REF_COUNT_HPP_
39
#define BLOCXX_REF_COUNT_HPP_
40
#include "blocxx/BLOCXX_config.h"
41
#include "
blocxx/AtomicOps.hpp
"
42
43
// The classes and functions defined in this file are not meant for general
44
// use, they are internal implementation details. They may change at any time.
45
46
namespace
BLOCXX_NAMESPACE
47
{
48
50
class
BLOCXX_COMMON_API
RefCount
51
{
52
public
:
53
RefCount
()
54
:
m_count
(1)
55
{
56
}
57
RefCount
(
Atomic_t
c)
58
:
m_count
(c)
59
{
60
}
61
void
inc
()
62
{
63
AtomicInc
(
m_count
);
64
}
65
bool
decAndTest
()
66
{
67
return
AtomicDecAndTest
(
m_count
);
68
}
69
int
get
()
const
70
{
71
return
AtomicGet
(
m_count
);
72
}
73
private
:
74
Atomic_t
m_count
;
75
};
76
77
}
// end namespace BLOCXX_NAMESPACE
78
79
#endif
AtomicOps.hpp
BLOCXX_NAMESPACE::RefCount::m_count
Atomic_t m_count
Definition
RefCount.hpp:74
BLOCXX_NAMESPACE::RefCount::inc
void inc()
Definition
RefCount.hpp:61
BLOCXX_NAMESPACE::RefCount::RefCount
RefCount(Atomic_t c)
Definition
RefCount.hpp:57
BLOCXX_NAMESPACE::RefCount::decAndTest
bool decAndTest()
Definition
RefCount.hpp:65
BLOCXX_NAMESPACE::RefCount::RefCount
RefCount()
Definition
RefCount.hpp:53
BLOCXX_NAMESPACE::RefCount::get
int get() const
Definition
RefCount.hpp:69
BLOCXX_NAMESPACE
Taken from RFC 1321.
Definition
AppenderLogger.cpp:48
BLOCXX_NAMESPACE::AtomicDecAndTest
bool AtomicDecAndTest(Atomic_t &v)
Definition
AtomicOps.cpp:62
BLOCXX_NAMESPACE::AtomicInc
void AtomicInc(Atomic_t &v)
Definition
AtomicOps.cpp:56
BLOCXX_NAMESPACE::AtomicGet
int AtomicGet(Atomic_t const &v)
Definition
AtomicOps.cpp:70
BLOCXX_NAMESPACE::Atomic_t
Definition
AtomicOps.hpp:332
Generated by
1.13.2