Op

Enum Op 

Source
#[non_exhaustive]
pub enum Op {
Show 15 variants Interrupt, UserInput { items: Vec<UserInput>, }, UserTurn { items: Vec<UserInput>, cwd: PathBuf, approval_policy: AskForApproval, sandbox_policy: SandboxPolicy, model: String, effort: Option<ReasoningEffort>, summary: ReasoningSummary, final_output_json_schema: Option<Value>, }, OverrideTurnContext { cwd: Option<PathBuf>, approval_policy: Option<AskForApproval>, sandbox_policy: Option<SandboxPolicy>, model: Option<String>, effort: Option<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, ListCustomPrompts, Compact, Undo, Review { review_request: ReviewRequest, }, Shutdown, RunUserShellCommand { command: String, },
}
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<UserInput>

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

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: Option<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.

§final_output_json_schema: Option<Value>
§

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<Option<ReasoningEffort>>

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

Use Some(Some(_)) to set a specific effort, Some(None) to clear the effort, or None to leave the existing value unchanged.

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

§

ListCustomPrompts

Request the list of available custom prompts.

§

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.

§

Undo

Request Codex to undo a turn (turn are stacked so it is the same effect as CMD + Z).

§

Review

Request a code review from the agent.

Fields

§review_request: ReviewRequest
§

Shutdown

Request to shut down codex instance.

§

RunUserShellCommand

Execute a user-initiated one-off shell command (triggered by “!cmd”).

The command string is executed using the user’s default shell and may include shell syntax (pipes, redirects, etc.). Output is streamed via ExecCommand* events and the UI regains control upon TaskComplete.

Fields

§command: String

The raw command string after ‘!’

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

Source§

fn schema_name() -> Cow<'static, str>

The name of the generated JSON Schema. Read more
Source§

fn schema_id() -> Cow<'static, str>

Returns a string that uniquely identifies the schema produced by this type. Read more
Source§

fn json_schema(generator: &mut SchemaGenerator) -> Schema

Generates a JSON Schema for this type. Read more
Source§

fn inline_schema() -> bool

Whether JSON Schemas generated for this type should be included directly in parent schemas, rather than being re-used where possible using the $ref keyword. 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> DynClone for T
where T: Clone,

Source§

fn __clone_box(&self, _: Private) -> *mut ()

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

Source§

impl<T> ErasedDestructor for T
where T: 'static,