Skip to main content

LogicalWorkspace

Struct LogicalWorkspace 

Source
pub struct LogicalWorkspace { /* private fields */ }
Expand description

A logical workspace — the unit of identity for cross-repo / workspace indexing.

Implementations§

Source§

impl LogicalWorkspace

Source

pub fn from_sqry_workspace(path: &Path) -> Result<Self, LogicalWorkspaceError>

Construct from a .sqry-workspace registry file.

WorkspaceRegistry::load accepts both v1 (flat repositories list) and v2 (source_roots, member_folders, exclusions, project_root_mode) on-disk shapes — v1 is auto-upgraded to v2 in memory. This constructor projects every v2 field into the resulting LogicalWorkspace:

  • repositoriessource_roots (canonicalized).
  • member_foldersMemberFolder { path, reason } (canonicalized).
  • exclusions → canonical absolute paths.
  • project_root_mode → carried verbatim.

STEP_7 codex iter4 fix — pre-iter4 this constructor dropped member_folders, exclusions, and project_root_mode on the floor, defeating acceptance criteria 5/6 end-to-end (the redactor receives an empty LogicalWorkspaceView::exclusions / member_folders, so redact_excluded_in_passthrough and the member-folder prefix renderer never fire on real .sqry-workspace-loaded sessions). The pre-iter4 inline TODO pointed at “STEP_2 will overhaul the registry layer entirely” — STEP_2 shipped the registry-side v2 schema but did not update this projection. Fixed here so STEP_7’s MCP redaction wiring is observable end-to-end.

§Errors

Returns LogicalWorkspaceError when the registry file cannot be loaded or any path canonicalization fails irrecoverably.

Source

pub fn from_code_workspace( workspace_file: &Path, heuristic_fn: &dyn Fn(&Path) -> HeuristicVerdict, ) -> Result<Self, LogicalWorkspaceError>

Construct from a .code-workspace JSON file.

The heuristic_fn is invoked for every folder that does not carry an explicit sqry.role, is not in the top-level sqry.workspace.sourceRoots / .exclusions overrides, and is not already classified as a member by an explicit sqry.workspace.memberFolders entry.

§Errors

Returns LogicalWorkspaceError for IO failures, JSON parse errors, malformed folder entries, or path canonicalization failures that cannot be recovered via lexical absolutization.

Source

pub fn anonymous_multi_root( folders: Vec<PathBuf>, ) -> Result<Self, LogicalWorkspaceError>

Construct an ad-hoc multi-root workspace (every folder is a source root). Folders are sorted lexically before hashing so identity is stable under reorder.

§Errors

Returns LogicalWorkspaceError if any folder cannot be canonicalized irrecoverably.

Source

pub fn single_root(path: PathBuf) -> Result<Self, LogicalWorkspaceError>

Construct a single-root workspace (one source root, no members).

§Errors

Returns LogicalWorkspaceError if path cannot be canonicalized irrecoverably.

Source

pub fn workspace_id(&self) -> &WorkspaceId

The stable BLAKE3-256 identity of this workspace.

Source

pub fn identity(&self) -> &WorkspaceIdentity

The identity inputs that produced Self::workspace_id.

Source

pub fn source_roots(&self) -> &[SourceRoot]

The auto-indexed source roots.

Source

pub fn member_folders(&self) -> &[MemberFolder]

The non-indexed member folders.

Source

pub fn exclusions(&self) -> &[PathBuf]

Explicitly excluded paths.

Source

pub fn project_root_mode(&self) -> ProjectRootMode

The workspace-level ProjectRootMode.

Source

pub fn index_root_override(&self) -> Option<&Path>

Optional --index-root override.

Source

pub fn config_fingerprint(&self) -> u64

Workspace-level config fingerprint. Populated by the plugin-selection / cost-tier pipeline via Self::set_config_fingerprint and consumed by sqry-daemon::WorkspaceKey so two source roots sharing path but differing fingerprint stay in distinct cache entries.

Source

pub fn set_config_fingerprint(&mut self, fingerprint: u64)

STEP_11_4 — set the workspace-level config fingerprint computed via crate::config::compute_workspace_config_fingerprint.

The fingerprint is not part of the WorkspaceId hash input — it is a separate cache dimension consumed by the daemon’s WorkspaceKey. Two LogicalWorkspaces with the same identity but different fingerprints share an identity but produce distinct daemon cache entries.

Source

pub fn set_config_fingerprint_with_inheritance(&mut self, fingerprint: u64)

STEP_11_4 — set the workspace-level config fingerprint and propagate it to every SourceRoot that does not already carry an explicit per-root override (i.e. whose config_fingerprint == 0).

This is the typical wiring point: callers compute one workspace-level fingerprint, then call set_config_fingerprint_with_inheritance so source roots without an explicit override inherit the workspace value. Source roots that carry a non-zero override are left untouched.

