Skip to main content

AttentionEntry

Struct AttentionEntry 

Source
pub struct AttentionEntry {
    pub agent: String,
    pub project: String,
    pub cwd: String,
    pub event: String,
    pub tmux_pane: String,
    pub ts: u64,
    pub message: Option<String>,
    pub pid: Option<u32>,
}
Expand description

One entry stored per active agent session that is waiting on user attention.

Serialized as compact JSON to one file per session (keyed by session_id) under ${XDG_RUNTIME_DIR:-/tmp}/agent-status/. The field shape is wire-compatible with the bash version of this tool.

Fields§

§agent: String

Stable identifier of the agent that wrote this entry (e.g. "claude-code").

§project: String

Basename of the project directory (typically the cwd’s last component).

§cwd: String

Absolute path of the project directory at the time the hook fired.

§event: String

Hook event label, for example notify or done.

§tmux_pane: String

Tmux pane id (such as %17), or empty if the hook fired outside tmux.

§ts: u64

Unix timestamp (seconds) when the entry was written.

§message: Option<String>

Optional last-message text from the agent (e.g. Claude Code Notification’s message field). Absent in the JSON when None; absent on entries written by older binaries.

§pid: Option<u32>

PID of the agent process at the time the hook fired (typically getppid() from inside the hook script — the claude/opencode/pi binary). Used to clean up state files whose owning process has exited without firing its session-end hook. Absent in entries written by older binaries; entries without a pid are never auto-pruned.

Trait Implementations§

Source§

impl Clone for AttentionEntry

Source§

fn clone(&self) -> AttentionEntry

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 AttentionEntry

Source§

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

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

impl<'de> Deserialize<'de> for AttentionEntry

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 AttentionEntry

Source§

fn eq(&self, other: &AttentionEntry) -> 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 AttentionEntry

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 AttentionEntry

Source§

impl StructuralPartialEq for AttentionEntry

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<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

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> 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> DeserializeOwned for T
where T: for<'de> Deserialize<'de>,