base: cmake is fucking retarded

This commit is contained in:
tt2468 2021-04-27 16:33:47 -07:00
parent 5d170d6bb3
commit d9ee288cf1
18 changed files with 138 additions and 36 deletions

View File

@ -89,7 +89,7 @@ set(obs-websocket_HEADERS
src/requesthandler/rpc/Request.h src/requesthandler/rpc/Request.h
src/requesthandler/rpc/RequestResult.h src/requesthandler/rpc/RequestResult.h
src/forms/SettingsDialog.h src/forms/SettingsDialog.h
src/utils/JsonUtils.h) src/utils/Utils.h)
# Platform-independent build settings # Platform-independent build settings

View File

@ -1,6 +1,8 @@
#include <QTime> #include <QTime>
#include <obs-frontend-api.h> #include <obs-frontend-api.h>
#include "plugin-macros.generated.h"
#include "Config.h" #include "Config.h"
#define CONFIG_SECTION_NAME "OBSWebSocket" #define CONFIG_SECTION_NAME "OBSWebSocket"

View File

@ -3,8 +3,6 @@
#include <QString> #include <QString>
#include <util/config-file.h> #include <util/config-file.h>
#include "plugin-macros.generated.h"
class Config { class Config {
public: public:
Config(); Config();

View File

@ -1,4 +1,95 @@
#include <QtConcurrent> #include <QtConcurrent>
#include "plugin-macros.generated.h"
#include "WebSocketServer.h" #include "WebSocketServer.h"
#include "requesthandler/RequestHandler.h" #include "obs-websocket.h"
#include "Config.h"
#include "requesthandler/RequestHandler.h"
WebSocketServer::WebSocketServer() :
QObject(nullptr),
_sessionMutex(QMutex::Recursive),
_sessions()
{
_server.get_alog().clear_channels(websocketpp::log::alevel::frame_header | websocketpp::log::alevel::frame_payload | websocketpp::log::alevel::control);
_server.init_asio();
#ifndef _WIN32
_server.set_reuse_addr(true);
#endif
_server.set_open_handler(
websocketpp::lib::bind(
&WebSocketServer::onOpen, this, websocketpp::lib::placeholders::_1
)
);
_server.set_close_handler(
websocketpp::lib::bind(
&WebSocketServer::onClose, this, websocketpp::lib::placeholders::_1
)
);
_server.set_message_handler(
websocketpp::lib::bind(
&WebSocketServer::onMessage, this, websocketpp::lib::placeholders::_1, websocketpp::lib::placeholders::_2
)
);
blog(LOG_INFO, "test");
}
WebSocketServer::~WebSocketServer()
{
Stop();
}
void WebSocketServer::Start()
{
;
}
void WebSocketServer::Stop()
{
;
}
void WebSocketServer::InvalidateSession(websocketpp::connection_hdl hdl)
{
;
}
std::vector<WebSocketServer::WebSocketState> WebSocketServer::GetWebSocketSessions()
{
std::vector<WebSocketServer::WebSocketState> webSocketSessions;
return webSocketSessions;
}
std::string WebSocketServer::GetConnectUrl()
{
return "";
}
void WebSocketServer::BroadcastEvent(uint64_t requiredIntent, std::string eventType, json eventData)
{
;
}
WebSocketSession *WebSocketServer::GetWebSocketSession(websocketpp::connection_hdl hdl)
{
return new WebSocketSession();
}
void WebSocketServer::onOpen(websocketpp::connection_hdl hdl)
{
;
}
void WebSocketServer::onClose(websocketpp::connection_hdl hdl)
{
;
}
void WebSocketServer::onMessage(websocketpp::connection_hdl hdl, websocketpp::server<websocketpp::config::asio>::message_ptr message)
{
;
}

View File

@ -9,7 +9,6 @@
#include <websocketpp/server.hpp> #include <websocketpp/server.hpp>
#include "WebSocketSession.h" #include "WebSocketSession.h"
#include "requesthandler/RequestHandler.h"
using json = nlohmann::json; using json = nlohmann::json;
@ -65,19 +64,21 @@ class WebSocketServer : public QObject
return &_threadPool; return &_threadPool;
} }
std::string GetConnectUrl();
public Q_SLOTS: public Q_SLOTS:
void BroadcastEvent(uint64_t requiredIntent, std::string eventType, json eventData = nullptr); void BroadcastEvent(uint64_t requiredIntent, std::string eventType, json eventData = nullptr);
private: private:
WebSocketSession *GetWebSocketSession(websocketpp::connection_hdl hdl);
void onOpen(websocketpp::connection_hdl hdl); void onOpen(websocketpp::connection_hdl hdl);
void onClose(websocketpp::connection_hdl hdl); void onClose(websocketpp::connection_hdl hdl);
void onMessage(websocketpp::connection_hdl hdl); void onMessage(websocketpp::connection_hdl hdl, websocketpp::server<websocketpp::config::asio>::message_ptr message);
WebSocketSession *GetWebSocketSession(websocketpp::connection_hdl hdl);
websocketpp::server<websocketpp::config::asio> _server; websocketpp::server<websocketpp::config::asio> _server;
QThreadPool _threadPool; QThreadPool _threadPool;
QMutex _sessionMutex; QMutex _sessionMutex;
std::map<websocketpp::connection_hdl, WebSocketSession, std::owner_less<websocketpp::connection_hdl>> _sessions; std::map<websocketpp::connection_hdl, WebSocketSession, std::owner_less<websocketpp::connection_hdl>> _sessions;
uint16_t _serverPort;
}; };

