dlib C++ Library - queue_kernel_c.h

// Copyright (C) 2003 Davis E. King (davis@dlib.net)
// License: Boost Software License See LICENSE.txt for the full license.
#ifndef DLIB_QUEUE_KERNEl_C_
#define DLIB_QUEUE_KERNEl_C_
#include "queue_kernel_abstract.h"
#include "../algs.h"
#include "../assert.h"
namespace dlib
{
 template <
 typename queue_base // is an implementation of queue_kernel_abstract.h
 >
 class queue_kernel_c : public queue_base
 {
 typedef typename queue_base::type T;
 public:
 void dequeue (
 T& item
 );
 T& current (
 );
 const T& current (
 ) const;
 const T& element (
 ) const;
 T& element (
 );
 void remove_any (
 T& item
 );
 };
 template <
 typename queue_base
 >
 inline void swap (
 queue_kernel_c<queue_base>& a, 
 queue_kernel_c<queue_base>& b 
 ) { a.swap(b); }
// ----------------------------------------------------------------------------------------
// ----------------------------------------------------------------------------------------
 // member function definitions
// ----------------------------------------------------------------------------------------
// ----------------------------------------------------------------------------------------
 template <
 typename queue_base
 >
 void queue_kernel_c<queue_base>::
 dequeue (
 T& item
 )
 {
 // make sure requires clause is not broken
 DLIB_CASSERT(this->size() != 0,
 "\tvoid queue::dequeue"
 << "\n\tsize of queue should not be zero"
 << "\n\tthis: " << this
 );
 // call the real function
 queue_base::dequeue(item);
 }
// ----------------------------------------------------------------------------------------
 template <
 typename queue_base
 >
 const typename queue_base::type& queue_kernel_c<queue_base>::
 current (
 ) const
 {
 // make sure requires clause is not broken
 DLIB_CASSERT(this->size() != 0,
 "\tconst T& queue::current"
 << "\n\tsize of queue should not be zero"
 << "\n\tthis: " << this
 );
 // call the real function
 return queue_base::current();
 }
// ----------------------------------------------------------------------------------------
 template <
 typename queue_base
 >
 typename queue_base::type& queue_kernel_c<queue_base>::
 current (
 ) 
 {
 // make sure requires clause is not broken
 DLIB_CASSERT(this->size() != 0,
 "\tT& queue::current"
 << "\n\tsize of queue should not be zero"
 << "\n\tthis: " << this
 );
 // call the real function
 return queue_base::current();
 }
// ----------------------------------------------------------------------------------------
 template <
 typename queue_base
 >
 const typename queue_base::type& queue_kernel_c<queue_base>::
 element (
 ) const
 {
 // make sure requires clause is not broken
 DLIB_CASSERT(this->current_element_valid() == true,
 "\tconst T& queue::element"
 << "\n\tyou can't access the current element if it doesn't exist"
 << "\n\tthis: " << this
 );
 // call the real function
 return queue_base::element();
 }
// ----------------------------------------------------------------------------------------
 template <
 typename queue_base
 >
 typename queue_base::type& queue_kernel_c<queue_base>::
 element (
 ) 
 {
 // make sure requires clause is not broken
 DLIB_CASSERT(this->current_element_valid() == true,
 "\tT& queue::element"
 << "\n\tyou can't access the current element if it doesn't exist"
 << "\n\tthis: " << this
 );
 // call the real function
 return queue_base::element();
 }
// ----------------------------------------------------------------------------------------
 template <
 typename queue_base
 >
 void queue_kernel_c<queue_base>::
 remove_any (
 T& item
 ) 
 {
 // make sure requires clause is not broken
 DLIB_CASSERT( (this->size() > 0),
 "\tvoid queue::remove_any"
 << "\n\tsize() must be greater than zero if something is going to be removed"
 << "\n\tsize(): " << this->size() 
 << "\n\tthis: " << this
 );
 // call the real function
 queue_base::remove_any(item);
 }
// ----------------------------------------------------------------------------------------
}
#endif // DLIB_QUEUE_KERNEl_C_

AltStyle によって変換されたページ (->オリジナル) /