/* This file is part of cpp-ethereum. cpp-ethereum 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 3 of the License, or (at your option) any later version. cpp-ethereum is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with cpp-ethereum. If not, see . */ /** @file AssemblyDebuggerControl.h * @author Yann yann@ethdev.com * @date 2014 * Extension which display debugging steps in assembly code. */ #pragma once #include #include "Extension.h" #include "AssemblyDebuggerModel.h" using AssemblyDebuggerData = std::tuple, dev::mix::QQMLMap*>; Q_DECLARE_METATYPE(AssemblyDebuggerData) Q_DECLARE_METATYPE(dev::mix::DebuggingContent) class AppContext; namespace dev { namespace mix { /** * @brief Extension which display transaction creation or transaction call debugging. handle: F5 to deploy contract, F6 to reset state. */ class AssemblyDebuggerControl: public Extension { Q_OBJECT public: AssemblyDebuggerControl(AppContext* _context); ~AssemblyDebuggerControl() {} void start() const override; QString title() const override; QString contentUrl() const override; Q_PROPERTY(bool running MEMBER m_running NOTIFY stateChanged) private: void executeSequence(std::vector const& _sequence, u256 _balance); std::unique_ptr m_modelDebugger; bool m_running; public slots: /// Run the contract constructor and show debugger window. void debugDeployment(); /// Setup state, run transaction sequence, show debugger for the last transaction /// @param _state JS object with state configuration void debugState(QVariantMap _state); private slots: /// Update UI with machine states result. Display a modal dialog. void showDebugger(QList const& _returnParams = QList(), QList const& _wStates = QList(), AssemblyDebuggerData const& _code = AssemblyDebuggerData()); void showDebugError(QString const& _error); signals: void runStarted(); void runComplete(); void runFailed(QString const& _message); void stateChanged(); /// Emited when machine states are available. void dataAvailable(QList const& _returnParams = QList(), QList const& _wStates = QList(), AssemblyDebuggerData const& _code = AssemblyDebuggerData()); }; } }