Skip to content
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

Draft
wants to merge 3 commits into
base: development
Choose a base branch
from

Conversation

moschmdt
Copy link

@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 the SoarCLI.
Additionally, the CMake build uses the conan package manager to fetch dependencies for all platforms, currently only SQLite3.

The only part where scons and CMake interfere is the following problem:
scons adds a file called build_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?

Starting the devcontainer will install essential vs code extensions and directly start a build via cmake in the debug configuration.
@garfieldnate
Copy link
Collaborator

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.

@garfieldnate
Copy link
Collaborator

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?

@moschmdt
Copy link
Author

moschmdt commented Nov 20, 2024

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?

SWIG

SWIG is not built with CMake right now, but should be possible according to swig_add_library(..) CMake.

SVS

Not built.

SoarCLI

Already built with CMake, cf. SoarCLI/CMakeLists.txt as a subproject.

Unit Tests

I got them built with CMake but this is not ready to merge, thus not included in this PR.

SCU and non-SCU versions of the build

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.

@moschmdt
Copy link
Author

I do think we need to generate the build_time_date.h file.

Is there any specific reason why it is not tracked via git and generated during build time? The following code is from the generated build_time_date.h file, but the __TIME__ and __DATE__ all already macros replaced during build time. This looks to me like that was from a time before those macros existed?
If there are no opposing arguments, we could just add the file to the git repo and the problem is fixed? No further CMake required and SCons checks if the file is available - so no change needed here.

const char *kTimestamp = __TIME__;
const char *kDatestamp = __DATE__;
//* Last build of Soar 9.6.3 occurred at Fri Nov 22 17:20:20 2024 *//

@moschmdt
Copy link
Author

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

@moschmdt moschmdt mentioned this pull request Dec 9, 2024
@moschmdt moschmdt marked this pull request as draft December 11, 2024 19:17
@moschmdt
Copy link
Author

@garfieldnate
Copy link
Collaborator

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.

@garfieldnate
Copy link
Collaborator

Sorry, I don't see a reference to stdint.h in that ticket. Could you be more specific?

@garfieldnate
Copy link
Collaborator

If there are no opposing arguments, we could just add the file to the git repo

That sounds fine to me, as well.

@moschmdt
Copy link
Author

Sorry, I don't see a reference to stdint.h in that ticket. Could you be more specific?

#322 (comment)

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.

The same unit tests are running, except the testCommandToFile because they keep failing with the following error in this line:

no_agent_assertTrue(result == resultString);

result = 0x7fa228012650 "Error changing to ./SoarUnitTests//\nError while sourcing file\n"

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.

@garfieldnate
Copy link
Collaborator

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.

@moschmdt
Copy link
Author

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).

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants