Browse Source

ui improvements, bugfixes

cl-refactor
arkpar 10 years ago
parent
commit
3f4370162f
  1. 13
      mix/ClientModel.cpp
  2. 9
      mix/ClientModel.h
  3. 3
      mix/MixClient.cpp
  4. 26
      mix/qml/DebugInfoList.qml
  5. 122
      mix/qml/Debugger.qml
  6. 3
      mix/qml/WebPreview.qml
  7. 2
      mix/qml/js/Debugger.js
  8. 1
      mix/qml/js/ProjectModel.js
  9. 2
      mix/qml/main.qml

13
mix/ClientModel.cpp

@ -113,24 +113,27 @@ QString ClientModel::apiCall(QString const& _message)
void ClientModel::mine() void ClientModel::mine()
{ {
if (m_running) if (m_running || m_mining)
BOOST_THROW_EXCEPTION(ExecutionStateException()); BOOST_THROW_EXCEPTION(ExecutionStateException());
m_running = true; m_mining = true;
emit runStarted(); emit miningStarted();
emit runStateChanged(); emit miningStateChanged();
QtConcurrent::run([=]() QtConcurrent::run([=]()
{ {
try try
{ {
m_client->mine(); m_client->mine();
newBlock(); newBlock();
m_mining = false;
emit miningComplete();
} }
catch (...) catch (...)
{ {
m_mining = false;
std::cerr << boost::current_exception_diagnostic_information(); std::cerr << boost::current_exception_diagnostic_information();
emit runFailed(QString::fromStdString(boost::current_exception_diagnostic_information())); emit runFailed(QString::fromStdString(boost::current_exception_diagnostic_information()));
} }
m_running = false; emit miningStateChanged();
}); });
} }

9
mix/ClientModel.h

@ -114,6 +114,8 @@ public:
~ClientModel(); ~ClientModel();
/// @returns true if currently executing contract code /// @returns true if currently executing contract code
Q_PROPERTY(bool running MEMBER m_running NOTIFY runStateChanged) Q_PROPERTY(bool running MEMBER m_running NOTIFY runStateChanged)
/// @returns true if currently mining
Q_PROPERTY(bool mining MEMBER m_mining NOTIFY miningStateChanged)
/// @returns address of the last executed contract /// @returns address of the last executed contract
Q_PROPERTY(QString contractAddress READ contractAddress NOTIFY contractAddressChanged) Q_PROPERTY(QString contractAddress READ contractAddress NOTIFY contractAddressChanged)
/// ethereum.js RPC request entry point /// ethereum.js RPC request entry point
@ -144,6 +146,12 @@ signals:
void runStarted(); void runStarted();
/// Transaction execution completed successfully /// Transaction execution completed successfully
void runComplete(); void runComplete();
/// Mining has started
void miningStarted();
/// Mined a new block
void miningComplete();
/// Mining stopped or started
void miningStateChanged();
/// Transaction execution completed with error /// Transaction execution completed with error
/// @param _message Error message /// @param _message Error message
void runFailed(QString const& _message); void runFailed(QString const& _message);
@ -174,6 +182,7 @@ private:
AppContext* m_context; AppContext* m_context;
std::atomic<bool> m_running; std::atomic<bool> m_running;
std::atomic<bool> m_mining;
std::unique_ptr<MixClient> m_client; std::unique_ptr<MixClient> m_client;
std::unique_ptr<RpcConnector> m_rpcConnector; std::unique_ptr<RpcConnector> m_rpcConnector;
std::unique_ptr<Web3Server> m_web3Server; std::unique_ptr<Web3Server> m_web3Server;

3
mix/MixClient.cpp

