Class: Riffer::ToolRuntime
- Inherits:
-
Object
- Object
- Riffer::ToolRuntime
- Defined in:
- lib/riffer/tool_runtime.rb
Overview
Riffer::ToolRuntime handles tool call execution for an agent.
Composes with a Riffer::Runner for concurrency control and provides execute as the sole public entry point.
Subclass and override dispatch_tool_call to customize how individual tool calls are dispatched (e.g., HTTP, gRPC).
runtime = Riffer::ToolRuntime::Inline.new
results = runtime.execute(tool_calls, tools: tools, context: context)
Defined Under Namespace
Classes: Fibers, Inline, Threaded
Instance Method Summary collapse
-
#around_tool_call(tool_call, context:) ⇒ Object
Hook that wraps each tool call execution.
-
#execute(tool_calls, tools:, context:) ⇒ Object
Executes a batch of tool calls, returning
[tool_call, response]pairs. -
#initialize(runner:) ⇒ ToolRuntime
constructor
- runner
-
the concurrency runner to use for batch execution.
Constructor Details
#initialize(runner:) ⇒ ToolRuntime
- runner
-
the concurrency runner to use for batch execution.
Subclasses must provide a runner; instantiating ToolRuntime directly raises NotImplementedError.
– : (runner: Riffer::Runner) -> void
25 26 27 28 |
# File 'lib/riffer/tool_runtime.rb', line 25 def initialize(runner:) raise NotImplementedError, "#{self.class} is abstract — use a subclass like Riffer::ToolRuntime::Inline" if instance_of?(Riffer::ToolRuntime) @runner = runner end |
Instance Method Details
#around_tool_call(tool_call, context:) ⇒ Object
Hook that wraps each tool call execution. Override in subclasses to customize. Must yield to continue execution.
The default implementation simply yields.
class InstrumentedRuntime < Riffer::ToolRuntime::Inline
private
def around_tool_call(tool_call, context:)
start = Time.now
result = yield
Rails.logger.info("Tool #{tool_call.name} took #{Time.now - start}s")
result
end
end
– : (Riffer::Messages::Assistant::ToolCall, context: Hash[Symbol, untyped]?) { () -> Riffer::Tools::Response } -> Riffer::Tools::Response
65 66 67 |
# File 'lib/riffer/tool_runtime.rb', line 65 def around_tool_call(tool_call, context:) yield end |
#execute(tool_calls, tools:, context:) ⇒ Object
Executes a batch of tool calls, returning [tool_call, response] pairs.
- tool_calls
-
the tool calls to execute.
- tools
-
the resolved tool classes.
- context
-
the context hash.
– : (Array, tools: Array, context: Hash[Symbol, untyped]?) -> Array[[Riffer::Messages::Assistant::ToolCall, Riffer::Tools::Response]]
38 39 40 41 42 43 44 45 |
# File 'lib/riffer/tool_runtime.rb', line 38 def execute(tool_calls, tools:, context:) @runner.map(tool_calls, context: context) do |tool_call| result = around_tool_call(tool_call, context: context) do dispatch_tool_call(tool_call, tools: tools, context: context) end [tool_call, result] end end |