removing unsupported option m in cachetable
[csql.git] / include / Util.h
blobbd4ecf352e75dbd60233a4fc60afd0dcc5a18eab
1 /***************************************************************************
2 * Copyright (C) 2007 by Prabakaran Thirumalai *
3 * praba_tuty@yahoo.com *
4 * *
5 * This program is free software; you can redistribute it and/or modify *
6 * it under the terms of the GNU General Public License as published by *
7 * the Free Software Foundation; either version 2 of the License, or *
8 * (at your option) any later version. *
9 * *
10 * This program is distributed in the hope that it will be useful, *
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of *
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
13 * GNU General Public License for more details. *
14 * *
15 ***************************************************************************/
16 #ifndef UTIL_H
17 #define UTIL_H
18 #include<ErrorType.h>
19 #include<Debug.h>
20 class ListNode
22 public:
23 void *element;
24 ListNode *next;
28 class ListIterator
30 ListNode *iter;
31 ListNode *start;
32 ListIterator();
33 public:
35 ListIterator(ListNode *head) { iter = head; start = head; }
37 bool hasElement()
39 if (iter == NULL) return false; else return true;
42 void reset()
44 iter = start;
46 //isRemove ->the node needs to deleted after returning
47 void* nextElement(bool isRemove = false)
49 if (iter == NULL) return NULL;
50 ListNode *node = iter;
51 iter = iter ->next;
52 return node->element;
55 //index start with one, such that 1->first element in list
56 void* getElement(int index)
58 ListNode *localIter = start;
59 if (localIter == NULL) return NULL;
60 for (int i=0; i <index; i++) {
61 localIter = localIter->next;
62 if (localIter == NULL) break;
64 return localIter->element;
68 class Identifier
70 public:
71 char name[IDENTIFIER_LENGTH];
74 class List
76 ListNode *head;
77 int totalElements;
78 public:
79 List() { head = NULL; totalElements = 0;}
81 DbRetVal append(void *elem)
83 ListNode *newNode = new ListNode();
84 newNode->element = elem;
85 newNode->next = NULL;
86 totalElements++;
87 //If this is the first node, set it as head
88 if (NULL == head) { head = newNode; return OK; }
90 ListNode *iter = head;
91 while (NULL != iter->next) iter = iter->next;
92 iter->next = newNode;
93 return OK;
95 //Warning:Try to avoid using this method while using the iterator.The behavior
96 //is undefined. Instead set flag isRemove to yes and call nextElement of iterator.
97 DbRetVal remove(void *elem)
99 if (NULL == head)
101 printError(ErrNotExists, "There are no elements in the list. Empty list");
102 return ErrNotExists;
104 ListNode *iter = head, *prev = head;
105 while (iter != NULL)
107 if (elem == iter->element)
109 prev->next = iter->next;
110 delete iter;
111 totalElements--;
112 if (iter == head) { head = NULL; return OK;}
113 return OK;
115 prev = iter;
116 iter = iter->next;
118 printError(ErrNotFound, "There are no elements in the list");
119 return ErrNotFound;
122 //index start with one, such that 1->first element in list
123 void* get(int index)
125 ListNode *localIter = head;
126 if (localIter == NULL) return NULL;
127 for (int i=0; i <index -1; i++) {
128 localIter = localIter->next;
129 if (localIter == NULL) break;
131 return localIter->element;
135 bool exists(void *elem)
137 ListNode *iter = head;
138 while (iter != NULL)
140 if (elem == iter->element)
142 return true;
144 iter = iter->next;
146 return false;
149 ListIterator getIterator()
151 ListIterator iter(head);
152 return iter;
154 void reset()
156 if (NULL == head) return;
157 ListNode *iter = head, *prevIter = head;
158 while (iter->next != NULL)
160 prevIter = iter;
161 iter = iter->next;
162 delete prevIter;
165 delete iter;
166 head = NULL;
167 totalElements = 0;
168 return;
170 int size()
172 return totalElements;
176 class UniqueID
178 int startID;
179 Mutex mutex;
180 public:
181 UniqueID() { startID = 1; mutex.init(); }
182 int getID()
184 if (mutex.getLock(-1, false) != 0) return 0;
185 startID++;
186 mutex.releaseLock(-1, false);
187 return startID;
191 #endif