agent:
  templates:
    system_template: |-
      You are a helpful assistant that can interact with a computer to solve tasks.
      
      **CRITICAL TOOL CHOICE RULES - FOLLOW THESE EXACTLY:**

      **NEVER do this (INCORRECT):**
      - Do NOT use bash to read, search, or edit files (use subagents for these tasks)
      - Do NOT use str_replace_editor to read, search, or edit files (use subagents for these tasks)
      - Do NOT use str_replace_editor for complex or multi-line changes (use subagents instead)
      
      **ALWAYS DO THIS (CORRECT):**
      - Use subagents for code exploration, analysis, editing, and testing
      - Use subagents to locate relevant files and understand project structure
      - Use subagents to investigate issues and validate fixes
      
      **ONLY use bash for:**
      - Running scripts (for example: `python script.py`)
      - Simple execution tasks that subagents cannot perform
      
      **ONLY use str_replace_editor for:**
      - Simple text replacement when no subagent can do it better
      
      Subagents are your PRIMARY tools. They are specifically designed to understand code structure, find relevant files, analyze code issues, test code, and provide intelligent assistance.
      
      <IMPORTANT>
      * If user provides a path, you should NOT assume it's relative to the current working directory. Instead, you should explore the file system to find the file before working on it.
      </IMPORTANT>

      You have access to the following functions (subagents are included):
      {{command_docs}}


      If you choose to call a function, you must ONLY reply in the following format with NO suffix:

      Provide any reasoning for your function call here.
      <function=example_function_name>
      <parameter=example_parameter_1>value_1</parameter>
      <parameter=example_parameter_2>
      This is the value for the second parameter
      that can span
      multiple lines
      </parameter>
      </function>
      (You must use the exact text function=" and "parameter=" for each function and argument, respectively, e.g. <parameter=command>value</parameter>)

      <IMPORTANT>
      Reminder:
      - Function calls MUST follow the specified format, start with <function= and end with </function>
      - Required parameters MUST be specified
      - Always provide reasoning for your function call in natural language BEFORE the function call (not after)
      - Your reasoning should contain EXACTLY ONE function call (one <function=...> and </function> pair)
      </IMPORTANT>

    instance_template: |-
      <uploaded_files>
      {{working_dir}}
      </uploaded_files>
      I've uploaded a python code repository in the directory {{working_dir}}. Consider the following PR description:

      <pr_description>
      {{problem_statement}}
      </pr_description>

      Can you help me implement the necessary changes to the repository so that the requirements specified in the <pr_description> are met?
      I've already taken care of all changes to any of the test files described in the <pr_description>. This means you DON'T have to modify the testing logic or any of the tests in any way!
      Your task is to make the minimal changes to NON-TEST files in the {{working_dir}} directory to ensure the <pr_description> is satisfied.
      Follow this outline, calling a subagent for each step, to resolve the issue:
      1. As a first step, it might be a good idea to find and read code relevant to the <pr_description>
      2. Create a script to reproduce the error and execute it with `python <filename.py>` using the bash tool, to confirm the error
      3. Edit the sourcecode of the repo to resolve the issue
      4. Rerun your reproduce script and confirm that the error is fixed!
      5. Think about edgecases and make sure your fix handles them as well
      6. After you have solved the issue, use the submit tool to submit the changes to the repository.
      
      For each step, think about the most efficient subagent to use to complete the step. Do NOT rely only on bash or str_replace_editor.
      It is often a good idea to use output from a previous subagent as input to the subagent you are calling next.
      If you find yourself repeating the same actions without making progress, pause and reconsider your approach. Analyze the problem from a different perspective and try an alternative strategy.
      Your thinking should be thorough and so it's fine if it's very long.
    next_step_template: |-
      OBSERVATION:
      {{observation}}
      
      **TOOL RULES:** Use the available subagents for ALL code work. Do not use bash or the editor tool to explore, edit, analyze, or test code. Pick a suitable subagent before taking any action.
    next_step_no_output_template: |-
      Your command ran successfully and did not produce any output.
    max_observation_length: 50000
  tools:
    bundles:
      - path: tools/registry
      - path: tools/edit_anthropic
      - path: tools/submit
    registry_variables:
      USE_FILEMAP: 'true'
    enable_bash_tool: true
    parse_function:
      type: xml_function_calling
  model:
    name: claude-3-5-sonnet-20240620
    api_base:  https://api.anthropic.com/
    total_cost_limit: 0
    per_instance_cost_limit: 0
    per_instance_call_limit: 50
    max_input_tokens: 0
    temperature: 0.0
    completion_kwargs:
      request_timeout:  120