-
Notifications
You must be signed in to change notification settings - Fork 26
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
[c++] Support dynamic linking to libspdlog #3585
Comments
Now that I am aware that we aren't dynamically linking against the conda-installed libspdlog, this is allowing me to re-interpret our conversation in the Issue dedicated to troubleshooting the C++20 compilation errors. My mental model was that we were linking against the conda-installed libspdlog, but it appears that we were explicitly not doing that for some reason. It's a super-long Issue that discusses various things. Below are comments relevant to the discussion of linking against spdlog:
This raises a lot of questions for me. What are our requirements in regards to linking against spdlog that we have to statically link it instead of dynamically linking against a system version (eg installed by conda)? Does the patch used in the conda-forge recipe reveal how we could accomplish linking against a system version? |
I defer to @nguyenv and/or @XanthosXanthopoulos (in addition to @jdblischak ). All I want is green CI, in this repo as well as the I'm happy with whatever it takes to get us there. |
Sorry for any confusion, but I only suggested building |
@nguyenv thanks for the clarification! Now I better understand your previous suggestion. Thus I think we should be able to fix the CMake files to support either static linking an external project or dynamically linking a system library for libspdlog. I am not the CMake expert among us, so if someone better understands the patch I linked above, please feel free to experiment. Otherwise I can attempt to investigate more next week. |
These finding match what I saw with some experiments when debugging the C++20 builds. There where some linking errors regarding |
Replicating the steps in the patch file, I haven't managed to dynamically link |
Some more thoughts after having seen TileDB-Inc/TileDB#5427:
|
Following the discussion in TileDB-Inc/TileDB/pull/5427 and spdlog/pull/3322 I managed to build locally and found the issue. When we migrated to C++20 we added a flag The recipe in conda-forge succeeded because TileDB-SOMA 1.15 is still in C++17 and without this flag so the linking was succeesful. So in order to support dynamic linking this flag needs to be unset and only be enabled if we are using the header only version or we are compiling spdlog ourselves. |
When installing libtiledbsoma in a conda environment, we want to dynamically link to the binaries installed by conda. Currently our conda-build in tiledbsoma-feedstock dynamically links to the conda-installed libfmt but not to the conda-installed libspdlog.
This was discovered in the PR to add tiledbsoma to conda-forge (conda-forge/staged-recipes#28828). The contributor added a patch that allowed libtiledbsoma to dynamically link to the conda-installed libspdlog. We need to evaluate this patch. While we want to enable dynamically linking to an existing libspdlog installed in the system, we also need to ensure that we continue to support a bootstrapped installation where we download libspdlog and statically link it.
For more details, please see the discussion starting at conda-forge/staged-recipes#28828 (comment)
The text was updated successfully, but these errors were encountered: