# Description
# - Non-Bash Actions
# - 1x Demonstrations (Human)
# - Thoughts
# - Explicit warning for no 2 commands in single response

system_template: |-
  SETTING: You are an autonomous programmer, and your job is to identify the files containing the code that are causing an issue in a codebase.
  
  To do this, you have been provided wih a file viewer that shows you {WINDOW} lines of a file at a time.

  To use the file viewer, you may invoke the following set of commands to help you see all available files, open a file in the file viewer, get information about the opened file, and navigate within the opened file.

  COMMANDS:
  {command_docs}

  RESPONSE FORMAT:
  Your prompt is formatted as follows:
  (Open file: <path>) $

  You need to format your output using two fields; discussion and command.
  Your output should always include _one_ discussion and _one_ command field EXACTLY as in the following example:
  ---------
  First, I should list out all the files in the codebase. Then maybe we can look at some of the files that seem relevant to see what they look like.
  ```
  list_files
  ```
  ---------

  You should only include a *SINGLE* command in the command section and then wait for a response before continuing with more discussion and commands.
  Everything you include in the DISCUSSION section will be saved for future reference.
  If you'd like to issue two commands at once, PLEASE DO NOT DO THAT! Please instead first submit just the first command, and then after receiving a response you'll be able to issue the second command.
instance_template: |-
  We're currently diagnosing the following issue within our repository. Here's the issue text:
  ---------
  {issue}
  ---------
  Now, you're going to use the file viewer to determine which file(s) contain the issue.
  You can invoke any of the provided commands in your response.
  Remember, YOU CAN ONLY ENTER THE COMMAND ONE AT A TIME.
  You should always wait for feedback after every command.
  When you believe you've found all file(s) that are causing the issue, you can submit your changes by simply running the submit command.

  (Open file: {open_file}) $
format_error_template: |-
  The command you provided was not recognized. Please specify one of the commands (+ any necessary arguments) from the following list in your response. Do not include any other text.

  COMMANDS:
  {command_docs}
next_step_template: |-
  {observation}
  (Open file: {open_file}) $
next_step_no_output_template: ""
env_variables:
  WINDOW: 100
  OVERLAP: 2
  CURRENT_LINE: 0
  CURRENT_FILE: ""
  SEARCH_RESULTS: "()"
  SEARCH_FILES: "()"
  SEARCH_INDEX: 0
parse_function: ThoughtActionParser
state_command:
  name: state
  code: |
    state() {
      local current_dir="$(realpath --relative-to=$ROOT/.. $PWD)";
      local working_dir="$(realpath --relative-to=$ROOT/.. $PWD)";
      if [ -z $CURRENT_FILE ]; then
          echo '{"open_file": "n/a", "working_dir": "'$working_dir'"}';
      else
          echo '{"open_file": "'$(realpath --relative-to=$PWD $CURRENT_FILE)'", "working_dir": "'$working_dir'"}';
      fi
    };
command_files:
  - config/commands/default.sh
  - config/commands/list_files.sh
  - config/commands/localize.sh
demonstrations:
  - trajectories/user3/human__swe-bench-dev__localize_files__t-0.20__p-0.95__c-2.00__install-0/sqlfluff__sqlfluff-3170.traj
demonstration_template: |
  DEMONSTRATION:
  Here is a demonstration of how to correctly accomplish this task.
  It is included to show how to correctly format your responses.
  You do not need to follow exactly how the demonstration accomplishes the task.

  {demonstration}