mirror of
https://github.com/zed-industries/zed.git
synced 2024-11-08 07:35:01 +03:00
Document release_channel
crate (#8695)
This PR documents the `release_channel` crate. Release Notes: - N/A
This commit is contained in:
parent
e3608af992
commit
cfe90c37fc
@ -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,
|
||||||
|
Loading…
Reference in New Issue
Block a user