mirror of
https://github.com/denoland/deno.git
synced 2025-01-22 06:09:25 -05:00
fb021d7cef
These methods are confusing because the arguments are backwards. I feel like they should have never been added to `Option<T>` and that clippy should suggest rewriting to `map(...).unwrap_or(...)`/`map(...).unwrap_or_else(|| ...)` https://github.com/rust-lang/rfcs/issues/1025
27 lines
683 B
Rust
27 lines
683 B
Rust
// Copyright 2018-2023 the Deno authors. All rights reserved. MIT license.
|
|
|
|
pub const GIT_COMMIT_HASH: &str = env!("GIT_COMMIT_HASH");
|
|
pub const TYPESCRIPT: &str = env!("TS_VERSION");
|
|
|
|
pub fn deno() -> String {
|
|
let version = env!("CARGO_PKG_VERSION");
|
|
option_env!("DENO_CANARY")
|
|
.map(|_| format!("{}+{}", version, &GIT_COMMIT_HASH[..7]))
|
|
.unwrap_or_else(|| version.to_string())
|
|
}
|
|
|
|
pub fn is_canary() -> bool {
|
|
option_env!("DENO_CANARY").is_some()
|
|
}
|
|
|
|
pub fn release_version_or_canary_commit_hash() -> &'static str {
|
|
if is_canary() {
|
|
GIT_COMMIT_HASH
|
|
} else {
|
|
env!("CARGO_PKG_VERSION")
|
|
}
|
|
}
|
|
|
|
pub fn get_user_agent() -> String {
|
|
format!("Deno/{}", deno())
|
|
}
|