restructure and manage own deps

This commit is contained in:
Green Sky 2024-02-04 13:20:15 +01:00
parent 20af7dd705
commit a1f5add8d3
No known key found for this signature in database
17 changed files with 115 additions and 27 deletions

View File

@ -1,34 +1,66 @@
cmake_minimum_required(VERSION 3.9 FATAL_ERROR)
cmake_minimum_required(VERSION 3.24 FATAL_ERROR)
project(solanaceae)
# cmake setup begin
project(solanaceae_message3)
add_library(solanaceae_message3
./solanaceae/message3/file.hpp
./solanaceae/message3/file_r_mem.hpp
./solanaceae/message3/file_r_file.hpp
./solanaceae/message3/file_w_file.hpp
./solanaceae/message3/file_rw_file.hpp
if (CMAKE_SOURCE_DIR STREQUAL CMAKE_CURRENT_SOURCE_DIR)
set(SOLANACEAE_MESSAGE3_STANDALONE ON)
else()
set(SOLANACEAE_MESSAGE3_STANDALONE OFF)
endif()
message("II SOLANACEAE_MESSAGE3_STANDALONE " ${SOLANACEAE_MESSAGE3_STANDALONE})
./solanaceae/message3/components.hpp
./solanaceae/message3/components_id.inl
if (SOLANACEAE_MESSAGE3_STANDALONE)
set(CMAKE_POSITION_INDEPENDENT_CODE ON)
./solanaceae/message3/message_model3.hpp
# defaulting to debug mode, if not specified
if(NOT CMAKE_BUILD_TYPE)
set(CMAKE_BUILD_TYPE "Debug")
endif()
./solanaceae/message3/registry_message_model.hpp
./solanaceae/message3/registry_message_model.cpp
# setup my vim ycm :D
set(CMAKE_EXPORT_COMPILE_COMMANDS ON)
./solanaceae/message3/message_time_sort.hpp
./solanaceae/message3/message_time_sort.cpp
# more paths
set(CMAKE_ARCHIVE_OUTPUT_DIRECTORY "${CMAKE_BINARY_DIR}/lib")
set(CMAKE_LIBRARY_OUTPUT_DIRECTORY "${CMAKE_BINARY_DIR}/bin")
set(CMAKE_RUNTIME_OUTPUT_DIRECTORY "${CMAKE_BINARY_DIR}/bin")
endif()
./solanaceae/message3/message_command_dispatcher.hpp
./solanaceae/message3/message_command_dispatcher.cpp
)
# external libs
add_subdirectory(./external EXCLUDE_FROM_ALL) # before increasing warn levels, sad :(
target_include_directories(solanaceae_message3 PUBLIC .)
target_compile_features(solanaceae_message3 PUBLIC cxx_std_17)
target_link_libraries(solanaceae_message3 PUBLIC
solanaceae_util
solanaceae_contact
EnTT::EnTT
)
if (SOLANACEAE_MESSAGE3_STANDALONE)
set(CMAKE_CXX_EXTENSIONS OFF)
# bump up warning levels appropriately for clang, gcc & msvc
if (${CMAKE_CXX_COMPILER_ID} STREQUAL "GNU" OR ${CMAKE_CXX_COMPILER_ID} STREQUAL "Clang")
add_compile_options(
-Wall -Wextra # Reasonable and standard
-Wpedantic # Warn if non-standard C++ is used
-Wunused # Warn on anything being unused
#-Wconversion # Warn on type conversions that may lose data
#-Wsign-conversion # Warn on sign conversions
-Wshadow # Warn if a variable declaration shadows one from a parent context
)
if (NOT WIN32)
#link_libraries(-fsanitize=address)
#link_libraries(-fsanitize=address,undefined)
#link_libraries(-fsanitize-address-use-after-scope)
#link_libraries(-fsanitize=undefined)
endif()
elseif (${CMAKE_CXX_COMPILER_ID} STREQUAL "MSVC")
if (CMAKE_CXX_FLAGS MATCHES "/W[0-4]")
string(REGEX REPLACE "/W[0-4]" "/W4" CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS}")
else()
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} /W4")
endif()
endif()
endif()
# cmake setup end
add_subdirectory(./src)

22
external/CMakeLists.txt vendored Normal file
View File

@ -0,0 +1,22 @@
cmake_minimum_required(VERSION 3.24 FATAL_ERROR)
include(FetchContent)
if (NOT TARGET solanaceae_contact)
FetchContent_Declare(solanaceae_contact
GIT_REPOSITORY https://github.com/Green-Sky/solanaceae_contact.git
GIT_TAG master
EXCLUDE_FROM_ALL
)
FetchContent_MakeAvailable(solanaceae_contact)
endif()
if (NOT TARGET solanaceae_util)
FetchContent_Declare(solanaceae_util
GIT_REPOSITORY https://github.com/Green-Sky/solanaceae_util.git
GIT_TAG master
EXCLUDE_FROM_ALL
)
FetchContent_MakeAvailable(solanaceae_util)
endif()

30
src/CMakeLists.txt Normal file
View File

@ -0,0 +1,30 @@
add_library(solanaceae_message3
./solanaceae/message3/file.hpp
./solanaceae/message3/file_r_mem.hpp
./solanaceae/message3/file_r_file.hpp
./solanaceae/message3/file_w_file.hpp
./solanaceae/message3/file_rw_file.hpp
./solanaceae/message3/components.hpp
./solanaceae/message3/components_id.inl
./solanaceae/message3/message_model3.hpp
./solanaceae/message3/registry_message_model.hpp
./solanaceae/message3/registry_message_model.cpp
./solanaceae/message3/message_time_sort.hpp
./solanaceae/message3/message_time_sort.cpp
./solanaceae/message3/message_command_dispatcher.hpp
./solanaceae/message3/message_command_dispatcher.cpp
)
target_include_directories(solanaceae_message3 PUBLIC .)
target_compile_features(solanaceae_message3 PUBLIC cxx_std_17)
target_link_libraries(solanaceae_message3 PUBLIC
solanaceae_util
solanaceae_contact
EnTT::EnTT
)

View File

@ -41,14 +41,18 @@ MessageCommandDispatcher::MessageCommandDispatcher(
MessageCommandDispatcher::~MessageCommandDispatcher(void) {
}
void MessageCommandDispatcher::iterate(float) {
float MessageCommandDispatcher::iterate(float) {
if (!_message_queue.empty()) {
_rmm.sendText(
_message_queue.front().to,
_message_queue.front().message
);
_message_queue.pop_front();
return 0.05f;
}
return 1.f*60.f*60.f; // 1h
}
static std::string_view get_first_word(std::string_view text, std::string_view::size_type& out_next) {

View File

@ -59,7 +59,7 @@ class MessageCommandDispatcher : public RegistryMessageModelEventI {
MessageCommandDispatcher(Contact3Registry& cr, RegistryMessageModel& rmm, ConfigModelI& conf);
~MessageCommandDispatcher(void);
void iterate(float time_delta);
float iterate(float time_delta);
// TODO: think more about permissions?
// - user(s)