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

Use rapids-build-backend. #1502

Merged
merged 81 commits into from
May 24, 2024
Merged
Show file tree
Hide file tree
Changes from 2 commits
Commits
Show all changes
81 commits
Select commit Hold shift + click to select a range
8ffedf2
Use rapids-build-backend.
bdice Mar 13, 2024
f5e6177
Update dependencies.
bdice Mar 14, 2024
008b20c
Use build module.
bdice Mar 14, 2024
2d4c846
Fix pyproject.toml.
bdice Mar 14, 2024
ab0b17a
Fix key.
bdice Mar 14, 2024
0a2e648
Read GIT_COMMIT.
bdice Mar 14, 2024
697f340
Merge branch 'branch-24.04' into rapids_build_backend
bdice Mar 14, 2024
10ccd85
Install rapids-build-backend.
bdice Mar 14, 2024
f29fa7a
Merge branch 'rapids_build_backend' of github.com:bdice/rmm into rapi…
bdice Mar 14, 2024
952dedc
Fix build-system.requires until packages are available.
bdice Mar 14, 2024
1301e60
Update for changes in rapids-build-backend.
bdice Mar 14, 2024
e4a5abf
Use pip wheel for wheel builds to find it during installation.
bdice Mar 15, 2024
ee87798
Fix scikit-build-core to include pyproject extras.
bdice Mar 15, 2024
8c9c4df
Add dependency on rapids-build-backend.
bdice Mar 15, 2024
747a28c
Remove testing hacks now that packages are available.
bdice Mar 18, 2024
8a28056
Merge remote-tracking branch 'upstream/branch-24.06' into rapids_buil…
bdice Mar 18, 2024
9def158
Update conda recipe.
bdice Mar 18, 2024
ee886d5
Add rapidsai-nightly to dependencies.yaml.
bdice Mar 21, 2024
ba766dd
merge latest branch-24.06
jameslamb May 2, 2024
92949db
fix link in README
jameslamb May 2, 2024
6766df2
add pyproject_dir
jameslamb May 2, 2024
5812808
Merge branch 'rapids_build_backend' of github.com:bdice/rmm into rapi…
jameslamb May 2, 2024
b049e8f
go all the way to the latest dfg
jameslamb May 2, 2024
8a6e4c4
get rapids-build-backend from github
jameslamb May 3, 2024
f0caeac
update scripts
jameslamb May 3, 2024
0a5919f
fix path
jameslamb May 3, 2024
ea2d856
revert changes from local debugging
jameslamb May 3, 2024
5e94960
paths
jameslamb May 3, 2024
b62e232
fix installation in conda build
jameslamb May 3, 2024
a310550
remove duplicate cloning
jameslamb May 3, 2024
0ca672f
revert more stuff from local testing
jameslamb May 3, 2024
4455d9a
merge latest changes
jameslamb May 3, 2024
714f572
thank you rapids-dependency-file-generator, for putting my dependenci…
jameslamb May 3, 2024
9743105
the C++ wheels and Python wheels both need a scikit-build-core dep, b…
jameslamb May 3, 2024
352731c
adjust to presence of cpp wheels
jameslamb May 3, 2024
4554a7e
maybe you need to point at a dependencies.yaml for the suffix-adding …
jameslamb May 3, 2024
793d2ac
Merge branch 'branch-24.06' of github.com:rapidsai/rmm into rapids_bu…
jameslamb May 6, 2024
31fcf91
remove fallback librmm requirement
jameslamb May 6, 2024
535ecab
copyright updates
jameslamb May 6, 2024
7e0988e
add alpha specs
jameslamb May 6, 2024
b212f9b
Merge branch 'branch-24.06' into rapids_build_backend
jameslamb May 7, 2024
eed5625
get better logs, comment out conda jobs
jameslamb May 7, 2024
c291130
get even more logs
jameslamb May 7, 2024
a4c1b4f
use upstream rapids-build-backend
jameslamb May 7, 2024
20c98e8
fix rapids-build-backend installation
jameslamb May 8, 2024
1c78f07
move pin to dependencies.yaml
jameslamb May 8, 2024
9791fef
fix copyrights
jameslamb May 8, 2024
5ade208
fix pin
jameslamb May 8, 2024
f57e124
uncomment more CI
jameslamb May 8, 2024
3be15c6
remove conditions
jameslamb May 8, 2024
09a0b3b
fix rbb installation in conda and devcontainers
jameslamb May 8, 2024
7865d55
Merge branch 'branch-24.06' into rapids_build_backend
jameslamb May 8, 2024
f5eddbb
remove cuda-python rewriting
jameslamb May 8, 2024
2a6b7d5
make GIT_COMMIT stricter
jameslamb May 8, 2024
3190d98
Merge branch 'branch-24.06' of github.com:rapidsai/rmm into rapids_bu…
jameslamb May 9, 2024
b3bb256
make _version.py more generic
jameslamb May 9, 2024
c6d5a78
use rapids-build-backend packages
jameslamb May 9, 2024
620ccd4
copyright
jameslamb May 9, 2024
ae80cb4
fix version specifier for conda
jameslamb May 9, 2024
58f418f
librmm wheel too
jameslamb May 9, 2024
7569d4d
Merge branch 'branch-24.06' into rapids_build_backend
jameslamb May 13, 2024
3c40558
update to latest branch-24.06, move test
jameslamb May 13, 2024
294f7db
revert testing changes
jameslamb May 13, 2024
0494363
Merge branch 'branch-24.06' of github.com:rapidsai/rmm into rapids_bu…
jameslamb May 14, 2024
a507ae1
add ceiling on rapids-build-backend
jameslamb May 14, 2024
dcba4c2
and the conda recipe
jameslamb May 14, 2024
efc5a61
Merge branch 'branch-24.06' of github.com:rapidsai/rmm into rapids_bu…
jameslamb May 16, 2024
dd51662
use rapids-build-backend 0.2.0
jameslamb May 16, 2024
4965a44
more copyright
jameslamb May 16, 2024
92b7133
Revert "more copyright"
jameslamb May 16, 2024
3374f01
Revert "use rapids-build-backend 0.2.0"
jameslamb May 16, 2024
d5d2052
use rapids-build-backend 0.2.0
jameslamb May 16, 2024
8fb02bc
Merge branch 'branch-24.06' into rapids_build_backend
jameslamb May 16, 2024
940d86f
merge branch-24.08
jameslamb May 21, 2024
32f623f
Merge branch 'branch-24.08' into rapids_build_backend
jameslamb May 23, 2024
c6e522c
upgrade to v0.3.0, consolidate rapids-generate-version uses
jameslamb May 23, 2024
cc76e35
rapids-dependency-file-generator version
jameslamb May 23, 2024
b9a31fb
populate __all__ in _version.py
jameslamb May 23, 2024
4aab1c3
set 'rapidsai.disable-cuda=true' in conda builds
jameslamb May 23, 2024
7aeba94
standardize rapids-build-backend version constraint, revert build_cpp…
jameslamb May 24, 2024
1a9b4f1
--config-settings, not --config-setting, for pip
jameslamb May 24, 2024
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
7 changes: 7 additions & 0 deletions .github/workflows/pr.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -83,6 +83,13 @@ jobs:
arch: '["amd64"]'
cuda: '["12.2"]'
build_command: |
# For testing, will be removed when the package is released
git clone https://github.com/rapidsai/rapids-build-backend.git
pushd rapids-build-backend
python -m pip wheel . --no-deps
popd
export PIP_FIND_LINKS="file://${PWD}/rapids-build-backend"

