Class: LLM::Message
- Inherits:
-
Object
- Object
- LLM::Message
- Defined in:
- lib/llm/message.rb
Instance Attribute Summary collapse
-
#role ⇒
Symbol readonly
Returns the role of the message.
-
#content ⇒
String readonly
Returns the content of the message.
-
#extra ⇒
Hash readonly
Returns extra context associated with the message.
Instance Method Summary collapse
-
#inspect ⇒
String
Returns a string representation of the message.
-
#to_h ⇒
Hash
Returns a Hash representation of the message.
- #to_json ⇒ String
-
#==(other) ⇒ Boolean
(also: #eql?)
Returns true when two objects have the same role and content.
-
#content! ⇒
Hash
Try to parse JSON content.
- #functions ⇒ Array<LLM::Function>
-
#assistant? ⇒
Boolean
Returns true when the message is an assistant message.
-
#system? ⇒
Boolean
Returns true when the message is a system message.
-
#user? ⇒
Boolean
Returns true when the message is a user message.
-
#tool_call? ⇒
Boolean
Returns true when the message requests a function call.
-
#tool_return? ⇒
Boolean
Returns true when the message represents a function return.
-
#response ⇒
LLM::Response?
Returns the response associated with the message, or nil.
-
#annotations ⇒
Array<LLM::Object>
Returns annotations associated with the message.
-
#usage ⇒
LLM::Object? (also: #token_usage)
Returns token usage statistics.
-
#model ⇒
String?
Returns the model associated with a message.
-
#initialize(role,
content, extra = {}) ⇒ LLM::Message constructor
Returns a new message.
Constructor Details
#initialize(role, content, extra = {}) ⇒ LLM::Message
Returns a new message
26 27 28 29 30 |
# File 'lib/llm/message.rb', line 26 def initialize(role, content, extra = {}) @role = role.to_s @content = content @extra = extra end |
Instance Attribute Details
#role ⇒ Symbol (readonly)
Returns the role of the message
8 9 10 |
# File 'lib/llm/message.rb', line 8 def role @role end |
#content ⇒ String (readonly)
Returns the content of the message
13 14 15 |
# File 'lib/llm/message.rb', line 13 def content @content end |
#extra ⇒ Hash (readonly)
Returns extra context associated with the message
18 19 20 |
# File 'lib/llm/message.rb', line 18 def extra @extra end |
Instance Method Details
#inspect ⇒ String
Returns a string representation of the message
157 158 159 160 161 |
# File 'lib/llm/message.rb', line 157 def inspect "#<#{self.class.name}:0x#{object_id.to_s(16)} " \ "tool_call=#{tool_calls.any?} role=#{role.inspect} " \ "content=#{content.inspect}>" end |
#to_h ⇒ Hash
Returns a Hash representation of the message.
35 36 37 38 39 |
# File 'lib/llm/message.rb', line 35 def to_h {role:, content:, tools: @extra[:tool_calls], original_tool_calls: extra[:original_tool_calls]}.compact end |
#to_json ⇒ String
43 44 45 |
# File 'lib/llm/message.rb', line 43 def to_json(...) LLM.json.dump(to_h, ...) end |
#==(other) ⇒ Boolean Also known as: eql?
Returns true when two objects have the same role and content
52 53 54 55 56 57 58 |
# File 'lib/llm/message.rb', line 52 def ==(other) if other.respond_to?(:to_h) to_h == other.to_h else false end end |
#content! ⇒ Hash
Try to parse JSON content
65 66 67 |
# File 'lib/llm/message.rb', line 65 def content! LLM.json.load(content) end |
#functions ⇒ Array<LLM::Function>
71 72 73 74 75 76 77 |
# File 'lib/llm/message.rb', line 71 def functions @functions ||= tool_calls.map do |fn| function = available_tools.find { _1.name.to_s == fn["name"] }.dup function.tap { _1.id = fn.id } function.tap { _1.arguments = fn.arguments } end end |
#assistant? ⇒ Boolean
Returns true when the message is an assistant message
82 83 84 |
# File 'lib/llm/message.rb', line 82 def assistant? role == "assistant" || role == "model" end |
#system? ⇒ Boolean
Returns true when the message is a system message
89 90 91 |
# File 'lib/llm/message.rb', line 89 def system? role == "system" end |
#user? ⇒ Boolean
Returns true when the message is a user message
96 97 98 |
# File 'lib/llm/message.rb', line 96 def user? role == "user" end |
#tool_call? ⇒ Boolean
Returns true when the message requests a function call
103 104 105 |
# File 'lib/llm/message.rb', line 103 def tool_call? tool_calls.any? end |
#tool_return? ⇒ Boolean
Returns true when the message represents a function return
110 111 112 113 |
# File 'lib/llm/message.rb', line 110 def tool_return? LLM::Function::Return === content || [*content].grep(LLM::Function::Return).any? end |
#response ⇒ LLM::Response?
This method returns a response for assistant messages, and it returns nil for non-assistant messages
Returns the response associated with the message, or nil
121 122 123 |
# File 'lib/llm/message.rb', line 121 def response extra[:response] end |
#annotations ⇒ Array<LLM::Object>
This method might return annotations for assistant messages, and it returns an empty array for non-assistant messages
Returns annotations associated with the message
131 132 133 |
# File 'lib/llm/message.rb', line 131 def annotations @annotations ||= LLM::Object.from(extra["annotations"] || []) end |
#usage ⇒ LLM::Object? Also known as: token_usage
This method returns token usage for assistant messages, and it returns nil for non-assistant messages
Returns token usage statistics
141 142 143 144 |
# File 'lib/llm/message.rb', line 141 def usage return nil unless response @usage ||= response.usage end |
#model ⇒ String?
Returns the model associated with a message
150 151 152 |
# File 'lib/llm/message.rb', line 150 def model response&.model end |