Merge branch 'main' of github.com:Rconybea/xo-websock
This commit is contained in:
commit
3e64ed53e5
8 changed files with 41 additions and 39 deletions
|
|
@ -3,25 +3,11 @@
|
||||||
cmake_minimum_required(VERSION 3.10)
|
cmake_minimum_required(VERSION 3.10)
|
||||||
|
|
||||||
project(websock VERSION 1.0)
|
project(websock VERSION 1.0)
|
||||||
enable_language(CXX)
|
|
||||||
|
|
||||||
# common XO cmake macros (see proj/xo-cmake)
|
include(GNUInstallDirs)
|
||||||
include(cmake/xo-bootstrap-macros.cmake)
|
include(cmake/xo-bootstrap-macros.cmake)
|
||||||
|
|
||||||
# ----------------------------------------------------------------
|
xo_cxx_toplevel_options3()
|
||||||
# unit test setup
|
|
||||||
|
|
||||||
enable_testing()
|
|
||||||
# activate code coverage for all executables + libraries (when configured with -DCODE_COVERAGE=ON)
|
|
||||||
add_code_coverage()
|
|
||||||
# 1. assuming that /nix/store/ prefixes .hpp files belonging to gcc, catch2 etc.
|
|
||||||
# we're not interested in code coverage for these sources.
|
|
||||||
# 2. exclude the utest/ subdir, we don't need coverage on the unit tests themselves;
|
|
||||||
# rather, want coverage on the code that the unit tests exercise.
|
|
||||||
#
|
|
||||||
# NOTE: this seems to work only with the 'ccov-all' target. In particular, doesn't seem to do anything with the 'ccov' target
|
|
||||||
#
|
|
||||||
add_code_coverage_all_targets(EXCLUDE /nix/store/* ${PROJECT_SOURCE_DIR}/utest/* ${PROJECT_BINARY_DIR}/local/* ${PROJECT_SOURCE_DIR}/repo/*)
|
|
||||||
|
|
||||||
# ----------------------------------------------------------------
|
# ----------------------------------------------------------------
|
||||||
# c++ settings
|
# c++ settings
|
||||||
|
|
@ -31,8 +17,6 @@ set(PROJECT_CXX_FLAGS "")
|
||||||
#set(PROJECT_CXX_FLAGS "-fconcepts-diagnostics-depth=2")
|
#set(PROJECT_CXX_FLAGS "-fconcepts-diagnostics-depth=2")
|
||||||
add_definitions(${PROJECT_CXX_FLAGS})
|
add_definitions(${PROJECT_CXX_FLAGS})
|
||||||
|
|
||||||
xo_toplevel_compile_options()
|
|
||||||
|
|
||||||
# ----------------------------------------------------------------
|
# ----------------------------------------------------------------
|
||||||
|
|
||||||
add_subdirectory(src/websock)
|
add_subdirectory(src/websock)
|
||||||
|
|
|
||||||
|
|
@ -1,14 +1,35 @@
|
||||||
if (("${CMAKE_MODULE_PATH}" STREQUAL "") OR ("${CMAKE_MODULE_PATH}" STREQUAL "prefix"))
|
# ----------------------------------------------------------------
|
||||||
# default to typical install location for xo-project-macros
|
# for example:
|
||||||
set(CMAKE_MODULE_PATH ${CMAKE_INSTALL_PREFIX}/share/cmake)
|
# $ PREFIX=/usr/local # for example
|
||||||
|
# $ cmake -DCMAKE_MODULE_PATH=prefix -DCMAKE_INSTALL_PREFIX=$PREFIX -B .build
|
||||||
|
#
|
||||||
|
# will get
|
||||||
|
# CMAKE_MODULE_PATH
|
||||||
|
# from xo-cmake-config --cmake-module-path
|
||||||
|
#
|
||||||
|
# and expect .cmake macros in
|
||||||
|
# CMAKE_MODULE_PATH/xo_macros/xo_cxx.cmake
|
||||||
|
# ----------------------------------------------------------------
|
||||||
|
|
||||||
|
find_program(XO_CMAKE_CONFIG_EXECUTABLE NAMES xo-cmake-config REQUIRED)
|
||||||
|
|
||||||
|
if ("${XO_CMAKE_CONFIG_EXECUTABLE}" STREQUAL "XO_CMAKE_CONFIG_EXECUTABLE-NOT_FOUND")
|
||||||
|
message(FATAL "could not find xo-cmake-config executable")
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
|
message(STATUS "XO_CMAKE_CONFIG_EXECUTABLE=${XO_CMAKE_CONFIG_EXECUTABLE}")
|
||||||
|
|
||||||
if (NOT XO_SUBMODULE_BUILD)
|
if (NOT XO_SUBMODULE_BUILD)
|
||||||
message("-- CMAKE_INSTALL_PREFIX=${CMAKE_INSTALL_PREFIX}")
|
if (("${CMAKE_MODULE_PATH}" STREQUAL "") OR ("${CMAKE_MODULE_PATH}" STREQUAL prefix))
|
||||||
message("-- CMAKE_MODULE_PATH=${CMAKE_MODULE_PATH}")
|
# default to typical install location for xo-project-macros
|
||||||
|
execute_process(COMMAND ${XO_CMAKE_CONFIG_EXECUTABLE} --cmake-module-path OUTPUT_VARIABLE CMAKE_MODULE_PATH)
|
||||||
|
message(STATUS "CMAKE_MODULE_PATH=${CMAKE_MODULE_PATH}")
|
||||||
|
endif()
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
# needs to have been installed somewhere on CMAKE_MODULE_PATH,
|
# needs to have been installed somewhere on CMAKE_MODULE_PATH,
|
||||||
# (e.g. from xo-cmake with the same value for CMAKE_INSTALL_PREFIX)
|
# (e.g. from xo-cmake with the same value for CMAKE_INSTALL_PREFIX)
|
||||||
#
|
#
|
||||||
include(xo_macros/xo-project-macros)
|
include(xo_macros/xo_cxx)
|
||||||
|
|
||||||
|
xo_cxx_bootstrap_message()
|
||||||
|
|
|
||||||
|
|
@ -67,7 +67,7 @@ namespace xo {
|
||||||
* send output to ws_sink
|
* send output to ws_sink
|
||||||
*/
|
*/
|
||||||
CallbackId subscribe(std::string const & incoming_uri,
|
CallbackId subscribe(std::string const & incoming_uri,
|
||||||
ref::rp<AbstractSink> const & ws_sink) const;
|
rp<AbstractSink> const & ws_sink) const;
|
||||||
|
|
||||||
/* unsubscribe stream from this endpoint;
|
/* unsubscribe stream from this endpoint;
|
||||||
* reverses the effect of a previous call to .subscribe()
|
* reverses the effect of a previous call to .subscribe()
|
||||||
|
|
|
||||||
|
|
@ -83,8 +83,8 @@ namespace xo {
|
||||||
* the underlying libwebsocket library is not advertised to be
|
* the underlying libwebsocket library is not advertised to be
|
||||||
* threadsafe
|
* threadsafe
|
||||||
*/
|
*/
|
||||||
static ref::rp<Webserver> make(WebserverConfig const & ws_config,
|
static rp<Webserver> make(WebserverConfig const & ws_config,
|
||||||
ref::rp<PrintJson> const & pjson);
|
rp<PrintJson> const & pjson);
|
||||||
|
|
||||||
/* current state */
|
/* current state */
|
||||||
virtual Runstate state() const = 0;
|
virtual Runstate state() const = 0;
|
||||||
|
|
|
||||||
|
|
@ -17,10 +17,10 @@ namespace xo {
|
||||||
using PrintJson = xo::json::PrintJson;
|
using PrintJson = xo::json::PrintJson;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
static ref::rp<WebsocketSink> make(ref::rp<Webserver> const & websrv,
|
static rp<WebsocketSink> make(rp<Webserver> const & websrv,
|
||||||
ref::rp<PrintJson> const & pjson,
|
rp<PrintJson> const & pjson,
|
||||||
uint32_t session_id,
|
uint32_t session_id,
|
||||||
std::string const & stream_name);
|
std::string const & stream_name);
|
||||||
}; /*WebsocketSink*/
|
}; /*WebsocketSink*/
|
||||||
} /*namespace web*/
|
} /*namespace web*/
|
||||||
} /*namespace xo*/
|
} /*namespace xo*/
|
||||||
|
|
|
||||||
|
|
@ -8,7 +8,6 @@
|
||||||
namespace xo {
|
namespace xo {
|
||||||
using xo::web::Alist;
|
using xo::web::Alist;
|
||||||
using xo::fn::CallbackId;
|
using xo::fn::CallbackId;
|
||||||
using xo::ref::rp;
|
|
||||||
|
|
||||||
namespace web {
|
namespace web {
|
||||||
DynamicEndpoint::DynamicEndpoint(std::string uri_pattern,
|
DynamicEndpoint::DynamicEndpoint(std::string uri_pattern,
|
||||||
|
|
|
||||||
|
|
@ -34,7 +34,6 @@ namespace xo {
|
||||||
using xo::reactor::AbstractSink;
|
using xo::reactor::AbstractSink;
|
||||||
using xo::json::PrintJson;
|
using xo::json::PrintJson;
|
||||||
using xo::fn::CallbackId;
|
using xo::fn::CallbackId;
|
||||||
using xo::ref::rp;
|
|
||||||
using xo::scope;
|
using xo::scope;
|
||||||
using xo::xtag;
|
using xo::xtag;
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -16,7 +16,6 @@ namespace xo {
|
||||||
using xo::reflect::Reflect;
|
using xo::reflect::Reflect;
|
||||||
using xo::reflect::TaggedPtr;
|
using xo::reflect::TaggedPtr;
|
||||||
using xo::reflect::TypeDescr;
|
using xo::reflect::TypeDescr;
|
||||||
using xo::ref::rp;
|
|
||||||
using xo::ref::brw;
|
using xo::ref::brw;
|
||||||
using xo::print::quot;
|
using xo::print::quot;
|
||||||
using xo::print::qcstr;
|
using xo::print::qcstr;
|
||||||
|
|
@ -36,8 +35,8 @@ namespace xo {
|
||||||
using AbstractSource = reactor::AbstractSource;
|
using AbstractSource = reactor::AbstractSource;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
WebsocketSinkImpl(ref::rp<Webserver> const & websrv,
|
WebsocketSinkImpl(rp<Webserver> const & websrv,
|
||||||
ref::rp<PrintJson> const & pjson,
|
rp<PrintJson> const & pjson,
|
||||||
uint32_t session_id,
|
uint32_t session_id,
|
||||||
std::string stream_name)
|
std::string stream_name)
|
||||||
: websrv_{std::move(websrv)},
|
: websrv_{std::move(websrv)},
|
||||||
|
|
@ -56,7 +55,7 @@ namespace xo {
|
||||||
virtual TypeDescr sink_ev_type() const override;
|
virtual TypeDescr sink_ev_type() const override;
|
||||||
virtual bool allow_volatile_source() const override { return true; }
|
virtual bool allow_volatile_source() const override { return true; }
|
||||||
virtual uint32_t n_in_ev() const override { return n_in_ev_; }
|
virtual uint32_t n_in_ev() const override { return n_in_ev_; }
|
||||||
virtual void attach_source(ref::rp<AbstractSource> const & src) override;
|
virtual void attach_source(rp<AbstractSource> const & src) override;
|
||||||
virtual void notify_ev_tp(TaggedPtr const & ev_tp) override;
|
virtual void notify_ev_tp(TaggedPtr const & ev_tp) override;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
|
@ -66,9 +65,9 @@ namespace xo {
|
||||||
*/
|
*/
|
||||||
std::string name_;
|
std::string name_;
|
||||||
/* webserver implementation */
|
/* webserver implementation */
|
||||||
ref::rp<Webserver> websrv_;
|
rp<Webserver> websrv_;
|
||||||
/* print arbitrary reflected stuff as json */
|
/* print arbitrary reflected stuff as json */
|
||||||
ref::rp<PrintJson> pjson_;
|
rp<PrintJson> pjson_;
|
||||||
/* websocket session id# - events arriving at this sink
|
/* websocket session id# - events arriving at this sink
|
||||||
* will be sent only to the session identified by .session_id
|
* will be sent only to the session identified by .session_id
|
||||||
*/
|
*/
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue