Verified Commit 4d12b240 authored by Alberto Miranda's avatar Alberto Miranda ♨️
Browse files

Reorganize source code

- `scord` daemon now has its own directory in `src/scord`
- `scord-ctl` daemon now has its own directory in `src/scord-ctl`
- library code now lives under the  `lib` directory
- public rpc definitions now live in `src/lib/rpcs/`
- private rpc definitions for each daemon now live in
  `src/scord/rpcs/` and `src/scord-ctl/rpcs/`, respectively
- `config`, `logger`, and `network` code now live under the `common` directory
parent de4632cf
Loading
Loading
Loading
Loading
Loading
+1 −1
Original line number Diff line number Diff line
@@ -38,6 +38,6 @@ foreach (example IN LISTS examples_cxx)
    add_executable(${example}_cxx)
    target_sources(${example}_cxx PRIVATE ${example}.cpp)
    target_link_libraries(${example}_cxx
      PUBLIC network_engine fmt::fmt adm_iosched)
      PUBLIC common::network::engine fmt::fmt adm_iosched)
    set_target_properties(${example}_cxx PROPERTIES OUTPUT_NAME ${example})
endforeach()
+5 −33
Original line number Diff line number Diff line
@@ -22,37 +22,9 @@
# SPDX-License-Identifier: GPL-3.0-or-later                                    #
################################################################################

add_subdirectory(config)
add_subdirectory(utils)
add_subdirectory(logger)
add_subdirectory(network)
add_subdirectory(rpcs)
add_subdirectory(common)
add_subdirectory(scord)
add_subdirectory(scord-ctl)

# scord daemon
add_executable(scord scord.cpp)

target_include_directories(
  scord PRIVATE ${CMAKE_CURRENT_SOURCE_DIR} ${CMAKE_CURRENT_BINARY_DIR}
)

target_link_libraries(
  scord PRIVATE config logger rpc_server fmt::fmt Boost::program_options
)

install(TARGETS scord DESTINATION ${CMAKE_INSTALL_BINDIR})

# scord-ctl daemon
add_executable(scord-ctl scord-ctl.cpp)

target_include_directories(
  scord-ctl PRIVATE ${CMAKE_CURRENT_SOURCE_DIR} ${CMAKE_CURRENT_BINARY_DIR}
)

target_link_libraries(
  scord-ctl PRIVATE config logger rpc_server fmt::fmt Boost::program_options
)

install(TARGETS scord DESTINATION ${CMAKE_INSTALL_BINDIR})

# public api libraries
add_subdirectory(api)
# public libraries
add_subdirectory(lib)
+46 −0
Original line number Diff line number Diff line
################################################################################
# Copyright 2021-2022, Barcelona Supercomputing Center (BSC), Spain            #
#                                                                              #
# This software was partially supported by the EuroHPC-funded project ADMIRE   #
#   (Project ID: 956748, https://www.admire-eurohpc.eu).                       #
#                                                                              #
# This file is part of scord.                                                  #
#                                                                              #
# scord is free software: you can redistribute it and/or modify                #
# it under the terms of the GNU General Public License as published by         #
# the Free Software Foundation, either version 3 of the License, or            #
# (at your option) any later version.                                          #
#                                                                              #
# scord is distributed in the hope that it will be useful,                     #
# but WITHOUT ANY WARRANTY; without even the implied warranty of               #
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the                #
# GNU General Public License for more details.                                 #
#                                                                              #
# You should have received a copy of the GNU General Public License            #
# along with scord.  If not, see <https://www.gnu.org/licenses/>.              #
#                                                                              #
# SPDX-License-Identifier: GPL-3.0-or-later                                    #
################################################################################

add_library(common INTERFACE)
target_include_directories(common INTERFACE ${CMAKE_CURRENT_SOURCE_DIR})

add_subdirectory(utils)
target_include_directories(_utils INTERFACE ${CMAKE_CURRENT_SOURCE_DIR})
add_library(common::utils ALIAS _utils)

add_subdirectory(config)
target_include_directories(_config INTERFACE ${CMAKE_CURRENT_SOURCE_DIR})
add_library(common::config ALIAS _config)

add_subdirectory(logger)
target_include_directories(_logger INTERFACE ${CMAKE_CURRENT_SOURCE_DIR})
add_library(common::logger ALIAS _logger)

add_subdirectory(network)
target_include_directories(_network_engine INTERFACE
  ${CMAKE_CURRENT_SOURCE_DIR})
add_library(common::network::engine ALIAS _network_engine)
target_include_directories(_rpc_server INTERFACE
  ${CMAKE_CURRENT_SOURCE_DIR})
add_library(common::network::rpc_server ALIAS _rpc_server)
+5 −5
Original line number Diff line number Diff line
@@ -23,18 +23,18 @@
################################################################################

# Create a config target for all configuration code
add_library(config STATIC)
add_library(_config STATIC)

# Since some of the sources will be auto-generated, we need to search for
# includes in ${CMAKE_CURRENT_BINARY_DIR}
target_include_directories(
  config PRIVATE ${CMAKE_SOURCE_DIR}/src ${CMAKE_CURRENT_SOURCE_DIR}
  _config PRIVATE ${CMAKE_CURRENT_SOURCE_DIR}
                 ${CMAKE_CURRENT_BINARY_DIR}
)
set_property(TARGET config PROPERTY POSITION_INDEPENDENT_CODE ON)
set_property(TARGET _config PROPERTY POSITION_INDEPENDENT_CODE ON)

target_sources(
  config
  _config
  PRIVATE config.hpp
          defaults.hpp
          ${CMAKE_CURRENT_BINARY_DIR}/defaults.cpp
@@ -46,7 +46,7 @@ target_sources(
          settings.hpp
)

target_link_libraries(config PRIVATE utils file_options::file_options)
target_link_libraries(_config PRIVATE common::utils file_options::file_options)

# ##############################################################################
# Produce several auto-generated files for 'config'
+0 −0

File moved.

Loading