Source

pub fn populate_classpath_dirs(&mut self) -> Vec<(PathBuf, Error)>

STEP_11_4 — populate every SourceRoot::classpath_dir in this workspace by probing <root>/.sqry/classpath/ for each. Returns a vector of (source_root, io::Error) pairs for any probe that failed for a reason other than NotFound; callers typically fold these into super::cache::WorkspaceWarning::ClasspathProbeFailed.

Source

pub fn is_source_root(&self, path: &Path) -> bool

Returns true if path matches one of the registered source roots exactly (not a descendant).

Source

pub fn classify(&self, path: &Path) -> Classification

Classify a path against the workspace per §1.4 of the implementation plan.

Trait Implementations§

Source§

impl Clone for LogicalWorkspace

Source§

fn clone(&self) -> LogicalWorkspace

Returns a duplicate of the value. Read more
1.0.0 (const: unstable) · Source§

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

Performs copy-assignment from source. Read more
Source§

impl Debug for LogicalWorkspace

Source§

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

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

impl<'de> Deserialize<'de> for LogicalWorkspace

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 PartialEq for LogicalWorkspace

Source§

fn eq(&self, other: &LogicalWorkspace) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 (const: unstable) · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl Serialize for LogicalWorkspace

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
Source§

impl Eq for LogicalWorkspace

Source§

impl StructuralPartialEq for LogicalWorkspace

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
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
Source§

impl<Q, K> Equivalent<K> for Q
where Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,

Source§

fn equivalent(&self, key: &K) -> bool

Compare self to key and return true if they are equal.
Source§

impl<Q, K> Equivalent<K> for Q
where Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,

Source§

fn equivalent(&self, key: &K) -> bool

Checks if this value is equivalent to the given key. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T> Instrument for T

Source§

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

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

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
Source§

impl<D> OwoColorize for D

Source§

fn fg<C>(&self) -> FgColorDisplay<'_, C, Self>
where C: Color,

Set the foreground color generically Read more
Source§

fn bg<C>(&self) -> BgColorDisplay<'_, C, Self>
where C: Color,

Set the background color generically. Read more
Source§

fn black(&self) -> FgColorDisplay<'_, Black, Self>

Change the foreground color to black
Source§

fn on_black(&self) -> BgColorDisplay<'_, Black, Self>

Change the background color to black
Source§

fn red(&self) -> FgColorDisplay<'_, Red, Self>

Change the foreground color to red
Source§

fn on_red(&self) -> BgColorDisplay<'_, Red, Self>

Change the background color to red
Source§

fn green(&self) -> FgColorDisplay<'_, Green, Self>

Change the foreground color to green
Source§

fn on_green(&self) -> BgColorDisplay<'_, Green, Self>

Change the background color to green
Source§

fn yellow(&self) -> FgColorDisplay<'_, Yellow, Self>

Change the foreground color to yellow
Source§

fn on_yellow(&self) -> BgColorDisplay<'_, Yellow, Self>

Change the background color to yellow
Source§

fn blue(&self) -> FgColorDisplay<'_, Blue, Self>

Change the foreground color to blue
Source§

fn on_blue(&self) -> BgColorDisplay<'_, Blue, Self>

Change the background color to blue
Source§

fn magenta(&self) -> FgColorDisplay<'_, Magenta, Self>

Change the foreground color to magenta
Source§

fn on_magenta(&self) -> BgColorDisplay<'_, Magenta, Self>

Change the background color to magenta
Source§

fn purple(&self) -> FgColorDisplay<'_, Magenta, Self>

Change the foreground color to purple
Source§

fn on_purple(&self) -> BgColorDisplay<'_, Magenta, Self>

Change the background color to purple
Source§

fn cyan(&self) -> FgColorDisplay<'_, Cyan, Self>

Change the foreground color to cyan
Source§

fn on_cyan(&self) -> BgColorDisplay<'_, Cyan, Self>

Change the background color to cyan
Source§

fn white(&self) -> FgColorDisplay<'_, White, Self>

Change the foreground color to white
Source§

fn on_white(&self) -> BgColorDisplay<'_, White, Self>

Change the background color to white
Source§

fn default_color(&self) -> FgColorDisplay<'_, Default, Self>

Change the foreground color to the terminal default
Source§

fn on_default_color(&self) -> BgColorDisplay<'_, Default, Self>

Change the background color to the terminal default
Source§

fn bright_black(&self) -> FgColorDisplay<'_, BrightBlack, Self>

Change the foreground color to bright black
Source§

fn on_bright_black(&self) -> BgColorDisplay<'_, BrightBlack, Self>

Change the background color to bright black
Source§

fn bright_red(&self) -> FgColorDisplay<'_, BrightRed, Self>

Change the foreground color to bright red
Source§

