home *** CD-ROM | disk | FTP | other *** search
/ OS/2 Shareware BBS: 10 Tools / 10-Tools.zip / oclsrc15.zip / OCL / Include / OQueue.inl < prev    next >
Text File  |  1996-08-12  |  2KB  |  83 lines

  1. // OCL - OS/2 Class Library
  2. // (c) Cubus 1995
  3. // All Rights Reserved
  4. // OQueue.inl
  5.  
  6. /*
  7.  * Redistribution and use in source and binary forms, with or without
  8.  * modification, are permitted provided that the following conditions
  9.  * are met:
  10.  * 1. Redistributions of source code must retain the above copyright
  11.  *    notice, this list of conditions and the following disclaimer.
  12.  * 2. Neither the name Cubus nor the name Team OCL may be used to
  13.  *    endorse or promote products derived from this software
  14.  *    without specific prior written permission.
  15.  * 3. See OCL.INF for a detailed copyright notice.
  16.  *
  17.  *              THIS SOFTWARE IS PROVIDED ``AS IS'' AND
  18.  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
  19.  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
  20.  * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
  21.  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
  22.  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
  23.  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
  24.  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
  25.  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
  26.  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
  27.  * SUCH DAMAGE.
  28.  */
  29.  
  30. // $Header: W:/Projects/OCL/Include/rcs/OQueue.inl 1.50 1996/08/11 23:47:28 B.STEIN Release $
  31.  
  32. #ifndef OQUEUE_INLINED
  33.   #define OQUEUE_INLINED
  34.  
  35. template <class T>
  36. OQueue<T>::OQueue(BOOL copyElements)
  37.   : OList<T>(copyElements)
  38.   {} 
  39.  
  40. template <class T>
  41. OQueue<T>::OQueue(OQueue<T>& queue, BOOL copyElements)
  42.   : OList<T>(queue, copyElements)
  43.   {}
  44.  
  45.  
  46. template <class T>
  47. OQueue<T>::~OQueue()
  48.  {}
  49.  
  50. template <class T>
  51. PSZ OQueue<T>::isOfType() const
  52. {
  53.  return("OQueue<T>");
  54.  
  55. template <class T>
  56. void OQueue<T>::put(T& item)
  57. {
  58.  addLast(&item);
  59. }
  60.  
  61. template <class T>
  62. void OQueue<T>::put(T *item)
  63. {
  64.  addLast(item);
  65. }
  66.  
  67. template <class T>
  68. T* OQueue<T>::get()
  69. {
  70.  T* retVal = (T*) _getFirst();
  71.  
  72.  if (retVal)
  73.    remove(retVal);
  74.  
  75.  return(retVal); 
  76. }
  77.  
  78.  
  79. #endif // OQUEUE_INLINED
  80.  
  81. // end of source
  82.