sccache -z;
build-all -DBUILD_BENCHMARKS=ON --verbose;
sccache -s;
2 changes: 1 addition & 1 deletion .pre-commit-config.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,7 @@ repos:
- id: trailing-whitespace
- id: end-of-file-fixer
- repo: https://github.com/rapidsai/dependency-file-generator
rev: v1.8.0
rev: v1.10.0
hooks:
- id: rapids-dependency-file-generator
args: ["--clean"]
Expand Down
6 changes: 6 additions & 0 deletions build.sh
Original file line number Diff line number Diff line change
Expand Up @@ -161,6 +161,12 @@ if hasArg clean; then
done
fi

# For testing, will be removed when the package is released
git clone https://github.com/rapidsai/rapids-build-backend.git
pushd rapids-build-backend
python -m pip wheel . --no-deps
popd

################################################################################
# Configure, build, and install librmm
if (( NUMARGS == 0 )) || hasArg librmm; then
Expand Down
5 changes: 0 additions & 5 deletions ci/build_python.sh
Original file line number Diff line number Diff line change
Expand Up @@ -13,14 +13,9 @@ export CMAKE_GENERATOR=Ninja

rapids-print-env

package_name="rmm"
package_dir="python"

version=$(rapids-generate-version)
jameslamb marked this conversation as resolved.
Show resolved Hide resolved
commit=$(git rev-parse HEAD)

