-
Notifications
You must be signed in to change notification settings - Fork 26
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
feat: System checks on
systemRequirements
(#379)
* feat: modifies `use_cran_defaults()` to perform system checks on cargo and rustc versions for CRAN compliance. * docs: add missing `rust_source.Rd`, `use_crate.Rd` and `write_license_note.Rd`, and update NAMESPACE. * chore: Bump dev version and update NEWS * feat: Add tools directory and msrv.R template for CRAN compliance * tests: Update snapshots for `use_cran_defaults()` and `use_extendr()` * tests: update tests * docs: Add `use_crate` to package development reference * Update snapshots * Update NEWS.md --------- Co-authored-by: Josiah Parry <[email protected]>
- Loading branch information
1 parent
0359070
commit 52cd2e5
Showing
15 changed files
with
329 additions
and
75 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,21 +1,3 @@ | ||
#!/usr/bin/env sh | ||
|
||
# https://github.com/eitsupi/prqlr/blob/main/configure | ||
export PATH="$PATH:$HOME/.cargo/bin" | ||
|
||
if [ ! "$(command -v cargo)" ]; then | ||
echo "----------------------- [RUST NOT FOUND]---------------------------" | ||
echo "The 'cargo' command was not found on the PATH. Please install rustc" | ||
echo "from: https://www.rust-lang.org/tools/install" | ||
echo "" | ||
echo "Alternatively, you may install cargo from your OS package manager:" | ||
echo " - Debian/Ubuntu: apt-get install cargo" | ||
echo " - Fedora/CentOS: dnf install cargo" | ||
echo " - macOS: brew install rustc" | ||
echo "-------------------------------------------------------------------" | ||
echo "" | ||
exit 1 | ||
fi | ||
|
||
exit 0 | ||
|
||
: "${R_HOME=`R RHOME`}" | ||
"${R_HOME}/bin/Rscript" tools/msrv.R |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,15 +1,2 @@ | ||
#!/bin/sh | ||
|
||
# https://github.com/eitsupi/prqlr/blob/main/configure.win | ||
export PATH="$PATH:$HOME/.cargo/bin" | ||
|
||
if [ ! "$(command -v cargo)" ]; then | ||
echo "----------------------- [RUST NOT FOUND]---------------------------" | ||
echo "The 'cargo' command was not found on the PATH. Please install rustc" | ||
echo "from: https://www.rust-lang.org/tools/install" | ||
echo "-------------------------------------------------------------------" | ||
echo "" | ||
exit 1 | ||
fi | ||
|
||
exit 0 | ||
#!/usr/bin/env sh | ||
"${R_HOME}/bin${R_ARCH_BIN}/Rscript.exe" tools/msrv.R |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,116 @@ | ||
# read the DESCRIPTION file | ||
desc <- read.dcf("DESCRIPTION") | ||
|
||
if (!"SystemRequirements" %in% colnames(desc)) { | ||
fmt <- c( | ||
"`SystemRequirements` not found in `DESCRIPTION`.", | ||
"Please specify `SystemRequirements: Cargo (Rust's package manager), rustc`" | ||
) | ||
stop(paste(fmt, collapse = "\n")) | ||
} | ||
|
||
# extract system requirements | ||
sysreqs <- desc[, "SystemRequirements"] | ||
|
||
# check that cargo and rustc is found | ||
if (!grepl("cargo", sysreqs, ignore.case = TRUE)) { | ||
stop("You must specify `Cargo (Rust's package manager)` in your `SystemRequirements`") | ||
} | ||
|
||
if (!grepl("rustc", sysreqs, ignore.case = TRUE)) { | ||
stop("You must specify `Cargo (Rust's package manager), rustc` in your `SystemRequirements`") | ||
} | ||
|
||
# split into parts | ||
parts <- strsplit(sysreqs, ", ")[[1]] | ||
|
||
# identify which is the rustc | ||
rustc_ver <- parts[grepl("rustc", parts)] | ||
|
||
# perform checks for the presence of rustc and cargo on the OS | ||
no_cargo_msg <- c( | ||
"----------------------- [CARGO NOT FOUND]--------------------------", | ||
"The 'cargo' command was not found on the PATH. Please install Cargo", | ||
"from: https://www.rust-lang.org/tools/install", | ||
"", | ||
"Alternatively, you may install Cargo from your OS package manager:", | ||
" - Debian/Ubuntu: apt-get install cargo", | ||
" - Fedora/CentOS: dnf install cargo", | ||
" - macOS: brew install rustc", | ||
"-------------------------------------------------------------------" | ||
) | ||
|
||
no_rustc_msg <- c( | ||
"----------------------- [RUST NOT FOUND]---------------------------", | ||
"The 'rustc' compiler was not found on the PATH. Please install", | ||
paste(rustc_ver, "or higher from:"), | ||
"https://www.rust-lang.org/tools/install", | ||
"", | ||
"Alternatively, you may install Rust from your OS package manager:", | ||
" - Debian/Ubuntu: apt-get install rustc", | ||
" - Fedora/CentOS: dnf install rustc", | ||
" - macOS: brew install rustc", | ||
"-------------------------------------------------------------------" | ||
) | ||
|
||
# Add {user}/.cargo/bin to path before checking | ||
new_path <- paste0( | ||
Sys.getenv("PATH"), | ||
":", | ||
paste0(Sys.getenv("HOME"), "/.cargo/bin") | ||
) | ||
|
||
# set the path with the new path | ||
Sys.setenv("PATH" = new_path) | ||
|
||
# check for rustc installation | ||
rustc_version <- tryCatch( | ||
system("rustc --version", intern = TRUE), | ||
error = function(e) { | ||
stop(paste(no_rustc_msg, collapse = "\n")) | ||
} | ||
) | ||
|
||
# check for cargo installation | ||
cargo_version <- tryCatch( | ||
system("cargo --version", intern = TRUE), | ||
error = function(e) { | ||
stop(paste(no_cargo_msg, collapse = "\n")) | ||
} | ||
) | ||
|
||
# helper function to extract versions | ||
extract_semver <- function(ver) { | ||
if (grepl("\\d+\\.\\d+(\\.\\d+)?", ver)) { | ||
sub(".*?(\\d+\\.\\d+(\\.\\d+)?).*", "\\1", ver) | ||
} else { | ||
NA | ||
} | ||
} | ||
|
||
# get the MSRV | ||
msrv <- extract_semver(rustc_ver) | ||
|
||
# extract current version | ||
current_rust_version <- extract_semver(rustc_version) | ||
|
||
# perform check | ||
if (!is.na(msrv)) { | ||
# -1 when current version is later | ||
# 0 when they are the same | ||
# 1 when MSRV is newer than current | ||
is_msrv <- utils::compareVersion(msrv, current_rust_version) | ||
if (is_msrv == 1) { | ||
fmt <- paste0( | ||
"\n------------------ [UNSUPPORTED RUST VERSION]------------------\n", | ||
"- Minimum supported Rust version is %s.\n", | ||
"- Installed Rust version is %s.\n", | ||
"---------------------------------------------------------------" | ||
) | ||
stop(sprintf(fmt, msrv, current_rust_version)) | ||
} | ||
} | ||
|
||
# print the versions | ||
versions_fmt <- "Using %s\nUsing %s" | ||
message(sprintf(versions_fmt, cargo_version, rustc_version)) |
Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.
Oops, something went wrong.
Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.
Oops, something went wrong.
Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.
Oops, something went wrong.
Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.
Oops, something went wrong.
Oops, something went wrong.