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", "summarize_file_structure" => "summarize_file_structure", "retrieve_tool_output" => "retrieve_tool_output", "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.
52 53 54 |
# File 'lib/kward/tools/tool_call.rb', line 52 def arguments(tool_call) parse_arguments(raw_arguments(tool_call)) end |
.camelize_args(args) ⇒ Hash
Recursively converts snake_case hash keys to camelCase symbols.
84 85 86 87 88 89 90 |
# File 'lib/kward/tools/tool_call.rb', line 84 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
107 108 109 |
# File 'lib/kward/tools/tool_call.rb', line 107 def camelize_key(key) key.to_s.gsub(/_([a-z])/) { Regexp.last_match(1).upcase }.to_sym end |
.camelize_value(item) ⇒ Object
96 97 98 99 100 101 102 103 104 105 |
# File 'lib/kward/tools/tool_call.rb', line 96 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.
44 45 46 47 |
# File 'lib/kward/tools/tool_call.rb', line 44 def display_name(tool_call) raw_name = name(tool_call) normalized_name(raw_name) || raw_name || "unknown_tool" end |
.function(tool_call) ⇒ Object
60 61 62 |
# File 'lib/kward/tools/tool_call.rb', line 60 def function(tool_call) value(tool_call, :function) || {} end |
.id(tool_call) ⇒ String?
Returns provider tool-call id.
32 33 34 |
# File 'lib/kward/tools/tool_call.rb', line 32 def id(tool_call) value(tool_call, :id) end |
.name(tool_call) ⇒ String?
Returns requested tool/function name.
37 38 39 |
# File 'lib/kward/tools/tool_call.rb', line 37 def name(tool_call) value(function(tool_call), :name) end |
.normalized_name(name) ⇒ Object
64 65 66 |
# File 'lib/kward/tools/tool_call.rb', line 64 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.
72 73 74 75 76 77 78 79 |
# File 'lib/kward/tools/tool_call.rb', line 72 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
56 57 58 |
# File 'lib/kward/tools/tool_call.rb', line 56 def raw_arguments(tool_call) value(function(tool_call), :arguments) end |
.value(object, key) ⇒ Object
92 93 94 |
# File 'lib/kward/tools/tool_call.rb', line 92 def value(object, key) MessageAccess.value(object, key) end |