mirror of https://github.com/buggins/dlangide.git
debugger improvements
This commit is contained in:
parent
b8b44a79e7
commit
611c2f2cb7
|
@ -212,6 +212,8 @@
|
||||||
<Compile Include="src\dlangide\ui\outputpanel.d" />
|
<Compile Include="src\dlangide\ui\outputpanel.d" />
|
||||||
<Compile Include="src\dlangide\ui\searchPanel.d" />
|
<Compile Include="src\dlangide\ui\searchPanel.d" />
|
||||||
<Compile Include="src\dlangide\ui\settings.d" />
|
<Compile Include="src\dlangide\ui\settings.d" />
|
||||||
|
<Compile Include="src\dlangide\ui\stackpanel.d" />
|
||||||
|
<Compile Include="src\dlangide\ui\watchpanel.d" />
|
||||||
<Compile Include="src\dlangide\ui\wspanel.d" />
|
<Compile Include="src\dlangide\ui\wspanel.d" />
|
||||||
<Compile Include="src\dlangide\ui\newfile.d" />
|
<Compile Include="src\dlangide\ui\newfile.d" />
|
||||||
<Compile Include="src\dlangide\workspace\project.d" />
|
<Compile Include="src\dlangide\workspace\project.d" />
|
||||||
|
|
|
@ -121,6 +121,8 @@
|
||||||
<Compile Include="src\dlangide\ui\outputpanel.d" />
|
<Compile Include="src\dlangide\ui\outputpanel.d" />
|
||||||
<Compile Include="src\dlangide\ui\searchPanel.d" />
|
<Compile Include="src\dlangide\ui\searchPanel.d" />
|
||||||
<Compile Include="src\dlangide\ui\settings.d" />
|
<Compile Include="src\dlangide\ui\settings.d" />
|
||||||
|
<Compile Include="src\dlangide\ui\stackpanel.d" />
|
||||||
|
<Compile Include="src\dlangide\ui\watchpanel.d" />
|
||||||
<Compile Include="src\dlangide\ui\wspanel.d" />
|
<Compile Include="src\dlangide\ui\wspanel.d" />
|
||||||
<Compile Include="src\dlangide\tools\editortool.d" />
|
<Compile Include="src\dlangide\tools\editortool.d" />
|
||||||
<Compile Include="src\dlangide\tools\d\dcdinterface.d" />
|
<Compile Include="src\dlangide\tools\d\dcdinterface.d" />
|
||||||
|
|
|
@ -462,6 +462,8 @@
|
||||||
<File path="src\dlangide\ui\outputpanel.d" />
|
<File path="src\dlangide\ui\outputpanel.d" />
|
||||||
<File path="src\dlangide\ui\searchPanel.d" />
|
<File path="src\dlangide\ui\searchPanel.d" />
|
||||||
<File path="src\dlangide\ui\settings.d" />
|
<File path="src\dlangide\ui\settings.d" />
|
||||||
|
<File path="src\dlangide\ui\stackpanel.d" />
|
||||||
|
<File path="src\dlangide\ui\watchpanel.d" />
|
||||||
<File path="src\dlangide\ui\wspanel.d" />
|
<File path="src\dlangide\ui\wspanel.d" />
|
||||||
</Folder>
|
</Folder>
|
||||||
<Folder name="workspace">
|
<Folder name="workspace">
|
||||||
|
|
2
dub.json
2
dub.json
|
@ -14,7 +14,7 @@
|
||||||
"copyFiles-windows": ["lib/win32/dcd-server.exe", "lib/win32/dcd-client.exe"],
|
"copyFiles-windows": ["lib/win32/dcd-server.exe", "lib/win32/dcd-client.exe"],
|
||||||
|
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"dlangui": "~>0.7.21",
|
"dlangui": "~>0.7.22",
|
||||||
"libdparse": "==0.2.0"
|
"libdparse": "==0.2.0"
|
||||||
},
|
},
|
||||||
|
|
||||||
|
|
|
@ -4,6 +4,8 @@ import core.thread;
|
||||||
import dlangui.core.logger;
|
import dlangui.core.logger;
|
||||||
import ddebug.common.queue;
|
import ddebug.common.queue;
|
||||||
import ddebug.common.execution;
|
import ddebug.common.execution;
|
||||||
|
import std.array : empty;
|
||||||
|
import std.algorithm : startsWith, endsWith, equal;
|
||||||
|
|
||||||
enum DebuggingState {
|
enum DebuggingState {
|
||||||
loaded,
|
loaded,
|
||||||
|
@ -29,6 +31,16 @@ class LocationBase {
|
||||||
class DebugLocation : LocationBase {
|
class DebugLocation : LocationBase {
|
||||||
ulong address;
|
ulong address;
|
||||||
string func;
|
string func;
|
||||||
|
void fillMissingFields(LocationBase v) {
|
||||||
|
if (file.empty)
|
||||||
|
file = v.file;
|
||||||
|
if (fullFilePath.empty)
|
||||||
|
fullFilePath = v.fullFilePath;
|
||||||
|
if (projectFilePath.empty)
|
||||||
|
projectFilePath = v.projectFilePath;
|
||||||
|
if (!line)
|
||||||
|
line = v.line;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
class Breakpoint : LocationBase {
|
class Breakpoint : LocationBase {
|
||||||
|
@ -272,8 +284,8 @@ abstract class DebuggerBase : Thread, Debugger {
|
||||||
}
|
}
|
||||||
|
|
||||||
~this() {
|
~this() {
|
||||||
stop();
|
//stop();
|
||||||
destroy(_queue);
|
//destroy(_queue);
|
||||||
_queue = null;
|
_queue = null;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -9,7 +9,7 @@ import ddebug.gdb.gdbmiparser;
|
||||||
import std.utf;
|
import std.utf;
|
||||||
import std.conv : to;
|
import std.conv : to;
|
||||||
import std.array : empty;
|
import std.array : empty;
|
||||||
import std.algorithm : startsWith, equal;
|
import std.algorithm : startsWith, endsWith, equal;
|
||||||
import core.thread;
|
import core.thread;
|
||||||
|
|
||||||
abstract class ConsoleDebuggerInterface : DebuggerBase, TextWriter {
|
abstract class ConsoleDebuggerInterface : DebuggerBase, TextWriter {
|
||||||
|
@ -416,6 +416,8 @@ class GDBInterface : ConsoleDebuggerInterface {
|
||||||
// ~message
|
// ~message
|
||||||
void handleStreamLineCLI(string s) {
|
void handleStreamLineCLI(string s) {
|
||||||
Log.d("GDB CLI: ", s);
|
Log.d("GDB CLI: ", s);
|
||||||
|
if (s.length >= 2 && s.startsWith('\"') && s.endsWith('\"'))
|
||||||
|
s = parseCString(s);
|
||||||
_callback.onDebuggerMessage(s);
|
_callback.onDebuggerMessage(s);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -456,8 +458,13 @@ class GDBInterface : ConsoleDebuggerInterface {
|
||||||
if (reason.equal("end-stepping-range")) {
|
if (reason.equal("end-stepping-range")) {
|
||||||
_callback.onDebugState(DebuggingState.paused, StateChangeReason.endSteppingRange, location, bp);
|
_callback.onDebugState(DebuggingState.paused, StateChangeReason.endSteppingRange, location, bp);
|
||||||
} else if (reason.equal("breakpoint-hit")) {
|
} else if (reason.equal("breakpoint-hit")) {
|
||||||
if (GDBBreakpoint gdbbp = findBreakpointByNumber(params.getString("bkptno")))
|
if (GDBBreakpoint gdbbp = findBreakpointByNumber(params.getString("bkptno"))) {
|
||||||
bp = gdbbp.bp;
|
bp = gdbbp.bp;
|
||||||
|
if (!location && bp) {
|
||||||
|
location = new DebugLocation();
|
||||||
|
location.fillMissingFields(bp);
|
||||||
|
}
|
||||||
|
}
|
||||||
_callback.onDebugState(DebuggingState.paused, StateChangeReason.breakpointHit, location, bp);
|
_callback.onDebugState(DebuggingState.paused, StateChangeReason.breakpointHit, location, bp);
|
||||||
} else {
|
} else {
|
||||||
_callback.onDebugState(DebuggingState.stopped, StateChangeReason.exited, null, null);
|
_callback.onDebugState(DebuggingState.stopped, StateChangeReason.exited, null, null);
|
||||||
|
|
|
@ -2,11 +2,14 @@ module dlangide.ui.debuggerui;
|
||||||
|
|
||||||
import dlangui.core.logger;
|
import dlangui.core.logger;
|
||||||
import dlangui.core.events;
|
import dlangui.core.events;
|
||||||
|
import dlangui.widgets.docks;
|
||||||
import dlangide.workspace.project;
|
import dlangide.workspace.project;
|
||||||
import dlangide.workspace.workspace;
|
import dlangide.workspace.workspace;
|
||||||
import dlangide.ui.frame;
|
import dlangide.ui.frame;
|
||||||
import dlangide.ui.commands;
|
import dlangide.ui.commands;
|
||||||
import dlangide.ui.dsourceedit;
|
import dlangide.ui.dsourceedit;
|
||||||
|
import dlangide.ui.stackpanel;
|
||||||
|
import dlangide.ui.watchpanel;
|
||||||
import ddebug.common.execution;
|
import ddebug.common.execution;
|
||||||
import ddebug.common.debugger;
|
import ddebug.common.debugger;
|
||||||
|
|
||||||
|
@ -26,6 +29,7 @@ class DebuggerUIHandler : DebuggerCallback {
|
||||||
void onProgramExecutionStatus(ProgramExecution process, ExecutionStatus status, int exitCode) {
|
void onProgramExecutionStatus(ProgramExecution process, ExecutionStatus status, int exitCode) {
|
||||||
Log.d("Debugger exit status: ", status, " ", exitCode);
|
Log.d("Debugger exit status: ", status, " ", exitCode);
|
||||||
updateLocation(null);
|
updateLocation(null);
|
||||||
|
switchToDevelopPerspective();
|
||||||
_ide.debugFinished(process, status, exitCode);
|
_ide.debugFinished(process, status, exitCode);
|
||||||
//_callbackDelegate( delegate() { _callback.onProgramExecutionStatus(this, status, exitCode); } );
|
//_callbackDelegate( delegate() { _callback.onProgramExecutionStatus(this, status, exitCode); } );
|
||||||
}
|
}
|
||||||
|
@ -42,6 +46,7 @@ class DebuggerUIHandler : DebuggerCallback {
|
||||||
/// debugger is started and loaded program, you can set breakpoints at this time
|
/// debugger is started and loaded program, you can set breakpoints at this time
|
||||||
void onProgramLoaded(bool successful, bool debugInfoLoaded) {
|
void onProgramLoaded(bool successful, bool debugInfoLoaded) {
|
||||||
_ide.logPanel.logLine("Program is loaded");
|
_ide.logPanel.logLine("Program is loaded");
|
||||||
|
switchToDebugPerspective();
|
||||||
// TODO: check succes status and debug info
|
// TODO: check succes status and debug info
|
||||||
if (_breakpoints.length)
|
if (_breakpoints.length)
|
||||||
_debugger.setBreakpoints(_breakpoints);
|
_debugger.setBreakpoints(_breakpoints);
|
||||||
|
@ -160,4 +165,30 @@ class DebuggerUIHandler : DebuggerCallback {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
private WatchPanel _watchPanel;
|
||||||
|
private StackPanel _stackPanel;
|
||||||
|
|
||||||
|
void switchToDebugPerspective() {
|
||||||
|
_ide.dockHost.layoutPriority = [DockAlignment.Bottom, DockAlignment.Top, DockAlignment.Left, DockAlignment.Right];
|
||||||
|
_watchPanel = new WatchPanel("watch");
|
||||||
|
_watchPanel.dockAlignment = DockAlignment.Bottom;
|
||||||
|
_ide.dockHost.addDockedWindow(_watchPanel);
|
||||||
|
_stackPanel = new StackPanel("stack");
|
||||||
|
_stackPanel.dockAlignment = DockAlignment.Right;
|
||||||
|
_ide.dockHost.addDockedWindow(_stackPanel);
|
||||||
|
}
|
||||||
|
|
||||||
|
void switchToDevelopPerspective() {
|
||||||
|
_ide.dockHost.layoutPriority = [DockAlignment.Top, DockAlignment.Left, DockAlignment.Right, DockAlignment.Bottom];
|
||||||
|
_watchPanel = null;
|
||||||
|
auto w = _ide.dockHost.removeDockedWindow("watch");
|
||||||
|
if (w)
|
||||||
|
destroy(w);
|
||||||
|
_stackPanel = null;
|
||||||
|
w = _ide.dockHost.removeDockedWindow("stack");
|
||||||
|
if (w)
|
||||||
|
destroy(w);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -91,6 +91,7 @@ class IDEFrame : AppFrame, ProgramExecutionStatusListener, BreakpointListChangeL
|
||||||
applySettings(_settings);
|
applySettings(_settings);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@property DockHost dockHost() { return _dockHost; }
|
||||||
@property OutputPanel logPanel() { return _logPanel; }
|
@property OutputPanel logPanel() { return _logPanel; }
|
||||||
|
|
||||||
/// stop current program execution
|
/// stop current program execution
|
||||||
|
|
|
@ -0,0 +1,43 @@
|
||||||
|
module dlangide.ui.stackpanel;
|
||||||
|
|
||||||
|
import dlangui;
|
||||||
|
|
||||||
|
class StackPanel : DockWindow {
|
||||||
|
|
||||||
|
this(string id) {
|
||||||
|
super(id);
|
||||||
|
_caption.text = "Stack"d;
|
||||||
|
}
|
||||||
|
|
||||||
|
override protected Widget createBodyWidget() {
|
||||||
|
VerticalLayout root = new VerticalLayout();
|
||||||
|
root.layoutWeight = FILL_PARENT;
|
||||||
|
root.layoutHeight = FILL_PARENT;
|
||||||
|
ComboBox comboBox = new ComboBox("threadComboBox", ["Thread1"d]);
|
||||||
|
comboBox.layoutWidth = FILL_PARENT;
|
||||||
|
comboBox.selectedItemIndex = 0;
|
||||||
|
StringGridWidget grid = new StringGridWidget("stackGrid");
|
||||||
|
grid.resize(2, 20);
|
||||||
|
grid.showColHeaders = true;
|
||||||
|
grid.showRowHeaders = false;
|
||||||
|
grid.layoutHeight = FILL_PARENT;
|
||||||
|
grid.layoutWidth = FILL_PARENT;
|
||||||
|
grid.setColTitle(0, "Function"d);
|
||||||
|
grid.setColTitle(1, "Address"d);
|
||||||
|
grid.setCellText(0, 0, "main()"d);
|
||||||
|
root.addChild(comboBox);
|
||||||
|
root.addChild(grid);
|
||||||
|
return root;
|
||||||
|
}
|
||||||
|
|
||||||
|
protected void onPopupMenuItem(MenuItem item) {
|
||||||
|
if (item.action)
|
||||||
|
handleAction(item.action);
|
||||||
|
}
|
||||||
|
|
||||||
|
/// override to handle specific actions
|
||||||
|
override bool handleAction(const Action a) {
|
||||||
|
return super.handleAction(a);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
|
@ -0,0 +1,70 @@
|
||||||
|
module dlangide.ui.watchpanel;
|
||||||
|
|
||||||
|
import dlangui;
|
||||||
|
|
||||||
|
class VariablesWindow : StringGridWidget {
|
||||||
|
this(string ID = null) {
|
||||||
|
super(ID);
|
||||||
|
resize(3, 20);
|
||||||
|
showColHeaders = true;
|
||||||
|
showRowHeaders = false;
|
||||||
|
layoutHeight = FILL_PARENT;
|
||||||
|
layoutWidth = FILL_PARENT;
|
||||||
|
setColTitle(0, "Variable"d);
|
||||||
|
setColTitle(1, "Value"d);
|
||||||
|
setColTitle(2, "Type"d);
|
||||||
|
setCellText(0, 0, "a"d);
|
||||||
|
setCellText(1, 0, "1"d);
|
||||||
|
setCellText(2, 0, "int"d);
|
||||||
|
setCellText(0, 1, "b"d);
|
||||||
|
setCellText(1, 1, "42"d);
|
||||||
|
setCellText(2, 1, "ulong"d);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
class WatchPanel : DockWindow {
|
||||||
|
|
||||||
|
this(string id) {
|
||||||
|
super(id);
|
||||||
|
_caption.text = "Watch"d;
|
||||||
|
_showCloseButton = false;
|
||||||
|
}
|
||||||
|
|
||||||
|
protected TabWidget _tabs;
|
||||||
|
protected VariablesWindow _locals;
|
||||||
|
protected VariablesWindow _autos;
|
||||||
|
|
||||||
|
override protected Widget createBodyWidget() {
|
||||||
|
_tabs = new TabWidget("WatchPanelTabs", Align.Bottom);
|
||||||
|
_tabs.setStyles(null, STYLE_TAB_DOWN_DARK, STYLE_TAB_DOWN_BUTTON_DARK, STYLE_TAB_UP_BUTTON_DARK_TEXT);
|
||||||
|
_tabs.layoutWidth(FILL_PARENT).layoutHeight(FILL_PARENT);
|
||||||
|
_tabs.tabHost.layoutWidth(FILL_PARENT).layoutHeight(FILL_PARENT);
|
||||||
|
|
||||||
|
_locals = new VariablesWindow("watchLocals");
|
||||||
|
_autos = new VariablesWindow("watchAutos");
|
||||||
|
_tabs.addTab(_locals, "Locals"d);
|
||||||
|
_tabs.addTab(_autos, "Autos"d);
|
||||||
|
_tabs.selectTab("watchAutos");
|
||||||
|
|
||||||
|
return _tabs;
|
||||||
|
}
|
||||||
|
|
||||||
|
override protected void init() {
|
||||||
|
//styleId = STYLE_DOCK_WINDOW;
|
||||||
|
styleId = null;
|
||||||
|
_bodyWidget = createBodyWidget();
|
||||||
|
//_bodyWidget.styleId = STYLE_DOCK_WINDOW_BODY;
|
||||||
|
addChild(_bodyWidget);
|
||||||
|
}
|
||||||
|
|
||||||
|
protected void onPopupMenuItem(MenuItem item) {
|
||||||
|
if (item.action)
|
||||||
|
handleAction(item.action);
|
||||||
|
}
|
||||||
|
|
||||||
|
/// override to handle specific actions
|
||||||
|
override bool handleAction(const Action a) {
|
||||||
|
return super.handleAction(a);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in New Issue