From 87f10dad540971c4aa22d892c676dce590ca189a Mon Sep 17 00:00:00 2001 From: Amlal Date: Sat, 9 Aug 2025 21:54:20 +0200 Subject: feat: move network.hpp to net/ and working on url.hpp Signed-off-by: Amlal --- dev/lib/fix/network.hpp | 117 ------------------------------------------------ dev/lib/fix/parser.hpp | 6 +-- 2 files changed, 3 insertions(+), 120 deletions(-) delete mode 100644 dev/lib/fix/network.hpp (limited to 'dev/lib/fix') diff --git a/dev/lib/fix/network.hpp b/dev/lib/fix/network.hpp deleted file mode 100644 index edd4c26..0000000 --- a/dev/lib/fix/network.hpp +++ /dev/null @@ -1,117 +0,0 @@ -/* - * File: fix/network.hpp - * Purpose: Financial Information Exchange in C++ - * Author: Amlal El Mahrouss (founder@snu.systems) - * Copyright 2025, Amlal El Mahrouss and SNU Systems Corp. - */ - -#ifndef _SNU_FIX_NETWORK_HPP -#define _SNU_FIX_NETWORK_HPP - -#include -#include -#include -#include - -#define SNU_MODEM : protected snu::fix::basic_delivery_modem - -namespace snu::fix -{ - class basic_delivery_modem; - - typedef int32_t delivery_socket_type; - - /// @brief a delivery modem is a container which establishes a comm. channel between the FIX session and application. - class basic_delivery_modem - { - public: - explicit basic_delivery_modem() = default; - virtual ~basic_delivery_modem() = default; - - basic_delivery_modem& operator=(const basic_delivery_modem&) = default; - basic_delivery_modem(const basic_delivery_modem&) = default; - - public: - static constexpr auto local_address = "127.0.0.1"; - static constexpr auto backlog_count = 18U; - - public: - delivery_socket_type fd_{}; - - template - bool receive(T& out, std::size_t len) noexcept - { - static_assert(std::is_pointer::value, "T is not a pointer!"); - - if (!out) - return false; - - if (!len) - return false; - - auto ret = ::recv(fd_, out, len, MSG_WAITALL); - - return ret > 0; - } - - template - bool transmit(T& out, std::size_t len) noexcept - { - static_assert(std::is_pointer::value, "T is not a pointer!"); - - if (!out) - return false; - - if (!len) - return false; - - auto ret = ::send(fd_, out, len, 0); - - return ret > 0; - } - - template - bool construct(const char* addr = basic_delivery_modem::local_address, const bool& is_server = false) noexcept - { - static_assert(AF != 0, "AF is zero"); - static_assert(Kind != 0, "Kind is zero"); - static_assert(IPProto != 0, "IPProto is zero"); - - fd_ = ::socket(AF, Kind, IPProto); - - if (fd_ < 1) - return false; - - struct sockaddr_in addr_ - { - }; - - addr_.sin_addr.s_addr = ::inet_addr(addr); - addr_.sin_port = Port; - - if (!is_server) - { - auto ret = ::connect(fd_, (struct sockaddr*)&addr_, sizeof(decltype(addr_))); - return ret == 0; - } - - ::listen(fd_, basic_delivery_modem::backlog_count); - - return true; - } - - bool destroy() noexcept - { - if (!fd_) - return false; - - ::shutdown(fd_, SHUT_RDWR); - - fd_ = 0U; - - return true; - } - }; -} // namespace snu::fix - -#endif // ifndef _SNU_FIX_NETWORK_HPP \ No newline at end of file diff --git a/dev/lib/fix/parser.hpp b/dev/lib/fix/parser.hpp index 5701783..f0f7141 100644 --- a/dev/lib/fix/parser.hpp +++ b/dev/lib/fix/parser.hpp @@ -27,7 +27,7 @@ namespace snu::fix struct basic_range; template - struct basic_range_data; + class basic_range_data; /// @brief Buffer+Length structure template @@ -65,7 +65,7 @@ namespace snu::fix bool is_valid() { - return bytes_ && length_ > 0; + return this->bytes_ && this->length_ > 0; } operator bool() @@ -98,7 +98,7 @@ namespace snu::fix static inline const char_type* begin = detail::begin_fix(); explicit basic_range_data() = default; - ~basic_range_data() = default; + ~basic_range_data() = default; basic_range_data& operator=(const basic_range_data&) = default; basic_range_data(const basic_range_data&) = default; -- cgit v1.2.3