Class: RubyLLM::Message
- Inherits:
-
Object
- Object
- RubyLLM::Message
- Defined in:
- lib/ruby_llm/message.rb
Overview
A single message in a chat conversation.
Direct Known Subclasses
Constant Summary collapse
- ROLES =
i[system user assistant tool].freeze
Instance Attribute Summary collapse
- #content ⇒ Object
-
#model_id ⇒ Object
readonly
Returns the value of attribute model_id.
-
#raw ⇒ Object
readonly
Returns the value of attribute raw.
-
#role ⇒ Object
readonly
Returns the value of attribute role.
-
#thinking ⇒ Object
readonly
Returns the value of attribute thinking.
-
#tokens ⇒ Object
readonly
Returns the value of attribute tokens.
-
#tool_call_id ⇒ Object
readonly
Returns the value of attribute tool_call_id.
-
#tool_calls ⇒ Object
readonly
Returns the value of attribute tool_calls.
Instance Method Summary collapse
- #cache_creation_tokens ⇒ Object
- #cached_tokens ⇒ Object
-
#initialize(options = {}) ⇒ Message
constructor
A new instance of Message.
- #input_tokens ⇒ Object
- #instance_variables ⇒ Object
- #output_tokens ⇒ Object
- #reasoning_tokens ⇒ Object
- #thinking_tokens ⇒ Object
- #to_h ⇒ Object
- #tool_call? ⇒ Boolean
- #tool_result? ⇒ Boolean
- #tool_results ⇒ Object
Constructor Details
#initialize(options = {}) ⇒ Message
Returns a new instance of Message.
11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 |
# File 'lib/ruby_llm/message.rb', line 11 def initialize( = {}) @role = .fetch(:role).to_sym @content = normalize_content(.fetch(:content)) @model_id = [:model_id] @tool_calls = [:tool_calls] @tool_call_id = [:tool_call_id] @tokens = [:tokens] || Tokens.build( input: [:input_tokens], output: [:output_tokens], cached: [:cached_tokens], cache_creation: [:cache_creation_tokens], thinking: [:thinking_tokens], reasoning: [:reasoning_tokens] ) @raw = [:raw] @thinking = [:thinking] ensure_valid_role end |
Instance Attribute Details
#content ⇒ Object
31 32 33 34 35 36 37 |
# File 'lib/ruby_llm/message.rb', line 31 def content if @content.is_a?(Content) && @content.text && @content..empty? @content.text else @content end end |
#model_id ⇒ Object (readonly)
Returns the value of attribute model_id.
8 9 10 |
# File 'lib/ruby_llm/message.rb', line 8 def model_id @model_id end |
#raw ⇒ Object (readonly)
Returns the value of attribute raw.
8 9 10 |
# File 'lib/ruby_llm/message.rb', line 8 def raw @raw end |
#role ⇒ Object (readonly)
Returns the value of attribute role.
8 9 10 |
# File 'lib/ruby_llm/message.rb', line 8 def role @role end |
#thinking ⇒ Object (readonly)
Returns the value of attribute thinking.
8 9 10 |
# File 'lib/ruby_llm/message.rb', line 8 def thinking @thinking end |
#tokens ⇒ Object (readonly)
Returns the value of attribute tokens.
8 9 10 |
# File 'lib/ruby_llm/message.rb', line 8 def tokens @tokens end |
#tool_call_id ⇒ Object (readonly)
Returns the value of attribute tool_call_id.
8 9 10 |
# File 'lib/ruby_llm/message.rb', line 8 def tool_call_id @tool_call_id end |
#tool_calls ⇒ Object (readonly)
Returns the value of attribute tool_calls.
8 9 10 |
# File 'lib/ruby_llm/message.rb', line 8 def tool_calls @tool_calls end |
Instance Method Details
#cache_creation_tokens ⇒ Object
63 64 65 |
# File 'lib/ruby_llm/message.rb', line 63 def cache_creation_tokens tokens&.cache_creation end |
#cached_tokens ⇒ Object
59 60 61 |
# File 'lib/ruby_llm/message.rb', line 59 def cached_tokens tokens&.cached end |
#input_tokens ⇒ Object
51 52 53 |
# File 'lib/ruby_llm/message.rb', line 51 def input_tokens tokens&.input end |
#instance_variables ⇒ Object
87 88 89 |
# File 'lib/ruby_llm/message.rb', line 87 def instance_variables super - [:@raw] end |
#output_tokens ⇒ Object
55 56 57 |
# File 'lib/ruby_llm/message.rb', line 55 def output_tokens tokens&.output end |
#reasoning_tokens ⇒ Object
71 72 73 |
# File 'lib/ruby_llm/message.rb', line 71 def reasoning_tokens tokens&.thinking end |
#thinking_tokens ⇒ Object
67 68 69 |
# File 'lib/ruby_llm/message.rb', line 67 def thinking_tokens tokens&.thinking end |
#to_h ⇒ Object
75 76 77 78 79 80 81 82 83 84 85 |
# File 'lib/ruby_llm/message.rb', line 75 def to_h { role: role, content: content, model_id: model_id, tool_calls: tool_calls, tool_call_id: tool_call_id, thinking: thinking&.text, thinking_signature: thinking&.signature }.merge(tokens ? tokens.to_h : {}).compact end |
#tool_call? ⇒ Boolean
39 40 41 |
# File 'lib/ruby_llm/message.rb', line 39 def tool_call? !tool_calls.nil? && !tool_calls.empty? end |
#tool_result? ⇒ Boolean
43 44 45 |
# File 'lib/ruby_llm/message.rb', line 43 def tool_result? !tool_call_id.nil? && !tool_call_id.empty? end |
#tool_results ⇒ Object
47 48 49 |
# File 'lib/ruby_llm/message.rb', line 47 def tool_results content if tool_result? end |