-
Notifications
You must be signed in to change notification settings - Fork 72
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Inital support CMake build and Devcontainer configuration #523
base: development
Are you sure you want to change the base?
Conversation
Starting the devcontainer will install essential vs code extensions and directly start a build via cmake in the debug configuration.
Wonderful, thank you very much! Just to confirm, SWIG, SVS and SoarCLI are excluded not because they are impossible to build with CMake, but because they were not needed for the ROS2 package, correct? I do think we need to generate the build_time_date.h file. I would also update it in the future to contain the commit SHA. I haven't tested this, but GPT suggested generation code that looks like this: cmake_minimum_required(VERSION 3.16)
project(MyProject)
# ... other CMake code ...
# Get timestamp and Git SHA
string(TIMESTAMP CURRENT_TIMESTAMP "%Y-%m-%d %H:%M:%S")
execute_process(
COMMAND git rev-parse HEAD
WORKING_DIRECTORY ${CMAKE_SOURCE_DIR}
OUTPUT_VARIABLE GIT_SHA
OUTPUT_STRIP_TRAILING_WHITESPACE
ERROR_QUIET
)
# Generate the version file
configure_file("${CMAKE_CURRENT_SOURCE_DIR}/build_time_date.h.in" "${CMAKE_CURRENT_BINARY_DIR}/build_time_date.h")
# Add the generated header file to the include directories
include_directories("${CMAKE_CURRENT_BINARY_DIR}") I will not have time to review this until December, but I'm very grateful for the contribution and look forward to improving the build system. |
Haven't reviewed it yet, but I do have a question: does this support both the SCU and non-SCU versions of the build? Or if only one, which one? The non-SCU version is supposed to be easier to debug (see #500). I'm not sure what the advantage of the SCU version is; perhaps compile time? |
SWIGSWIG is not built with CMake right now, but should be possible according to SVSNot built. SoarCLIAlready built with CMake, cf. SoarCLI/CMakeLists.txt as a subproject. Unit TestsI got them built with CMake but this is not ready to merge, thus not included in this PR.
For now, this supports only the builds based on the cxx files. As far as I can tell, this means SCU compilation, since there was no benefit to collecting all source files individually for me. The same applies to shared vs. static library. The PR only adds the static library build for now - could be extended without much additional effort later if needed, e.g. for SWIG or Python bindings. I did some debugging and never had any debugging problems with the CMake VS Code extensions. |
Is there any specific reason why it is not tracked via git and generated during build time? The following code is from the generated const char *kTimestamp = __TIME__;
const char *kDatestamp = __DATE__;
//* Last build of Soar 9.6.3 occurred at Fri Nov 22 17:20:20 2024 *// |
I just had a little time to work on the Unit Tests. Currently 384/394 test are completed successfully. Most of the failing tests are SVS related. @garfieldnate should I include it in this PR? Last test output: https://github.com/moschmdt/Soar/actions/runs/12046432023/job/33586895049#step:11:1 |
|
Sorry I missed that message before! Yes, would love to see it included. We do have to get the unit tests passing, but you'll see in our CI configuration that we disable a few of the tests. |
Sorry, I don't see a reference to |
That sounds fine to me, as well. |
The same unit tests are running, except the Soar/UnitTests/SoarUnitTests/FullTests.cpp Line 1668 in d3ce90c
SVS tests are disabled because building with CMake is not implemented. Might happen in a following PR. Unfortunately, I neither have a Windows machine nor a direct use case for it right now. Maybe someone from the Sour group can take the initial starting points and fix the build local and in CI. |
Why did you choose to use Conan as the package manager? I think vcpkg is the other popular one. I'm not familiar with either, so I'm just trying to understand the choices and trade-offs here a bit. |
We started to use Conan in other projects, and so far we have had good experience with it and the amount of available packages. There are multiple blog posts about the pro and cons, e.g. matgomes.com or reddit (comparison with deprecated Conan v1.x). |
@garfieldnate as discussed, this is the initial draft for CMake build without interfering with
scons
as far as possible.This builds the
soar
library, excluding the SWIG interfaces and SVS, as well as theSoarCLI
.Additionally, the CMake build uses the
conan
package manager to fetch dependencies for all platforms, currently onlySQLite3
.The only part where
scons
and CMake interfere is the following problem:scons
adds a file calledbuild_time_date.h
during the build process, which leads to failing builds for CMake. Is the build time still relevant that it should be behind a feature flag, is the feature rather deprecated and could be removed, or should this be replicated in CMake @garfieldnate?