Skip to main content

ExtensionDescriptionStateDTO

Struct ExtensionDescriptionStateDTO 

Source
pub struct ExtensionDescriptionStateDTO {
Show 27 fields pub Identifier: Value, pub Name: String, pub Version: String, pub Publisher: String, pub Engines: Value, pub Main: Option<String>, pub Browser: Option<String>, pub ModuleType: Option<String>, pub IsBuiltin: bool, pub IsUnderDevelopment: bool, pub ExtensionLocation: Value, pub ActivationEvents: Option<Vec<String>>, pub Contributes: Option<Value>, pub Categories: Option<Vec<String>>, pub DisplayName: Option<String>, pub Description: Option<String>, pub Keywords: Option<Vec<String>>, pub Repository: Option<Value>, pub Bugs: Option<Value>, pub Homepage: Option<String>, pub License: Option<String>, pub Icon: Option<String>, pub AiKey: Option<String>, pub ExtensionKind: Option<Value>, pub Capabilities: Option<Value>, pub ExtensionDependencies: Option<Vec<String>>, pub ExtensionPack: Option<Vec<String>>,
}
Expand description

Represents the deserialized content of an extension’s package.json file, augmented with location information and other metadata.

This is stored in ApplicationState to provide the extension host with the list of available extensions and their capabilities. VS Code extensions use camelCase in package.json. Serde renames from PascalCase Rust fields to camelCase JSON automatically. Fields that don’t exist in package.json (Identifier, ExtensionLocation, IsBuiltin) default to their zero values on deserialization.

Fields§

§Identifier: Value

Extension identifier: { value: string, uuid?: string } Not present in package.json - constructed from publisher.name after parsing.

§Name: String

Extension name (from package.json “name”)

Always serialized, even when empty, because VS Code’s scanner and the trusted-publishers migration (extensions.contribution.ts) both evaluate extension.manifest.name.toLowerCase() unconditionally. Dropping the field would leave a bare undefined and crash the renderer with TypeError: undefined is not an object.

§Version: String

Semantic version string (e.g., “1.0.0”).

Always serialized for the same reason as Name / Publisher: the renderer reads manifest.version in several hot paths and crashes if the field is missing outright.

§Publisher: String

Publisher name or identifier.

Always serialized, even when empty. VS Code’s extensions.contribution.ts trusted-publishers migration runs on every User-extension at workbench boot and executes extension.manifest.publisher.toLowerCase(). If the key is omitted the renderer crashes with TypeError: undefined is not an object (evaluating 'manifest.publisher').

§Engines: Value

Engine compatibility requirements: { vscode: string }

§Main: Option<String>

Main entry point path (Node.js runtime)

§Browser: Option<String>

Browser entry point path (web extension)

§ModuleType: Option<String>

Module type: commonjs or esm

§IsBuiltin: bool

Whether this is a built-in extension (not in package.json, set by scanner)

§IsUnderDevelopment: bool

Whether extension is under active development

§ExtensionLocation: Value

Installation location URI (set by scanner, not in package.json)

§ActivationEvents: Option<Vec<String>>

Activation event triggers (e.g., “onStartupFinished”)

§Contributes: Option<Value>

Extension contributions (commands, views, etc.)

§Categories: Option<Vec<String>>

VS Code category tags (“Themes”, “Programming Languages”, “Snippets”, “Language Packs”, “Debuggers”, “Formatters”, “Keymaps”, “SCM Providers”, “Testing”, “Education”, “Other”).

Atom TH1: Wind’s Extensions sidebar filters @builtin category:themes against this array. Without the field the filter never matches - user reported theme extensions absent on @builtin search despite being on disk. Scanner-passthrough surfaces the raw package.json value; resolved NLS placeholders survive because the serde deserialisation happens after the NLS rewrite.

§DisplayName: Option<String>

