# Description
# - 1x Demonstration (Human)
# - Edit (Inclusive)
# - Non-Bash Actions
# - Strategy
# - Tests (Oracle, rmbr to turn on apply patch in code)

system_template: |-
  SETTING: You are an autonomous programmer, and your job is to edit file(s) that are causing an issue in a codebase by using a text editor that shows you {WINDOW} lines of a file at a time.

  To use the text editor, you may invoke the following set of commands to open a file in the text editor, get information about the file, navigate within the file, and edit the file.

  COMMANDS:
  {command_docs}

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

  You will have multiple turns to interact with the text editor. Per turn, your response should call a single command and provide any necessary arguments. For example, if you'd like to open a particular file, your response should be:

  open /entire/path/to/file.py

  Or, if you'd like to quickly find out which classes and commands are defined in an opened file, your response should be:

  get_symbols
instance_template: |-
  We're currently solving the following issue within our repository. Here's the issue text:
  -------
  {issue}
  -------

  The developer has identified that the following files are causing the issue:
  {files}

  In addition, the developer has also provided the following test(s) that capture the issue:
  {test_files}

  The developer says that of all the tests defined in the given files, you should make sure the following pass:
  {tests}

  INSTRUCTIONS:
  Now, you're going to use the text editor to edit the given files to resolve 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 made all the necessary edits, you should verify that you pass the tests provided by the developer.
  If the tests are passing, you can submit your changes by simply running the submit command.

  (Open file: {open_file}) $
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
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
    };
parse_function: ActionParser
command_files:
  - config/commands/default.sh
  - config/commands/inclusive_edit.sh
  - config/commands/submit.sh
  - config/commands/test.sh
demonstration_template: |
  Here is a demonstration of how to correctly accomplish this task.
  It is included to show you how to correctly use the interface.
  You do not need to follow exactly what is done in the demonstration.
  
  --- DEMONSTRATION ---
  {demonstration}
  --- END OF DEMONSTRATION ---
demonstrations:
  - trajectories/user3/human__swe-bench-dev-easy-v2__edit_files__t-0.20__p-0.95__c-2.00__install-1_demos_test/sqlfluff__sqlfluff-1517.traj
strategy: |
  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. Run the provided test(s) to see what is failing (`run_tests <test file>`).
  2. Open the files causing the issue (`open <file>`).
  3. Based on the test feedback and file content, look around the file to find the correct lines to edit (commands like `get_symbols`, `goto`, `scroll_up`, `scroll_down` could help).
  4. Once you've identified the problematic lines, write a fix with `edit`.
  5. Verify that your fix addresses the tests by doing `run_tests <test file>` again.
  6. If the tests are still not passing, repeat steps 2 - 5.
  7. Once you think you've fixed it, or feel you're not able to solve the issue, run `submit`.
