51
|
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 |
{
|
53
|
218 |
|
|
219 |
RArray<CMemSpyApiThreadInfoItem*> threadInfoItems;
|
|
220 |
iMemSpySession.GetThreadInfoItems( threadInfoItems, iThreadId, iType ); // TODO don't ignore error!
|
|
221 |
CleanupClosePushL( threadInfoItems );
|
51
|
222 |
|
53
|
223 |
CDesCArrayFlat* model = new (ELeave) CDesC16ArrayFlat( threadInfoItems.Count() + 10 );
|
|
224 |
CleanupStack::PushL( model );
|
|
225 |
|
|
226 |
for( TInt i=0; i<threadInfoItems.Count(); i++)
|
51
|
227 |
{
|
53
|
228 |
HBufC* combined = HBufC::NewLC( threadInfoItems[i]->Caption().Length() + threadInfoItems[i]->Value().Length() + 30 );
|
51
|
229 |
|
|
230 |
TPtr pCombined( combined->Des() );
|
|
231 |
pCombined.Zero();
|
|
232 |
pCombined.Copy( _L("\t") );
|
53
|
233 |
if( threadInfoItems[i]->Caption() != KNullDesC )
|
|
234 |
pCombined.Append( threadInfoItems[i]->Caption() );
|
51
|
235 |
if( iType != EMemSpyThreadInfoItemTypeChunk )
|
|
236 |
{
|
|
237 |
pCombined.Append( _L("\t\t") );
|
53
|
238 |
pCombined.Append( threadInfoItems[i]->Value() );
|
51
|
239 |
}
|
|
240 |
|
53
|
241 |
model->AppendL( pCombined );
|
51
|
242 |
|
53
|
243 |
CleanupStack::PopAndDestroy( combined );
|
51
|
244 |
}
|
|
245 |
|
|
246 |
CAknSettingStyleListBox* listbox = static_cast< CAknSettingStyleListBox* >( iListBox );
|
|
247 |
//listbox->Model()->SetItemTextArray( iInfoItem );
|
53
|
248 |
listbox->Model()->SetItemTextArray( model );
|
51
|
249 |
listbox->Model()->SetOwnershipType( ELbmDoesNotOwnItemArray );
|
53
|
250 |
|
|
251 |
CleanupStack::Pop( model );
|
|
252 |
CleanupStack::PopAndDestroy( &threadInfoItems );
|
51
|
253 |
}
|
|
254 |
|
|
255 |
|
|
256 |
void CMemSpyViewThreadInfoItemGeneric::HandleListBoxItemActionedL( TInt /*aIndex*/ )
|
|
257 |
{
|
|
258 |
// Notify observer about an item being 'fired'
|
|
259 |
ReportEventL( MMemSpyViewObserver::EEventItemActioned );
|
|
260 |
}
|
|
261 |
|
|
262 |
|
|
263 |
void CMemSpyViewThreadInfoItemGeneric::HandleListBoxItemSelectedL( TInt /*aIndex*/ )
|
|
264 |
{
|
|
265 |
// Notify observer about item selection
|
|
266 |
ReportEventL( MMemSpyViewObserver::EEventItemSelected );
|
|
267 |
}
|
|
268 |
|
|
269 |
|
|
270 |
|
|
271 |
void CMemSpyViewThreadInfoItemGeneric::ShowWaitNoteL()
|
|
272 |
{
|
|
273 |
// Ugly, but I'm not adding an observer mechanism just for this wait dialog.
|
|
274 |
// __ASSERT_ALWAYS( iWaitConstructionChecker == NULL, User::Invariant() );
|
|
275 |
iWaitConstructionChecker = CPeriodic::NewL( CActive::EPriorityLow );
|
|
276 |
iWaitConstructionChecker->Start( KMemSpyConstructionCheckerTimerPeriod,
|
|
277 |
KMemSpyConstructionCheckerTimerPeriod,
|
|
278 |
TCallBack( CheckForItemConstructionComplete, this ) );
|
|
279 |
|
|
280 |
if ( !iWaitNote )
|
|
281 |
{
|
|
282 |
iWaitNote = new ( ELeave ) CAknWaitDialog( reinterpret_cast<CEikDialog**> ( &iWaitNote ), ETrue );
|
|
283 |
iWaitNote->ExecuteDlgLD( CAknNoteDialog::ENoTone, R_MEMSPY_PREPARING_INFO_ITEM_CONTAINER_WAIT_NOTE );
|
|
284 |
}
|
|
285 |
}
|
|
286 |
|
|
287 |
|
|
288 |
void CMemSpyViewThreadInfoItemGeneric::DestroyWaitNote()
|
|
289 |
{
|
|
290 |
#ifdef _DEBUG
|
|
291 |
RDebug::Printf( "CMemSpyViewThreadInfoItemGeneric::DestroyWaitNote() - START" );
|
|
292 |
#endif
|
|
293 |
//
|
|
294 |
delete iWaitConstructionChecker;
|
|
295 |
iWaitConstructionChecker = NULL;
|
|
296 |
//
|
|
297 |
if ( iWaitNote )
|
|
298 |
{
|
|
299 |
TRAP_IGNORE( iWaitNote->ProcessFinishedL() ); // deletes the dialog
|
|
300 |
iWaitNote = NULL;
|
|
301 |
}
|
|
302 |
//
|
|
303 |
#ifdef _DEBUG
|
|
304 |
RDebug::Printf( "CMemSpyViewThreadInfoItemGeneric::DestroyWaitNote() - END" );
|
|
305 |
#endif
|
|
306 |
}
|
|
307 |
|
|
308 |
|
|
309 |
TInt CMemSpyViewThreadInfoItemGeneric::CheckForItemConstructionComplete( TAny* aSelf )
|
|
310 |
{
|
|
311 |
/*
|
|
312 |
CMemSpyViewThreadInfoItemGeneric& self = *reinterpret_cast< CMemSpyViewThreadInfoItemGeneric* >( aSelf );
|
|
313 |
*/
|
|
314 |
//
|
|
315 |
#ifdef _DEBUG
|
|
316 |
/* RDebug::Printf( "CMemSpyViewThreadInfoItemGeneric::CheckForItemConstructionComplete() - ready status: %d, iType: %d", self.iInfoItem->IsReady(), self.iInfoItem->Type() );*/
|
|
317 |
#endif
|
|
318 |
//
|
|
319 |
/*
|
|
320 |
TBool callAgain = ETrue;
|
|
321 |
if ( self.iInfoItem->IsReady() )
|
|
322 |
{
|
|
323 |
self.DestroyWaitNote();
|
|
324 |
callAgain = EFalse;
|
|
325 |
}
|
|
326 |
//
|
|
327 |
return callAgain;
|
|
328 |
*/
|
|
329 |
}
|
|
330 |
|
|
331 |
|
|
332 |
|
|
333 |
|
|
334 |
|