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

CPM_SOURCE_CACHE is ignored if SOURCE_DIR is set #542

Closed
gerhardol opened this issue Mar 1, 2024 · 0 comments · Fixed by #543
Closed

CPM_SOURCE_CACHE is ignored if SOURCE_DIR is set #542

gerhardol opened this issue Mar 1, 2024 · 0 comments · Fixed by #543

Comments

@gerhardol
Copy link
Contributor

gerhardol commented Mar 1, 2024

CPM.cmake is great but I see some improvements:

  • When using CPM_SOURCE_CACHE it would be nice to see the version in the cachepath, so you see what version there is on the filesystem
  • If SOURCE_DIR is set, the behavior is basically the same as FetchContent. CPM_SOURCE_CACHE is effectively ignored, you have to implement locking and files are downloaded again each time the command runs.
  • With CPM_SOURCE_CACHE the download dir is a sha from the arguments. If e.g. the patch command has a path, the sha is different also if the contents is identical. The contents of files are not checked though, so the sha is not reliable.

One way to solve all of this is to use SOURCE_DIR as the path if CPM_SOURCE_CACHE is set, at least if SOURCE_DIR starts with CPM_SOURCE_CACHE . Then it is up to the caller to set a unique path that is viewable.
(I also would like to add the version to the sha if not set as an extra measure.)
That would change the behavior slightly, but a new configuration could be confusing too.
Edit: I will start by adding a new argument to CPMAddPackage like CACHE_DIR_NAME, that can be described in a sane way and no backward compatibility issues.

I want to use this to download a 1GB package with compiler etc. That will be shared with maybe 50 application repos so there should be only one copy and must be locked when downloading.
(Annoyingly, the toolchain requires env vars and CMake does not set those so the build script has to download them as a separate step before configure and due to #541 (probably CMake) this must be done in a project()).
So far I have added some private patches but it would be nice to avoid these patches. I can make a PR.

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 a pull request may close this issue.

1 participant