echo "${version}" > VERSION
sed -i "/^__git_commit__/ s/= .*/= \"${commit}\"/g" "${package_dir}/${package_name}/_version.py"

rapids-logger "Begin py build"

Expand Down
32 changes: 16 additions & 16 deletions ci/build_wheel.sh
Original file line number Diff line number Diff line change
Expand Up @@ -10,30 +10,30 @@ source rapids-configure-sccache
source rapids-date-string

version=$(rapids-generate-version)
commit=$(git rev-parse HEAD)

RAPIDS_PY_CUDA_SUFFIX="$(rapids-wheel-ctk-name-gen ${RAPIDS_CUDA_VERSION})"

# This is the version of the suffix with a preceding hyphen. It's used
# everywhere except in the final wheel name.
PACKAGE_CUDA_SUFFIX="-${RAPIDS_PY_CUDA_SUFFIX}"

# Patch project metadata files to include the CUDA version suffix and version override.
pyproject_file="${package_dir}/pyproject.toml"

sed -i "s/name = \"${package_name}\"/name = \"${package_name}${PACKAGE_CUDA_SUFFIX}\"/g" ${pyproject_file}
echo "${version}" > VERSION
sed -i "/^__git_commit__/ s/= .*/= \"${commit}\"/g" "${package_dir}/${package_name}/_version.py"

if [[ $PACKAGE_CUDA_SUFFIX == "-cu12" ]]; then
sed -i "s/cuda-python[<=>\.,0-9a]*/cuda-python>=12.0,<13.0a0/g" ${pyproject_file}
if rapids-is-release-build; then
export RAPIDS_ONLY_RELEASE_DEPS=1
fi
bdice marked this conversation as resolved.
Show resolved Hide resolved

# Need to manually patch the cuda-python version for CUDA 12.
ctk_major=$(echo "${RAPIDS_CUDA_VERSION}" | cut -d'.' -f1)
if [[ ${ctk_major} == "12" ]]; then
sed -i "s/cuda-python[<=>\.,0-9a]*/cuda-python>=12.0,<13.0a0/g" ${package_dir}/pyproject.toml
fi

cd "${package_dir}"

python -m pip wheel . -w dist -vvv --no-deps --disable-pip-version-check
# For testing, will be removed when the package is released
git clone https://github.com/rapidsai/rapids-build-backend.git
pushd rapids-build-backend
python -m pip wheel . --no-deps
popd

PIP_FIND_LINKS="file://${PWD}/rapids-build-backend/" python -m pip wheel . -w dist -vvv --no-deps --disable-pip-version-check

