go-ethereum/ethereal/assets/debugger/debugger.qml

378 lines
7.2 KiB
QML
Raw Normal View History

2014-05-27 08:42:37 +00:00
import QtQuick 2.0
import QtQuick.Controls 1.0;
import QtQuick.Layouts 1.0;
import QtQuick.Dialogs 1.0;
import QtQuick.Window 2.1;
import QtQuick.Controls.Styles 1.1
import Ethereum 1.0
ApplicationWindow {
id: win
2014-05-28 21:14:23 +00:00
visible: false
title: "IceCREAM"
2014-05-28 21:14:23 +00:00
minimumWidth: 1280
minimumHeight: 700
2014-05-28 21:14:23 +00:00
width: 1290
2014-07-02 11:08:18 +00:00
height: 750
2014-05-27 11:09:47 +00:00
property alias codeText: codeEditor.text
property alias dataText: rawDataField.text
onClosing: {
2014-07-12 09:02:50 +00:00
//compileTimer.stop()
}
2014-05-27 14:23:53 +00:00
MenuBar {
Menu {
title: "Debugger"
MenuItem {
text: "Run"
shortcut: "Ctrl+r"
onTriggered: debugCurrent()
}
MenuItem {
text: "Next"
shortcut: "Ctrl+n"
onTriggered: dbg.next()
}
2014-07-02 11:08:18 +00:00
MenuItem {
text: "Continue"
shortcut: "Ctrl+g"
2014-07-02 11:08:18 +00:00
onTriggered: dbg.continue()
}
MenuItem {
text: "Command"
shortcut: "Ctrl+l"
onTriggered: {
dbgCommand.focus = true
}
}
MenuItem {
text: "Focus code"
shortcut: "Ctrl+1"
onTriggered: {
codeEditor.focus = true
}
}
MenuItem {
text: "Focus data"
shortcut: "Ctrl+2"
onTriggered: {
rawDataField.focus = true
}
}
/*
MenuItem {
text: "Close window"
shortcut: "Ctrl+w"
onTriggered: {
win.close()
}
}
*/
2014-05-27 14:23:53 +00:00
}
2014-05-28 21:14:23 +00:00
}
2014-05-28 21:14:23 +00:00
SplitView {
anchors.fill: parent
property var asmModel: ListModel {
id: asmModel
}
2014-07-02 11:08:18 +00:00
2014-05-28 21:14:23 +00:00
TableView {
id: asmTableView
width: 200
2014-06-26 16:58:37 +00:00
TableViewColumn{ role: "value" ; title: "" ; width: 200 }
2014-05-28 21:14:23 +00:00
model: asmModel
}
Rectangle {
color: "#00000000"
anchors.left: asmTableView.right
anchors.right: parent.right
SplitView {
orientation: Qt.Vertical
anchors.fill: parent
Rectangle {
color: "#00000000"
height: 330
2014-05-28 21:14:23 +00:00
anchors.left: parent.left
anchors.right: parent.right
TextArea {
id: codeEditor
anchors.top: parent.top
anchors.bottom: parent.bottom
anchors.left: parent.left
anchors.right: settings.left
focus: true
2014-07-12 09:02:50 +00:00
/*
Timer {
id: compileTimer
interval: 500 ; running: true ; repeat: true
onTriggered: {
2014-07-11 14:04:27 +00:00
dbg.autoComp(codeEditor.text)
}
}
2014-07-12 09:02:50 +00:00
*/
2014-05-28 21:14:23 +00:00
}
Column {
id: settings
spacing: 5
width: 300
height: parent.height
anchors.right: parent.right
anchors.top: parent.top
anchors.bottom: parent.bottom
Label {
text: "Arbitrary data"
}
TextArea {
id: rawDataField
anchors.left: parent.left
anchors.right: parent.right
height: 150
}
Label {
text: "Amount"
}
TextField {
id: txValue
width: 200
placeholderText: "Amount"
validator: RegExpValidator { regExp: /\d*/ }
}
Label {
text: "Amount of gas"
}
TextField {
id: txGas
width: 200
validator: RegExpValidator { regExp: /\d*/ }
text: "10000"
placeholderText: "Gas"
}
Label {
text: "Gas price"
}
TextField {
id: txGasPrice
width: 200
placeholderText: "Gas price"
text: "1000000000000"
validator: RegExpValidator { regExp: /\d*/ }
}
}
}
SplitView {
orientation: Qt.Vertical
id: inspectorPane
height: 500
SplitView {
orientation: Qt.Horizontal
height: 150
TableView {
id: stackTableView
property var stackModel: ListModel {
id: stackModel
}
height: parent.height
width: 300
TableViewColumn{ role: "value" ; title: "Temp" ; width: 200 }
2014-05-28 21:14:23 +00:00
model: stackModel
}
TableView {
id: memoryTableView
property var memModel: ListModel {
id: memModel
}
height: parent.height
width: parent.width - stackTableView.width
TableViewColumn{ id:mnumColmn ; role: "num" ; title: "#" ; width: 50}
TableViewColumn{ role: "value" ; title: "Memory" ; width: 750}
model: memModel
}
}
Rectangle {
height: 100
width: parent.width
TableView {
id: storageTableView
property var memModel: ListModel {
id: storageModel
}
height: parent.height
width: parent.width
TableViewColumn{ id: key ; role: "key" ; title: "#" ; width: storageTableView.width / 2}
2014-06-09 20:04:16 +00:00
TableViewColumn{ role: "value" ; title: "Storage" ; width: storageTableView.width / 2}
2014-05-28 21:14:23 +00:00
model: storageModel
}
}
Rectangle {
height: 200
width: parent.width
TableView {
id: logTableView
property var logModel: ListModel {
id: logModel
}
height: parent.height
width: parent.width
2014-07-04 13:31:13 +00:00
TableViewColumn{ id: message ; role: "message" ; title: "log" ; width: logTableView.width - 2 }
2014-05-28 21:14:23 +00:00
model: logModel
}
}
}
}
}
}
2014-07-02 11:08:18 +00:00
function exec() {
dbg.execCommand(dbgCommand.text);
dbgCommand.text = "";
}
statusBar: StatusBar {
height: 30
TextField {
id: dbgCommand
y: 1
x: asmTableView.width
width: 500
placeholderText: "Debugger (type 'help')"
2014-07-02 11:08:18 +00:00
Keys.onReturnPressed: {
exec()
}
}
}
2014-05-28 21:14:23 +00:00
toolBar: ToolBar {
height: 30
2014-05-28 21:14:23 +00:00
RowLayout {
spacing: 5
Button {
property var enabled: true
id: debugStart
onClicked: {
debugCurrent()
}
text: "Debug"
}
Button {
property var enabled: true
id: debugNextButton
onClicked: {
dbg.next()
}
text: "Next"
}
2014-07-02 11:08:18 +00:00
Button {
id: debugContinueButton
onClicked: {
dbg.continue()
}
text: "Continue"
2014-06-26 08:37:48 +00:00
}
2014-05-28 21:14:23 +00:00
}
ComboBox {
id: snippets
anchors.right: parent.right
model: ListModel {
ListElement { text: "Snippets" ; value: "" }
ListElement { text: "Call Contract" ; value: "var[2] in;\nvar ret;\n\nin[0] = \"arg1\"\nin[1] = 0xdeadbeef\n\nvar success = call(0x0c542ddea93dae0c2fcb2cf175f03ad80d6be9a0, 0, 7000, in, ret)\n\nreturn ret" }
}
onCurrentIndexChanged: {
if(currentIndex != 0) {
var code = snippets.model.get(currentIndex).value;
codeEditor.insert(codeEditor.cursorPosition, code)
}
}
}
2014-05-28 21:14:23 +00:00
}
function debugCurrent() {
dbg.debug(txValue.text, txGas.text, txGasPrice.text, codeEditor.text, rawDataField.text)
}
function setAsm(asm) {
asmModel.append({asm: asm})
}
function clearAsm() {
asmModel.clear()
}
function setInstruction(num) {
asmTableView.selection.clear()
asmTableView.selection.select(num)
2014-05-28 21:14:23 +00:00
}
function setMem(mem) {
memModel.append({num: mem.num, value: mem.value})
}
function clearMem(){
memModel.clear()
}
function setStack(stack) {
stackModel.append({value: stack})
}
function addDebugMessage(message){
debuggerLog.append({value: message})
}
function clearStack() {
stackModel.clear()
}
function clearStorage() {
storageModel.clear()
}
function setStorage(storage) {
storageModel.append({key: storage.key, value: storage.value})
}
function setLog(msg) {
2014-07-02 11:08:18 +00:00
// Remove first item once we've reached max log items
if(logModel.count > 250) {
logModel.remove(0)
}
if(msg.len != 0) {
if(logTableView.flickableItem.atYEnd) {
logModel.append({message: msg})
logTableView.positionViewAtRow(logTableView.rowCount - 1, ListView.Contain)
} else {
logModel.append({message: msg})
}
}
}
function clearLog() {
logModel.clear()
2014-05-28 21:14:23 +00:00
}
2014-05-27 08:42:37 +00:00
}