Skip to main content

DaemonError

Enum DaemonError 

Source
pub enum DaemonError {
Show 13 variants Config { path: PathBuf, source: Error, }, Io(Error), WorkspaceBuildFailed { root: PathBuf, reason: String, }, WorkspaceStaleExpired { root: PathBuf, age_hours: u64, cap_hours: u32, last_good_at: Option<SystemTime>, last_error: Option<String>, }, MemoryBudgetExceeded { limit_bytes: u64, current_bytes: u64, reserved_bytes: u64, retained_bytes: u64, requested_bytes: u64, }, WorkspaceEvicted { root: PathBuf, }, WorkspaceNotLoaded { root: PathBuf, }, ToolTimeout { root: PathBuf, secs: u64, deadline_ms: u64, }, InvalidArgument { reason: String, }, Internal(Error), AlreadyRunning { socket: PathBuf, lock: PathBuf, owner_pid: Option<u32>, }, AutoStartTimeout { timeout_secs: u64, socket: PathBuf, }, SignalSetup { source: Error, },
}
Expand description

All daemon-surface error variants.

Variants§

§

Config

Config file could not be read or parsed.

Fields

§path: PathBuf
§source: Error
§

Io(Error)

An io::Error occurred outside the config surface (socket bind, pidfile lock, filesystem probe, etc.).

§

WorkspaceBuildFailed

Workspace load / rebuild failed with no prior-good graph to serve from.

Maps to JSON-RPC -32001.

Fields

§root: PathBuf
§reason: String
§

WorkspaceStaleExpired

Workspace is in the Failed state and the most recent successful build is older than the configured stale_serve_max_age_hours cap.

Maps to JSON-RPC -32002.

Fields

§root: PathBuf
§age_hours: u64
§cap_hours: u32
§last_good_at: Option<SystemTime>

Last successful build timestamp, if any. None when the workspace has never successfully built (edge case: should not reach WorkspaceStaleExpired in that case — WorkspaceBuildFailed is returned instead — but the type is permissive for future-proofing).

§last_error: Option<String>

Textual diagnostic from the most recent failed build, if any.

§

MemoryBudgetExceeded

Admission control could not satisfy a reservation after evicting every non-pinned workspace.

Maps to JSON-RPC -32003.

Fields

§limit_bytes: u64
§current_bytes: u64
§reserved_bytes: u64
§retained_bytes: u64
§requested_bytes: u64
§

WorkspaceEvicted

Workspace was evicted or removed between a rebuild dispatch and its admission / publish commit. Signals the Task 7b2 watcher task and any direct handle_changes caller to terminate their per-workspace loop — subsequent dispatches on the same WorkspaceKey must route through a fresh get_or_load first.

Surfaced by RebuildDispatcher::handle_changes’ top-of-drain-loop eviction gate AND by WorkspaceManager::reserve_rebuild’s Phase-1 workspaces.read() membership + cancellation check (both paths use this typed variant so 7b2 can match on it without string parsing).

Maps to JSON-RPC -32004.

Fields

§root: PathBuf
§

WorkspaceNotLoaded

Caller requested daemon/rebuild or daemon/cancel_rebuild for a path that is not currently registered in the WorkspaceManager.

Shares the JSON-RPC -32004 code with Self::WorkspaceEvicted. The error_data "hint" field distinguishes the two situations on the wire.

Maps to JSON-RPC -32004.

Fields

§root: PathBuf
§

ToolTimeout

Tool invocation exceeded DaemonConfig::tool_timeout_secs. Emitted by tool_core::classify_and_execute (Task 8 Phase 8c U6) when the tokio::time::timeout(tool_timeout, spawn_blocking(run)) outer timer fires. The detached tokio::task::JoinHandle is dropped — the OS thread may continue executing the tool closure but its result is discarded.

The deadline_ms field is the canonical wire value (populated by the constructor as secs * 1000) so error_data does not have to re-derive it on every call and serialised payloads remain byte-for-byte identical regardless of constructor shape.

Maps to JSON-RPC -32000.

Fields

§root: PathBuf
§secs: u64
§deadline_ms: u64

Derived: secs * 1000. Stored explicitly to avoid re-calculating inside error_data / Display impls and to give the MCP-path wrapper (daemon_err_to_mcp, Phase 8c U8) a single field to read.

§

InvalidArgument

Argument validation failure surfaced by tool_core BEFORE any workspace classification runs. Used for resolve_index_root failures, missing path arguments in MCP tool args, and any other precondition violation that must be rejected with a JSON-RPC -32602 “Invalid params” response.

