HPCToolkit
HashTableSortedIterator.cpp
Go to the documentation of this file.
1 // -*-Mode: C++;-*-
2 
3 // * BeginRiceCopyright *****************************************************
4 //
5 // $HeadURL$
6 // $Id$
7 //
8 // --------------------------------------------------------------------------
9 // Part of HPCToolkit (hpctoolkit.org)
10 //
11 // Information about sources of support for research and development of
12 // HPCToolkit is at 'hpctoolkit.org' and in 'README.Acknowledgments'.
13 // --------------------------------------------------------------------------
14 //
15 // Copyright ((c)) 2002-2019, Rice University
16 // All rights reserved.
17 //
18 // Redistribution and use in source and binary forms, with or without
19 // modification, are permitted provided that the following conditions are
20 // met:
21 //
22 // * Redistributions of source code must retain the above copyright
23 // notice, this list of conditions and the following disclaimer.
24 //
25 // * Redistributions in binary form must reproduce the above copyright
26 // notice, this list of conditions and the following disclaimer in the
27 // documentation and/or other materials provided with the distribution.
28 //
29 // * Neither the name of Rice University (RICE) nor the names of its
30 // contributors may be used to endorse or promote products derived from
31 // this software without specific prior written permission.
32 //
33 // This software is provided by RICE and contributors "as is" and any
34 // express or implied warranties, including, but not limited to, the
35 // implied warranties of merchantability and fitness for a particular
36 // purpose are disclaimed. In no event shall RICE or contributors be
37 // liable for any direct, indirect, incidental, special, exemplary, or
38 // consequential damages (including, but not limited to, procurement of
39 // substitute goods or services; loss of use, data, or profits; or
40 // business interruption) however caused and on any theory of liability,
41 // whether in contract, strict liability, or tort (including negligence
42 // or otherwise) arising in any way out of the use of this software, even
43 // if advised of the possibility of such damage.
44 //
45 // ******************************************************* EndRiceCopyright *
46 
47 /******************************************************************************
48  * *
49  * File: C++ Hash Table Sorted Iterator Utility *
50  * Author: Kevin Cureton *
51  * Date: March 1993 *
52  * *
53  * See the include file HashTable.h for an explanation of the *
54  * data and functions in the HashTable class. *
55  * *
56  * Programming Environment Project *
57  * *
58  *****************************************************************************/
59 
60 //************************** System Include Files ***************************
61 
62 #include <iostream>
63 
64 //*************************** User Include Files ****************************
65 
66 //*************************** Forward Declarations **************************
67 
68 //***************************************************************************
69 
70 #include "HashTable.hpp"
71 #include "QuickSort.hpp"
72 
73 /*************** HashTableSortedIterator public member functions *************/
74 
75 //
76 //
78  EntryCompareFunctPtr const _EntryCompare)
79 {
80  sortedEntries = (void **) NULL;
81  hashTable = (HashTable*) theHashTable;
82  EntryCompare = _EntryCompare;
83 
85 
86  return;
87 }
88 
89 //
90 //
92 {
93  if (sortedEntries) delete [] sortedEntries;
94 
95  return;
96 }
97 
98 //
99 //
101 {
103  return;
104 }
105 
107 {
109 }
110 
111 //
112 //
114 {
116  {
117  if (sortedEntries) return (void*)sortedEntries[currentEntryNumber];
118  else return (void*)NULL;
119  }
120  else
121  {
122  return (void*)NULL;
123  }
124 }
125 
126 //
127 //
129 {
130  HashTableIterator anIterator(hashTable);
131  QuickSort localQuickSort;
132 
133  currentEntryNumber = 0;
134 
135  if (sortedEntries) delete [] sortedEntries;
136 
138 
139  sortedEntries = new void* [numberOfSortedEntries];
140 
141  for (int i = 0; i < numberOfSortedEntries; i++, anIterator++)
142  {
143  sortedEntries[i] = anIterator.Current();
144  }
145 
146  localQuickSort.Create(sortedEntries, EntryCompare);
147  localQuickSort.Sort(0, numberOfSortedEntries-1);
148  localQuickSort.Destroy();
149 
150  return;
151 }
152 
153 
int(* EntryCompareFunctPtr)(const void *, const void *)
Definition: HashTable.hpp:300
HashTableSortedIterator(const HashTable *theHashTable, EntryCompareFunctPtr const _EntryCompare)
void Sort(const int minEntryIndex, const int maxEntryIndex)
Definition: QuickSort.cpp:133
void Destroy()
Definition: QuickSort.cpp:86
void * Current() const
Definition: HashTable.cpp:932
uint NumberOfEntries() const
Definition: HashTable.cpp:460
void Create(void **UserArrayPtr, const EntryCompareFunctPtr _CompareFunct)
Definition: QuickSort.cpp:76
#define NULL
Definition: ElfHelper.cpp:85