# Description:
# - 1x Demonstration (Human)
# - Edit (Inclusive)
# - Non-Bash Actions
# - Strategy

system_template: |-
  SETTING: You are an autonomous programmer, and you're working on fixing 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 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}

  INSTRUCTIONS:
  Now, you're going to use the text editor to solve this issue on your own.
  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 the necessary edits to fix the issue, 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: ""
demonstrations:
  - trajectories/user3/human__pvlib-python-1216__edit_files__t-0.20__p-0.95__c-2.00__install-1__demos_inclusive/pvlib__pvlib-python-1216.traj
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 ---
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
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. Open Relevant Files: Begin by using the open <file path> function to open the files that are indicated by the developer as needing edits.
  2. Understand File Contents: Utilize the get_symbols and summarize functions to understand the structure and content of the opened files. This will help you identify where edits might be necessary.
    a. Navigate Within the File: Use the goto <n>, scroll_up, and scroll_down functions to navigate to specific lines or scroll through the file content. This is crucial for identifying areas that require modification.
    b. Search for Keywords: Employ the search <query> function to look for specific keywords or phrases mentioned in the issue or related to the problem. This can help pinpoint areas in the code that need attention.
  5. Edit the File: When you identify lines that need editing, use the edit <n>:<m> function to replace lines [n,m) with the desired text. Make sure to format the replacement text properly and terminate it with END_OF_EDIT.
  6. Submit Edits: Once you've made the necessary edits in all indicated files, use the submit function to submit the changes. This will conclude the task session.
  7. Iterate if Necessary: If there are multiple files to edit or if the initial edits don't fully resolve the issue, repeat steps 1-6 until you believe all necessary edits have been made.