1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
|
/***************************************************************************
begin : Tue Oct 5 1999
copyright : (C) 1999 by John Birch
email : [email protected]
***************************************************************************/
/***************************************************************************
* *
* This program is free software; you can redistribute it and/or modify *
* it under the terms of the GNU General Public License as published by *
* the Free Software Foundation; either version 2 of the License, or *
* (at your option) any later version. *
* *
***************************************************************************/
#ifndef _MEMVIEW_H_
#define _MEMVIEW_H_
#include "mi/gdbmi.h"
#include <kdialog.h>
#include <qvaluevector.h>
class KLineEdit;
class QMultiLineEdit;
class QToolBox;
namespace GDBDebugger
{
class MemoryView;
class GDBController;
class ViewerWidget : public QWidget
{
Q_OBJECT
public:
ViewerWidget(GDBController* controller,
QWidget* parent, const char* name);
public slots:
/** Adds a new memory view to *this, initially showing
no data. */
void slotAddMemoryView();
/** Informs *this about change in debugger state. Should always
be connected to, so that *this can disable itself when
debugger is not running. */
void slotDebuggerState(const QString&, int state);
signals:
void setViewShown(bool shown);
private slots:
void slotChildCaptionChanged(const QString& caption);
void slotChildDestroyed(QObject* child);
private: // Data
GDBController* controller_;
QToolBox* toolBox_;
QValueVector<MemoryView*> memoryViews_;
};
class MemoryView : public QWidget
{
Q_OBJECT
public:
MemoryView(GDBController* controller,
QWidget* parent, const char* name = 0);
void debuggerStateChanged(int state);
signals:
void captionChanged(const QString& caption);
private: // Callbacks
void sizeComputed(const QString& value);
void memoryRead(const GDBMI::ResultRecord& r);
private slots:
void memoryEdited(int start, int end);
private:
// Returns true is we successfully created the hexeditor, and so
// can work.
bool isOk() const;
private slots:
/** Invoked when user has changed memory range.
Gets memory for the new range. */
void slotChangeMemoryRange();
void slotHideRangeDialog();
void slotEnableOrDisable();
private: // QWidget overrides
void contextMenuEvent(QContextMenuEvent* e);
private:
void initWidget();
private:
GDBController* controller_;
class MemoryRangeSelector* rangeSelector_;
QWidget* khexedit2_widget;
QWidget* khexedit2_real_widget;
uint start_, amount_;
QString startAsString_, amountAsString_;
char* data_;
int debuggerState_;
};
}
#endif
|