Class: Anthropic::Models::Beta::BetaTool

Inherits:
Internal::Type::BaseModel show all
Defined in:
lib/anthropic/models/beta/beta_tool.rb

Defined Under Namespace

Modules: AllowedCaller, Type Classes: InputSchema

Instance Attribute Summary collapse

Class Method Summary collapse

Instance Method Summary collapse

Methods inherited from Internal::Type::BaseModel

==, #==, #[], coerce, #deconstruct_keys, #deep_to_h, dump, fields, hash, #hash, inherited, inspect, #inspect, known_fields, optional, recursively_to_h, required, #to_h, #to_json, #to_s, to_sorbet_type, #to_yaml

Methods included from Internal::Type::Converter

#coerce, coerce, #dump, dump, inspect, #inspect, meta_info, new_coerce_state, type_info

Methods included from Internal::Util::SorbetRuntimeSupport

#const_missing, #define_sorbet_constant!, #sorbet_constant_defined?, #to_sorbet_type, to_sorbet_type

Constructor Details

#initialize(properties: nil, required: nil, type: :object) ⇒ void

JSON schema for this tool's input.

This defines the shape of the input that your tool accepts and that the model will produce.

Parameters:

  • properties (Hash{Symbol=>Object}, nil) (defaults to: nil)
  • required (Array<String>, nil) (defaults to: nil)
  • type (Symbol, :object) (defaults to: :object)


# File 'lib/anthropic/models/beta/beta_tool.rb', line 70

Instance Attribute Details

#allowed_callersArray<Symbol, Anthropic::Models::Beta::BetaTool::AllowedCaller>?

Returns:



27
28
# File 'lib/anthropic/models/beta/beta_tool.rb', line 27

optional :allowed_callers,
-> { Anthropic::Internal::Type::ArrayOf[enum: Anthropic::Beta::BetaTool::AllowedCaller] }

#cache_controlAnthropic::Models::Beta::BetaCacheControlEphemeral?

Create a cache control breakpoint at this content block.



34
# File 'lib/anthropic/models/beta/beta_tool.rb', line 34

optional :cache_control, -> { Anthropic::Beta::BetaCacheControlEphemeral }, nil?: true

#defer_loadingBoolean?

If true, tool will not be included in initial system prompt. Only loaded when returned via tool_reference from tool search.

Returns:



41
# File 'lib/anthropic/models/beta/beta_tool.rb', line 41

optional :defer_loading, Anthropic::Internal::Type::Boolean

#descriptionString?

Description of what this tool does.

Tool descriptions should be as detailed as possible. The more information that the model has about what the tool is and how to use it, the better it will perform. You can use natural language descriptions to reinforce important aspects of the tool input JSON schema.

Returns:

  • (String, nil)


52
# File 'lib/anthropic/models/beta/beta_tool.rb', line 52

optional :description, String

#input_examplesArray<Hash{Symbol=>Object}>?

Returns:

  • (Array<Hash{Symbol=>Object}>, nil)


57
58
# File 'lib/anthropic/models/beta/beta_tool.rb', line 57

optional :input_examples,
Anthropic::Internal::Type::ArrayOf[Anthropic::Internal::Type::HashOf[Anthropic::Internal::Type::Unknown]]

#input_schemaAnthropic::Models::Beta::BetaTool::InputSchema

JSON schema for this tool's input.

This defines the shape of the input that your tool accepts and that the model will produce.



14
# File 'lib/anthropic/models/beta/beta_tool.rb', line 14

required :input_schema, -> { Anthropic::Beta::BetaTool::InputSchema }

#nameString

Name of the tool.

This is how the tool will be called by the model and in tool_use blocks.

Returns:

  • (String)


22
# File 'lib/anthropic/models/beta/beta_tool.rb', line 22

required :name, String

#strictBoolean?

Returns:



63
# File 'lib/anthropic/models/beta/beta_tool.rb', line 63

optional :strict, Anthropic::Internal::Type::Boolean

#typeSymbol, ...

Returns:



68
# File 'lib/anthropic/models/beta/beta_tool.rb', line 68

optional :type, enum: -> { Anthropic::Beta::BetaTool::Type }, nil?: true

Class Method Details

.valuesArray<Symbol>

Returns:

  • (Array<Symbol>)


# File 'lib/anthropic/models/beta/beta_tool.rb', line 128