forked from quickshell/quickshell
feat(socket): add SocketServer and Socket.write
This commit is contained in:
parent
f004454395
commit
f45d298b66
5 changed files with 248 additions and 7 deletions
|
@ -1,10 +1,15 @@
|
|||
#pragma once
|
||||
|
||||
#include <qlocalserver.h>
|
||||
#include <qlocalsocket.h>
|
||||
#include <qobject.h>
|
||||
#include <qqmlcomponent.h>
|
||||
#include <qqmlintegration.h>
|
||||
#include <qtclasshelpermacros.h>
|
||||
#include <qtmetamacros.h>
|
||||
|
||||
#include "datastream.hpp"
|
||||
#include "reload.hpp"
|
||||
|
||||
///! Unix socket listener.
|
||||
class Socket: public DataStream {
|
||||
|
@ -24,6 +29,9 @@ class Socket: public DataStream {
|
|||
public:
|
||||
explicit Socket(QObject* parent = nullptr): DataStream(parent) {}
|
||||
|
||||
/// Write data to the socket. Does nothing if not connected.
|
||||
Q_INVOKABLE void write(const QString& data);
|
||||
|
||||
// takes ownership
|
||||
void setSocket(QLocalSocket* socket);
|
||||
|
||||
|
@ -56,3 +64,80 @@ private:
|
|||
bool targetConnected = false;
|
||||
QString mPath;
|
||||
};
|
||||
|
||||
///! Unix socket server.
|
||||
/// #### Example
|
||||
/// ```qml
|
||||
/// SocketServer {
|
||||
/// active: true
|
||||
/// path: "/path/too/socket.sock"
|
||||
/// handler: Socket {
|
||||
/// onConnectedChanged: {
|
||||
/// console.log(connected ? "new connection!" : "connection dropped!")
|
||||
/// }
|
||||
/// parser: SplitParser {
|
||||
/// onRead: message => console.log(`read message from socket: ${message}`)
|
||||
/// }
|
||||
/// }
|
||||
/// }
|
||||
/// ```
|
||||
class SocketServer
|
||||
: public QObject
|
||||
, public PostReloadHook {
|
||||
Q_OBJECT;
|
||||
/// If the socket server is currently active. Defaults to false.
|
||||
///
|
||||
/// Setting this to false will destory all active connections and delete
|
||||
/// the socket file on disk.
|
||||
///
|
||||
/// If path is empty setting this property will have no effect.
|
||||
Q_PROPERTY(bool active READ isActive WRITE setActive NOTIFY activeStatusChanged);
|
||||
/// The path to create the socket server at.
|
||||
///
|
||||
/// Setting this property while the server is active will have no effect.
|
||||
Q_PROPERTY(QString path READ path WRITE setPath NOTIFY pathChanged);
|
||||
/// Connection handler component. Must creeate a `Socket`.
|
||||
///
|
||||
/// The created socket should not set `connected` or `path` or the incoming
|
||||
/// socket connection will be dropped (they will be set by the socket server.)
|
||||
/// Setting `connected` to false on the created socket after connection will
|
||||
/// close and delete it.
|
||||
Q_PROPERTY(QQmlComponent* handler READ handler WRITE setHandler NOTIFY handlerChanged);
|
||||
QML_ELEMENT;
|
||||
|
||||
public:
|
||||
explicit SocketServer(QObject* parent = nullptr): QObject(parent) {}
|
||||
~SocketServer() override;
|
||||
Q_DISABLE_COPY_MOVE(SocketServer);
|
||||
|
||||
void onPostReload() override;
|
||||
|
||||
[[nodiscard]] bool isActive() const;
|
||||
void setActive(bool active);
|
||||
|
||||
[[nodiscard]] QString path() const;
|
||||
void setPath(QString path);
|
||||
|
||||
[[nodiscard]] QQmlComponent* handler() const;
|
||||
void setHandler(QQmlComponent* handler);
|
||||
|
||||
signals:
|
||||
void activeStatusChanged();
|
||||
void pathChanged();
|
||||
void handlerChanged();
|
||||
|
||||
private slots:
|
||||
void onNewConnection();
|
||||
|
||||
private:
|
||||
bool isActivatable();
|
||||
void enableServer();
|
||||
void disableServer();
|
||||
|
||||
QLocalServer* server = nullptr;
|
||||
QQmlComponent* mHandler = nullptr;
|
||||
QList<Socket*> mSockets;
|
||||
bool activeTarget = false;
|
||||
bool postReload = false;
|
||||
QString mPath;
|
||||
};
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue