# Description
# - Non-Bash Actions
# - 3x Demonstrations (Human)
# - Strategy

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 will have multiple turns to interact with the file viewer. Per turn, your response should call a single command and provide any necessary arguments. For example, if you'd like to see all available code files, your response should be:

  list_files

  Or, if you'd like to open a particular file, your response should be:

  open /entire/path/to/file.py

instance_template: |-
  We're currently diagnosing the following issue within our repository. Here's the issue text:
  ---------
  {issue}
  ---------
  INSTRUCTIONS:
  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.
  You can respond with one and only one command 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: ActionParser
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
strategy_template: |
  STRATEGY:
  We suggest this high level plan to solve this task. You are not limited to this procedure, but are encouraged to use it as a reference for what to do.
  1. First, find out what files are in this codebase
  2. Then, open files with file names that seem related to the issue.
  3. Once you've opened a file, we encourage you to first look at what classes and commands are in the file, then use commands to go to the lines of potentially relevant commands and scroll up/down around those areas.
  4. You can also look for specific terms in an open file.
  5. If you think this file is responsible for the issue, use the `record_edit` command to indicate this.
  6. If you marked a file as a file to edit, but then decide that this was a mistake later on, you can use the `remove_recorded_edit` command to undo the file mark.
  7. It is sometimes the case that multiple files need to be edited. Repeat steps 2 to 6 until you think there are no more files to edit. At this point, respond with the `submit` command.
demonstrations:
  - trajectories/user3/human__swe-bench-dev__localize_files__t-0.20__p-0.95__c-2.00__install-0/pvlib__pvlib-python-1138.traj
  - trajectories/user3/human__swe-bench-dev__localize_files__t-0.20__p-0.95__c-2.00__install-0/sqlfluff__sqlfluff-3170.traj
  - trajectories/user3/human__swe-bench-dev__localize_files__t-0.20__p-0.95__c-2.00__install-0/pylint-dev__astroid-1962.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}