View File

@ -1,3 +1,5 @@
#include "plugin-macros.generated.h"
#include "WebSocketSession.h" #include "WebSocketSession.h"
WebSocketSession::WebSocketSession() : WebSocketSession::WebSocketSession() :

View File

@ -2,8 +2,6 @@
#include <atomic> #include <atomic>
#include "plugin-macros.generated.h"
class WebSocketSession class WebSocketSession
{ {
public: public:

View File

@ -4,6 +4,8 @@
#include <QClipboard> #include <QClipboard>
#include <QTime> #include <QTime>
#include "../plugin-macros.generated.h"
#include "SettingsDialog.h" #include "SettingsDialog.h"
#include "../obs-websocket.h" #include "../obs-websocket.h"
#include "../Config.h" #include "../Config.h"

View File

@ -6,6 +6,8 @@
#include <QtWidgets/QAction> #include <QtWidgets/QAction>
#include <QtWidgets/QMainWindow> #include <QtWidgets/QMainWindow>
#include "plugin-macros.generated.h"
#include "obs-websocket.h" #include "obs-websocket.h"
#include "Config.h" #include "Config.h"
#include "WebSocketServer.h" #include "WebSocketServer.h"

View File

@ -3,8 +3,6 @@
#include <obs.hpp> #include <obs.hpp>
#include <memory> #include <memory>
#include "plugin-macros.generated.h"
// Autorelease object declarations // Autorelease object declarations
void ___source_dummy_addref(obs_source_t*); void ___source_dummy_addref(obs_source_t*);
void ___sceneitem_dummy_addref(obs_sceneitem_t*); void ___sceneitem_dummy_addref(obs_sceneitem_t*);

View File

@ -27,4 +27,4 @@ with this program. If not, see <https://www.gnu.org/licenses/>
#define blog(level, msg, ...) blog(level, "[obs-websocket] " msg, ##__VA_ARGS__) #define blog(level, msg, ...) blog(level, "[obs-websocket] " msg, ##__VA_ARGS__)
#endif // PLUGINNAME_H #endif

View File

@ -27,4 +27,4 @@ with this program. If not, see <https://www.gnu.org/licenses/>
#define blog(level, msg, ...) blog(level, "[obs-websocket] " msg, ##__VA_ARGS__) #define blog(level, msg, ...) blog(level, "[obs-websocket] " msg, ##__VA_ARGS__)
#endif // PLUGINNAME_H #endif

View File

@ -1 +1,3 @@
#include "../plugin-macros.generated.h"
#include "RequestHandler.h" #include "RequestHandler.h"

View File

@ -1 +1,3 @@
#include "../../plugin-macros.generated.h"
#include "Request.h" #include "Request.h"

View File

@ -1 +1,3 @@
#include "../../plugin-macros.generated.h"
#include "RequestResult.h" #include "RequestResult.h"

View File

@ -1,6 +1,9 @@
#include "JsonUtils.h" // For AutoRelease types
#include "../obs-websocket.h"
bool JsonUtils::JsonArrayIsValidObsArray(json j) #include "Utils.h"
bool Utils::Json::JsonArrayIsValidObsArray(json j)
{ {
for (auto it : j) { for (auto it : j) {
if (!it.is_object()) if (!it.is_object())
@ -54,7 +57,7 @@ void obs_data_set_json_object_item(obs_data_t *d, json j)
} }
} }
obs_data_t *JsonUtils::JsonToObsData(json j) obs_data_t *Utils::Json::JsonToObsData(json j)
{ {
obs_data_t *data = obs_data_create(); obs_data_t *data = obs_data_create();
@ -93,7 +96,7 @@ void set_json_bool(json *j, const char *name, obs_data_item_t *item)
void set_json_object(json *j, const char *name, obs_data_item_t *item, bool includeDefault) void set_json_object(json *j, const char *name, obs_data_item_t *item, bool includeDefault)
{ {
obs_data_t *obj = obs_data_item_get_obj(item); obs_data_t *obj = obs_data_item_get_obj(item);
j->emplace(name, JsonUtils::ObsDataToJson(obj, includeDefault)); j->emplace(name, Utils::Json::ObsDataToJson(obj, includeDefault));
obs_data_release(obj); obs_data_release(obj);
} }
void set_json_array(json *j, const char *name, obs_data_item_t *item, bool includeDefault) void set_json_array(json *j, const char *name, obs_data_item_t *item, bool includeDefault)
@ -104,14 +107,14 @@ void set_json_array(json *j, const char *name, obs_data_item_t *item, bool inclu
for (size_t idx = 0; idx < count; idx++) { for (size_t idx = 0; idx < count; idx++) {
OBSDataAutoRelease subItem = obs_data_array_item(array, idx); OBSDataAutoRelease subItem = obs_data_array_item(array, idx);
json jItem = JsonUtils::ObsDataToJson(subItem, includeDefault); json jItem = Utils::Json::ObsDataToJson(subItem, includeDefault);
jArray.push_back(jItem); jArray.push_back(jItem);
} }
j->emplace(name, jArray); j->emplace(name, jArray);
} }
json JsonUtils::ObsDataToJson(obs_data_t *d, bool includeDefault) json Utils::Json::ObsDataToJson(obs_data_t *d, bool includeDefault)
{ {
json j; json j;
obs_data_item_t *item = nullptr; obs_data_item_t *item = nullptr;

View File

@ -1,15 +0,0 @@
#pragma once
#include <nlohmann/json.hpp>
#include <obs-data.h>
// For AutoRelease types
#include "../obs-websocket.h"
using json = nlohmann::json;
namespace JsonUtils {
bool JsonArrayIsValidObsArray(json j);
obs_data_t *JsonToObsData(json j);
json ObsDataToJson(obs_data_t *d, bool includeDefault = false);
};

14
src/utils/Utils.h Normal file
View File

@ -0,0 +1,14 @@
#pragma once
#include <nlohmann/json.hpp>
#include <obs-data.h>
using json = nlohmann::json;
namespace Utils {
namespace Json {
bool JsonArrayIsValidObsArray(json j);
obs_data_t *JsonToObsData(json j);
json ObsDataToJson(obs_data_t *d, bool includeDefault = false);
};
};