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.
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.
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
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).
MemoryBudgetExceeded
Admission control could not satisfy a reservation after evicting every non-pinned workspace.
Maps to JSON-RPC -32003.
Fields
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.
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.
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
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.
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
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).
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).
Implementations§
Source§impl DaemonError
impl DaemonError
Sourcepub const fn jsonrpc_code(&self) -> Option<i32>
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.
Sourcepub const fn exit_code(&self) -> u8
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).
| Code | Symbol | Semantics |
|---|---|---|
| 0 | EX_OK | Success (not an error; included for completeness) |
| 69 | EX_UNAVAILABLE | Service unavailable (timeout, not-ready) |
| 70 | EX_SOFTWARE | Internal software error |
| 73 | EX_CANTCREAT | IO error / cannot create required file |
| 75 | EX_TEMPFAIL | Try again (e.g. another instance is running) |
| 78 | EX_CONFIG | Configuration 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.
Sourcepub fn error_data(&self) -> Option<Value>
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
impl Debug for DaemonError
Source§impl Display for DaemonError
impl Display for DaemonError
Source§impl Error for DaemonError
impl Error for DaemonError
Source§fn source(&self) -> Option<&(dyn Error + 'static)>
fn source(&self) -> Option<&(dyn Error + 'static)>
1.0.0 · Source§fn description(&self) -> &str
fn description(&self) -> &str
use the Display impl or to_string()
Auto Trait Implementations§
impl Freeze for DaemonError
impl !RefUnwindSafe for DaemonError
impl Send for DaemonError
impl Sync for DaemonError
impl Unpin for DaemonError
impl UnsafeUnpin for DaemonError
impl !UnwindSafe for DaemonError
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Source§impl<T> Instrument for T
impl<T> Instrument for T
Source§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
Source§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
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 moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
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 moreSource§impl<D> OwoColorize for D
impl<D> OwoColorize for D
Source§fn fg<C>(&self) -> FgColorDisplay<'_, C, Self>where
C: Color,
fn fg<C>(&self) -> FgColorDisplay<'_, C, Self>where
C: Color,
Source§fn bg<C>(&self) -> BgColorDisplay<'_, C, Self>where
C: Color,
fn bg<C>(&self) -> BgColorDisplay<'_, C, Self>where
C: Color,
Source§fn black(&self) -> FgColorDisplay<'_, Black, Self>
fn black(&self) -> FgColorDisplay<'_, Black, Self>
Source§fn on_black(&self) -> BgColorDisplay<'_, Black, Self>
fn on_black(&self) -> BgColorDisplay<'_, Black, Self>
Source§fn red(&self) -> FgColorDisplay<'_, Red, Self>
fn red(&self) -> FgColorDisplay<'_, Red, Self>
Source§fn on_red(&self) -> BgColorDisplay<'_, Red, Self>
fn on_red(&self) -> BgColorDisplay<'_, Red, Self>
Source§fn green(&self) -> FgColorDisplay<'_, Green, Self>
fn green(&self) -> FgColorDisplay<'_, Green, Self>
Source§fn on_green(&self) -> BgColorDisplay<'_, Green, Self>
fn on_green(&self) -> BgColorDisplay<'_, Green, Self>
Source§fn yellow(&self) -> FgColorDisplay<'_, Yellow, Self>
fn yellow(&self) -> FgColorDisplay<'_, Yellow, Self>
Source§fn on_yellow(&self) -> BgColorDisplay<'_, Yellow, Self>
fn on_yellow(&self) -> BgColorDisplay<'_, Yellow, Self>
Source§fn blue(&self) -> FgColorDisplay<'_, Blue, Self>
fn blue(&self) -> FgColorDisplay<'_, Blue, Self>
Source§fn on_blue(&self) -> BgColorDisplay<'_, Blue, Self>
fn on_blue(&self) -> BgColorDisplay<'_, Blue, Self>
Source§fn magenta(&self) -> FgColorDisplay<'_, Magenta, Self>
fn magenta(&self) -> FgColorDisplay<'_, Magenta, Self>
Source§fn on_magenta(&self) -> BgColorDisplay<'_, Magenta, Self>
fn on_magenta(&self) -> BgColorDisplay<'_, Magenta, Self>
Source§fn purple(&self) -> FgColorDisplay<'_, Magenta, Self>
fn purple(&self) -> FgColorDisplay<'_, Magenta, Self>
Source§fn on_purple(&self) -> BgColorDisplay<'_, Magenta, Self>
fn on_purple(&self) -> BgColorDisplay<'_, Magenta, Self>
Source§fn cyan(&self) -> FgColorDisplay<'_, Cyan, Self>
fn cyan(&self) -> FgColorDisplay<'_, Cyan, Self>
Source§fn on_cyan(&self) -> BgColorDisplay<'_, Cyan, Self>
fn on_cyan(&self) -> BgColorDisplay<'_, Cyan, Self>
Source§fn white(&self) -> FgColorDisplay<'_, White, Self>
fn white(&self) -> FgColorDisplay<'_, White, Self>
Source§fn on_white(&self) -> BgColorDisplay<'_, White, Self>
fn on_white(&self) -> BgColorDisplay<'_, White, Self>
Source§fn default_color(&self) -> FgColorDisplay<'_, Default, Self>
fn default_color(&self) -> FgColorDisplay<'_, Default, Self>
Source§fn on_default_color(&self) -> BgColorDisplay<'_, Default, Self>
fn on_default_color(&self) -> BgColorDisplay<'_, Default, Self>
Source§fn bright_black(&self) -> FgColorDisplay<'_, BrightBlack, Self>
fn bright_black(&self) -> FgColorDisplay<'_, BrightBlack, Self>
Source§fn on_bright_black(&self) -> BgColorDisplay<'_, BrightBlack, Self>
fn on_bright_black(&self) -> BgColorDisplay<'_, BrightBlack, Self>
Source§fn bright_red(&self) -> FgColorDisplay<'_, BrightRed, Self>
fn bright_red(&self) -> FgColorDisplay<'_, BrightRed, Self>
Source§fn on_bright_red(&self) -> BgColorDisplay<'_, BrightRed, Self>
fn on_bright_red(&self) -> BgColorDisplay<'_, BrightRed, Self>
Source§fn bright_green(&self) -> FgColorDisplay<'_, BrightGreen, Self>
fn bright_green(&self) -> FgColorDisplay<'_, BrightGreen, Self>
Source§fn on_bright_green(&self) -> BgColorDisplay<'_, BrightGreen, Self>
fn on_bright_green(&self) -> BgColorDisplay<'_, BrightGreen, Self>
Source§fn bright_yellow(&self) -> FgColorDisplay<'_, BrightYellow, Self>
fn bright_yellow(&self) -> FgColorDisplay<'_, BrightYellow, Self>
Source§fn on_bright_yellow(&self) -> BgColorDisplay<'_, BrightYellow, Self>
fn on_bright_yellow(&self) -> BgColorDisplay<'_, BrightYellow, Self>
Source§fn bright_blue(&self) -> FgColorDisplay<'_, BrightBlue, Self>
fn bright_blue(&self) -> FgColorDisplay<'_, BrightBlue, Self>
Source§fn on_bright_blue(&self) -> BgColorDisplay<'_, BrightBlue, Self>
fn on_bright_blue(&self) -> BgColorDisplay<'_, BrightBlue, Self>
Source§fn bright_magenta(&self) -> FgColorDisplay<'_, BrightMagenta, Self>
fn bright_magenta(&self) -> FgColorDisplay<'_, BrightMagenta, Self>
Source§fn on_bright_magenta(&self) -> BgColorDisplay<'_, BrightMagenta, Self>
fn on_bright_magenta(&self) -> BgColorDisplay<'_, BrightMagenta, Self>
Source§fn bright_purple(&self) -> FgColorDisplay<'_, BrightMagenta, Self>
fn bright_purple(&self) -> FgColorDisplay<'_, BrightMagenta, Self>
Source§fn on_bright_purple(&self) -> BgColorDisplay<'_, BrightMagenta, Self>
fn on_bright_purple(&self) -> BgColorDisplay<'_, BrightMagenta, Self>
Source§fn bright_cyan(&self) -> FgColorDisplay<'_, BrightCyan, Self>
fn bright_cyan(&self) -> FgColorDisplay<'_, BrightCyan, Self>
Source§fn on_bright_cyan(&self) -> BgColorDisplay<'_, BrightCyan, Self>
fn on_bright_cyan(&self) -> BgColorDisplay<'_, BrightCyan, Self>
Source§fn bright_white(&self) -> FgColorDisplay<'_, BrightWhite, Self>
fn bright_white(&self) -> FgColorDisplay<'_, BrightWhite, Self>
Source§fn on_bright_white(&self) -> BgColorDisplay<'_, BrightWhite, Self>
fn on_bright_white(&self) -> BgColorDisplay<'_, BrightWhite, Self>
Source§fn bold(&self) -> BoldDisplay<'_, Self>
fn bold(&self) -> BoldDisplay<'_, Self>
Source§fn dimmed(&self) -> DimDisplay<'_, Self>
fn dimmed(&self) -> DimDisplay<'_, Self>
Source§fn italic(&self) -> ItalicDisplay<'_, Self>
fn italic(&self) -> ItalicDisplay<'_, Self>
Source§fn underline(&self) -> UnderlineDisplay<'_, Self>
fn underline(&self) -> UnderlineDisplay<'_, Self>
Source§fn blink(&self) -> BlinkDisplay<'_, Self>
fn blink(&self) -> BlinkDisplay<'_, Self>
Source§fn blink_fast(&self) -> BlinkFastDisplay<'_, Self>
fn blink_fast(&self) -> BlinkFastDisplay<'_, Self>
Source§fn reversed(&self) -> ReversedDisplay<'_, Self>
fn reversed(&self) -> ReversedDisplay<'_, Self>
Source§fn strikethrough(&self) -> StrikeThroughDisplay<'_, Self>
fn strikethrough(&self) -> StrikeThroughDisplay<'_, Self>
Source§fn color<Color>(&self, color: Color) -> FgDynColorDisplay<'_, Color, Self>where
Color: DynColor,
fn color<Color>(&self, color: Color) -> FgDynColorDisplay<'_, Color, Self>where
Color: DynColor,
OwoColorize::fg or
a color-specific method, such as OwoColorize::green, Read moreSource§fn on_color<Color>(&self, color: Color) -> BgDynColorDisplay<'_, Color, Self>where
Color: DynColor,
fn on_color<Color>(&self, color: Color) -> BgDynColorDisplay<'_, Color, Self>where
Color: DynColor,
OwoColorize::bg or
a color-specific method, such as OwoColorize::on_yellow, Read moreSource§fn fg_rgb<const R: u8, const G: u8, const B: u8>(
&self,
) -> FgColorDisplay<'_, CustomColor<R, G, B>, Self>
fn fg_rgb<const R: u8, const G: u8, const B: u8>( &self, ) -> FgColorDisplay<'_, CustomColor<R, G, B>, Self>
Source§fn bg_rgb<const R: u8, const G: u8, const B: u8>(
&self,
) -> BgColorDisplay<'_, CustomColor<R, G, B>, Self>
fn bg_rgb<const R: u8, const G: u8, const B: u8>( &self, ) -> BgColorDisplay<'_, CustomColor<R, G, B>, Self>
Source§fn truecolor(&self, r: u8, g: u8, b: u8) -> FgDynColorDisplay<'_, Rgb, Self>
fn truecolor(&self, r: u8, g: u8, b: u8) -> FgDynColorDisplay<'_, Rgb, Self>
Source§fn on_truecolor(&self, r: u8, g: u8, b: u8) -> BgDynColorDisplay<'_, Rgb, Self>
fn on_truecolor(&self, r: u8, g: u8, b: u8) -> BgDynColorDisplay<'_, Rgb, Self>
Source§impl<T> Pointable for T
impl<T> Pointable for T
Source§impl<T> ToCompactString for Twhere
T: Display,
impl<T> ToCompactString for Twhere
T: Display,
Source§fn try_to_compact_string(&self) -> Result<CompactString, ToCompactStringError>
fn try_to_compact_string(&self) -> Result<CompactString, ToCompactStringError>
ToCompactString::to_compact_string() Read moreSource§fn to_compact_string(&self) -> CompactString
fn to_compact_string(&self) -> CompactString
CompactString. Read more