Browse Source
update sirit-ci, fix zstd, update CPMUtil
update sirit-ci, fix zstd, update CPMUtil
Signed-off-by: crueter <crueter@eden-emu.dev>pull/2666/head
11 changed files with 36 additions and 289 deletions
-
3CMakeModules/Findzstd.cmake
-
258docs/CPM.md
-
14docs/CPMUtil.md
-
1docs/Deps.md
-
2docs/README.md
-
15externals/CMakeLists.txt
-
2externals/cpmfile.json
-
3tools/cpm/check-updates.sh
-
17tools/cpm/common.sh
-
5tools/cpm/format.sh
-
5tools/cpm/which.sh
@ -1,258 +0,0 @@ |
|||||
# CPM |
|
||||
|
|
||||
CPM (CMake Package Manager) is the preferred method of managing dependencies within Eden. |
|
||||
|
|
||||
Global Options: |
|
||||
|
|
||||
- `YUZU_USE_CPM` is set by default on MSVC and Android. Other platforms should use this if certain "required" system dependencies (e.g. OpenSSL) are broken or missing |
|
||||
* If this is `OFF`, required system dependencies will be searched via `find_package`, although certain externals use CPM regardless. |
|
||||
- `CPMUTIL_FORCE_SYSTEM` (default `OFF`): Require all CPM dependencies to use system packages. NOT RECOMMENDED! |
|
||||
* Many packages, e.g. mcl, sirit, xbyak, discord-rpc, are not generally available as a system package. |
|
||||
* You may optionally override these (see CPMUtil section) |
|
||||
- `CPMUTIL_FORCE_BUNDLED` (default `ON` on MSVC and Android, `OFF` elsewhere): Require all CPM dependencies to use bundled packages. |
|
||||
|
|
||||
## CPMUtil |
|
||||
|
|
||||
CPMUtil is a wrapper around CPM that aims to reduce boilerplate and add useful utility functions to make dependency management a piece of cake. |
|
||||
|
|
||||
### AddPackage |
|
||||
|
|
||||
`AddPackage` is the core of the CPMUtil wrapper, and is generally the lowest level you will need to go when dealing with dependencies. |
|
||||
|
|
||||
**Identification/Fetching** |
|
||||
|
|
||||
- `NAME` (required): The package name (must be the same as the `find_package` name if applicable) |
|
||||
- `VERSION`: The minimum version of this package that can be used on the system |
|
||||
- `GIT_VERSION`: The "version" found within git |
|
||||
- `URL`: The URL to fetch. |
|
||||
- `REPO`: The GitHub repo to use (`owner/repo`). |
|
||||
* Only GitHub is supported for now, though other platforms will see support at some point |
|
||||
- `TAG`: The tag to fetch, if applicable. |
|
||||
- `ARTIFACT`: The name of the artifact, if applicable. |
|
||||
- `SHA`: Commit sha to fetch, if applicable. |
|
||||
- `BRANCH`: Branch to fetch, if applicable. |
|
||||
|
|
||||
The following configurations are supported, in descending order of precedence: |
|
||||
|
|
||||
- `URL`: Bare URL download, useful for custom artifacts |
|
||||
* If this is set, `GIT_URL` or `REPO` should be set to allow the dependency viewer to link to the project's Git repository. |
|
||||
* If this is NOT set, `REPO` must be defined. |
|
||||
- `REPO + TAG + ARTIFACT`: GitHub release artifact |
|
||||
* The final download URL will be `https://github.com/${REPO}/releases/download/${TAG}/${ARTIFACT}` |
|
||||
* Useful for prebuilt libraries and prefetched archives |
|
||||
- `REPO + TAG`: GitHub tag archive |
|
||||
* The final download URL will be `https://github.com/${REPO}/archive/refs/tags/${TAG}.tar.gz` |
|
||||
* Useful for pinning to a specific tag, better for build identification |
|
||||
- `REPO + SHA`: GitHub commit archive |
|
||||
* The final download URL will be `https://github.com/${REPO}/archive/${SHA}.zip` |
|
||||
* Useful for pinning to a specific commit |
|
||||
- `REPO + BRANCH`: GitHub branch archive |
|
||||
* The final download URL will be `https://github.com/${REPO}/archive/refs/heads/${BRANCH}.zip` |
|
||||
* Generally not recommended unless the branch is frozen |
|
||||
- `REPO`: GitHub master archive |
|
||||
* The final download URL will be `https://github.com/${REPO}/archive/refs/heads/master.zip` |
|
||||
* Generally not recommended unless the project is dead |
|
||||
|
|
||||
**Hashing** |
|
||||
|
|
||||
Hashing is used for verifying downloads. It's highly recommended to use these. |
|
||||
|
|
||||
- `HASH_ALGO` (default `SHA512`): Hash algorithm to use |
|
||||
|
|
||||
Hashing strategies, descending order of precedence: |
|
||||
|
|
||||
- `HASH`: Bare hash verification, useful for static downloads e.g. commit archives |
|
||||
- `HASH_SUFFIX`: Download the hash as `${DOWNLOAD_URL}.${HASH_SUFFIX}` |
|
||||
* The downloaded hash *must* match the hash algorithm and contain nothing but the hash; no filenames or extra content. |
|
||||
- `HASH_URL`: Download the hash from a separate URL |
|
||||
|
|
||||
**Additional Options** |
|
||||
|
|
||||
- `KEY`: Custom cache key to use (stored as `.cache/cpm/${packagename_lower}/${key}`) |
|
||||
* Default is based on, in descending order of precedence: |
|
||||
- First 4 characters of the sha |
|
||||
- `GIT_VERSION` |
|
||||
- Tag |
|
||||
- `VERSION` |
|
||||
- Otherwise, CPM defaults will be used. This is not recommended as it doesn't produce reproducible caches |
|
||||
- `DOWNLOAD_ONLY`: Whether or not to configure the downloaded package via CMake |
|
||||
* Useful to turn `OFF` if the project doesn't use CMake |
|
||||
- `SOURCE_SUBDIR`: Subdirectory of the project containing a CMakeLists.txt file |
|
||||
- `FIND_PACKAGE_ARGUMENTS`: Arguments to pass to the `find_package` call |
|
||||
- `BUNDLED_PACKAGE`: Set to `ON` to force the usage of a bundled package |
|
||||
- `OPTIONS`: Options to pass to the configuration of the package |
|
||||
- `PATCHES`: Patches to apply to the package, stored in `.patch/${packagename_lower}/0001-patch-name.patch` and so on |
|
||||
- Other arguments can be passed to CPM as well |
|
||||
|
|
||||
**Extra Variables** |
|
||||
|
|
||||
For each added package, users may additionally force usage of the system/bundled package. |
|
||||
|
|
||||
- `${package}_FORCE_SYSTEM`: Require the package to be installed on the system |
|
||||
- `${package}_FORCE_BUNDLED`: Force the package to be fetched and use the bundled version |
|
||||
|
|
||||
**Bundled/System Switching** |
|
||||
|
|
||||
Descending order of precedence: |
|
||||
- If `${package}_FORCE_SYSTEM` is true, requires the package to be on the system |
|
||||
- If `${package}_FORCE_BUNDLED` is true, forcefully uses the bundled package |
|
||||
- If `CPMUTIL_FORCE_SYSTEM` is true, requires the package to be on the system |
|
||||
- If `CPMUTIL_FORCE_BUNDLED` is true, forcefully uses the bundled package |
|
||||
- If the `BUNDLED_PACKAGE` argument is true, forcefully uses the bundled package |
|
||||
- Otherwise, CPM will search for the package first, and if not found, will use the bundled package |
|
||||
|
|
||||
**Identification** |
|
||||
|
|
||||
All dependencies must be identifiable in some way for usage in the dependency viewer. Lists are provided in descending order of precedence. |
|
||||
|
|
||||
URLs: |
|
||||
|
|
||||
- `GIT_URL` |
|
||||
- `REPO` as a Git repository |
|
||||
* You may optionally specify `GIT_HOST` to use a custom host, e.g. `GIT_HOST git.crueter.xyz`. Note that the git host MUST be GitHub-like in its artifact/archive downloads, e.g. Forgejo |
|
||||
* If `GIT_HOST` is unspecified, defaults to `github.com` |
|
||||
- `URL` |
|
||||
|
|
||||
Versions (bundled): |
|
||||
|
|
||||
- `SHA` |
|
||||
- `GIT_VERSION` |
|
||||
- `VERSION` |
|
||||
- `TAG` |
|
||||
- "unknown" |
|
||||
|
|
||||
If the package is a system package, AddPackage will attempt to determine the package version and append ` (system)` to the identifier. Otherwise, it will be marked as `unknown (system)` |
|
||||
|
|
||||
### AddCIPackage |
|
||||
|
|
||||
Adds a package that follows crueter's CI repository spec. |
|
||||
|
|
||||
- `VERSION` (required): The version to get (the tag will be `v${VERSION}`) |
|
||||
- `NAME` (required): Name used within the artifacts |
|
||||
- `REPO` (required): CI repository, e.g. `crueter-ci/OpenSSL` |
|
||||
- `PACKAGE` (required): `find_package` package name |
|
||||
- `EXTENSION`: Artifact extension (default `tar.zst`) |
|
||||
- `MIN_VERSION`: Minimum version for `find_package`. Only used if platform does not support this package as a bundled artifact |
|
||||
- `DISABLED_PLATFORMS`: List of platforms that lack artifacts for this package. One of: |
|
||||
* `windows-amd64` |
|
||||
* `windows-arm64` |
|
||||
* `android` |
|
||||
* `solaris-amd64` |
|
||||
* `freebsd-amd64` |
|
||||
* `linux-amd64` |
|
||||
* `linux-aarch64` |
|
||||
* `macos-universal` |
|
||||
|
|
||||
### AddJsonPackage |
|
||||
|
|
||||
This is the recommended method of usage for CPMUtil. In each directory that utilizes `CPMUtil`, there must be a `cpmfile.json` that defines dependencies in a similar manner to the individual calls. |
|
||||
|
|
||||
The cpmfile is an object of objects, with each sub-object being named according to the package's identifier, e.g. `openssl`, which can then be fetched with `AddJsonPackage(<identifier>)`. Options are designed to map closely to the argument names, and are always strings unless otherwise specified. |
|
||||
|
|
||||
- `package` -> `NAME` (`PACKAGE` for CI), defaults to the object key |
|
||||
- `repo` -> `REPO` |
|
||||
- `version` -> `VERSION` |
|
||||
- `ci` (bool) |
|
||||
|
|
||||
If `ci` is `false`: |
|
||||
|
|
||||
- `hash` -> `HASH` |
|
||||
- `hash_suffix` -> `HASH_SUFFIX` |
|
||||
- `sha` -> `SHA` |
|
||||
- `key` -> `KEY` |
|
||||
- `tag` -> `TAG` |
|
||||
* If the tag contains `%VERSION%`, that part will be replaced by the `git_version`, OR `version` if `git_version` is not specified |
|
||||
- `url` -> `URL` |
|
||||
- `artifact` -> `ARTIFACT` |
|
||||
* If the artifact contains `%VERSION%`, that part will be replaced by the `git_version`, OR `version` if `git_version` is not specified |
|
||||
* If the artifact contains `%TAG%`, that part will be replaced by the `tag` (with its replacement already done) |
|
||||
- `git_version` -> `GIT_VERSION` |
|
||||
- `git_host` -> `GIT_HOST` |
|
||||
- `source_subdir` -> `SOURCE_SUBDIR` |
|
||||
- `bundled` -> `BUNDLED_PACKAGE` |
|
||||
- `find_args` -> `FIND_PACKAGE_ARGUMENTS` |
|
||||
- `patches` -> `PATCHES` (array) |
|
||||
- `options` -> `OPTIONS` (array) |
|
||||
|
|
||||
Other arguments aren't currently supported. If you wish to add them, see the `AddJsonPackage` function in `CMakeModules/CPMUtil.cmake`. |
|
||||
|
|
||||
If `ci` is `true`: |
|
||||
|
|
||||
- `name` -> `NAME`, defaults to the object key |
|
||||
- `extension` -> `EXTENSION`, defaults to `tar.zst` |
|
||||
- `min_version` -> `MIN_VERSION` |
|
||||
- `extension` -> `EXTENSION` |
|
||||
|
|
||||
### Examples |
|
||||
|
|
||||
In order: OpenSSL CI, Boost (tag + artifact), Opus (options + find_args), discord-rpc (sha + options + patches) |
|
||||
|
|
||||
```json |
|
||||
{ |
|
||||
"openssl": { |
|
||||
"ci": true, |
|
||||
"package": "OpenSSL", |
|
||||
"name": "openssl", |
|
||||
"repo": "crueter-ci/OpenSSL", |
|
||||
"version": "3.5.2", |
|
||||
"min_version": "1.1.1" |
|
||||
}, |
|
||||
"boost": { |
|
||||
"package": "Boost", |
|
||||
"repo": "boostorg/boost", |
|
||||
"tag": "boost-%VERSION%", |
|
||||
"artifact": "%TAG%-cmake.7z", |
|
||||
"hash": "e5b049e5b61964480ca816395f63f95621e66cb9bcf616a8b10e441e0e69f129e22443acb11e77bc1e8170f8e4171b9b7719891efc43699782bfcd4b3a365f01", |
|
||||
"git_version": "1.88.0", |
|
||||
"version": "1.57" |
|
||||
}, |
|
||||
"opus": { |
|
||||
"package": "Opus", |
|
||||
"repo": "xiph/opus", |
|
||||
"sha": "5ded705cf4", |
|
||||
"hash": "0dc89e58ddda1f3bc6a7037963994770c5806c10e66f5cc55c59286fc76d0544fe4eca7626772b888fd719f434bc8a92f792bdb350c807968b2ac14cfc04b203", |
|
||||
"version": "1.3", |
|
||||
"find_args": "MODULE", |
|
||||
"options": [ |
|
||||
"OPUS_BUILD_TESTING OFF", |
|
||||
"OPUS_BUILD_PROGRAMS OFF", |
|
||||
"OPUS_INSTALL_PKG_CONFIG_MODULE OFF", |
|
||||
"OPUS_INSTALL_CMAKE_CONFIG_MODULE OFF" |
|
||||
] |
|
||||
}, |
|
||||
"discord-rpc": { |
|
||||
"repo": "discord/discord-rpc", |
|
||||
"sha": "963aa9f3e5", |
|
||||
"hash": "386e1344e9a666d730f2d335ee3aef1fd05b1039febefd51aa751b705009cc764411397f3ca08dffd46205c72f75b235c870c737b2091a4ed0c3b061f5919bde", |
|
||||
"options": [ |
|
||||
"BUILD_EXAMPLES OFF" |
|
||||
], |
|
||||
"patches": [ |
|
||||
"0001-cmake-version.patch", |
|
||||
"0002-no-clang-format.patch", |
|
||||
"0003-fix-cpp17.patch" |
|
||||
] |
|
||||
}, |
|
||||
} |
|
||||
``` |
|
||||
|
|
||||
### Inclusion |
|
||||
|
|
||||
To include CPMUtil: |
|
||||
|
|
||||
```cmake |
|
||||
include(CPMUtil) |
|
||||
``` |
|
||||
|
|
||||
## Prefetching |
|
||||
|
|
||||
- To prefetch a CPM dependency (requires cpmfile): |
|
||||
* `tools/cpm-fetch.sh <packages>` |
|
||||
- To prefetch all CPM dependencies: |
|
||||
* `tools/cpm-fetch-all.sh` |
|
||||
|
|
||||
Currently, `cpm-fetch.sh` defines the following directories for cpmfiles (max depth of 2, so subdirs are caught as well): |
|
||||
|
|
||||
`externals src/qt_common src/dynarmic .` |
|
||||
|
|
||||
Whenever you add a new cpmfile, update the script accordingly |
|
||||
@ -0,0 +1,14 @@ |
|||||
|
# CPMUtil |
||||
|
|
||||
|
CPMUtil is a wrapper around CPM that aims to reduce boilerplate and add useful utility functions to make dependency management a piece of cake. |
||||
|
|
||||
|
See more in [its repository](https://git.crueter.xyz/CMake/CPMUtil) |
||||
|
|
||||
|
Eden-specific options: |
||||
|
|
||||
|
- `YUZU_USE_CPM` is set by default on MSVC and Android. Other platforms should use this if certain "required" system dependencies (e.g. OpenSSL) are broken or missing |
||||
|
* If this is `OFF`, required system dependencies will be searched via `find_package`, although most externals use CPM regardless. |
||||
|
|
||||
|
## Tooling |
||||
|
|
||||
|
See the [tooling docs](../tools/cpm) |
||||
@ -1,15 +1,12 @@ |
|||||
#!/bin/sh -e |
#!/bin/sh -e |
||||
|
|
||||
# SPDX-FileCopyrightText: Copyright 2025 Eden Emulator Project |
|
||||
# SPDX-License-Identifier: GPL-3.0-or-later |
|
||||
|
|
||||
# SPDX-FileCopyrightText: 2025 crueter |
# SPDX-FileCopyrightText: 2025 crueter |
||||
# SPDX-License-Identifier: GPL-3.0-or-later |
# SPDX-License-Identifier: GPL-3.0-or-later |
||||
|
|
||||
# check which file a package is in |
# check which file a package is in |
||||
|
|
||||
# like common.sh, change for your directories |
# like common.sh, change for your directories |
||||
JSON=$(find . src -maxdepth 3 -name cpmfile.json -exec grep -l "$1" {} \;) |
|
||||
|
JSON=$(find "$DIRS" -maxdepth "$MAXDEPTH" -name cpmfile.json -exec grep -l "$1" {} \;) |
||||
|
|
||||
[ -z "$JSON" ] && echo "!! No cpmfile definition for $1" |
[ -z "$JSON" ] && echo "!! No cpmfile definition for $1" |
||||
|
|
||||
Write
Preview
Loading…
Cancel
Save
Reference in new issue