// --- ---------- -----------------------------------------------------------\r
// JPM 12/07/2017 Created this file\r
// JPM 09/14/2018 Added a status bar, better status report and set information values in a tab\r
-// JPM 10/05/2018 Added a sorting filter \r
+// JPM April/2019 Added a sorting filter, tableview unique rows creation\r
//\r
\r
// STILL TO DO:\r
// Better presentation\r
// To set the information display at the right\r
+// To understand/fix the problem with the sorting filter\r
+// Display arrays information\r
+// Display structures information\r
//\r
\r
+//#define AW_SORTINGFILTER // Authorise the sorting filtes\r
//#define AW_DEBUGNUMVARIABLE 4415 // Set the global variable number to debug\r
#ifndef AW_DEBUGNUMVARIABLE\r
#define AW_STARTNUMVARIABLE 0 // Must be kept to 0 in case of no debug is required\r
// \r
AllWatchBrowserWindow::AllWatchBrowserWindow(QWidget * parent/*= 0*/) : QWidget(parent, Qt::Dialog),\r
layout(new QVBoxLayout),\r
+symbol(new QLineEdit),\r
+search(new QPushButton(tr("Search"))),\r
#ifdef AW_LAYOUTTEXTS\r
text(new QTextBrowser),\r
#else\r
model(new QStandardItemModel),\r
#endif\r
NbWatch(0),\r
+CurrentWatch(0),\r
statusbar(new QStatusBar),\r
PtrWatchInfo(NULL)\r
{\r
setWindowTitle(tr("All Watch"));\r
\r
- // Set the font\r
+ // set the font\r
QFont fixedFont("Lucida Console", 8, QFont::Normal);\r
fixedFont.setStyleHint(QFont::TypeWriter);\r
\r
layout->addWidget(TableView);\r
#endif\r
\r
- // Status bar\r
+ // search bar\r
+ QHBoxLayout * hbox1 = new QHBoxLayout;\r
+ symbol->setPlaceholderText("symbol name");\r
+ hbox1->addWidget(symbol);\r
+ hbox1->addWidget(search);\r
+ layout->addLayout(hbox1);\r
+\r
+ // status bar\r
layout->addWidget(statusbar);\r
setLayout(layout);\r
+\r
+ // connect slot\r
+ connect(search, SIGNAL(clicked()), this, SLOT(SearchSymbol()));\r
+ connect(symbol, SIGNAL(cursorPositionChanged(int, int)), this, SLOT(SelectSearchSymbol()));\r
}\r
\r
\r
}\r
\r
\r
+// Search the symbol in the watch list\r
+void AllWatchBrowserWindow::SearchSymbol(void)
+{
+ bool found = false;
+ size_t i;
+
+ // user cannot enter symbol to allow the search
+ symbol->setDisabled(true);
+
+ // look for the symbol in the watch list
+ for (i = AW_STARTNUMVARIABLE; (i < NbWatch) && !found; i++)\r
+ {\r
+ // check symbol presence\r
+ if (!symbol->text().compare(PtrWatchInfo[i].PtrVariableName, Qt::CaseSensitive))\r
+ {\r
+ found = true;\r
+ }\r
+ }\r
+\r
+ if (found)\r
+ {\r
+ // remove previous highlight\r
+ if (CurrentWatch)\r
+ {\r
+ model->item((int)(CurrentWatch - 1), 0)->setBackground(QColor(255, 255, 255));\r
+ model->item((int)(CurrentWatch - 1), 1)->setBackground(QColor(255, 255, 255));\r
+ model->item((int)(CurrentWatch - 1), 2)->setBackground(QColor(255, 255, 255));\r
+ }\r
+ // Get the slider maximum position\r
+ int MaxSlider = TableView->verticalScrollBar()->maximum(); \r
+ // Number of items displayed in the scroll bar slider\r
+ int DeltaSlider = (int)NbWatch - MaxSlider;\r
+ // set the scroll bar\r
+ TableView->verticalScrollBar()->setSliderPosition((int)i - (DeltaSlider / 2) - 1);\r
+ // highlight watch symbol\r
+ CurrentWatch = i;\r
+ model->item((int)(CurrentWatch - 1), 0)->setBackground(QColor(0xff, 0xfa, 0xcd));\r
+ model->item((int)(CurrentWatch - 1), 1)->setBackground(QColor(0xff, 0xfa, 0xcd));\r
+ model->item((int)(CurrentWatch - 1), 2)->setBackground(QColor(0xff, 0xfa, 0xcd));\r
+ // allow new symbol\r
+ symbol->setText("");\r
+ }\r
+ else\r
+ {\r
+ // invalid symbol\r
+ symbol->setStyleSheet("color: red");\r
+ }\r
+
+ // user can enter a symbol
+ symbol->setEnabled(true);
+ symbol->setFocus();
+}
+
+
+//
+void AllWatchBrowserWindow::SelectSearchSymbol(void)\r
+{\r
+ symbol->setStyleSheet("color: black");\r
+}\r
+\r
+\r
//\r
void AllWatchBrowserWindow::Reset(void)\r
{\r
if (NbWatch = DBGManager_GetNbGlobalVariables())\r
{\r
PtrWatchInfo = (WatchInfo *)calloc(NbWatch, sizeof(WatchInfo));\r
-\r
+#ifndef AW_LAYOUTTEXTS\r
+#ifdef AW_SORTINGFILTER\r
+ TableView->setSortingEnabled(false);\r
+#endif\r
+ model->setRowCount(0);\r
+#endif\r
for (uint32_t i = AW_STARTNUMVARIABLE; i < NbWatch; i++)\r
{\r
PtrWatchInfo[i].PtrVariableName = DBGManager_GetGlobalVariableName(i + 1);\r
}\r
#else\r
PtrWatchInfo[i].PtrVariableBaseTypeName = DBGManager_GetGlobalVariableTypeName(i + 1);\r
+ model->insertRow(i);\r
#endif\r
}\r
}\r
}\r
-#ifndef AW_LAYOUTTEXTS\r
- TableView->setSortingEnabled(false);\r
- model->setRowCount(0);\r
-#endif\r
+\r
if (NbWatch)\r
{\r
for (uint32_t i = AW_STARTNUMVARIABLE; i < NbWatch; i++)\r
sprintf(string, "%i : %s | %s | 0x%06X | %s", (i + 1), PtrWatchInfo[i].PtrVariableBaseTypeName, PtrWatchInfo[i].PtrVariableName, (unsigned int)PtrWatchInfo[i].addr, PtrValue ? PtrValue : (char *)"<font color='#ff0000'>N/A</font>");\r
WatchAll += QString(string);\r
#else\r
- model->insertRow(i);\r
model->setItem(i, 0, new QStandardItem(QString("%1").arg(PtrWatchInfo[i].PtrVariableName)));\r
model->setItem(i, 1, new QStandardItem(QString("%1").arg(PtrValue)));\r
model->setItem(i, 2, new QStandardItem(QString("%1").arg(PtrWatchInfo[i].PtrVariableBaseTypeName)));\r
text->clear();\r
text->setText(WatchAll);\r
#else\r
+#ifdef AW_SORTINGFILTER\r
TableView->setSortingEnabled(true);\r
+#endif\r
#endif\r
sprintf(msg, "Ready");\r
}\r
}\r
\r
\r
-// \r
+// Handle keyboard event\r
void AllWatchBrowserWindow::keyPressEvent(QKeyEvent * e)\r
{\r
+ // ESC to close / hide the window\r
if (e->key() == Qt::Key_Escape)\r
{\r
hide();\r
}\r
+ else\r
+ {\r
+ // select the \r
+ if (e->key() == Qt::Key_Return)\r
+ {\r
+ SearchSymbol();\r
+ }\r
+ }\r
}\r
\r