-
Notifications
You must be signed in to change notification settings - Fork 1.8k
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
Updated cuda-api-wrappers with versions 0.7.1 and 0.8.0 #26256
Conversation
d5053a9
to
8f8353e
Compare
@valgur , @franramirez688 : Four months have passed, and I've released a new version. Closed the last PR, opened this one. Please don't let me wait four more months... edit: Now passing the checks. |
b266bc0
to
b9c01ff
Compare
@@ -1,10 +1,10 @@ | |||
cmake_minimum_required(VERSION 3.15) | |||
cmake_minimum_required(VERSION 3.25) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
thanks @eyalroz for your PR.
it's a bit unusual for a test package (and a test package alone) to require a higher version of CMake - because the find_package(cuda-api-wrappers REQUIRED CONFIG)
call is resolved with files that COnan generates targeting compatible with at least CMake 3.15
if you could provide more details as to why this is needed (e.g. what error this is fixing, with logs), that would be great, thanks!
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Well, let me first note that the (non-test) package does requires v3.25; it's just that the package doesn't get build - it's a header-only library.
The CMake version bump is due to the need is for decent and relatively comprehensive CUDA support, and as you may be aware, that's still very much a work in progress at Kitware. Some changes in locating / identifying the "NVIDIA Toolkit Extensions" library were made in v3.25, which make it actually work on Windows.
See also:
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I see, thanks for providing additional insights!
The recipe itself is not currently using CMake, and only "copies" header files to the package folder:
conan-center-index/recipes/cuda-api-wrappers/all/conanfile.py
Lines 37 to 42 in b9c01ff
copy( | |
self, | |
pattern="*", | |
dst=os.path.join(self.package_folder, "include"), | |
src=os.path.join(self.source_folder, "src"), | |
) |
So while this project https://github.com/eyalroz/cuda-api-wrappers/blob/master/CMakeLists.txt would require a recent version of CMake, it's not really part of the package process.
As for the test package in this repository: the purpose is to have a very simple check of verifying that find_package(cuda-api-wrappers)
works, for a header-only library, that the compiler can locate a header from the package (assuming
#include <cuda/define_specifiers.hpp> |
std::cout << "cuda-api-wrappers v" << CUDA_API_WRAPPERS_VERSION << std::endl; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
So while this project https://github.com/eyalroz/cuda-api-wrappers/blob/master/CMakeLists.txt would require a recent version of CMake, it's not really part of the package process.
I'm the opposite of an expert on conan matters, but still... CMake 3.25 is necessary to properly locate and register the relevant dependencies in the exported .cmake
files; does that not make it part of the packaging process?
As for the test package in this repository: the purpose is to have a very simple check of verifying that
find_package(cuda-api-wrappers)
works, for a header-only library, that the compiler can locate a header from the package
But that's not how the library works. find_package(cuda-api-wrappers)
locates configuration files; and these files require CMake 3.25 . Are you suggesting I write a test package which does a lower-level file search? I suppose I could do that, but it wouldn't really test much of anything.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
What I mean is that the the test package does not require CMake 3.25, and it should work with whatever version was there before (just for the purposes of the test package).
in the exported .cmake files; does that not make it part of the packaging process?
Conan Center does not make use of packaged .cmake files - instead, the relevant information is included in package_info()
- and then Conan generates the files for the consumer. Those files, as generated by Conan, target CMake 3.15 (and usually, when they are generated by CMake,t hey are also compatible with other versions).
As I mentioned before, the recipe for cuda-api-wrappers
, not only is it not generating or packaging the exported CMake files - it is not even invoking CMake at all
https://github.com/conan-io/conan-center-index/blob/b9c01ff294197ca0120d734546d838811324e36a/recipes/cuda-api-wrappers/all/conanfile.py
But that's not how the library works. find_package(cuda-api-wrappers) locates configuration files; and these files require CMake 3.25 .
The configuration files that the test package are locating, are generated by Conan and they are compatible with CMake 3.15 -
Are you suggesting I write a test package which does a lower-level file search?
Just suggesting that for the sake of the test_package inside Conan Center in this PR - these cmake changes are not necessary - I understand that they are necessary for actual users of the library, but that is not the in the scope of the test package.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
the test package does not require CMake 3.25, and it should work with whatever version was there before
Ok, removed that requirement and it does indeed work. :-)
Sorry for being a little slow to understand.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Sorry for being a little slow to understand.
Oh no need to apologise! Our goal here is to ensure that the reason for changes proposed in PRs is understood and visible to anyone who reviews the PR now or in the future - as it helps with ongoing maintenance too :)
b9c01ff
to
adb2d94
Compare
* Removed 0.7 beta versions * Added versions 0.7.0, 0.7.1 and 0.8.0 * Now specifying the correct exported target name in the main `conanfile.py` * Now using the correct the target name in the test package's `CMakeLists.txt`
adb2d94
to
11f6099
Compare
self.cpp_info.set_property("cmake_target_name", "cuda-api-wrappers::runtime-and-driver") | ||
if Version(self.version) < "0.7.0": | ||
# For previously published versions the target name was different, maintain compatibility | ||
self.cpp_info.set_property("cmake_target_aliases", ["cuda-api-wrappers::cuda-api-wrappers"]) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
For older versions and just a precaution I'm also adding the previously used target name - to avoid disruption if existing users update the recipe revision.
users wishing to move to a newer version will have to use the correct target name
Summary
Changes to recipe: cuda-api-wrappers
Motivation
Details