blocxx
ThreadTypes.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
39#ifndef BLOCXX_THREAD_TYPES_HPP_
40#define BLOCXX_THREAD_TYPES_HPP_
41#include "blocxx/BLOCXX_config.h"
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#if defined(BLOCXX_USE_PTHREAD)
47
48 #include <pthread.h>
49
50#ifdef BLOCXX_NCR //for the function pthread_cond_init
51#define PTHREAD_COND_ATTR_DEFAULT pthread_condattr_default
52#else
53#define PTHREAD_COND_ATTR_DEFAULT 0
54#endif
55
56 namespace BLOCXX_NAMESPACE
57 {
58
59 // Platform specific thread type
60 typedef pthread_t Thread_t;
63 {
65 };
66
67 #if defined(BLOCXX_HAVE_PTHREAD_MUTEXATTR_SETTYPE)
68 // Platform specific mutex type
69 // we have native recursive mutexes.
70 struct Mutex_t
71 {
73 };
74
75 #else
76
77 // we have to emulate recursive mutexes.
78 struct Mutex_t
79 {
82 bool valid_id;
83 unsigned count;
85 };
86 #endif
87
88 // Platform specific conditional variable type
91 {
94 };
95
96 } // end namespace BLOCXX_NAMESPACE
97
98#elif defined(BLOCXX_WIN32)
99
100#define WIN32_LEAN_AND_MEAN // Exclude rarely-used stuff from Windows headers
101#include <wtypes.h>
102
103 namespace BLOCXX_NAMESPACE
104 {
105 // Platform specific thread type
106 typedef DWORD Thread_t;
107 typedef HANDLE NativeMutex_t;
110
111 // Platform specific conditional variable type
112 typedef struct
113 {
114 // Number of waiting threads
115 int waitersCount;
116 // Serialize access to waitersCount
118 // Semaphore used to queue up threads waiting for the condition to
119 // become signaled
121 // An auto-reset event used during broadcasting to wait for all the
122 // threads to wake up and be released from the queue
124 // Keeps track of whether we are broadcasting or signaling. This allows
125 // for optimization if just signaling.
126 bool wasBroadcast;
128
130 //typedef void* ConditionVar_t;
132 {
135 };
136
137 } // end namespace BLOCXX_NAMESPACE
138
139#endif
140
141#endif // #ifndef BLOCXX_THREAD_TYPES_HPP_
142
Taken from RFC 1321.
bool operator==(const Array< T > &x, const Array< T > &y)