My Project
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Groups Pages
sortdict.h
Go to the documentation of this file.
1 /******************************************************************************
2  *
3  *
4  *
5  *
6  * Copyright (C) 1997-2015 by Dimitri van Heesch.
7  *
8  * Permission to use, copy, modify, and distribute this software and its
9  * documentation under the terms of the GNU General Public License is hereby
10  * granted. No representations are made about the suitability of this software
11  * for any purpose. It is provided "as is" without express or implied warranty.
12  * See the GNU General Public License for more details.
13  *
14  * Documents produced by Doxygen are derivative works derived from the
15  * input used in their production; they are not affected by this license.
16  *
17  */
18 
19 #ifndef _SORTDICT_H
20 #define _SORTDICT_H
21 
22 #include <qlist.h>
23 #include <qdict.h>
24 #include <qintdict.h>
25 
26 #define AUTORESIZE 1
27 
28 #if AUTORESIZE
29 const uint SDict_primes[] =
30 {
31  17,
32  29,
33  47,
34  71,
35  113,
36  179,
37  293,
38  457,
39  733,
40  1171,
41  1871,
42  2999,
43  4787,
44  7669,
45  12251,
46  19603,
47  31379,
48  50177,
49  80287,
50  128449,
51  205519,
52  328829,
53  526139,
54  841801,
55  1346881,
56  2155007,
57  3448033,
58  5516827,
59  8826919,
60  14123059,
61  23538433,
62  39230771,
63  65384537,
64  108974231,
65  181623707,
66  302706181,
67  504510283,
68  840850487,
69  0xffffffff
70 };
71 #endif
72 
73 template<class T> class SDict;
74 template<class T> class SIntDict;
75 
79 template<class T>
80 class SList : public QList<T>
81 {
82  public:
83  SList(SDict<T> *owner) : m_owner(owner) {}
84  virtual ~SList() {}
85  int compareValues(const T *item1,const T *item2) const
86  {
87  return m_owner->compareValues(item1,item2);
88  }
89  private:
91 };
92 
96 template<class T>
97 class SDict
98 {
99  private:
101  QDict<T> *m_dict;
103 
104  public:
111  SDict(int size=17,bool caseSensitive=TRUE) : m_sizeIndex(0)
112  {
113  m_list = new SList<T>(this);
114 #if AUTORESIZE
115  while ((uint)size>SDict_primes[m_sizeIndex]) m_sizeIndex++;
116  m_dict = new QDict<T>(SDict_primes[m_sizeIndex],caseSensitive);
117 #else
118  m_dict = new QDict<T>(size,caseSensitive);
119 #endif
120  }
121 
123  virtual ~SDict()
124  {
125  delete m_list;
126  delete m_dict;
127  }
128 
135  void append(const char *key,const T *d)
136  {
137  m_list->append(d);
138  m_dict->insert(key,d);
139 #if AUTORESIZE
140  if (m_dict->size()>SDict_primes[m_sizeIndex])
141  {
142  m_dict->resize(SDict_primes[++m_sizeIndex]);
143  }
144 #endif
145  }
146 
153  void prepend(const char *key,const T *d)
154  {
155  m_list->prepend(d);
156  m_dict->insert(key,d);
157 #if AUTORESIZE
158  if (m_dict->size()>SDict_primes[m_sizeIndex])
159  {
160  m_dict->resize(SDict_primes[++m_sizeIndex]);
161  }
162 #endif
163  }
164 
166  bool remove(const char *key)
167  {
168  T *item = m_dict->take(key);
169  return item ? m_list->remove(item) : FALSE;
170  }
171 
173  T *take(const char *key)
174  {
175  T *item = m_dict->take(key);
176  if (item)
177  {
178  int i = m_list->find(item);
179  m_list->take(i);
180  }
181  return item;
182  }
183 
188  void sort()
189  {
190  m_list->sort();
191  }
197  void inSort(const char *key,const T *d)
198  {
199  m_list->inSort(d);
200  m_dict->insert(key,d);
201 #if AUTORESIZE
202  if (m_dict->size()>SDict_primes[m_sizeIndex])
203  {
204  m_dict->resize(SDict_primes[++m_sizeIndex]);
205  }
206 #endif
207  }
208 
209  void insertAt(int i,const char *key,const T *d)
210  {
211  m_list->insert(i,d);
212  m_dict->insert(key,d);
213 #if AUTORESIZE
214  if (m_dict->size()>SDict_primes[m_sizeIndex])
215  {
216  m_dict->resize(SDict_primes[++m_sizeIndex]);
217  }
218 #endif
219  }
220 
222  void setAutoDelete(bool val)
223  {
224  m_list->setAutoDelete(val);
225  }
226 
232  T *find(const char *key)
233  {
234  return m_dict->find(key);
235  }
236  T *find(const QCString &key)
237  {
238  return m_dict->find(key);
239  }
240  T *find(const QString &key)
241  {
242  return m_dict->find(key);
243  }
244  int findAt(const QCString &key)
245  {
246  T *item = find(key);
247  if (item==0) return -1;
248  return m_list->find(item);
249  }
250 
252  T *operator[](const char *key) const
253  {
254  return m_dict->find(key);
255  }
256 
258  T *at(uint i)
259  {
260  return m_list->at(i);
261  }
262 
267  virtual int compareValues(const T *item1,const T *item2) const
268  {
269  return item1!=item2;
270  }
271 
276  void clear()
277  {
278  m_list->clear();
279  m_dict->clear();
280  }
281 
284  int count() const
285  {
286  return m_list->count();
287  }
288 
289  class Iterator; // first forward declare
290  friend class Iterator; // then make it a friend
294  class Iterator
295  {
296  public:
298  Iterator(const SDict<T> &dict)
299  {
300  m_li = new QListIterator<T>(*dict.m_list);
301  }
302 
304  virtual ~Iterator()
305  {
306  delete m_li;
307  }
308 
312  T *toFirst() const
313  {
314  return m_li->toFirst();
315  }
316 
320  T *toLast() const
321  {
322  return m_li->toLast();
323  }
324 
326  T *current() const
327  {
328  return m_li->current();
329  }
330 
336  {
337  return m_li->operator++();
338  }
339 
345  {
346  return m_li->operator--();
347  }
348 
349  private:
350  QListIterator<T> *m_li;
351  };
352 
353  class IteratorDict; // first forward declare
354  friend class IteratorDict; // then make it a friend
359  {
360  public:
362  IteratorDict(const SDict<T> &dict)
363  {
364  m_di = new QDictIterator<T>(*dict.m_dict);
365  }
366 
368  virtual ~IteratorDict()
369  {
370  delete m_di;
371  }
372 
376  T *toFirst() const
377  {
378  return m_di->toFirst();
379  }
380 
384  T *toLast() const
385  {
386  return m_di->toLast();
387  }
388 
390  T *current() const
391  {
392  return m_di->current();
393  }
394 
396  QCString currentKey() const
397  {
398  return m_di->currentKey();
399  }
400 
406  {
407  return m_di->operator++();
408  }
409 
415  {
416  return m_di->operator--();
417  }
418 
419  private:
420  QDictIterator<T> *m_di;
421  };
422 };
423 
427 template<class T>
428 class SIntList : public QList<T>
429 {
430  public:
431  SIntList(SIntDict<T> *owner) : m_owner(owner) {}
432  virtual ~SIntList() {}
433  private:
434  int compareValues(const T *item1,const T *item2) const
435  {
436  return m_owner->compareValues(item1,item2);
437  }
439 };
440 
444 template<class T>
445 class SIntDict
446 {
447  private:
449  QIntDict<T> *m_dict;
451 
452  public:
457  SIntDict(int size=17) : m_sizeIndex(0)
458  {
459  m_list = new SIntList<T>(this);
460 #if AUTORESIZE
461  while ((uint)size>SDict_primes[m_sizeIndex]) m_sizeIndex++;
462  m_dict = new QIntDict<T>(SDict_primes[m_sizeIndex]);
463 #else
464  m_dict = new QIntDict<T>(size);
465 #endif
466  }
467 
469  virtual ~SIntDict()
470  {
471  delete m_list;
472  delete m_dict;
473  }
474 
481  void append(int key,const T *d)
482  {
483  m_list->append(d);
484  m_dict->insert(key,d);
485 #if AUTORESIZE
486  if (m_dict->size()>SDict_primes[m_sizeIndex])
487  {
488  m_dict->resize(SDict_primes[++m_sizeIndex]);
489  }
490 #endif
491  }
492 
499  void prepend(int key,const T *d)
500  {
501  m_list->prepend(d);
502  m_dict->insert(key,d);
503 #if AUTORESIZE
504  if (m_dict->size()>SDict_primes[m_sizeIndex])
505  {
506  m_dict->resize(SDict_primes[++m_sizeIndex]);
507  }
508 #endif
509  }
510 
512  bool remove(int key)
513  {
514  T *item = m_dict->take(key);
515  return item ? m_list->remove(item) : FALSE;
516  }
517 
522  void sort()
523  {
524  m_list->sort();
525  }
526 
532  void inSort(int key,const T *d)
533  {
534  m_list->inSort(d);
535  m_dict->insert(key,d);
536 #if AUTORESIZE
537  if (m_dict->size()>SDict_primes[m_sizeIndex])
538  {
539  m_dict->resize(SDict_primes[++m_sizeIndex]);
540  }
541 #endif
542  }
543 
545  void setAutoDelete(bool val)
546  {
547  m_list->setAutoDelete(val);
548  }
549 
555  T *find(int key)
556  {
557  return m_dict->find(key);
558  }
559 
561  T *operator[](int key) const
562  {
563  return m_dict->find(key);
564  }
565 
567  T *at(uint i)
568  {
569  return m_list->at(i);
570  }
571 
576  virtual int compareValues(const T *item1,const T *item2) const
577  {
578  return item1!=item2;
579  }
580 
585  void clear()
586  {
587  m_list->clear();
588  m_dict->clear();
589  }
590 
593  int count()
594  {
595  return m_list->count();
596  }
597 
598  class Iterator; // first forward declare
599  friend class Iterator; // then make it a friend
603  class Iterator
604  {
605  public:
607  Iterator(const SIntDict<T> &dict)
608  {
609  m_li = new QListIterator<T>(*dict.m_list);
610  }
611 
613  virtual ~Iterator()
614  {
615  delete m_li;
616  }
617 
621  T *toFirst() const
622  {
623  return m_li->toFirst();
624  }
625 
629  T *toLast() const
630  {
631  return m_li->toLast();
632  }
633 
635  T *current() const
636  {
637  return m_li->current();
638  }
639 
645  {
646  return m_li->operator++();
647  }
648 
654  {
655  return m_li->operator--();
656  }
657 
658  private:
659  QListIterator<T> *m_li;
660  };
661 
662  class IteratorDict; // first forward declare
663  friend class IteratorDict; // then make it a friend
668  {
669  public:
672  {
673  m_di = new QIntDictIterator<T>(*dict.m_dict);
674  }
675 
677  virtual ~IteratorDict()
678  {
679  delete m_di;
680  }
681 
685  T *toFirst() const
686  {
687  return m_di->toFirst();
688  }
689 
693  T *toLast() const
694  {
695  return m_di->toLast();
696  }
697 
699  T *current() const
700  {
701  return m_di->current();
702  }
703 
705  int currentKey() const
706  {
707  return m_di->currentKey();
708  }
709 
715  {
716  return m_di->operator++();
717  }
718 
724  {
725  return m_di->operator--();
726  }
727 
728  private:
729  QDictIterator<T> *m_di;
730  };
731 
732 };
733 
734 #endif