annotate TaskManager/kernel/ppe/QueueInfo.h @ 958:58ff7b6fdbce

add freeOnce()
author Shinji KONO <kono@ie.u-ryukyu.ac.jp>
date Wed, 04 Aug 2010 17:42:36 +0900
parents 15026ebf7a17
children 02f1a707ee82
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
801
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
1 #ifndef INCLUDED_QUEUE_INFO
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
2 #define INCLUDED_QUEUE_INFO
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
3
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
4 #include "base.h"
821
6e8f8eb1e407 queueInfoTest 90% done
game@zeus.cr.ie.u-ryukyu.ac.jp
parents: 820
diff changeset
5 #include "types.h"
801
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
6
818
19c6cdeb23d6 too few template-parameter-lists
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 801
diff changeset
7 #if 0
19c6cdeb23d6 too few template-parameter-lists
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 801
diff changeset
8 template <typename T> class Queue : T {
801
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
9 public:
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
10
818
19c6cdeb23d6 too few template-parameter-lists
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 801
diff changeset
11 T();
801
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
12
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
13 T *waiter;
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
14 T *next;
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
15 T *prev;
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
16
958
58ff7b6fdbce add freeOnce()
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 956
diff changeset
17 void initOnce(); // to initialize object in pool
58ff7b6fdbce add freeOnce()
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 956
diff changeset
18 void freeOnce(); // to destroy object in pool
58ff7b6fdbce add freeOnce()
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 956
diff changeset
19
818
19c6cdeb23d6 too few template-parameter-lists
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 801
diff changeset
20 // virual void init();
801
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
21 };
818
19c6cdeb23d6 too few template-parameter-lists
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 801
diff changeset
22 #endif
801
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
23
818
19c6cdeb23d6 too few template-parameter-lists
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 801
diff changeset
24 template <typename T> class QueueInfo : public T {
801
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
25
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
26 public:
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
27 /* constructor */
958
58ff7b6fdbce add freeOnce()
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 956
diff changeset
28
58ff7b6fdbce add freeOnce()
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 956
diff changeset
29 /**
58ff7b6fdbce add freeOnce()
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 956
diff changeset
30 singleton constructor
58ff7b6fdbce add freeOnce()
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 956
diff changeset
31 use this in non initialize envrionment is wrong.
58ff7b6fdbce add freeOnce()
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 956
diff changeset
32 */
821
6e8f8eb1e407 queueInfoTest 90% done
game@zeus.cr.ie.u-ryukyu.ac.jp
parents: 820
diff changeset
33 QueueInfo<T>(){
6e8f8eb1e407 queueInfoTest 90% done
game@zeus.cr.ie.u-ryukyu.ac.jp
parents: 820
diff changeset
34 queueInfoInit();
6e8f8eb1e407 queueInfoTest 90% done
game@zeus.cr.ie.u-ryukyu.ac.jp
parents: 820
diff changeset
35 }
958
58ff7b6fdbce add freeOnce()
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 956
diff changeset
36 /**
58ff7b6fdbce add freeOnce()
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 956
diff changeset
37 normal constructor requires
58ff7b6fdbce add freeOnce()
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 956
diff changeset
38 */
820
e6eea3a208cd give up singleton pattern.
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 818
diff changeset
39 QueueInfo<T>(QueueInfo<T> *p) {
821
6e8f8eb1e407 queueInfoTest 90% done
game@zeus.cr.ie.u-ryukyu.ac.jp
parents: 820
diff changeset
40 queueInfoInit();
820
e6eea3a208cd give up singleton pattern.
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 818
diff changeset
41 queuePool = p;
821
6e8f8eb1e407 queueInfoTest 90% done
game@zeus.cr.ie.u-ryukyu.ac.jp
parents: 820
diff changeset
42 queuePool->queuePool = queuePool;
820
e6eea3a208cd give up singleton pattern.
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 818
diff changeset
43 }
801
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
44
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
45 BASE_NEW_DELETE(QueueInfo);
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
46
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
47 /* functions */
818
19c6cdeb23d6 too few template-parameter-lists
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 801
diff changeset
48 T *create();
801
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
49
818
19c6cdeb23d6 too few template-parameter-lists
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 801
diff changeset
50 void free_(T *queue);
801
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
51
818
19c6cdeb23d6 too few template-parameter-lists
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 801
diff changeset
52 void addFirst(T* e);
19c6cdeb23d6 too few template-parameter-lists
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 801
diff changeset
53 void addLast(T* e);
19c6cdeb23d6 too few template-parameter-lists
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 801
diff changeset
54 T* getFirst();
19c6cdeb23d6 too few template-parameter-lists
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 801
diff changeset
55 T* getLast();
19c6cdeb23d6 too few template-parameter-lists
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 801
diff changeset
56 int remove(T* e);
19c6cdeb23d6 too few template-parameter-lists
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 801
diff changeset
57 T* poll();
19c6cdeb23d6 too few template-parameter-lists
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 801
diff changeset
58 void moveToFirst(T* e); // or use();
19c6cdeb23d6 too few template-parameter-lists
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 801
diff changeset
59 T* get(int index);
19c6cdeb23d6 too few template-parameter-lists
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 801
diff changeset
60 T* find(T *task);
801
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
61 int empty();
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
62 void freePool() ;
955
9989dd7b9ac2 unify all QueueInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 899
diff changeset
63 void freeAll();
801
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
64
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
65 // Iterator
818
19c6cdeb23d6 too few template-parameter-lists
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 801
diff changeset
66 T* getNext(T* q) ;
801
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
67 int length();
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
68
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
69 private:
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
70 /* variables */
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
71
958
58ff7b6fdbce add freeOnce()
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 956
diff changeset
72 /* we cannot use static in template */
820
e6eea3a208cd give up singleton pattern.
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 818
diff changeset
73 /* static */ QueueInfo<T> *queuePool;
818
19c6cdeb23d6 too few template-parameter-lists
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 801
diff changeset
74 T* first;
19c6cdeb23d6 too few template-parameter-lists
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 801
diff changeset
75 T* last;
801
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
76
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
77 /* functions */
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
78 int extend_pool(int num);
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
79 void destroy();
821
6e8f8eb1e407 queueInfoTest 90% done
game@zeus.cr.ie.u-ryukyu.ac.jp
parents: 820
diff changeset
80 void queueInfoInit();
899
586b4f825f24 minor fix..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 895
diff changeset
81 } ;
801
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
82
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
83
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
84
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
85 #ifdef CHECK
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
86 #include <stdio.h>
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
87 #endif
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
88 #include <stdlib.h>
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
89
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
90
958
58ff7b6fdbce add freeOnce()
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 956
diff changeset
91 /**
58ff7b6fdbce add freeOnce()
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 956
diff changeset
92 singleton constructor
58ff7b6fdbce add freeOnce()
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 956
diff changeset
93 all queueInfo should share this as a pool.
58ff7b6fdbce add freeOnce()
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 956
diff changeset
94
58ff7b6fdbce add freeOnce()
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 956
diff changeset
95 exteren QueueInfo<H> pool;
58ff7b6fdbce add freeOnce()
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 956
diff changeset
96 QueueInfo<H> pool = new QueueInfo<H>();
58ff7b6fdbce add freeOnce()
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 956
diff changeset
97
58ff7b6fdbce add freeOnce()
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 956
diff changeset
98 use this in non initialize envrionment is wrong.
58ff7b6fdbce add freeOnce()
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 956
diff changeset
99 */
801
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
100
821
6e8f8eb1e407 queueInfoTest 90% done
game@zeus.cr.ie.u-ryukyu.ac.jp
parents: 820
diff changeset
101 template<typename T>void QueueInfo<T>::queueInfoInit() {
801
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
102 // 最初の一つは自分
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
103 first = last = this;
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
104 this->next = this->prev = this;
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
105 this->waiter = NULL;
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
106 }
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
107
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
108 template<typename T>void
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
109 QueueInfo<T>::freePool() {
820
e6eea3a208cd give up singleton pattern.
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 818
diff changeset
110 for(T * p = queuePool->waiter; p; ) {
818
19c6cdeb23d6 too few template-parameter-lists
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 801
diff changeset
111 T * next = p->waiter;
801
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
112 p->waiter = NULL;
958
58ff7b6fdbce add freeOnce()
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 956
diff changeset
113 p->freeOnce();
801
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
114 free(p);
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
115 p = next;
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
116 }
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
117 }
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
118
958
58ff7b6fdbce add freeOnce()
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 956
diff changeset
119 /**
58ff7b6fdbce add freeOnce()
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 956
diff changeset
120 all pools are shared among QueueInfo (separated by size and type).
58ff7b6fdbce add freeOnce()
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 956
diff changeset
121 it automatically extended by 64.
58ff7b6fdbce add freeOnce()
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 956
diff changeset
122 */
801
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
123 template<typename T>int
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
124 QueueInfo<T>::extend_pool(int num)
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
125 {
821
6e8f8eb1e407 queueInfoTest 90% done
game@zeus.cr.ie.u-ryukyu.ac.jp
parents: 820
diff changeset
126 T* q = (T*)malloc(sizeof(T)*(num+1)+DEFAULT_ALIGNMENT);
801
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
127
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
128 // First Queue is previous pool
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
129 q->waiter = this->waiter; this->waiter = q;
821
6e8f8eb1e407 queueInfoTest 90% done
game@zeus.cr.ie.u-ryukyu.ac.jp
parents: 820
diff changeset
130 q = (T*)ROUND_UP_ALIGN((long)q, DEFAULT_ALIGNMENT);
801
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
131 q++;
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
132
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
133 /* Connect all free queue in the pool */
821
6e8f8eb1e407 queueInfoTest 90% done
game@zeus.cr.ie.u-ryukyu.ac.jp
parents: 820
diff changeset
134 T* p = q;
6e8f8eb1e407 queueInfoTest 90% done
game@zeus.cr.ie.u-ryukyu.ac.jp
parents: 820
diff changeset
135 for (; num-- > 0;) {
6e8f8eb1e407 queueInfoTest 90% done
game@zeus.cr.ie.u-ryukyu.ac.jp
parents: 820
diff changeset
136 p->waiter = NULL;
956
15026ebf7a17 unified queue worked on Mac OS X
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 955
diff changeset
137 p->initOnce();
821
6e8f8eb1e407 queueInfoTest 90% done
game@zeus.cr.ie.u-ryukyu.ac.jp
parents: 820
diff changeset
138 queuePool->addLast(p);
6e8f8eb1e407 queueInfoTest 90% done
game@zeus.cr.ie.u-ryukyu.ac.jp
parents: 820
diff changeset
139 p = (T*)ROUND_UP_ALIGN((long)(p+1),DEFAULT_ALIGNMENT);
801
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
140 }
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
141
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
142 return 0;
821
6e8f8eb1e407 queueInfoTest 90% done
game@zeus.cr.ie.u-ryukyu.ac.jp
parents: 820
diff changeset
143
801
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
144 }
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
145
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
146 /**
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
147 * Task をプールから取って来て返す
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
148 *
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
149 * @param [cmd] タスクコマンド
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
150 */
818
19c6cdeb23d6 too few template-parameter-lists
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 801
diff changeset
151 template<typename T>T *
801
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
152 QueueInfo<T>::create()
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
153 {
820
e6eea3a208cd give up singleton pattern.
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 818
diff changeset
154 T * q = queuePool->poll();
801
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
155 if (! q) {
820
e6eea3a208cd give up singleton pattern.
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 818
diff changeset
156 queuePool->extend_pool(64);
e6eea3a208cd give up singleton pattern.
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 818
diff changeset
157 q = queuePool->poll();
801
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
158 }
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
159 q->init();
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
160 return q;
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
161 }
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
162
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
163
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
164 template<typename T>void
818
19c6cdeb23d6 too few template-parameter-lists
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 801
diff changeset
165 QueueInfo<T>::free_(T * q)
801
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
166 {
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
167 q->waiter = NULL;
820
e6eea3a208cd give up singleton pattern.
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 818
diff changeset
168 queuePool->addLast(q);
801
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
169 }
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
170
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
171
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
172 /*!
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
173 QueueInfo<T> は空にならない。最低1個は要素が入っていて
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
174 1個目は特別扱いする。getFirst すると first->next を返す
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
175 */
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
176
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
177 /*!
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
178 最初の1個は特別扱いなので、それの後に追加していく
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
179 */
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
180 template<typename T>void
818
19c6cdeb23d6 too few template-parameter-lists
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 801
diff changeset
181 QueueInfo<T>::addFirst(T* e)
801
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
182 {
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
183 e->prev = first;
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
184 e->next = first->next;
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
185 first->next->prev = e;
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
186 first->next = e;
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
187 }
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
188
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
189 template<typename T>void
818
19c6cdeb23d6 too few template-parameter-lists
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 801
diff changeset
190 QueueInfo<T>::addLast(T* e)
801
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
191 {
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
192 #ifdef CHECK
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
193 if (find(e)) {
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
194 fprintf(stderr,"Add duplicate task %0x\n",(int)e);
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
195 return;
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
196 // ...
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
197 }
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
198 #endif
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
199 e->next = first;
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
200 e->prev = last;
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
201 last->next = e;
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
202 last = e;
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
203 }
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
204
818
19c6cdeb23d6 too few template-parameter-lists
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 801
diff changeset
205 template<typename T>T*
801
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
206 QueueInfo<T>::getFirst()
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
207 {
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
208 if (empty()) return NULL;
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
209 return first->next;
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
210 }
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
211
818
19c6cdeb23d6 too few template-parameter-lists
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 801
diff changeset
212 template<typename T>T*
801
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
213 QueueInfo<T>::getLast()
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
214 {
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
215 if (empty()) return NULL;
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
216 return last;
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
217 }
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
218
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
219 template<typename T>int
818
19c6cdeb23d6 too few template-parameter-lists
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 801
diff changeset
220 QueueInfo<T>::remove(T* e)
801
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
221 {
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
222 #ifdef CHECK
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
223 if (!find(e)) {
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
224 fprintf(stderr,"Remove non existing task %0x\n",(int)e);
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
225 return 0;
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
226 // ...
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
227 }
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
228 #endif
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
229 e->prev->next = e->next;
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
230 e->next->prev = e->prev;
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
231
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
232 if (first->next == e) {
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
233 first->next = e->next;
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
234 }
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
235 if (last == e) {
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
236 last = e->prev;
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
237 }
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
238
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
239 e->prev = NULL;
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
240 e->next = NULL;
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
241
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
242 return 1;
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
243 }
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
244
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
245 /*!
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
246 リストの先頭を取得および削除する。リストが空の場合は NULL を返す。
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
247 */
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
248
818
19c6cdeb23d6 too few template-parameter-lists
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 801
diff changeset
249 template<typename T>T*
801
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
250 QueueInfo<T>::poll()
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
251 {
818
19c6cdeb23d6 too few template-parameter-lists
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 801
diff changeset
252 T* e = first->next;
801
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
253 if (e == this) {
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
254 return NULL;
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
255 }
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
256 remove(e);
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
257 return e;
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
258 }
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
259
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
260 template<typename T>void
818
19c6cdeb23d6 too few template-parameter-lists
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 801
diff changeset
261 QueueInfo<T>::moveToFirst(T* e)
801
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
262 {
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
263 remove(e);
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
264 addFirst(e);
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
265 }
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
266
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
267 /*!
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
268 リスト内の指定された位置にある要素を返す。
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
269 要素数を超えた位置を指定した場合 NULL を返す。
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
270 */
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
271
818
19c6cdeb23d6 too few template-parameter-lists
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 801
diff changeset
272 template<typename T>T*
801
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
273 QueueInfo<T>::get(int index)
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
274 {
818
19c6cdeb23d6 too few template-parameter-lists
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 801
diff changeset
275 T* e = first->next;
801
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
276 for (int i = 0; i < index; i++) {
822
ba45c7b81d2a testQueueInfo 100% passed
game@zeus.cr.ie.u-ryukyu.ac.jp
parents: 821
diff changeset
277 if (e->next == this) return NULL;
801
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
278 e = e->next;
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
279 }
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
280 return e;
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
281 }
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
282
818
19c6cdeb23d6 too few template-parameter-lists
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 801
diff changeset
283 template<typename T>T*
19c6cdeb23d6 too few template-parameter-lists
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 801
diff changeset
284 QueueInfo<T>::find(T* task)
801
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
285 {
818
19c6cdeb23d6 too few template-parameter-lists
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 801
diff changeset
286 T* e = first->next;
801
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
287 for(;;) {
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
288 if (e == this) return NULL;
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
289 if (e == task) break;
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
290 e = e->next;
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
291 }
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
292 return e;
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
293 }
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
294
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
295 template<typename T>int
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
296 QueueInfo<T>::empty()
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
297 {
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
298 return this->next == this;
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
299 }
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
300
818
19c6cdeb23d6 too few template-parameter-lists
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 801
diff changeset
301 template<typename T>T*
19c6cdeb23d6 too few template-parameter-lists
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 801
diff changeset
302 QueueInfo<T>::getNext(T* q)
801
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
303 {
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
304 if (q->next==this) return NULL;
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
305 return q->next;
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
306 }
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
307
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
308 template<typename T>int
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
309 QueueInfo<T>::length()
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
310 {
822
ba45c7b81d2a testQueueInfo 100% passed
game@zeus.cr.ie.u-ryukyu.ac.jp
parents: 821
diff changeset
311 int i = 0;
801
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
312 if (empty()) return 0;
818
19c6cdeb23d6 too few template-parameter-lists
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 801
diff changeset
313 T* e = first;
801
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
314 while((e = e->next) != this ) i++;
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
315 return i;
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
316 }
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
317
955
9989dd7b9ac2 unify all QueueInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 899
diff changeset
318 template<typename T>void
9989dd7b9ac2 unify all QueueInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 899
diff changeset
319 QueueInfo<T>::freeAll()
9989dd7b9ac2 unify all QueueInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 899
diff changeset
320 {
9989dd7b9ac2 unify all QueueInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 899
diff changeset
321 T* t;
9989dd7b9ac2 unify all QueueInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 899
diff changeset
322 while((t=poll())) free_(t);
9989dd7b9ac2 unify all QueueInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 899
diff changeset
323 }
801
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
324
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
325
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
326
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
327 /* end */
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
328
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
329
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
330
974cd68383b3 TaslListInfo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
331 #endif