# Description
# - Inclusive Edit
# - 1x Demo
# - Thoughts
# - No bash, strategy
# - List test files action (NO ORACLE TESTS)
# - Prompt:
#     - Encouraged to identify + run test files to verify changes
#     - Warned to not do 2+ discussion/commands
#     - Warned about edit command indentation

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}

  Please note that THE EDIT COMMAND REQUIRES PROPER INDENTATION. 
  If you'd like to add the line '        print(x)' you must fully write that out, with all those spaces before the code! Indentation is important and code that is not indented correctly will fail and require fixing before it can be run.

  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:
  --------
  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.
  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 solving the following issue within our repository. Here's the issue text:
  --------
  {issue}
  --------
  FILES TO EDIT:
  {files}
  --------

  INSTRUCTIONS:
  Now, you're going to solve this issue on your own.
  Edit all the files you need and run any checks or test that you want.
  Remember, YOU CAN ONLY ENTER ONE COMMAND AT A TIME.
  You should always wait for feedback after every command.
  When you're satisfied with all of the changes that you've made and have performed verification as necessary, you can submit your changes to the codebase by simply running the submit command.

  NOTE ABOUT EDIT COMMAND: Indentation really matters! When editing a file, make sure to insert appropriate indentation before each line!

  STRATEGY:
  1. Then, start trying to fix the code via edits in the file identified by the developer.
  2. You should then look for existing tests that may be relevant to the file that you've been asked to edit.
    a. If you don't find relevant test files, you can this step
    b. If you do, run the tests to verify that your edits don't break existing code.
  3. You can also decide whether to write new tests to check that the edits solve the issue; if your fixes are minor and simple, there may be no need to.
  4. Once you've finished your editing (and optionally have performed some testing), submit.

  (Open file: {open_file})
  bash-$
next_step_template: |-
  {observation}
  (Open file: {open_file})
  bash-$
next_step_no_output_template: ""
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/replay__pvlib__pvlib-python-1216__edit_files_v5__t-0.20__p-0.95__c-2.00__install-1__v5.1/pvlib__pvlib-python-1216.traj
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 working_dir="$PWD";
      if [ -z $CURRENT_FILE ]; then
          echo '{"open_file": "n/a", "working_dir": "'$working_dir'"}';
      else
          echo '{"open_file": "'$(realpath $CURRENT_FILE)'", "working_dir": "'$working_dir'"}';
      fi
    };
parse_function: ThoughtActionParser
command_files:
  - config/commands/default_cwd.sh
  - config/commands/inclusive_edit.sh
  - config/commands/submit_no_test.sh
  - config/commands/list_test_files.sh
  - config/commands/test.sh
subroutine_types:
  - name: summarize
    init_observation: "echo Filename: {args}; cat {args}"
    return_type: thought
    docstring: gets a summary of the given file
    signature: summarize <path>
    agent_file: config/subroutines/summarize/agent.yaml
    model:
      model_name: gpt3
      temperature: 0.2