File: PriorityQueue_Impl.h

package info (click to toggle)
libassa 3.5.0-1
  • links: PTS, VCS
  • area: main
  • in suites: lenny
  • size: 3,084 kB
  • ctags: 2,323
  • sloc: cpp: 15,641; sh: 8,704; makefile: 372; perl: 51
file content (83 lines) | stat: -rw-r--r-- 2,462 bytes parent folder | download | duplicates (9)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
// -*- c++ -*-
//------------------------------------------------------------------------------
//                        PriorityQueue_Impl.h
//------------------------------------------------------------------------------
//  Copyright (C) 1997-2002  Vladislav Grinchenko 
//
//  This library is free software; you can redistribute it and/or
//  modify it under the terms of the GNU Library General Public
//  License as published by the Free Software Foundation; either
//  version 2 of the License, or (at your option) any later version.
//------------------------------------------------------------------------------
//  Created: 09/17/1999
//------------------------------------------------------------------------------

#ifndef PRIORITY_QUEUE_IMPL_H
#define PRIORITY_QUEUE_IMPL_H

namespace ASSA {

/** @file PriorityQueue_Impl.h 
	Interface class that defines Implementor of the Bridge pattern.
*/

// less<> is borrowed from STL implementation.

/** @struct Bfunc
	Bfunc is used by PriorityQueue_impl.
*/
template <class Arg1, class Arg2, class Result>
struct Bfunc {
	typedef Arg1   first_argument_type;
	typedef Arg2   second_argument_type;
	typedef Result result_type;
};
 

/** @struct Less
	Less is  borrowed from STL implementation.
*/
template <class T>
struct Less : public Bfunc<T, T, bool> {
	bool operator()(const T& x, const T& y) const { return x < y; }
};


/** Class PriorityQueue_Impl.

    Interface class that defines Implementor of the Bridge pattern.
    Derived classes provide concrete implementations of PriorityQueue.
*/

template< class T, class Compare >
class PriorityQueue_Impl
{
public:
	virtual ~PriorityQueue_Impl ();

	virtual void     insert (const T&) =0;
	virtual T        pop () =0;
	virtual const T& top () const =0;
	virtual bool     remove (T) =0;
	virtual size_t   size () =0;
	virtual T&       operator[] (int) =0;
};

template<class T, class Compare>
inline
PriorityQueue_Impl<T, Compare>::
~PriorityQueue_Impl () 
{ 
	// Here is the twist: we must provide a definition for the virtual
	// destructor. We need the definition here because the way virtual 
	// destructors work. Most derived class's destructor is called first,
	// then the destructor of each base class is called. That means that
	// the compiler will generate a call to ~PriorityQueue_Impl, even
	// though the class is abstract - that's why we need body here.
	
	/* no-op */ 
}

} // end namespace ASSA

#endif /* PRIORITY_QUEUE_IMPL_H */