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

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 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:
  DISCUSSION
  I will open one of the files that is causing the issue. Then, I will look around the file first before then determining what edits need to be performed.
  ```
  open pydicom/filereader.py
  ```

  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.
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: ThoughtActionParser
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_thoughts.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`.
