For AI agents: a documentation index is available at the root level at /llms.txt and /llms-full.txt. Append /llms.txt to any URL for a page-level index, or .md for the markdown version of any page.
  • About NVIDIA NeMo Relay
    • Overview
    • Architecture
    • Ecosystem
    • Concepts
    • Release Notes
  • Getting Started
    • Agent Runtime Primer
    • Prerequisites
    • Installation
    • Configuration / Setup
    • Quick Start
  • NVIDIA NeMo Relay CLI
    • About
    • Basic Usage
    • Claude Code
    • Codex
    • Cursor
    • Hermes Agent
  • Supported Integrations
    • About
    • OpenClaw Plugin Guide
    • LangChain Integration Guide
    • LangGraph Integration Guide
    • Deep Agents Integration Guide
  • Instrument Applications
    • About
    • Adding Scopes and Marks
    • Instrument a Tool Call
    • Instrument an LLM Call
    • Add Middleware
    • Code Examples
  • Observability Plugin
    • About
    • Configuration
    • Agent Trajectory Interchange Format (ATIF)
    • Agent Trajectory Observability Format (ATOF)
    • OpenTelemetry
    • OpenInference
  • Adaptive Plugin
    • About
    • Configuration
    • Adaptive Cache Governor (ACG)
    • Adaptive Hints
  • NeMo Guardrails Plugin
    • About
    • Configuration
  • Integrate into Frameworks
    • About
    • Adding Scopes
    • Wrap Tool Calls
    • Wrap LLM Calls
    • Handle Non-Serializable Data
    • Using Codecs
    • Provider Codecs
    • Provider Response Codecs
    • Code Examples
  • Build Plugins
    • About
    • Define a Plugin
    • Validate Plugin Configuration
    • Plugin Configuration Files
    • Register Plugin Behavior
    • Design Plugin Configuration
    • NeMo Guardrails Example Plugin
    • Code Examples
  • Contribute
    • About
    • Development Setup
    • Workflow and Reviews
    • Testing and Documentation
  • Reference
    • APIs
      • Python Library Reference
      • Node.js Library Reference
      • Rust Library Reference
        • nemo-relay
          • api
          • codec
            • anthropic
            • openai_chat
            • openai_responses
            • request
            • response
              • AnnotatedLlmResponse
              • ResponseToolCall
              • Usage
              • ApiSpecificResponse
              • FinishReason
            • streaming
            • traits
          • config_editor
          • error
          • json
          • observability
          • plugin
          • plugins
          • stream
          • editor_config
        • nemo-relay-adaptive
        • nemo-relay-ffi
    • Performance
  • Resources
    • Support and FAQs
    • Glossary
    • Troubleshooting Guide
    • Community
    • Legal
NVIDIANVIDIA
Developer-friendly docs for your API
Privacy Policy | Your Privacy Choices | Terms of Service | Accessibility | Corporate Policies | Product Security | Contact

Copyright © 2026, NVIDIA Corporation.

LogoLogo
On this page
  • Variants
  • Complete
  • Length
  • ToolUse
  • ContentFilter
  • Unknown(String)
  • Implementations
  • impl FinishReason
  • is_complete
  • Trait Implementations
  • impl Clone for FinishReason
  • clone
  • clone_from
  • impl Debug for FinishReason
  • fmt
  • impl<'de> Deserialize<'de> for FinishReason
  • deserialize
  • impl PartialEq for FinishReason
  • eq
  • ne
  • impl Serialize for FinishReason
  • serialize
  • impl Eq for FinishReason
  • impl StructuralPartialEq for FinishReason
ReferenceAPIsRust Library Referencenemo-relaycodecresponse

Enum Finish Reason

||View as Markdown|
Previous

Enum ApiSpecific Response

Next

Module streaming

Generated from cargo doc --no-deps -p nemo-relay -p nemo-relay-adaptive -p nemo-relay-ffi.

pub enum FinishReason {
    Complete,
    Length,
    ToolUse,
    ContentFilter,
    Unknown(String),
}

Normalized reason why the model stopped generating.

Maps from provider-specific stop reasons:

  • Complete: OpenAI Chat "stop", Anthropic "end_turn", Responses "completed"
  • Length: OpenAI Chat "length", Anthropic "max_tokens", Responses incomplete+max_output_tokens
  • ToolUse: OpenAI Chat "tool_calls", Anthropic "tool_use"
  • ContentFilter: OpenAI Chat "content_filter", Responses incomplete+content_filter
  • Unknown: Forward-compatible catch-all for unrecognized reasons

Variants

Complete

Complete

Model naturally completed its response.

Length

Length

Maximum token limit reached.

ToolUse

ToolUse

Model requested a tool call.

ContentFilter

ContentFilter

Content was filtered by safety systems.

Unknown(String)

Unknown(String)

Unknown or forward-compatible reason.

Implementations

impl FinishReason

impl FinishReason

is_complete

pub fn is_complete(&self) -> bool

Returns true if the model naturally completed its response.

Only the FinishReason::Complete variant returns true.

Trait Implementations

impl Clone for FinishReason

impl Clone for FinishReason

clone

fn clone(&self) -> FinishReason

clone_from

fn clone_from(&mut self, source: &Self)

impl Debug for FinishReason

impl Debug for FinishReason

fmt

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

impl<'de> Deserialize<'de> for FinishReason

impl<'de> Deserialize<'de> for FinishReason

deserialize

fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
    __D: Deserializer<'de>,

impl PartialEq for FinishReason

impl PartialEq for FinishReason

eq

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

ne

fn ne(&self, other: &Rhs) -> bool

impl Serialize for FinishReason

impl Serialize for FinishReason

serialize

fn serialize<__S>(&self, __serializer: __S) -> Result<__S::Ok, __S::Error>where
    __S: Serializer,

impl Eq for FinishReason

impl Eq for FinishReason

impl StructuralPartialEq for FinishReason

impl StructuralPartialEq for FinishReason