Document release_channel crate (#8695)

This PR documents the `release_channel` crate.

Release Notes:

- N/A
This commit is contained in:
Marshall Bowers 2024-03-01 22:05:46 -05:00 committed by GitHub
parent e3608af992
commit cfe90c37fc
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194

View File

@ -1,8 +1,12 @@
use gpui::{AppContext, Global, SemanticVersion}; //! Provides constructs for the Zed app version and release channel.
use once_cell::sync::Lazy;
#![deny(missing_docs)]
use std::env; use std::env;
#[doc(hidden)] use gpui::{AppContext, Global, SemanticVersion};
use once_cell::sync::Lazy;
static RELEASE_CHANNEL_NAME: Lazy<String> = if cfg!(debug_assertions) { static RELEASE_CHANNEL_NAME: Lazy<String> = if cfg!(debug_assertions) {
Lazy::new(|| { Lazy::new(|| {
env::var("ZED_RELEASE_CHANNEL") env::var("ZED_RELEASE_CHANNEL")
@ -22,6 +26,7 @@ pub static RELEASE_CHANNEL: Lazy<ReleaseChannel> =
_ => panic!("invalid release channel {}", *RELEASE_CHANNEL_NAME), _ => panic!("invalid release channel {}", *RELEASE_CHANNEL_NAME),
}); });
/// The Git commit SHA that Zed was built at.
#[derive(Clone)] #[derive(Clone)]
pub struct AppCommitSha(pub String); pub struct AppCommitSha(pub String);
@ -30,11 +35,13 @@ struct GlobalAppCommitSha(AppCommitSha);
impl Global for GlobalAppCommitSha {} impl Global for GlobalAppCommitSha {}
impl AppCommitSha { impl AppCommitSha {
/// Returns the global [`AppCommitSha`], if one is set.
pub fn try_global(cx: &AppContext) -> Option<AppCommitSha> { pub fn try_global(cx: &AppContext) -> Option<AppCommitSha> {
cx.try_global::<GlobalAppCommitSha>() cx.try_global::<GlobalAppCommitSha>()
.map(|sha| sha.0.clone()) .map(|sha| sha.0.clone())
} }
/// Sets the global [`AppCommitSha`].
pub fn set_global(sha: AppCommitSha, cx: &mut AppContext) { pub fn set_global(sha: AppCommitSha, cx: &mut AppContext) {
cx.set_global(GlobalAppCommitSha(sha)) cx.set_global(GlobalAppCommitSha(sha))
} }
@ -44,11 +51,18 @@ struct GlobalAppVersion(SemanticVersion);
impl Global for GlobalAppVersion {} impl Global for GlobalAppVersion {}
/// The version of Zed.
pub struct AppVersion; pub struct AppVersion;
impl AppVersion { impl AppVersion {
/// Initializes the global [`AppVersion`].
///
/// Attempts to read the version number from the following locations, in order:
/// 1. the `ZED_APP_VERSION` environment variable,
/// 2. the [`AppContext::app_metadata`],
/// 3. the passed in `pkg_version`.
pub fn init(pkg_version: &str, cx: &mut AppContext) { pub fn init(pkg_version: &str, cx: &mut AppContext) {
let version = if let Some(from_env) = env::var("ZED_APP_VERSION").ok() { let version = if let Ok(from_env) = env::var("ZED_APP_VERSION") {
from_env.parse().expect("invalid ZED_APP_VERSION") from_env.parse().expect("invalid ZED_APP_VERSION")
} else { } else {
cx.app_metadata() cx.app_metadata()
@ -58,17 +72,28 @@ impl AppVersion {
cx.set_global(GlobalAppVersion(version)) cx.set_global(GlobalAppVersion(version))
} }
/// Returns the global version number.
pub fn global(cx: &AppContext) -> SemanticVersion { pub fn global(cx: &AppContext) -> SemanticVersion {
cx.global::<GlobalAppVersion>().0 cx.global::<GlobalAppVersion>().0
} }
} }
/// A Zed release channel.
#[derive(Debug, Copy, Clone, PartialEq, Eq, Default)] #[derive(Debug, Copy, Clone, PartialEq, Eq, Default)]
pub enum ReleaseChannel { pub enum ReleaseChannel {
/// The development release channel.
///
/// Used for local debug builds of Zed.
#[default] #[default]
Dev, Dev,
/// The Nightly release channel.
Nightly, Nightly,
/// The Preview release channel.
Preview, Preview,
/// The Stable release channel.
Stable, Stable,
} }
@ -76,21 +101,25 @@ struct GlobalReleaseChannel(ReleaseChannel);
impl Global for GlobalReleaseChannel {} impl Global for GlobalReleaseChannel {}
/// Initializes the release channel.
pub fn init(pkg_version: &str, cx: &mut AppContext) { pub fn init(pkg_version: &str, cx: &mut AppContext) {
AppVersion::init(pkg_version, cx); AppVersion::init(pkg_version, cx);
cx.set_global(GlobalReleaseChannel(*RELEASE_CHANNEL)) cx.set_global(GlobalReleaseChannel(*RELEASE_CHANNEL))
} }
impl ReleaseChannel { impl ReleaseChannel {
/// Returns the global [`ReleaseChannel`].
pub fn global(cx: &AppContext) -> Self { pub fn global(cx: &AppContext) -> Self {
cx.global::<GlobalReleaseChannel>().0 cx.global::<GlobalReleaseChannel>().0
} }
/// Returns the global [`ReleaseChannel`], if one is set.
pub fn try_global(cx: &AppContext) -> Option<Self> { pub fn try_global(cx: &AppContext) -> Option<Self> {
cx.try_global::<GlobalReleaseChannel>() cx.try_global::<GlobalReleaseChannel>()
.map(|channel| channel.0) .map(|channel| channel.0)
} }
/// Returns the display name for this [`ReleaseChannel`].
pub fn display_name(&self) -> &'static str { pub fn display_name(&self) -> &'static str {
match self { match self {
ReleaseChannel::Dev => "Zed Dev", ReleaseChannel::Dev => "Zed Dev",
@ -100,6 +129,7 @@ impl ReleaseChannel {
} }
} }
/// Returns the programmatic name for this [`ReleaseChannel`].
pub fn dev_name(&self) -> &'static str { pub fn dev_name(&self) -> &'static str {
match self { match self {
ReleaseChannel::Dev => "dev", ReleaseChannel::Dev => "dev",
@ -109,6 +139,7 @@ impl ReleaseChannel {
} }
} }
/// Returns the URL scheme for this [`ReleaseChannel`].
pub fn url_scheme(&self) -> &'static str { pub fn url_scheme(&self) -> &'static str {
match self { match self {
ReleaseChannel::Dev => "zed-dev://", ReleaseChannel::Dev => "zed-dev://",
@ -118,6 +149,7 @@ impl ReleaseChannel {
} }
} }
/// Returns the link prefix for this [`ReleaseChannel`].
pub fn link_prefix(&self) -> &'static str { pub fn link_prefix(&self) -> &'static str {
match self { match self {
ReleaseChannel::Dev => "https://zed.dev/dev/", ReleaseChannel::Dev => "https://zed.dev/dev/",
@ -127,6 +159,7 @@ impl ReleaseChannel {
} }
} }
/// Returns the query parameter for this [`ReleaseChannel`].
pub fn release_query_param(&self) -> Option<&'static str> { pub fn release_query_param(&self) -> Option<&'static str> {
match self { match self {
Self::Dev => None, Self::Dev => None,
@ -137,6 +170,10 @@ impl ReleaseChannel {
} }
} }
/// Parses the given link into a Zed link.
///
/// Returns a [`Some`] containing the unprefixed link if the link is a Zed link.
/// Returns [`None`] otherwise.
pub fn parse_zed_link(link: &str) -> Option<&str> { pub fn parse_zed_link(link: &str) -> Option<&str> {
for release in [ for release in [
ReleaseChannel::Dev, ReleaseChannel::Dev,