~ubuntu-branches/ubuntu/saucy/resiprocate/saucy-proposed

« back to all changes in this revision

Viewing changes to rutil/Fifo.hxx

  • Committer: Package Import Robot
  • Author(s): Daniel Pocock
  • Date: 2012-05-17 19:29:59 UTC
  • Revision ID: package-import@ubuntu.com-20120517192959-vv00m77isztdy64q
Tags: upstream-1.8.2
ImportĀ upstreamĀ versionĀ 1.8.2

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
#if !defined(RESIP_FIFO_HXX)
 
2
#define RESIP_FIFO_HXX 
 
3
 
 
4
#include <cassert>
 
5
#include "rutil/AbstractFifo.hxx"
 
6
#include "rutil/SelectInterruptor.hxx"
 
7
 
 
8
namespace resip
 
9
{
 
10
 
 
11
/**
 
12
   @brief A templated, threadsafe message-queue class.
 
13
*/
 
14
template < class Msg >
 
15
class Fifo : public AbstractFifo<Msg*>
 
16
{
 
17
   public:
 
18
      Fifo(AsyncProcessHandler* interruptor=0);
 
19
      virtual ~Fifo();
 
20
      
 
21
      using AbstractFifo<Msg*>::mFifo;
 
22
      using AbstractFifo<Msg*>::mMutex;
 
23
      using AbstractFifo<Msg*>::mCondition;
 
24
      using AbstractFifo<Msg*>::empty;
 
25
      using AbstractFifo<Msg*>::size;
 
26
 
 
27
      /// Add a message to the fifo.
 
28
      size_t add(Msg* msg);
 
29
 
 
30
      typedef typename AbstractFifo<Msg*>::Messages Messages;
 
31
      size_t addMultiple(Messages& msgs);
 
32
 
 
33
      /** Returns the first message available. It will wait if no
 
34
       *  messages are available. If a signal interrupts the wait,
 
35
       *  it will retry the wait. Signals can therefore not be caught
 
36
       *  via getNext. If you need to detect a signal, use block
 
37
       *  prior to calling getNext.
 
38
       */
 
39
      Msg* getNext();
 
40
 
 
41
 
 
42
      /** Returns the next message available. Will wait up to
 
43
       *  ms milliseconds if no information is available. If
 
44
       *  the specified time passes or a signal interrupts the
 
45
       *  wait, this method returns 0. This interface provides
 
46
       *  no mechanism to distinguish between timeout and
 
47
       *  interrupt.
 
48
       */
 
49
      Msg* getNext(int ms);
 
50
 
 
51
      void getMultiple(Messages& other, unsigned int max);
 
52
      bool getMultiple(int ms, Messages& other, unsigned int max);
 
53
 
 
54
      /// delete all elements in the queue
 
55
      virtual void clear();
 
56
      void setInterruptor(AsyncProcessHandler* interruptor);
 
57
 
 
58
   private:
 
59
      AsyncProcessHandler* mInterruptor;
 
60
      Fifo(const Fifo& rhs);
 
61
      Fifo& operator=(const Fifo& rhs);
 
62
};
 
63
 
 
64
 
 
65
template <class Msg>
 
66
Fifo<Msg>::Fifo(AsyncProcessHandler* interruptor) : 
 
67
   AbstractFifo<Msg*>(),
 
68
   mInterruptor(interruptor)
 
69
{
 
70
}
 
71
 
 
72
template <class Msg>
 
73
Fifo<Msg>::~Fifo()
 
74
{
 
75
   clear();
 
76
}
 
77
 
 
78
template <class Msg>
 
79
void 
 
80
Fifo<Msg>::setInterruptor(AsyncProcessHandler* interruptor)
 
81
{
 
82
   Lock lock(mMutex); (void)lock;
 
83
   mInterruptor=interruptor;
 
84
}
 
85
 
 
86
 
 
87
template <class Msg>
 
88
void
 
89
Fifo<Msg>::clear()
 
90
{
 
91
   Lock lock(mMutex); (void)lock;
 
92
   while ( ! mFifo.empty() )
 
93
   {
 
94
      delete mFifo.front();
 
95
      mFifo.pop_front();
 
96
   }
 
97
   assert(mFifo.empty());
 
98
}
 
99
 
 
100
template <class Msg>
 
101
size_t
 
102
Fifo<Msg>::add(Msg* msg)
 
103
{
 
104
   size_t size = AbstractFifo<Msg*>::add(msg);
 
105
   if(size==1 && mInterruptor)
 
106
   {
 
107
      // Only do this when the queue goes from empty to not empty.
 
108
      mInterruptor->handleProcessNotification();
 
109
   }
 
110
   return size;
 
111
}
 
112
 
 
113
template <class Msg>
 
114
size_t
 
115
Fifo<Msg>::addMultiple(Messages& msgs)
 
116
{
 
117
   size_t inSize = msgs.size();
 
118
   size_t size = AbstractFifo<Msg*>::addMultiple(msgs);
 
119
   if(size==inSize && mInterruptor)
 
120
   {
 
121
      // Only do this when the queue goes from empty to not empty.
 
122
      mInterruptor->handleProcessNotification();
 
123
   }
 
124
   return size;
 
125
}
 
126
 
 
127
template <class Msg>
 
128
Msg*
 
129
Fifo<Msg> ::getNext()
 
130
{
 
131
   return AbstractFifo<Msg*>::getNext();
 
132
}
 
133
 
 
134
template <class Msg>
 
135
Msg*
 
136
Fifo<Msg> ::getNext(int ms)
 
137
{
 
138
   Msg* result(0);
 
139
   AbstractFifo<Msg*>::getNext(ms, result);
 
140
   return result;
 
141
}
 
142
 
 
143
template <class Msg>
 
144
void
 
145
Fifo<Msg>::getMultiple(Messages& other, unsigned int max)
 
146
{
 
147
   AbstractFifo<Msg*>::getMultiple(other, max);
 
148
}
 
149
 
 
150
template <class Msg>
 
151
bool
 
152
Fifo<Msg>::getMultiple(int ms, Messages& other, unsigned int max)
 
153
{
 
154
   return AbstractFifo<Msg*>::getMultiple(ms, other, max);
 
155
}
 
156
} // namespace resip
 
