Add num_cpus() function (#1568)
This commit is contained in:
parent
e6b39df749
commit
63ed00ff78
20
Cargo.lock
generated
20
Cargo.lock
generated
@ -301,6 +301,15 @@ dependencies = [
|
|||||||
"libc",
|
"libc",
|
||||||
]
|
]
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "hermit-abi"
|
||||||
|
version = "0.2.6"
|
||||||
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
|
checksum = "ee512640fe35acbfb4bb779db6f0d80704c2cacfa2e39b601ef3e3f47d1ae4c7"
|
||||||
|
dependencies = [
|
||||||
|
"libc",
|
||||||
|
]
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "hermit-abi"
|
name = "hermit-abi"
|
||||||
version = "0.3.1"
|
version = "0.3.1"
|
||||||
@ -370,6 +379,7 @@ dependencies = [
|
|||||||
"lexiclean",
|
"lexiclean",
|
||||||
"libc",
|
"libc",
|
||||||
"log",
|
"log",
|
||||||
|
"num_cpus",
|
||||||
"pretty_assertions",
|
"pretty_assertions",
|
||||||
"regex",
|
"regex",
|
||||||
"serde",
|
"serde",
|
||||||
@ -442,6 +452,16 @@ dependencies = [
|
|||||||
"static_assertions",
|
"static_assertions",
|
||||||
]
|
]
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "num_cpus"
|
||||||
|
version = "1.15.0"
|
||||||
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
|
checksum = "0fac9e2da13b5eb447a6ce3d392f23a29d8694bff781bf03a16cd9ac8697593b"
|
||||||
|
dependencies = [
|
||||||
|
"hermit-abi 0.2.6",
|
||||||
|
"libc",
|
||||||
|
]
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "once_cell"
|
name = "once_cell"
|
||||||
version = "1.17.2"
|
version = "1.17.2"
|
||||||
|
@ -31,6 +31,7 @@ heck = "0.4.0"
|
|||||||
lexiclean = "0.0.1"
|
lexiclean = "0.0.1"
|
||||||
libc = "0.2.0"
|
libc = "0.2.0"
|
||||||
log = "0.4.4"
|
log = "0.4.4"
|
||||||
|
num_cpus = "1.15.0"
|
||||||
regex = "1.5.4"
|
regex = "1.5.4"
|
||||||
serde = { version = "1.0.130", features = ["derive", "rc"] }
|
serde = { version = "1.0.130", features = ["derive", "rc"] }
|
||||||
serde_json = "1.0.68"
|
serde_json = "1.0.68"
|
||||||
|
@ -1079,6 +1079,7 @@ Done!
|
|||||||
#### System Information
|
#### System Information
|
||||||
|
|
||||||
- `arch()` — Instruction set architecture. Possible values are: `"aarch64"`, `"arm"`, `"asmjs"`, `"hexagon"`, `"mips"`, `"msp430"`, `"powerpc"`, `"powerpc64"`, `"s390x"`, `"sparc"`, `"wasm32"`, `"x86"`, `"x86_64"`, and `"xcore"`.
|
- `arch()` — Instruction set architecture. Possible values are: `"aarch64"`, `"arm"`, `"asmjs"`, `"hexagon"`, `"mips"`, `"msp430"`, `"powerpc"`, `"powerpc64"`, `"s390x"`, `"sparc"`, `"wasm32"`, `"x86"`, `"x86_64"`, and `"xcore"`.
|
||||||
|
- `num_cpus()` - Number of logical CPUs.
|
||||||
- `os()` — Operating system. Possible values are: `"android"`, `"bitrig"`, `"dragonfly"`, `"emscripten"`, `"freebsd"`, `"haiku"`, `"ios"`, `"linux"`, `"macos"`, `"netbsd"`, `"openbsd"`, `"solaris"`, and `"windows"`.
|
- `os()` — Operating system. Possible values are: `"android"`, `"bitrig"`, `"dragonfly"`, `"emscripten"`, `"freebsd"`, `"haiku"`, `"ios"`, `"linux"`, `"macos"`, `"netbsd"`, `"openbsd"`, `"solaris"`, and `"windows"`.
|
||||||
- `os_family()` — Operating system family; possible values are: `"unix"` and `"windows"`.
|
- `os_family()` — Operating system family; possible values are: `"unix"` and `"windows"`.
|
||||||
|
|
||||||
|
@ -38,6 +38,7 @@ pub(crate) fn get(name: &str) -> Option<Function> {
|
|||||||
"kebabcase" => Unary(kebabcase),
|
"kebabcase" => Unary(kebabcase),
|
||||||
"lowercamelcase" => Unary(lowercamelcase),
|
"lowercamelcase" => Unary(lowercamelcase),
|
||||||
"lowercase" => Unary(lowercase),
|
"lowercase" => Unary(lowercase),
|
||||||
|
"num_cpus" => Nullary(num_cpus),
|
||||||
"os" => Nullary(os),
|
"os" => Nullary(os),
|
||||||
"os_family" => Nullary(os_family),
|
"os_family" => Nullary(os_family),
|
||||||
"parent_directory" => Unary(parent_directory),
|
"parent_directory" => Unary(parent_directory),
|
||||||
@ -270,6 +271,11 @@ fn lowercase(_context: &FunctionContext, s: &str) -> Result<String, String> {
|
|||||||
Ok(s.to_lowercase())
|
Ok(s.to_lowercase())
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fn num_cpus(_context: &FunctionContext) -> Result<String, String> {
|
||||||
|
let num = num_cpus::get();
|
||||||
|
Ok(num.to_string())
|
||||||
|
}
|
||||||
|
|
||||||
fn os(_context: &FunctionContext) -> Result<String, String> {
|
fn os(_context: &FunctionContext) -> Result<String, String> {
|
||||||
Ok(target::os().to_owned())
|
Ok(target::os().to_owned())
|
||||||
}
|
}
|
||||||
|
@ -930,11 +930,11 @@ c := a + b + a + b",
|
|||||||
x := arch()
|
x := arch()
|
||||||
|
|
||||||
a:
|
a:
|
||||||
{{os()}} {{os_family()}}",
|
{{os()}} {{os_family()}} {{num_cpus()}}",
|
||||||
"x := arch()
|
"x := arch()
|
||||||
|
|
||||||
a:
|
a:
|
||||||
{{ os() }} {{ os_family() }}",
|
{{ os() }} {{ os_family() }} {{ num_cpus() }}",
|
||||||
}
|
}
|
||||||
|
|
||||||
test! {
|
test! {
|
||||||
|
@ -4,10 +4,10 @@ test! {
|
|||||||
name: test_os_arch_functions_in_interpolation,
|
name: test_os_arch_functions_in_interpolation,
|
||||||
justfile: r#"
|
justfile: r#"
|
||||||
foo:
|
foo:
|
||||||
echo {{arch()}} {{os()}} {{os_family()}}
|
echo {{arch()}} {{os()}} {{os_family()}} {{num_cpus()}}
|
||||||
"#,
|
"#,
|
||||||
stdout: format!("{} {} {}\n", target::arch(), target::os(), target::family()).as_str(),
|
stdout: format!("{} {} {} {}\n", target::arch(), target::os(), target::family(), num_cpus::get()).as_str(),
|
||||||
stderr: format!("echo {} {} {}\n", target::arch(), target::os(), target::family()).as_str(),
|
stderr: format!("echo {} {} {} {}\n", target::arch(), target::os(), target::family(), num_cpus::get()).as_str(),
|
||||||
}
|
}
|
||||||
|
|
||||||
test! {
|
test! {
|
||||||
@ -16,12 +16,13 @@ test! {
|
|||||||
a := arch()
|
a := arch()
|
||||||
o := os()
|
o := os()
|
||||||
f := os_family()
|
f := os_family()
|
||||||
|
n := num_cpus()
|
||||||
|
|
||||||
foo:
|
foo:
|
||||||
echo {{a}} {{o}} {{f}}
|
echo {{a}} {{o}} {{f}} {{n}}
|
||||||
"#,
|
"#,
|
||||||
stdout: format!("{} {} {}\n", target::arch(), target::os(), target::family()).as_str(),
|
stdout: format!("{} {} {} {}\n", target::arch(), target::os(), target::family(), num_cpus::get()).as_str(),
|
||||||
stderr: format!("echo {} {} {}\n", target::arch(), target::os(), target::family()).as_str(),
|
stderr: format!("echo {} {} {} {}\n", target::arch(), target::os(), target::family(), num_cpus::get()).as_str(),
|
||||||
}
|
}
|
||||||
|
|
||||||
#[cfg(not(windows))]
|
#[cfg(not(windows))]
|
||||||
@ -246,11 +247,11 @@ test! {
|
|||||||
test! {
|
test! {
|
||||||
name: test_os_arch_functions_in_default,
|
name: test_os_arch_functions_in_default,
|
||||||
justfile: r#"
|
justfile: r#"
|
||||||
foo a=arch() o=os() f=os_family():
|
foo a=arch() o=os() f=os_family() n=num_cpus():
|
||||||
echo {{a}} {{o}} {{f}}
|
echo {{a}} {{o}} {{f}} {{n}}
|
||||||
"#,
|
"#,
|
||||||
stdout: format!("{} {} {}\n", target::arch(), target::os(), target::family()).as_str(),
|
stdout: format!("{} {} {} {}\n", target::arch(), target::os(), target::family(), num_cpus::get()).as_str(),
|
||||||
stderr: format!("echo {} {} {}\n", target::arch(), target::os(), target::family()).as_str(),
|
stderr: format!("echo {} {} {} {}\n", target::arch(), target::os(), target::family(), num_cpus::get()).as_str(),
|
||||||
}
|
}
|
||||||
|
|
||||||
test! {
|
test! {
|
||||||
|
Loading…
Reference in New Issue
Block a user