Human-readable display name, usually a VS Code NLS placeholder like %displayName% that the scanner resolves against package.nls.json. Atom TH1: sidebar row rendering falls back to name when this is absent; having the real value populates tooltips and the details editor.

§Description: Option<String>

Short prose description. Same NLS-placeholder rules as DisplayName.

§Keywords: Option<Vec<String>>

Extension keywords array - searched by the sidebar when the query doesn’t match name, displayName, or description.

§Repository: Option<Value>

Repository info: Either a string URL or { type, url } object.

§Bugs: Option<Value>

Bug-tracker URL or object.

§Homepage: Option<String>

Homepage URL.

§License: Option<String>

License identifier (SPDX short code) or URL.

§Icon: Option<String>

Icon path relative to the extension root (for sidebar thumbnails).

§AiKey: Option<String>

Marketplace API key placeholder - still present in some upstream built-in manifests. @vscode/extension-telemetry reads its length on construction; if missing the activate throws Cannot read properties of undefined (reading 'length').

§ExtensionKind: Option<Value>

Marketplace-side extension kind (["ui"], ["workspace"], ["web"]). Wind uses this to decide which host to run the extension in. Missing → VS Code falls back to heuristics.

§Capabilities: Option<Value>

Capabilities descriptor - untrustedWorkspaces, virtualWorkspaces.

§ExtensionDependencies: Option<Vec<String>>

Dependency list - other extensions this one needs activated first.

§ExtensionPack: Option<Vec<String>>

Extension-pack children - extensions this one bundles by reference.

Implementations§

Source§

impl ExtensionDescriptionStateDTO

Source

pub fn Validate(&self) -> Result<(), String>

Validates the extension description data.

§Returns

Result indicating success or validation error with reason

Source

pub fn CreateMinimal( Identifier: Value, Name: String, Version: String, Publisher: String, ) -> Result<Self, String>

Creates a minimal extension description for testing or placeholder use.

§Arguments
  • Identifier - Extension identifier value
  • Name - Extension name
  • Version - Extension version
  • Publisher - Publisher name
§Returns

A new ExtensionDescriptionStateDTO with minimal required fields

Trait Implementations§

Source§

impl Clone for ExtensionDescriptionStateDTO

Source§

fn clone(&self) -> ExtensionDescriptionStateDTO

Returns a duplicate of the value. Read more
1.0.0 · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl Debug for ExtensionDescriptionStateDTO

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl<'de> Deserialize<'de> for ExtensionDescriptionStateDTO

Source§

fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>
where __D: Deserializer<'de>,

Deserialize this value from the given Serde deserializer. Read more
Source§

impl Serialize for ExtensionDescriptionStateDTO

Source§

fn serialize<__S>(&self, __serializer: __S) -> Result<__S::Ok, __S::Error>
where __S: Serializer,

Serialize this value into the given Serde serializer. Read more

Auto Trait Implementations§

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
§

impl<'a, T, E> AsTaggedExplicit<'a, E> for T
where T: 'a,

§

fn explicit(self, class: Class, tag: u32) -> TaggedParser<'a, Explicit, Self, E>

§

impl<'a, T, E> AsTaggedImplicit<'a, E> for T
where T: 'a,

§

fn implicit( self, class: Class, constructed: bool, tag: u32, ) -> TaggedParser<'a, Implicit, Self, E>

Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
§

impl<'de, D, R> CommandArg<'de, R> for D
where D: Deserialize<'de>, R: Runtime,

§