157
 
 
158
#endif
 
159
 
 
160
/* ====================================================================
 
161
 * The Vovida Software License, Version 1.0 
 
162
 * 
 
163
 * Redistribution and use in source and binary forms, with or without
 
164
 * modification, are permitted provided that the following conditions
 
165
 * are met:
 
166
 * 
 
167
 * 1. Redistributions of source code must retain the above copyright
 
168
 *    notice, this list of conditions and the following disclaimer.
 
169
 * 
 
170
 * 2. Redistributions in binary form must reproduce the above copyright
 
171
 *    notice, this list of conditions and the following disclaimer in
 
172
 *    the documentation and/or other materials provided with the
 
173
 *    distribution.
 
174
 * 
 
175
 * 3. The names "VOCAL", "Vovida Open Communication Application Library",
 
176
 *    and "Vovida Open Communication Application Library (VOCAL)" must
 
177
 *    not be used to endorse or promote products derived from this
 
178
 *    software without prior written permission. For written
 
179
 *    permission, please contact vocal@vovida.org.
 
180
 *
 
181
 * 4. Products derived from this software may not be called "VOCAL", nor
 
182
 *    may "VOCAL" appear in their name, without prior written
 
183
 *    permission of Vovida Networks, Inc.
 
184
 * 
 
185
 * THIS SOFTWARE IS PROVIDED "AS IS" AND ANY EXPRESSED OR IMPLIED
 
186
 * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
 
187
 * OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, TITLE AND
 
188
 * NON-INFRINGEMENT ARE DISCLAIMED.  IN NO EVENT SHALL VOVIDA
 
189
 * NETWORKS, INC. OR ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT DAMAGES
 
190
 * IN EXCESS OF $1,000, NOR FOR ANY INDIRECT, INCIDENTAL, SPECIAL,
 
191
 * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
 
192
 * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
 
193
 * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY
 
194
 * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
 
195
 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE
 
196
 * USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH
 
197
 * DAMAGE.
 
198
 * 
 
199
 * ====================================================================
 
200
 * 
 
201
 * This software consists of voluntary contributions made by Vovida
 
202
 * Networks, Inc. and many individuals on behalf of Vovida Networks,
 
203
 * Inc.  For more information on Vovida Networks, Inc., please see
 
204
 * <http://www.vovida.org/>.
 
205
 *
 
206
 */