fn on_bright_red(&self) -> BgColorDisplay<'_, BrightRed, Self>

Change the background color to bright red
Source§

fn bright_green(&self) -> FgColorDisplay<'_, BrightGreen, Self>

Change the foreground color to bright green
Source§

fn on_bright_green(&self) -> BgColorDisplay<'_, BrightGreen, Self>

Change the background color to bright green
Source§

fn bright_yellow(&self) -> FgColorDisplay<'_, BrightYellow, Self>

Change the foreground color to bright yellow
Source§

fn on_bright_yellow(&self) -> BgColorDisplay<'_, BrightYellow, Self>

Change the background color to bright yellow
Source§

fn bright_blue(&self) -> FgColorDisplay<'_, BrightBlue, Self>

Change the foreground color to bright blue
Source§

fn on_bright_blue(&self) -> BgColorDisplay<'_, BrightBlue, Self>

Change the background color to bright blue
Source§

fn bright_magenta(&self) -> FgColorDisplay<'_, BrightMagenta, Self>

Change the foreground color to bright magenta
Source§

fn on_bright_magenta(&self) -> BgColorDisplay<'_, BrightMagenta, Self>

Change the background color to bright magenta
Source§

fn bright_purple(&self) -> FgColorDisplay<'_, BrightMagenta, Self>

Change the foreground color to bright purple
Source§

fn on_bright_purple(&self) -> BgColorDisplay<'_, BrightMagenta, Self>

Change the background color to bright purple
Source§

fn bright_cyan(&self) -> FgColorDisplay<'_, BrightCyan, Self>

Change the foreground color to bright cyan
Source§

fn on_bright_cyan(&self) -> BgColorDisplay<'_, BrightCyan, Self>

Change the background color to bright cyan
Source§

fn bright_white(&self) -> FgColorDisplay<'_, BrightWhite, Self>

Change the foreground color to bright white
Source§

fn on_bright_white(&self) -> BgColorDisplay<'_, BrightWhite, Self>

Change the background color to bright white
Source§

fn bold(&self) -> BoldDisplay<'_, Self>

Make the text bold
Source§

fn dimmed(&self) -> DimDisplay<'_, Self>

Make the text dim
Source§

fn italic(&self) -> ItalicDisplay<'_, Self>

Make the text italicized
Source§

fn underline(&self) -> UnderlineDisplay<'_, Self>

Make the text underlined
Make the text blink
Make the text blink (but fast!)
Source§

fn reversed(&self) -> ReversedDisplay<'_, Self>

Swap the foreground and background colors
Source§

fn hidden(&self) -> HiddenDisplay<'_, Self>

Hide the text
Source§

fn strikethrough(&self) -> StrikeThroughDisplay<'_, Self>

Cross out the text
Source§

fn color<Color>(&self, color: Color) -> FgDynColorDisplay<'_, Color, Self>
where Color: DynColor,

Set the foreground color at runtime. Only use if you do not know which color will be used at compile-time. If the color is constant, use either OwoColorize::fg or a color-specific method, such as OwoColorize::green, Read more
Source§

fn on_color<Color>(&self, color: Color) -> BgDynColorDisplay<'_, Color, Self>
where Color: DynColor,

Set the background color at runtime. Only use if you do not know what color to use at compile-time. If the color is constant, use either OwoColorize::bg or a color-specific method, such as OwoColorize::on_yellow, Read more
Source§

fn fg_rgb<const R: u8, const G: u8, const B: u8>( &self, ) -> FgColorDisplay<'_, CustomColor<R, G, B>, Self>

Set the foreground color to a specific RGB value.
Source§

fn bg_rgb<const R: u8, const G: u8, const B: u8>( &self, ) -> BgColorDisplay<'_, CustomColor<R, G, B>, Self>

Set the background color to a specific RGB value.
Source§

fn truecolor(&self, r: u8, g: u8, b: u8) -> FgDynColorDisplay<'_, Rgb, Self>

Sets the foreground color to an RGB value.
Source§

fn on_truecolor(&self, r: u8, g: u8, b: u8) -> BgDynColorDisplay<'_, Rgb, Self>

Sets the background color to an RGB value.
Source§

fn style(&self, style: Style) -> Styled<&Self>

Apply a runtime-determined style
Source§

impl<T> Pointable for T

Source§

const ALIGN: usize

The alignment of pointer.
Source§

type Init = T

The type for initializers.
Source§

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

Initializes a with the given initializer. Read more
Source§

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

Dereferences the given pointer. Read more
Source§

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

Mutably dereferences the given pointer. Read more
Source§

unsafe fn drop(ptr: usize)

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

impl<T> Same for T

Source§

type Output = T

Should always be Self
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.
Source§

impl<T> WithSubscriber for T

Source§

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
Source§

fn with_current_subscriber(self) -> WithDispatch<Self>

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

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