fn from_command(command: CommandItem<'de, R>) -> Result<D, InvokeError>

Derives an instance of Self from the [CommandItem]. Read more
§

impl<T> Downcast for T
where T: Any,

§

fn into_any(self: Box<T>) -> Box<dyn Any>

Convert Box<dyn Trait> (where Trait: Downcast) to Box<dyn Any>. Box<dyn Any> can then be further downcast into Box<ConcreteType> where ConcreteType implements Trait.
§

fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>

Convert Rc<Trait> (where Trait: Downcast) to Rc<Any>. Rc<Any> can then be further downcast into Rc<ConcreteType> where ConcreteType implements Trait.
§

fn as_any(&self) -> &(dyn Any + 'static)

Convert &Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot generate &Any’s vtable from &Trait’s.
§

fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)

Convert &mut Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot generate &mut Any’s vtable from &mut Trait’s.
§

impl<T> DowncastSync for T
where T: Any + Send + Sync,

§

fn into_any_arc(self: Arc<T>) -> Arc<dyn Any + Sync + Send>

Convert Arc<Trait> (where Trait: Downcast) to Arc<Any>. Arc<Any> can then be further downcast into Arc<ConcreteType> where ConcreteType implements Trait.
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

§

impl<T> FromRef<T> for T
where T: Clone,

§

fn from_ref(input: &T) -> T

Converts to this type from a reference to the input type.
§

impl<T> FutureExt for T

§

fn with_context(self, otel_cx: Context) -> WithContext<Self>

Attaches the provided Context to this type, returning a WithContext wrapper. Read more
§

fn with_current_context(self) -> WithContext<Self>

Attaches the current Context to this type, returning a WithContext wrapper. Read more
§

impl<T> Instrument for T

§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided [Span], returning an Instrumented wrapper. Read more
§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> IntoEither for T

Source§

fn into_either(self, into_left: bool) -> Either<Self, Self>

Converts self into a Left variant of Either<Self, Self> if into_left is true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
Source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

Converts self into a Left variant of Either<Self, Self> if into_left(&self) returns true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
§

impl<T> IntoRequest<T> for T

§

fn into_request(self) -> Request<T>

Wrap the input message T in a tonic::Request
§

impl<T> IpcResponse for T
where T: Serialize,

§

fn body(self) -> Result<InvokeResponseBody, Error>

Resolve the IPC response body.
§

impl<L> LayerExt<L> for L

§

fn named_layer<S>(&self, service: S) -> Layered<<L as Layer<S>>::Service, S>
where L: Layer<S>,

Applies the layer to a service and wraps it in [Layered].
§

impl<T> Pointable for T

§

const ALIGN: usize

The alignment of pointer.
§

type Init = T

The type for initializers.
§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more
§

impl<T> PolicyExt for T
where T: ?Sized,

§

fn and<P, B, E>(self, other: P) -> And<T, P>
where T: Policy<B, E>, P: Policy<B, E>,

Create a new Policy that returns [Action::Follow] only if self and other return Action::Follow. Read more
§

fn or<P, B, E>(self, other: P) -> Or<T, P>
where T: Policy<B, E>, P: Policy<B, E>,

Create a new Policy that returns [Action::Follow] if either self or other returns Action::Follow. Read more
Source§

impl<T> Same for T

Source§

type Output = T

Should always be Self
§

impl<T> ScopeObject for T
where T: Send + Sync + Debug + DeserializeOwned + 'static,

§

type Error = Error

The error type.
§

fn deserialize<R>( _app: &AppHandle<R>, raw: Value, ) -> Result<T, <T as ScopeObject>::Error>
where R: Runtime,

Deserialize the raw scope value.
Source§

impl<T> Serialize for T
where T: Serialize + ?Sized,

Source§

fn erased_serialize(&self, serializer: &mut dyn Serializer) -> Result<(), Error>

Source§

fn do_erased_serialize( &self, serializer: &mut dyn Serializer, ) -> Result<(), ErrorImpl>

Source§

impl<T> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

§

fn vzip(self) -> V

§

impl<T> WithSubscriber for T

§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a [WithDispatch] wrapper. Read more
§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a [WithDispatch] wrapper. Read more
Source§

impl<T> AutoreleaseSafe for T
where T: ?Sized,

Source§

impl<T> DeserializeOwned for T
where T: for<'de> Deserialize<'de>,

§

impl<T> UserEvent for T
where T: Debug + Clone + Send + 'static,