@ -91,6 +91,7 @@ void MixClient::resetState(u256 _balance)
m_state.sync(bc()); m_state.sync(bc());
m_startState = m_state; m_startState = m_state;
m_pendingExecutions.clear(); m_pendingExecutions.clear();
m_executions.clear();
} }
void MixClient::executeTransaction(Transaction const& _t, State& _state) void MixClient::executeTransaction(Transaction const& _t, State& _state)
@ -215,7 +216,7 @@ ExecutionResult const& MixClient::execution(unsigned _block, unsigned _transacti
{ {
if (_block == bc().number() + 1) if (_block == bc().number() + 1)
return m_pendingExecutions.at(_transaction); return m_pendingExecutions.at(_transaction);
return m_executions.at(_block).at(_transaction); return m_executions.at(_block - 1).at(_transaction);
} }
ExecutionResult const& MixClient::lastExecution() const ExecutionResult const& MixClient::lastExecution() const

26
mix/qml/DebugInfoList.qml

@ -4,14 +4,19 @@ import QtQuick.Layouts 1.0
import QtQuick.Controls.Styles 1.1 import QtQuick.Controls.Styles 1.1
ColumnLayout { ColumnLayout {
id: root
property string title property string title
property variant listModel; property variant listModel;
property bool collapsible; property bool collapsible;
property bool enableSelection;
property real storedHeight;
property Component itemDelegate property Component itemDelegate
signal rowActivated(int index)
spacing: 0 spacing: 0
function collapse() function collapse()
{ {
storedHeight = childrenRect.height;
storageContainer.state = "collapsed"; storageContainer.state = "collapsed";
} }
@ -32,7 +37,9 @@ ColumnLayout {
Image { Image {
source: "qrc:/qml/img/opentriangleindicator.png" source: "qrc:/qml/img/opentriangleindicator.png"
width: 15 width: 15
height: 15
sourceSize.width: 15 sourceSize.width: 15
sourceSize.height: 15
id: storageImgArrow id: storageImgArrow
} }
@ -53,16 +60,20 @@ ColumnLayout {
if (storageContainer.state == "collapsed") if (storageContainer.state == "collapsed")
{ {
storageContainer.state = ""; storageContainer.state = "";
storageContainer.parent.parent.height = storageContainer.parent.parent.Layout.maximumHeight; storageContainer.parent.parent.height = storedHeight;
} }
else else
{
storedHeight = root.childrenRect.height;
storageContainer.state = "collapsed"; storageContainer.state = "collapsed";
} }
} }
} }
} }
}
Rectangle Rectangle
{ {
id: storageContainer
border.width: 3 border.width: 3
border.color: "#deddd9" border.color: "#deddd9"
Layout.fillWidth: true Layout.fillWidth: true
@ -80,18 +91,23 @@ ColumnLayout {
} }
} }
] ]
id: storageContainer TableView {
ListView {
clip: true; clip: true;
alternatingRowColors: false
anchors.top: parent.top anchors.top: parent.top
anchors.left: parent.left anchors.left: parent.left
anchors.topMargin: 3 anchors.topMargin: 3
anchors.leftMargin: 3 anchors.leftMargin: 3
width: parent.width - 3 width: parent.width - 3
height: parent.height - 6 height: parent.height - 6
id: storageList
model: listModel model: listModel
delegate: itemDelegate selectionMode: enableSelection ? SelectionMode.SingleSelection : SelectionMode.NoSelection
headerDelegate: null
itemDelegate: root.itemDelegate
TableViewColumn {
role: "modelData"
width: parent.width
}
} }
} }
} }

122
mix/qml/Debugger.qml

