mirror of
https://github.com/rizinorg/cutter.git
synced 2025-01-18 18:38:51 +00:00
Fix webserver deadlock
Removes the ability to stop the webserver, because 1. it's needed for the graph views to work 2. multiple start/stop calls could lead to a deadlock, because =h- was waiting for input (^C) Since =h& is used the server manager class doesn't need to be a QThread
This commit is contained in:
parent
6ffb18e6e4
commit
a562d5b0b6
@ -107,7 +107,7 @@ MainWindow::MainWindow(QWidget *parent, QRCore *kore) :
|
||||
sidebar_action(nullptr),
|
||||
sectionsDock(nullptr),
|
||||
consoleWidget(nullptr),
|
||||
webserverThread(core, this)
|
||||
webserver(core)
|
||||
{
|
||||
this->start_web_server();
|
||||
ui->setupUi(this);
|
||||
@ -264,8 +264,6 @@ MainWindow::MainWindow(QWidget *parent, QRCore *kore) :
|
||||
QShortcut *commands_shortcut = new QShortcut(QKeySequence(Qt::Key_Colon), this);
|
||||
connect(commands_shortcut, SIGNAL(activated()), this->omnibar, SLOT(showCommands()));
|
||||
|
||||
connect(&webserverThread, SIGNAL(finished()), this, SLOT(webserverThreadFinished()));
|
||||
|
||||
QShortcut *refresh_shortcut = new QShortcut(QKeySequence(QKeySequence::Refresh), this);
|
||||
connect(refresh_shortcut, SIGNAL(activated()), this, SLOT(refreshVisibleDockWidgets()));
|
||||
}
|
||||
@ -279,24 +277,15 @@ MainWindow::~MainWindow()
|
||||
void MainWindow::start_web_server()
|
||||
{
|
||||
// Start web server
|
||||
webserverThread.startServer();
|
||||
webserver.start();
|
||||
}
|
||||
|
||||
void MainWindow::webserverThreadFinished()
|
||||
{
|
||||
core->core()->http_up = webserverThread.isStarted() ? R_TRUE : R_FALSE;
|
||||
|
||||
// this is not true anymore, cause the webserver might have been stopped
|
||||
//if (core->core->http_up == R_FALSE) {
|
||||
// eprintf("FAILED TO LAUNCH\n");
|
||||
//}
|
||||
}
|
||||
|
||||
void MainWindow::setWebServerState(bool start)
|
||||
{
|
||||
if (start)
|
||||
{
|
||||
webserverThread.startServer();
|
||||
webserver.start();
|
||||
|
||||
// Open web interface on default browser
|
||||
// ballessay: well isn't this possible with =H&
|
||||
@ -305,7 +294,7 @@ void MainWindow::setWebServerState(bool start)
|
||||
}
|
||||
else
|
||||
{
|
||||
webserverThread.stopServer();
|
||||
webserver.stop();
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -164,8 +164,6 @@ private slots:
|
||||
|
||||
void on_actionReset_settings_triggered();
|
||||
|
||||
void webserverThreadFinished();
|
||||
|
||||
void on_actionQuit_triggered();
|
||||
|
||||
void refreshVisibleDockWidgets();
|
||||
@ -200,7 +198,7 @@ private:
|
||||
QAction *sidebar_action;
|
||||
SectionsDock *sectionsDock;
|
||||
ConsoleWidget *consoleWidget;
|
||||
WebServerThread webserverThread;
|
||||
RadareWebServer webserver;
|
||||
|
||||
RVA cursor_address;
|
||||
|
||||
|
@ -2,83 +2,37 @@
|
||||
#include "qrcore.h"
|
||||
#include <cassert>
|
||||
|
||||
WebServerThread::WebServerThread(QRCore *core, QObject *parent) :
|
||||
QThread(parent),
|
||||
|
||||
RadareWebServer::RadareWebServer(QRCore *core) :
|
||||
core(core),
|
||||
started(false)
|
||||
{
|
||||
// MEOW
|
||||
}
|
||||
|
||||
WebServerThread::~WebServerThread()
|
||||
RadareWebServer::~RadareWebServer()
|
||||
{
|
||||
if (isRunning())
|
||||
}
|
||||
|
||||
void RadareWebServer::start()
|
||||
{
|
||||
assert(core != nullptr);
|
||||
|
||||
if (!started && core != nullptr)
|
||||
{
|
||||
quit();
|
||||
wait();
|
||||
// command: see libr/core/rtr.c
|
||||
core->cmd("=h&");
|
||||
core->core()->http_up = R_TRUE;
|
||||
started = true;
|
||||
}
|
||||
}
|
||||
|
||||
void WebServerThread::startServer()
|
||||
void RadareWebServer::stop()
|
||||
{
|
||||
assert(nullptr != core);
|
||||
|
||||
if (!isRunning() && !started)
|
||||
{
|
||||
QThread::start();
|
||||
}
|
||||
// TODO: =h- waits for ^C
|
||||
}
|
||||
|
||||
void WebServerThread::stopServer()
|
||||
bool RadareWebServer::isStarted() const
|
||||
{
|
||||
assert(nullptr != core);
|
||||
|
||||
if (!isRunning() && started)
|
||||
{
|
||||
QThread::start();
|
||||
}
|
||||
}
|
||||
|
||||
bool WebServerThread::isStarted() const
|
||||
{
|
||||
QMutexLocker locker(&mutex);
|
||||
return started;
|
||||
}
|
||||
|
||||
void WebServerThread::run()
|
||||
{
|
||||
QMutexLocker locker(&mutex);
|
||||
|
||||
if (core == nullptr)
|
||||
return;
|
||||
//eprintf ("Starting webserver!");
|
||||
|
||||
toggleWebServer();
|
||||
}
|
||||
|
||||
void WebServerThread::toggleWebServer()
|
||||
{
|
||||
// access already locked
|
||||
|
||||
// see libr/core/rtr.c
|
||||
// "=h", " port", "listen for http connections (r2 -qc=H /bin/ls)",
|
||||
// "=h-", "", "stop background webserver",
|
||||
// "=h*", "", "restart current webserver",
|
||||
// "=h&", " port", "start http server in background)",
|
||||
|
||||
if (started)
|
||||
{
|
||||
// after this the only reaction to this commands is:
|
||||
// sandbox: connect disabled
|
||||
// and the webserver is still running
|
||||
// TODO: find out why
|
||||
core->cmd("=h-");
|
||||
}
|
||||
else
|
||||
{
|
||||
core->cmd("=h&");
|
||||
}
|
||||
|
||||
// cmd has no usefull return value for this commands, so just toogle the state
|
||||
started = !started;
|
||||
}
|
||||
|
@ -1,33 +1,26 @@
|
||||
#ifndef WEBSERVERTHREAD_H
|
||||
#define WEBSERVERTHREAD_H
|
||||
#ifndef RADARE_WEBSERVER_H
|
||||
#define RADARE_WEBSERVER_H
|
||||
|
||||
#include <QThread>
|
||||
#include <QMutex>
|
||||
|
||||
class QRCore;
|
||||
|
||||
class WebServerThread : public QThread
|
||||
class RadareWebServer
|
||||
{
|
||||
Q_OBJECT
|
||||
public:
|
||||
|
||||
explicit WebServerThread(QRCore *core, QObject *parent = 0);
|
||||
~WebServerThread();
|
||||
explicit RadareWebServer(QRCore *core);
|
||||
~RadareWebServer();
|
||||
|
||||
void startServer();
|
||||
void stopServer();
|
||||
void start();
|
||||
void stop();
|
||||
|
||||
bool isStarted() const;
|
||||
|
||||
private:
|
||||
void run();
|
||||
using QThread::start;
|
||||
|
||||
void toggleWebServer();
|
||||
|
||||
mutable QMutex mutex;
|
||||
QRCore *core;
|
||||
bool started;
|
||||
};
|
||||
|
||||
#endif // WEBSERVERTHREAD_H
|
||||
#endif // RADARE_WEBSERVER_H
|
||||
|
Loading…
Reference in New Issue
Block a user