mkdir -p final_dist
python -m auditwheel repair -w final_dist dist/*

RAPIDS_PY_CUDA_SUFFIX="$(rapids-wheel-ctk-name-gen ${RAPIDS_CUDA_VERSION})"
RAPIDS_PY_WHEEL_NAME="${package_name}_${RAPIDS_PY_CUDA_SUFFIX}" rapids-upload-wheels-to-s3 final_dist
6 changes: 6 additions & 0 deletions conda/recipes/rmm/meta.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -62,6 +62,12 @@ requirements:
- cuda-python >=12.0,<13.0a0
{% endif %}
- cython >=3.0.0
# TODO: Add rapids-build-backend once the package exists. Then we can remove dependencies up to the next TODO.
#- rapids-build-backend
- tomli
- tomli-w
- packaging
# TODO: Remove above dependencies after rapids-build-backend packages exist
- librmm ={{ version }}
- python
- scikit-build-core >=0.7.0
Expand Down
22 changes: 18 additions & 4 deletions dependencies.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -13,6 +13,7 @@ files:
- develop
- docs
- py_version
- rapids_build_backend
- run
- test_python
test_python:
Expand Down Expand Up @@ -41,6 +42,13 @@ files:
output: pyproject
extras:
table: build-system
includes:
- rapids_build_backend
py_rapids_build:
output: pyproject
extras:
table: tool.rapids_build_backend
key: requires
includes:
- build
py_run:
Expand All @@ -60,6 +68,16 @@ channels:
- rapidsai
- conda-forge
dependencies:
rapids_build_backend:
common:
- output_types: conda
packages:
# TODO: Enable once packages are available
#- rapids-build-backend
- scikit-build-core>=0.7.0
- output_types: pyproject # TODO: Enable requirements once packages are available
packages:
- rapids-build-backend[scikit-build-core]
build:
common:
- output_types: [conda, requirements, pyproject]
Expand All @@ -72,11 +90,7 @@ dependencies:
- c-compiler
- cxx-compiler
- fmt>=10.1.1,<11
- scikit-build-core>=0.7.0
- spdlog>=1.12.0,<1.13
- output_types: [requirements, pyproject]
packages:
- scikit-build-core[pyproject]>=0.7.0
specific:
- output_types: conda
matrices:
Expand Down
26 changes: 20 additions & 6 deletions python/pyproject.toml
Original file line number Diff line number Diff line change
Expand Up @@ -13,13 +13,9 @@
# limitations under the License.

[build-system]
build-backend = "scikit_build_core.build"
build-backend = "rapids_build_backend"
requires = [
"cmake>=3.26.4",
"cuda-python>=11.7.1,<12.0a0",
"cython>=3.0.0",
"ninja",
"scikit-build-core[pyproject]>=0.7.0",
"rapids-build-backend[scikit-build-core]",
] # This list was generated by `rapids-dependency-file-generator`. To make changes, edit ../dependencies.yaml and run `rapids-dependency-file-generator`.

[project]
Expand Down Expand Up @@ -123,3 +119,21 @@ wheel.packages = ["rmm"]
provider = "scikit_build_core.metadata.regex"
input = "rmm/VERSION"
regex = "(?P<value>.*)"

[tool.rapids_builder]
build-backend = "scikit_build_core.build"
commit-file = "rmm/_version.py"
bdice marked this conversation as resolved.
Show resolved Hide resolved
requires = [
"cmake>=3.26.4",
"cuda-python>=11.7.1,<12.0a0",
"cython>=3.0.0",
"ninja",
] # This list was generated by `rapids-dependency-file-generator`. To make changes, edit ../dependencies.yaml and run `rapids-dependency-file-generator`.

[tool.rapids_build_backend]
requires = [
"cmake>=3.26.4",
"cuda-python>=11.7.1,<12.0a0",
"cython>=3.0.0",
"ninja",
] # This list was generated by `rapids-dependency-file-generator`. To make changes, edit ../dependencies.yaml and run `rapids-dependency-file-generator`.
Loading