Restructure CMake Build System to Follow Modern Best Practices #1349
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
Restructure CMake Build System to Follow Modern Best Practices
Problem
The current yaml-cpp build system has several issues:
It uses
file(GLOB ...)
for finding source files, which:The build system structure doesn't follow modern CMake organization:
Solution
This MR implements a proper hierarchical CMake structure that:
Follows modern CMake best practices:
src/CMakeLists.txt
add_subdirectory()
approach instead of globbingThe structure establishes clear responsibilities:
Benefits
Implementation Details
The implementation follows a carefully structured approach:
Root CMakeLists.txt:
add_subdirectory(src)
to delegate library buildingsrc/CMakeLists.txt:
add_library(yaml-cpp)
)src/contrib/CMakeLists.txt:
The provided script can automatically generate this structure from an existing yaml-cpp repository.
Notes for Maintainers
With this new structure:
add_subdirectory()