00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026
00027
00028
00029
00030
00031
00032
00037 #include "timerentry.h"
00038
00043 CTimerEntry* CTimerEntry::NewL(CConsoleBase* aConsole)
00044 {
00045 CTimerEntry* self = new (ELeave) CTimerEntry(aConsole);
00046 CleanupStack::PushL(self);
00047 self->ConstructL();
00048 CleanupStack::Pop(self);
00049 return self;
00050 }
00051
00055 void CTimerEntry::ConstructL()
00056 {
00057
00058 CTimer::ConstructL();
00059
00060 CActiveScheduler::Add(this);
00061 }
00062
00067 CTimerEntry::CTimerEntry(CConsoleBase* aConsole):
00068
00069 CTimer(CActive::EPriorityStandard),
00070
00071 iIterator(iQueue),
00072
00073 iCount(-1),
00074
00075
00076 iOp(EInsert),
00077 iConsole(aConsole),
00078 iWaitFlag(ETrue)
00079 {
00080 }
00081
00085 void CTimerEntry::RunL()
00086 {
00087
00088 ArbitratorL();
00089
00090 PrintQue();
00091
00092 IssueRequest();
00093 }
00094
00095
00099 void CTimerEntry::IssueRequest()
00100 {
00101
00102
00103 TUint waitTime = KWaitTime;
00104 if (iWaitFlag)
00105 {
00106 waitTime = Math::Random() % KMaxTimeToWait;
00107
00108 waitTime++;
00109 }
00110 CTimer::After((waitTime) * 1000000);
00111 }
00112
00118 void CTimerEntry::ArbitratorL()
00119 {
00120
00121
00122 if(iOp == EInsert)
00123 {
00124
00125 TInt tc = (TInt)User::TickCount();
00126
00127 TBool redo = AddToQueueL(tc);
00128
00129 if(!redo)
00130 {
00131 _LIT(KTextQueFull,"Queue is full!\n");
00132 iConsole->Printf(KTextQueFull);
00133
00134
00135
00136
00137 iWaitFlag = EFalse;
00138 }
00139 }
00140
00141
00142 else
00143 {
00144
00145 TBool redo = RemoveFromQueue();
00146
00147 if(!redo)
00148 {
00149 _LIT(KTextQueEmpty,"Queue is empty!\n");
00150 iConsole->Printf(KTextQueEmpty);
00151
00152
00153
00154
00155 iWaitFlag = ETrue;
00156 }
00157 }
00158 }
00159
00165 TBool CTimerEntry::AddToQueueL(TInt aTicks)
00166 {
00167
00168 if(iCount >= (KMaxEntry - 1))
00169 {
00170 iOp = ERemove;
00171 return EFalse;
00172 }
00173
00174
00175 _LIT(KTextAddTick,"Added %d to the queue\n");
00176 iConsole->Printf(KTextAddTick,aTicks);
00177 iCount++;
00178
00179 TTimerEntry* ptr = new (ELeave) TTimerEntry;
00180 iQueue.Add(*ptr,aTicks);
00181
00182 return ETrue;
00183 }
00184
00188 void CTimerEntry::PrintQue()
00189 {
00190 _LIT(KTextCont,"Contents of the List:\n***\nINDEX\tDELTA\n");
00191 iConsole->Printf(KTextCont);
00192
00193 iIterator.SetToFirst();
00194
00195 TTimerEntry *ptr = iIterator++;
00196
00197 TInt ix = 0;
00198 while (ptr != NULL)
00199 {
00200 _LIT(KTextFormat,"%d\t\t%d\n");
00201 iConsole->Printf(KTextFormat,ix,ptr->iLink.iDelta);
00202 ptr = iIterator++;
00203 ix++;
00204 }
00205 _LIT(KTextEnd,"***\n");
00206 iConsole->Printf(KTextEnd);
00207 }
00208
00213 TBool CTimerEntry::RemoveFromQueue()
00214 {
00215
00216 if(iCount < 0)
00217 {
00218 iOp = EInsert;
00219 return EFalse;
00220 }
00221
00222 iIterator.SetToFirst();
00223
00224
00225 TInt pos = 0;
00226
00227
00228 if(iCount > 0)
00229 {
00230 pos = Math::Random() % iCount;
00231 }
00232
00233
00234
00235 for(TInt ix = 1; ix <= pos; ix++)
00236 {
00237 iIterator++;
00238 }
00239
00240 TTimerEntry* ptr = iIterator;
00241
00242 _LIT(KTextRemove,"Removed an element from the queue. Index: %d\n");
00243 iConsole->Printf(KTextRemove,pos);
00244
00245
00246 iQueue.Remove(*ptr);
00247 delete ptr;
00248
00249 iCount--;
00250
00251 return ETrue;
00252 }
00253
00259 CTimerEntry::~CTimerEntry()
00260 {
00261
00262 Cancel();
00263
00264 if(iIterator)
00265 {
00266 iIterator.SetToFirst();
00267
00268 TTimerEntry *ptr = iIterator++;
00269 while (ptr != NULL)
00270 {
00271 delete ptr;
00272 ptr = iIterator++;
00273 }
00274 }
00275 }
00276
00280 void CTimerEntry::DoCancel()
00281 {
00282
00283 CTimer::DoCancel();
00284 }
00285