Maps to JSON-RPC -32602.

Fields

§reason: String
§

Internal(Error)

Catch-all for errors surfaced by sqry_mcp::daemon_adapter tool execution that do not map to a more specific DaemonError variant. The wrapped anyhow::Error is flattened into a string on the wire via the Display/#[source] chain.

Maps to JSON-RPC -32603.

§

AlreadyRunning

A sqryd process already holds the exclusive flock on lock and has written its PID to pidfile. The caller should surface this to the user with the owner PID (if legible) and exit EX_TEMPFAIL (75).

This error fires before IpcServer::bind and therefore before any workspace is registered; it should never be stored in the workspace last_error field. [crate::workspace::manager::clone_err] maps it to WorkspaceBuildFailed as a defensive fallback.

Fields

§socket: PathBuf

The IPC socket path that the running daemon owns.

§lock: PathBuf

The flock file that proves ownership.

§owner_pid: Option<u32>

PID of the owner process, if the pidfile was legible.

§

AutoStartTimeout

The daemon did not become ready within timeout_secs seconds. Used by both the --detach parent wait loop and the lifecycle::start_detached auto-spawn helper (Task 10).

Callers should exit EX_UNAVAILABLE (69).

Fields

§timeout_secs: u64

How long we waited.

§socket: PathBuf

The socket we polled.

§

SignalSetup

Installing OS signal handlers failed (e.g. sigaction returned ENOSYS in a highly-restricted container, or tokio’s signal registration failed).

Callers should exit EX_SOFTWARE (70).

Fields

§source: Error

Implementations§

Source§

impl DaemonError

Source

pub const fn jsonrpc_code(&self) -> Option<i32>

Map to the stable JSON-RPC error code used on the wire.

Returns None for errors that have no public JSON-RPC code — these are serialised as -32603 "Internal error" per the JSON-RPC 2.0 spec at the IPC boundary (wired in Task 8).

The Task 9 lifecycle variants (AlreadyRunning, AutoStartTimeout, SignalSetup) fire before IpcServer::bind so they never cross the IPC boundary directly; None is returned for them here. They are only surfaced to human users via exit_code() and process exit.

Source

pub const fn exit_code(&self) -> u8

Map to a POSIX process exit code following the BSD sysexits.h conventions used for daemon CLI errors (Task 9 U1).

CodeSymbolSemantics
0EX_OKSuccess (not an error; included for completeness)
69EX_UNAVAILABLEService unavailable (timeout, not-ready)
70EX_SOFTWAREInternal software error
73EX_CANTCREATIO error / cannot create required file
75EX_TEMPFAILTry again (e.g. another instance is running)
78EX_CONFIGConfiguration error

For variants that only occur inside the IPC / workspace layer (not at process-startup time) the JSON-RPC code’s sign-flipped magnitude is used as a proxy, falling back to 70 (EX_SOFTWARE) for anything not covered.

Source

pub fn error_data(&self) -> Option<Value>

Build the error.data JSON payload surfaced alongside the JSON-RPC error code. Returns None when no structured payload should be attached (typically Io/Config errors routed through -32603).

Task 8 Phase 8a. The IPC method dispatch consumes this to populate JsonRpcError.data so clients can render actionable diagnostics without parsing the free-form message string.

Trait Implementations§

Source§

impl Debug for DaemonError

Source§

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

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

impl Display for DaemonError

Source§

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

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

impl Error for DaemonError

Source§

fn source(&self) -> Option<&(dyn Error + 'static)>

Returns the lower-level source of this error, if any. Read more
1.0.0 · Source§

fn description(&self) -> &str

👎Deprecated since 1.42.0:

use the Display impl or to_string()

1.0.0 · Source§

fn cause(&self) -> Option<&dyn Error>

👎Deprecated since 1.33.0:

replaced by Error::source, which can support downcasting

Source§

fn provide<'a>(&'a self, request: &mut Request<'a>)

🔬This is a nightly-only experimental API. (error_generic_member_access)
Provides type-based access to context intended for error reports. Read more
Source§

impl From<Error> for DaemonError

Source§

fn from(source: Error) -> Self

Converts to this type from the input type.

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> 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> ToCompactString for T
where T: Display,

Source§

impl<T> ToString for T
where T: Display + ?Sized,

Source§

fn to_string(&self) -> String

Converts the given value to a String. 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<V, T> VZip<V> for T
where V: MultiLane<T>,

Source§

fn vzip(self) -> V

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