Module: Kward::ToolCall
- Defined in:
- lib/kward/tools/tool_call.rb
Overview
Reads and normalizes model tool-call hashes.
Tool calls arrive from several providers and may be restored from session files. This module keeps provider/string/symbol compatibility in one place and exposes small helpers used by the agent loop, tool registry, transcript formatters, and RPC event normalizers.
Constant Summary collapse
- TOOL_NAME_MAP =
{ "read_file" => "read", "edit_file" => "edit", "write_file" => "write", "run_shell_command" => "bash", "list_directory" => "list_directory", "code_search" => "code_search", "web_search" => "web_search", "fetch_content" => "fetch_content", "fetch_raw" => "fetch_raw", "read_skill" => "read_skill", "ask_user_question" => "ask_user_question" }.freeze
Class Method Summary collapse
-
.arguments(tool_call) ⇒ Hash
Parses the requested tool arguments.
-
.camelize_args(args) ⇒ Hash
Recursively converts snake_case hash keys to camelCase symbols.
- .camelize_key(key) ⇒ Object
- .camelize_value(item) ⇒ Object
-
.display_name(tool_call) ⇒ String
Returns the short name used in compact UI labels.
- .function(tool_call) ⇒ Object
-
.id(tool_call) ⇒ String?
Provider tool-call id.
-
.name(tool_call) ⇒ String?
Requested tool/function name.
- .normalized_name(name) ⇒ Object
-
.parse_arguments(arguments) ⇒ Object
Converts provider argument payloads into hashes.
- .raw_arguments(tool_call) ⇒ Object
- .value(object, key) ⇒ Object
Class Method Details
.arguments(tool_call) ⇒ Hash
Parses the requested tool arguments.
50 51 52 |
# File 'lib/kward/tools/tool_call.rb', line 50 def arguments(tool_call) parse_arguments(raw_arguments(tool_call)) end |
.camelize_args(args) ⇒ Hash
Recursively converts snake_case hash keys to camelCase symbols.
82 83 84 85 86 87 88 |
# File 'lib/kward/tools/tool_call.rb', line 82 def camelize_args(args) return {} unless args.is_a?(Hash) args.each_with_object({}) do |(key, item), result| result[camelize_key(key)] = camelize_value(item) end end |
.camelize_key(key) ⇒ Object
105 106 107 |
# File 'lib/kward/tools/tool_call.rb', line 105 def camelize_key(key) key.to_s.gsub(/_([a-z])/) { Regexp.last_match(1).upcase }.to_sym end |
.camelize_value(item) ⇒ Object
94 95 96 97 98 99 100 101 102 103 |
# File 'lib/kward/tools/tool_call.rb', line 94 def camelize_value(item) case item when Hash camelize_args(item) when Array item.map { |entry| camelize_value(entry) } else item end end |
.display_name(tool_call) ⇒ String
Returns the short name used in compact UI labels.
42 43 44 45 |
# File 'lib/kward/tools/tool_call.rb', line 42 def display_name(tool_call) raw_name = name(tool_call) normalized_name(raw_name) || raw_name || "unknown_tool" end |
.function(tool_call) ⇒ Object
58 59 60 |
# File 'lib/kward/tools/tool_call.rb', line 58 def function(tool_call) value(tool_call, :function) || {} end |
.id(tool_call) ⇒ String?
Returns provider tool-call id.
30 31 32 |
# File 'lib/kward/tools/tool_call.rb', line 30 def id(tool_call) value(tool_call, :id) end |
.name(tool_call) ⇒ String?
Returns requested tool/function name.
35 36 37 |
# File 'lib/kward/tools/tool_call.rb', line 35 def name(tool_call) value(function(tool_call), :name) end |
.normalized_name(name) ⇒ Object
62 63 64 |
# File 'lib/kward/tools/tool_call.rb', line 62 def normalized_name(name) TOOL_NAME_MAP[name.to_s] end |
.parse_arguments(arguments) ⇒ Object
Converts provider argument payloads into hashes.
Providers normally send JSON strings, while tests and compatibility callers may pass hashes directly.
70 71 72 73 74 75 76 77 |
# File 'lib/kward/tools/tool_call.rb', line 70 def parse_arguments(arguments) return {} if arguments.nil? || (arguments.respond_to?(:empty?) && arguments.empty?) return arguments if arguments.is_a?(Hash) JSON.parse(arguments.to_s) rescue JSON::ParserError {} end |
.raw_arguments(tool_call) ⇒ Object
54 55 56 |
# File 'lib/kward/tools/tool_call.rb', line 54 def raw_arguments(tool_call) value(function(tool_call), :arguments) end |
.value(object, key) ⇒ Object
90 91 92 |
# File 'lib/kward/tools/tool_call.rb', line 90 def value(object, key) MessageAccess.value(object, key) end |