Op

Enum Op 

Source
#[non_exhaustive]
pub enum Op { Interrupt, UserInput { items: Vec<InputItem>, }, UserTurn { items: Vec<InputItem>, cwd: PathBuf, approval_policy: AskForApproval, sandbox_policy: SandboxPolicy, model: String, effort: ReasoningEffort, summary: ReasoningSummary, }, OverrideTurnContext { cwd: Option<PathBuf>, approval_policy: Option<AskForApproval>, sandbox_policy: Option<SandboxPolicy>, model: Option<String>, effort: Option<ReasoningEffort>, summary: Option<ReasoningSummary>, }, ExecApproval { id: String, decision: ReviewDecision, }, PatchApproval { id: String, decision: ReviewDecision, }, AddToHistory { text: String, }, GetHistoryEntryRequest { offset: usize, log_id: u64, }, ListMcpTools, Compact, Shutdown, }
Expand description

Submission operation

Variants (Non-exhaustive)§

This enum is marked as non-exhaustive
Non-exhaustive enums could have additional variants added in future. Therefore, when matching against variants of non-exhaustive enums, an extra wildcard arm must be added to account for any future variants.
§

Interrupt

Abort current task. This server sends EventMsg::TurnAborted in response.

§

UserInput

Input from the user

Fields

§items: Vec<InputItem>

User input items, see InputItem

§

UserTurn

Similar to Op::UserInput, but contains additional context required for a turn of a [crate::codex_conversation::CodexConversation].

Fields

§items: Vec<InputItem>

User input items, see InputItem

§cwd: PathBuf

cwd to use with the SandboxPolicy and potentially tool calls such as local_shell.

§approval_policy: AskForApproval

Policy to use for command approval.

§sandbox_policy: SandboxPolicy

Policy to use for tool calls such as local_shell.

§model: String

Must be a valid model slug for the [crate::client::ModelClient] associated with this conversation.

§effort: ReasoningEffort

Will only be honored if the model is configured to use reasoning.

§summary: ReasoningSummary

Will only be honored if the model is configured to use reasoning.

§

OverrideTurnContext

Override parts of the persistent turn context for subsequent turns.

All fields are optional; when omitted, the existing value is preserved. This does not enqueue any input – it only updates defaults used for future UserInput turns.

Fields

§cwd: Option<PathBuf>

Updated cwd for sandbox/tool calls.

§approval_policy: Option<AskForApproval>

Updated command approval policy.

§sandbox_policy: Option<SandboxPolicy>

Updated sandbox policy for tool calls.

§model: Option<String>

Updated model slug. When set, the model family is derived automatically.

§effort: Option<ReasoningEffort>

Updated reasoning effort (honored only for reasoning-capable models).

§summary: Option<ReasoningSummary>

Updated reasoning summary preference (honored only for reasoning-capable models).

§

ExecApproval

Approve a command execution

Fields

§id: String

The id of the submission we are approving

§decision: ReviewDecision

The user’s decision in response to the request.

§

PatchApproval

Approve a code patch

Fields

§id: String

The id of the submission we are approving

§decision: ReviewDecision

The user’s decision in response to the request.

§

AddToHistory

Append an entry to the persistent cross-session message history.

Note the entry is not guaranteed to be logged if the user has history disabled, it matches the list of “sensitive” patterns, etc.

Fields

§text: String

The message text to be stored.

§

GetHistoryEntryRequest

Request a single history entry identified by log_id + offset.

Fields

§offset: usize
§log_id: u64
§

ListMcpTools

Request the list of MCP tools available across all configured servers. Reply is delivered via EventMsg::McpListToolsResponse.

§

Compact

Request the agent to summarize the current conversation context. The agent will use its existing context (either conversation history or previous response id) to generate a summary which will be returned as an AgentMessage event.

§

Shutdown

Request to shut down codex instance.

Trait Implementations§

Source§

impl Clone for Op

Source§

fn clone(&self) -> Op

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 Op

Source§

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

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

impl<'de> Deserialize<'de> for Op

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 Op

Source§

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

Tests for self and other values to be equal, and is used by ==.
1.0.0 · 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 Op

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 StructuralPartialEq for Op

Auto Trait Implementations§

§

impl Freeze for Op

§

impl RefUnwindSafe for Op

§

impl Send for Op

§

impl Sync for Op

§

impl Unpin for Op

§

impl UnwindSafe for Op

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>,