GUI: fixed a bug with sorting in the ThreadView (the currently active thread would change if you sorted)
This commit is contained in:
		
							parent
							
								
									0a54341512
								
							
						
					
					
						commit
						3dde12e3a6
					
				|  | @ -1,6 +1,7 @@ | ||||||
| #include "ThreadView.h" | #include "ThreadView.h" | ||||||
| #include "Configuration.h" | #include "Configuration.h" | ||||||
| #include "Bridge.h" | #include "Bridge.h" | ||||||
|  | #include "StringUtil.h" | ||||||
| 
 | 
 | ||||||
| void ThreadView::contextMenuSlot(const QPoint & pos) | void ThreadView::contextMenuSlot(const QPoint & pos) | ||||||
| { | { | ||||||
|  | @ -222,12 +223,12 @@ void ThreadView::updateThreadList() | ||||||
|         if(!threadList.list[i].BasicInfo.ThreadNumber) |         if(!threadList.list[i].BasicInfo.ThreadNumber) | ||||||
|             setCellContent(i, 0, "Main"); |             setCellContent(i, 0, "Main"); | ||||||
|         else |         else | ||||||
|             setCellContent(i, 0, QString("%1").arg(threadList.list[i].BasicInfo.ThreadNumber, 0, 10)); |             setCellContent(i, 0, ToDecString(threadList.list[i].BasicInfo.ThreadNumber)); | ||||||
|         setCellContent(i, 1, QString("%1").arg(threadList.list[i].BasicInfo.ThreadId, 0, 16).toUpper()); |         setCellContent(i, 1, ToHexString(threadList.list[i].BasicInfo.ThreadId)); | ||||||
|         setCellContent(i, 2, QString("%1").arg(threadList.list[i].BasicInfo.ThreadStartAddress, sizeof(dsint) * 2, 16, QChar('0')).toUpper()); |         setCellContent(i, 2, ToPtrString(threadList.list[i].BasicInfo.ThreadStartAddress)); | ||||||
|         setCellContent(i, 3, QString("%1").arg(threadList.list[i].BasicInfo.ThreadLocalBase, sizeof(dsint) * 2, 16, QChar('0')).toUpper()); |         setCellContent(i, 3, ToPtrString(threadList.list[i].BasicInfo.ThreadLocalBase)); | ||||||
|         setCellContent(i, 4, QString("%1").arg(threadList.list[i].ThreadCip, sizeof(dsint) * 2, 16, QChar('0')).toUpper()); |         setCellContent(i, 4, ToPtrString(threadList.list[i].ThreadCip)); | ||||||
|         setCellContent(i, 5, QString().sprintf("%d", threadList.list[i].SuspendCount)); |         setCellContent(i, 5, ToDecString(threadList.list[i].SuspendCount)); | ||||||
|         QString priorityString; |         QString priorityString; | ||||||
|         switch(threadList.list[i].Priority) |         switch(threadList.list[i].Priority) | ||||||
|         { |         { | ||||||
|  | @ -379,16 +380,22 @@ void ThreadView::updateThreadList() | ||||||
|         setCellContent(i, 8, QString("%1").arg(threadList.list[i].LastError, sizeof(unsigned int) * 2, 16, QChar('0')).toUpper()); |         setCellContent(i, 8, QString("%1").arg(threadList.list[i].LastError, sizeof(unsigned int) * 2, 16, QChar('0')).toUpper()); | ||||||
|         setCellContent(i, 9, threadList.list[i].BasicInfo.threadName); |         setCellContent(i, 9, threadList.list[i].BasicInfo.threadName); | ||||||
|     } |     } | ||||||
|  |     mCurrentThreadId = "NONE"; | ||||||
|     if(threadList.count) |     if(threadList.count) | ||||||
|  |     { | ||||||
|         BridgeFree(threadList.list); |         BridgeFree(threadList.list); | ||||||
|     mCurrentThread = threadList.CurrentThread; |         int currentThread = threadList.CurrentThread; | ||||||
|  |         if(currentThread >= 0 && currentThread < threadList.count) | ||||||
|  |             mCurrentThreadId = ToHexString(threadList.list[currentThread].BasicInfo.ThreadId); | ||||||
|  |     } | ||||||
|     reloadData(); |     reloadData(); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| QString ThreadView::paintContent(QPainter* painter, dsint rowBase, int rowOffset, int col, int x, int y, int w, int h) | QString ThreadView::paintContent(QPainter* painter, dsint rowBase, int rowOffset, int col, int x, int y, int w, int h) | ||||||
| { | { | ||||||
|     QString ret = StdTable::paintContent(painter, rowBase, rowOffset, col, x, y, w, h); |     QString ret = StdTable::paintContent(painter, rowBase, rowOffset, col, x, y, w, h); | ||||||
|     if(rowBase + rowOffset == mCurrentThread && !col) |     QString threadId = getCellContent(rowBase + rowOffset, 1); | ||||||
|  |     if(threadId == mCurrentThreadId && !col) | ||||||
|     { |     { | ||||||
|         painter->fillRect(QRect(x, y, w, h), QBrush(ConfigColor("ThreadCurrentBackgroundColor"))); |         painter->fillRect(QRect(x, y, w, h), QBrush(ConfigColor("ThreadCurrentBackgroundColor"))); | ||||||
|         painter->setPen(QPen(ConfigColor("ThreadCurrentColor"))); //white text
 |         painter->setPen(QPen(ConfigColor("ThreadCurrentColor"))); //white text
 | ||||||
|  |  | ||||||
|  | @ -33,7 +33,7 @@ signals: | ||||||
|     void showCpu(); |     void showCpu(); | ||||||
| 
 | 
 | ||||||
| private: | private: | ||||||
|     int mCurrentThread; |     QString mCurrentThreadId; | ||||||
|     QAction* mSwitchThread; |     QAction* mSwitchThread; | ||||||
|     QAction* mSuspendThread; |     QAction* mSuspendThread; | ||||||
|     QAction* mGoToThreadEntry; |     QAction* mGoToThreadEntry; | ||||||
|  |  | ||||||
|  | @ -24,14 +24,27 @@ static QString ToPtrString(duint Address) | ||||||
|     return QString(temp); |     return QString(temp); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| static QString ToHexString(duint Address) | static QString ToHexString(duint Value) | ||||||
| { | { | ||||||
|     char temp[32]; |     char temp[32]; | ||||||
| 
 | 
 | ||||||
| #ifdef _WIN64 | #ifdef _WIN64 | ||||||
|     sprintf_s(temp, "%llX", Address); |     sprintf_s(temp, "%llX", Value); | ||||||
| #else | #else | ||||||
|     sprintf_s(temp, "%X", Address); |     sprintf_s(temp, "%X", Value); | ||||||
|  | #endif // _WIN64
 | ||||||
|  | 
 | ||||||
|  |     return QString(temp); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | static QString ToDecString(dsint Value) | ||||||
|  | { | ||||||
|  |     char temp[32]; | ||||||
|  | 
 | ||||||
|  | #ifdef _WIN64 | ||||||
|  |     sprintf_s(temp, "%lld", Value); | ||||||
|  | #else | ||||||
|  |     sprintf_s(temp, "%d", Value); | ||||||
| #endif // _WIN64
 | #endif // _WIN64
 | ||||||
| 
 | 
 | ||||||
|     return QString(temp); |     return QString(temp); | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue