|
1 /* |
|
2 * Copyright (c) 2009 Nokia Corporation and/or its subsidiary(-ies). |
|
3 * All rights reserved. |
|
4 * This component and the accompanying materials are made available |
|
5 * under the terms of "Eclipse Public License v1.0" |
|
6 * which accompanies this distribution, and is available |
|
7 * at the URL "http://www.eclipse.org/legal/epl-v10.html". |
|
8 * |
|
9 * Initial Contributors: |
|
10 * Nokia Corporation - initial contribution. |
|
11 * |
|
12 * Contributors: |
|
13 * |
|
14 * Description: |
|
15 * |
|
16 */ |
|
17 |
|
18 #include "MemSpyViewThreadInfoItemGeneric.h" |
|
19 |
|
20 // System includes |
|
21 #include <AknWaitDialog.h> |
|
22 #include <memspyui.rsg> |
|
23 |
|
24 // Engine includes |
|
25 #include <memspy/engine/memspyengine.h> |
|
26 #include <memspy/engine/memspyengineobjectprocess.h> |
|
27 #include <memspy/engine/memspyengineobjectthread.h> |
|
28 #include <memspy/engine/memspyengineobjectcontainer.h> |
|
29 #include <memspy/engine/memspyengineobjectthreadinfoobjects.h> |
|
30 #include <memspy/engine/memspyengineobjectthreadinfocontainer.h> |
|
31 #include <memspy/engine/memspyenginehelperprocess.h> |
|
32 #include <memspysession.h> |
|
33 |
|
34 // User includes |
|
35 #include "MemSpyContainerObserver.h" |
|
36 #include "MemSpyViewThreadInfoItemList.h" |
|
37 #include "MemSpyUiUtils.h" |
|
38 |
|
39 // Constants |
|
40 const TInt KMemSpyConstructionCheckerTimerPeriod = 500000; // 1/2 second |
|
41 |
|
42 CMemSpyViewThreadInfoItemGeneric::CMemSpyViewThreadInfoItemGeneric( RMemSpySession& aSession, MMemSpyViewObserver& aObserver, TProcessId aProcessId, TThreadId aId, TMemSpyThreadInfoItemType aType ) |
|
43 : CMemSpyViewBase( aSession, aObserver )//, iThreadId( aId ), iType( aType ) //iContainer( aInfoContainer ) |
|
44 { |
|
45 iParentProcessId = aProcessId; |
|
46 iThreadId = aId; |
|
47 iType = aType; |
|
48 } |
|
49 |
|
50 |
|
51 CMemSpyViewThreadInfoItemGeneric::~CMemSpyViewThreadInfoItemGeneric() |
|
52 {/* TODO: |
|
53 if ( iInfoItem ) |
|
54 { |
|
55 iInfoItem->Close(); |
|
56 } |
|
57 DestroyWaitNote(); |
|
58 */ |
|
59 } |
|
60 |
|
61 |
|
62 void CMemSpyViewThreadInfoItemGeneric::ConstructL( const TRect& aRect, CCoeControl& aContainer, TAny* aSelectionRune ) |
|
63 { |
|
64 const TPtrC pTitle( MemSpyUiUtils::ThreadInfoItemNameByType( iType ) ); |
|
65 SetTitleL( pTitle ); |
|
66 |
|
67 CMemSpyViewBase::ConstructL( aRect, aContainer, aSelectionRune ); |
|
68 } |
|
69 |
|
70 |
|
71 CMemSpyProcess& CMemSpyViewThreadInfoItemGeneric::Process() const |
|
72 { |
|
73 // return iContainer.Thread().Process(); |
|
74 } |
|
75 |
|
76 |
|
77 CMemSpyThread& CMemSpyViewThreadInfoItemGeneric::Thread() const |
|
78 { |
|
79 // return iContainer.Thread(); |
|
80 } |
|
81 |
|
82 |
|
83 CMemSpyThreadInfoContainer& CMemSpyViewThreadInfoItemGeneric::Container() const |
|
84 { |
|
85 // return iContainer; |
|
86 } |
|
87 |
|
88 |
|
89 CMemSpyThreadInfoItemBase& CMemSpyViewThreadInfoItemGeneric::InfoItem() const |
|
90 { |
|
91 // __ASSERT_ALWAYS( iInfoItem != NULL, User::Invariant() ); |
|
92 // return *iInfoItem; |
|
93 } |
|
94 |
|
95 |
|
96 void CMemSpyViewThreadInfoItemGeneric::RefreshL() |
|
97 { |
|
98 // iInfoItem->RebuildL(); //TODO |
|
99 SetListBoxModelL(); |
|
100 CMemSpyViewBase::RefreshL(); |
|
101 } |
|
102 |
|
103 |
|
104 TMemSpyViewType CMemSpyViewThreadInfoItemGeneric::ViewType() const |
|
105 { |
|
106 TMemSpyViewType type = EMemSpyViewTypeNone; |
|
107 // |
|
108 //switch( iInfoItem->Type() ) |
|
109 switch( iType ) |
|
110 { |
|
111 case EMemSpyThreadInfoItemTypeHeap: |
|
112 type = EMemSpyViewTypeThreadInfoItemHeap; |
|
113 break; |
|
114 case EMemSpyThreadInfoItemTypeStack: |
|
115 type = EMemSpyViewTypeThreadInfoItemStack; |
|
116 break; |
|
117 case EMemSpyThreadInfoItemTypeChunk: |
|
118 type = EMemSpyViewTypeThreadInfoItemChunk; |
|
119 break; |
|
120 case EMemSpyThreadInfoItemTypeCodeSeg: |
|
121 type = EMemSpyViewTypeThreadInfoItemCodeSeg; |
|
122 break; |
|
123 case EMemSpyThreadInfoItemTypeServer: |
|
124 type = EMemSpyViewTypeThreadInfoItemServer; |
|
125 break; |
|
126 case EMemSpyThreadInfoItemTypeSession: |
|
127 type = EMemSpyViewTypeThreadInfoItemSession; |
|
128 break; |
|
129 case EMemSpyThreadInfoItemTypeSemaphore: |
|
130 type = EMemSpyViewTypeThreadInfoItemSemaphore; |
|
131 break; |
|
132 case EMemSpyThreadInfoItemTypeMutex: |
|
133 type = EMemSpyViewTypeThreadInfoItemMutex; |
|
134 break; |
|
135 case EMemSpyThreadInfoItemTypeTimer: |
|
136 type = EMemSpyViewTypeThreadInfoItemTimer; |
|
137 break; |
|
138 case EMemSpyThreadInfoItemTypeLDD: |
|
139 type = EMemSpyViewTypeThreadInfoItemLDD; |
|
140 break; |
|
141 case EMemSpyThreadInfoItemTypePDD: |
|
142 type = EMemSpyViewTypeThreadInfoItemPDD; |
|
143 break; |
|
144 case EMemSpyThreadInfoItemTypeLogicalChannel: |
|
145 type = EMemSpyViewTypeThreadInfoItemLogicalChannel; |
|
146 break; |
|
147 case EMemSpyThreadInfoItemTypeChangeNotifier: |
|
148 type = EMemSpyViewTypeThreadInfoItemChangeNotifier; |
|
149 break; |
|
150 case EMemSpyThreadInfoItemTypeUndertaker: |
|
151 type = EMemSpyViewTypeThreadInfoItemUndertaker; |
|
152 break; |
|
153 case EMemSpyThreadInfoItemTypeMessageQueue: |
|
154 type = EMemSpyViewTypeThreadInfoItemMessageQueue; |
|
155 break; |
|
156 case EMemSpyThreadInfoItemTypeConditionalVariable: |
|
157 type = EMemSpyViewTypeThreadInfoItemConditionalVariable; |
|
158 break; |
|
159 case EMemSpyThreadInfoItemTypeOpenFiles: |
|
160 type = EMemSpyViewTypeThreadInfoItemOpenFiles; |
|
161 break; |
|
162 case EMemSpyThreadInfoItemTypeActiveObject: |
|
163 type = EMemSpyViewTypeThreadInfoItemActiveObject; |
|
164 break; |
|
165 case EMemSpyThreadInfoItemTypeGeneralInfo: |
|
166 type = EMemSpyViewTypeThreadInfoItemGeneralInfo; |
|
167 break; |
|
168 case EMemSpyThreadInfoItemTypeOtherThreads: |
|
169 type = EMemSpyViewTypeThreadInfoItemOtherThreads; |
|
170 break; |
|
171 case EMemSpyThreadInfoItemTypeOtherProcesses: |
|
172 type = EMemSpyViewTypeThreadInfoItemOtherProcesses; |
|
173 break; |
|
174 case EMemSpyThreadInfoItemTypeOwnedThreadHandles: |
|
175 type = EMemSpyViewTypeThreadInfoItemOwnedThreadHandles; |
|
176 break; |
|
177 case EMemSpyThreadInfoItemTypeOwnedProcessHandles: |
|
178 type = EMemSpyViewTypeThreadInfoItemOwnedProcessHandles; |
|
179 break; |
|
180 |
|
181 default: |
|
182 //__ASSERT_DEBUG( EFalse, User::Invariant() ); |
|
183 break; |
|
184 } |
|
185 // |
|
186 return type; |
|
187 } |
|
188 |
|
189 |
|
190 CMemSpyViewBase* CMemSpyViewThreadInfoItemGeneric::PrepareParentViewL() |
|
191 { |
|
192 CMemSpyViewThreadInfoItemList* parent = new(ELeave) CMemSpyViewThreadInfoItemList( iMemSpySession, iObserver, iParentProcessId, iThreadId ); |
|
193 CleanupStack::PushL( parent ); |
|
194 parent->ConstructL( Rect(), *Parent(), iType ); |
|
195 CleanupStack::Pop( parent ); |
|
196 return parent; |
|
197 } |
|
198 |
|
199 |
|
200 CMemSpyViewBase* CMemSpyViewThreadInfoItemGeneric::PrepareChildViewL() |
|
201 { |
|
202 //__ASSERT_ALWAYS( iInfoItem != NULL, User::Invariant() ); |
|
203 CMemSpyViewBase* child = NULL; |
|
204 // |
|
205 return child; |
|
206 } |
|
207 |
|
208 |
|
209 TBool CMemSpyViewThreadInfoItemGeneric::HandleCommandL( TInt aCommand ) |
|
210 { |
|
211 TBool handled = CMemSpyViewBase::HandleCommandL( aCommand ); |
|
212 return handled; |
|
213 } |
|
214 |
|
215 |
|
216 void CMemSpyViewThreadInfoItemGeneric::SetListBoxModelL() |
|
217 { |
|
218 iMemSpySession.GetThreadInfoItems( iThreadInfoItems, iThreadId, iType ); // TODO don't ignore error! |
|
219 |
|
220 iModel = new (ELeave) CDesC16ArrayFlat( iThreadInfoItems.Count() + 10 ); |
|
221 |
|
222 for( TInt i=0; i<iThreadInfoItems.Count(); i++) |
|
223 { |
|
224 HBufC* combined = HBufC::NewLC( iThreadInfoItems[i]->Caption().Length() + iThreadInfoItems[i]->Value().Length() + 30 ); |
|
225 |
|
226 TPtr pCombined( combined->Des() ); |
|
227 pCombined.Zero(); |
|
228 pCombined.Copy( _L("\t") ); |
|
229 if( iThreadInfoItems[i]->Caption() != KNullDesC ) |
|
230 pCombined.Append( iThreadInfoItems[i]->Caption() ); |
|
231 if( iType != EMemSpyThreadInfoItemTypeChunk ) |
|
232 { |
|
233 pCombined.Append( _L("\t\t") ); |
|
234 pCombined.Append( iThreadInfoItems[i]->Value() ); |
|
235 } |
|
236 |
|
237 iModel->AppendL( pCombined ); |
|
238 |
|
239 CleanupStack::PopAndDestroy(combined); |
|
240 } |
|
241 |
|
242 CAknSettingStyleListBox* listbox = static_cast< CAknSettingStyleListBox* >( iListBox ); |
|
243 //listbox->Model()->SetItemTextArray( iInfoItem ); |
|
244 listbox->Model()->SetItemTextArray( iModel ); |
|
245 listbox->Model()->SetOwnershipType( ELbmDoesNotOwnItemArray ); |
|
246 } |
|
247 |
|
248 |
|
249 void CMemSpyViewThreadInfoItemGeneric::HandleListBoxItemActionedL( TInt /*aIndex*/ ) |
|
250 { |
|
251 // Notify observer about an item being 'fired' |
|
252 ReportEventL( MMemSpyViewObserver::EEventItemActioned ); |
|
253 } |
|
254 |
|
255 |
|
256 void CMemSpyViewThreadInfoItemGeneric::HandleListBoxItemSelectedL( TInt /*aIndex*/ ) |
|
257 { |
|
258 // Notify observer about item selection |
|
259 ReportEventL( MMemSpyViewObserver::EEventItemSelected ); |
|
260 } |
|
261 |
|
262 |
|
263 |
|
264 void CMemSpyViewThreadInfoItemGeneric::ShowWaitNoteL() |
|
265 { |
|
266 // Ugly, but I'm not adding an observer mechanism just for this wait dialog. |
|
267 // __ASSERT_ALWAYS( iWaitConstructionChecker == NULL, User::Invariant() ); |
|
268 iWaitConstructionChecker = CPeriodic::NewL( CActive::EPriorityLow ); |
|
269 iWaitConstructionChecker->Start( KMemSpyConstructionCheckerTimerPeriod, |
|
270 KMemSpyConstructionCheckerTimerPeriod, |
|
271 TCallBack( CheckForItemConstructionComplete, this ) ); |
|
272 |
|
273 if ( !iWaitNote ) |
|
274 { |
|
275 iWaitNote = new ( ELeave ) CAknWaitDialog( reinterpret_cast<CEikDialog**> ( &iWaitNote ), ETrue ); |
|
276 iWaitNote->ExecuteDlgLD( CAknNoteDialog::ENoTone, R_MEMSPY_PREPARING_INFO_ITEM_CONTAINER_WAIT_NOTE ); |
|
277 } |
|
278 } |
|
279 |
|
280 |
|
281 void CMemSpyViewThreadInfoItemGeneric::DestroyWaitNote() |
|
282 { |
|
283 #ifdef _DEBUG |
|
284 RDebug::Printf( "CMemSpyViewThreadInfoItemGeneric::DestroyWaitNote() - START" ); |
|
285 #endif |
|
286 // |
|
287 delete iWaitConstructionChecker; |
|
288 iWaitConstructionChecker = NULL; |
|
289 // |
|
290 if ( iWaitNote ) |
|
291 { |
|
292 TRAP_IGNORE( iWaitNote->ProcessFinishedL() ); // deletes the dialog |
|
293 iWaitNote = NULL; |
|
294 } |
|
295 // |
|
296 #ifdef _DEBUG |
|
297 RDebug::Printf( "CMemSpyViewThreadInfoItemGeneric::DestroyWaitNote() - END" ); |
|
298 #endif |
|
299 } |
|
300 |
|
301 |
|
302 TInt CMemSpyViewThreadInfoItemGeneric::CheckForItemConstructionComplete( TAny* aSelf ) |
|
303 { |
|
304 /* |
|
305 CMemSpyViewThreadInfoItemGeneric& self = *reinterpret_cast< CMemSpyViewThreadInfoItemGeneric* >( aSelf ); |
|
306 */ |
|
307 // |
|
308 #ifdef _DEBUG |
|
309 /* RDebug::Printf( "CMemSpyViewThreadInfoItemGeneric::CheckForItemConstructionComplete() - ready status: %d, iType: %d", self.iInfoItem->IsReady(), self.iInfoItem->Type() );*/ |
|
310 #endif |
|
311 // |
|
312 /* |
|
313 TBool callAgain = ETrue; |
|
314 if ( self.iInfoItem->IsReady() ) |
|
315 { |
|
316 self.DestroyWaitNote(); |
|
317 callAgain = EFalse; |
|
318 } |
|
319 // |
|
320 return callAgain; |
|
321 */ |
|
322 } |
|
323 |
|
324 |
|
325 |
|
326 |
|
327 |