@ -58,7 +58,7 @@ Rectangle {
Settings { Settings {
id: splitSettings id: splitSettings
property alias transactionLogHeight: transactionLog.height property alias transactionLogHeight: transactionLog.height
property alias callStackHeight: callStack.height property alias callStackHeight: callStackRect.height
property alias storageHeightSettings: storageRect.height property alias storageHeightSettings: storageRect.height
property alias memoryDumpHeightSettings: memoryRect.height property alias memoryDumpHeightSettings: memoryRect.height
property alias callDataHeightSettings: callDataRect.height property alias callDataHeightSettings: callDataRect.height
@ -154,18 +154,19 @@ Rectangle {
id: statesLayout id: statesLayout
spacing: machineStates.sideMargin spacing: machineStates.sideMargin
RowLayout { Rectangle {
// step button + slider // step button + slider
id: buttonRow id: buttonRow
spacing: machineStates.sideMargin
height: 27 height: 27
Layout.fillWidth: true Layout.fillWidth: true
color: "transparent"
Rectangle { Rectangle {
height: parent.height anchors.top: parent.top
anchors.bottom: parent.bottom
anchors.left: parent.left
color: "transparent" color: "transparent"
Layout.minimumWidth: stateListContainer.width width: stateListContainer.width
Layout.maximumWidth: stateListContainer.width
RowLayout { RowLayout {
anchors.horizontalCenter: parent.horizontalCenter anchors.horizontalCenter: parent.horizontalCenter
id: jumpButtons id: jumpButtons
@ -245,9 +246,11 @@ Rectangle {
} }
Rectangle { Rectangle {
anchors.top: parent.top
anchors.bottom: parent.bottom
anchors.right: parent.right
width: debugInfoContainer.width
color: "transparent" color: "transparent"
Layout.fillWidth: true
height: parent.height
Slider { Slider {
id: statesSlider id: statesSlider
anchors.fill: parent anchors.fill: parent
@ -324,7 +327,6 @@ Rectangle {
Component { Component {
id: renderDelegate id: renderDelegate
Item { Item {
Rectangle { Rectangle {
radius: 4 radius: 4
anchors.fill: parent anchors.fill: parent
@ -334,8 +336,6 @@ Rectangle {
RowLayout { RowLayout {
id: wrapperItem id: wrapperItem
height: 20
//width: parent.width
anchors.fill: parent anchors.fill: parent
spacing: 5 spacing: 5
@ -365,6 +365,7 @@ Rectangle {
} }
Rectangle { Rectangle {
id: debugInfoContainer
width: parent.width * 0.6 - machineStates.sideMargin width: parent.width * 0.6 - machineStates.sideMargin
anchors.top : parent.top anchors.top : parent.top
anchors.bottom: parent.bottom anchors.bottom: parent.bottom
@ -409,7 +410,7 @@ Rectangle {
title : qsTr("Stack") title : qsTr("Stack")
itemDelegate: Item { itemDelegate: Item {
id: renderedItem id: renderedItem
height: 25 //height: 25
width: parent.width width: parent.width
RowLayout RowLayout
{ {
@ -428,7 +429,7 @@ Rectangle {
anchors.leftMargin: 5 anchors.leftMargin: 5
font.family: "monospace" font.family: "monospace"
color: "#4a4a4a" color: "#4a4a4a"
text: model.index; text: styleData.row;
font.pointSize: 9 font.pointSize: 9
} }
} }
@ -439,7 +440,6 @@ Rectangle {
Layout.fillWidth: true Layout.fillWidth: true
Layout.minimumWidth: 15 Layout.minimumWidth: 15
Layout.preferredWidth: 15 Layout.preferredWidth: 15
Layout.maximumWidth: 60
Layout.minimumHeight: parent.height Layout.minimumHeight: parent.height
Text { Text {
anchors.left: parent.left anchors.left: parent.left
@ -447,7 +447,7 @@ Rectangle {
font.family: "monospace" font.family: "monospace"
anchors.verticalCenter: parent.verticalCenter anchors.verticalCenter: parent.verticalCenter
color: "#4a4a4a" color: "#4a4a4a"
text: modelData text: styleData.value
font.pointSize: 9 font.pointSize: 9
} }
} }
@ -477,18 +477,82 @@ Rectangle {
{ {
id: callStackRect; id: callStackRect;
color: "transparent" color: "transparent"
height: 120 Layout.minimumHeight: 25
width: parent.width Layout.maximumHeight: 800
Layout.minimumHeight: 120
Layout.maximumHeight: 400
onHeightChanged: machineStates.updateHeight(); onHeightChanged: machineStates.updateHeight();
CallStack { DebugInfoList
anchors.fill: parent {
id: callStack id: callStack
onFrameActivated: Debugger.displayFrame(index); collapsible: true
anchors.fill: parent
title : qsTr("Call Stack")
enableSelection: true
onRowActivated: Debugger.displayFrame(index);
itemDelegate:
Item {
anchors.fill: parent
Rectangle {
anchors.fill: parent
color: "#4A90E2"
visible: styleData.selected;
}
RowLayout
{
id: row
anchors.fill: parent
Rectangle
{
color: "#f7f7f7"
Layout.fillWidth: true
Layout.minimumWidth: 30
Layout.maximumWidth: 30
Text {
anchors.verticalCenter: parent.verticalCenter
anchors.left: parent.left
font.family: "monospace"
anchors.leftMargin: 5
color: "#4a4a4a"
text: styleData.row;
font.pointSize: 9
width: parent.width - 5
elide: Text.ElideRight
}
}
Rectangle
{
color: "transparent"
Layout.fillWidth: true
Layout.minimumWidth: parent.width - 30
Layout.maximumWidth: parent.width - 30
Text {
anchors.leftMargin: 5
width: parent.width - 5
wrapMode: Text.Wrap
anchors.left: parent.left
font.family: "monospace"
anchors.verticalCenter: parent.verticalCenter
color: "#4a4a4a"
text: styleData.value;
elide: Text.ElideRight
font.pointSize: 9
}
} }
} }
Rectangle {
anchors.top: row.bottom
width: parent.width;
height: 1;
color: "#cccccc"
anchors.bottom: parent.bottom
}
}
}
}
Rectangle Rectangle
{ {
id: storageRect id: storageRect
@ -505,28 +569,24 @@ Rectangle {
title : qsTr("Storage") title : qsTr("Storage")
itemDelegate: itemDelegate:
Item { Item {
height: 27 anchors.fill: parent
width: parent.width;
RowLayout RowLayout
{ {
id: row id: row
width: parent.width anchors.fill: parent
height: 26
Rectangle Rectangle
{ {
color: "#f7f7f7" color: "#f7f7f7"
Layout.fillWidth: true Layout.fillWidth: true
Layout.minimumWidth: parent.width / 2 Layout.minimumWidth: parent.width / 2
Layout.preferredWidth: parent.width / 2
Layout.maximumWidth: parent.width / 2 Layout.maximumWidth: parent.width / 2
Layout.minimumHeight: parent.height
Text { Text {
anchors.verticalCenter: parent.verticalCenter anchors.verticalCenter: parent.verticalCenter
anchors.left: parent.left anchors.left: parent.left
font.family: "monospace" font.family: "monospace"
anchors.leftMargin: 5 anchors.leftMargin: 5
color: "#4a4a4a" color: "#4a4a4a"
text: modelData.split('\t')[0]; text: styleData.value.split('\t')[0];
font.pointSize: 9 font.pointSize: 9
width: parent.width - 5 width: parent.width - 5
elide: Text.ElideRight elide: Text.ElideRight
@ -537,9 +597,7 @@ Rectangle {
color: "transparent" color: "transparent"
Layout.fillWidth: true Layout.fillWidth: true
Layout.minimumWidth: parent.width / 2 Layout.minimumWidth: parent.width / 2
Layout.preferredWidth: parent.width / 2
Layout.maximumWidth: parent.width / 2 Layout.maximumWidth: parent.width / 2
Layout.minimumHeight: parent.height
Text { Text {
anchors.leftMargin: 5 anchors.leftMargin: 5
width: parent.width - 5 width: parent.width - 5
@ -548,7 +606,7 @@ Rectangle {
font.family: "monospace" font.family: "monospace"
anchors.verticalCenter: parent.verticalCenter anchors.verticalCenter: parent.verticalCenter
color: "#4a4a4a" color: "#4a4a4a"
text: modelData.split('\t')[1]; text: styleData.value.split('\t')[1];
elide: Text.ElideRight elide: Text.ElideRight
font.pointSize: 9 font.pointSize: 9
} }

3
mix/qml/WebPreview.qml

@ -114,7 +114,8 @@ Item {
onClientConnected: { onClientConnected: {
//filter polling spam //filter polling spam
//TODO: do it properly //TODO: do it properly
var log = _request.content.indexOf("eth_changed") < 0; //var log = _request.content.indexOf("eth_changed") < 0;
var log = true;
if (log) if (log)
console.log(_request.content); console.log(_request.content);
var response = clientModel.apiCall(_request.content); var response = clientModel.apiCall(_request.content);

2
mix/qml/js/Debugger.js

@ -107,7 +107,7 @@ function select(stateIndex)
callStackData.push(address); callStackData.push(address);
} }
callStackData.push(debugData.states[0].address); callStackData.push(debugData.states[0].address);
callStack.model = callStackData; callStack.listModel = callStackData;
} }
function codeStr(stateIndex) function codeStr(stateIndex)

1
mix/qml/js/ProjectModel.js

@ -153,6 +153,7 @@ function doCloseProject() {
console.log("closing project"); console.log("closing project");
projectListModel.clear(); projectListModel.clear();
projectPath = ""; projectPath = "";
currentDocumentId = "";
projectClosed(); projectClosed();
} }

2
mix/qml/main.qml

@ -88,7 +88,7 @@ ApplicationWindow {
text: qsTr("Mine") text: qsTr("Mine")
shortcut: "Ctrl+M" shortcut: "Ctrl+M"
onTriggered: clientModel.mine(); onTriggered: clientModel.mine();
enabled: codeModel.hasContract && !clientModel.running enabled: codeModel.hasContract && !clientModel.running &&!clientModel.mining
} }
Connections { Connections {

Loading…
Cancel
Save