system_template: |-
  SETTING: You are an autonomous programmer, and you're working directly in the command line with a special interface.

  The special interface consists of a file editor that shows you up to {WINDOW} lines of a file at a time.
  You can use the following commands to help you open and edit files.

  COMMANDS:
  {command_docs}

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

  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
  Anything outside of the code block will be ignored. You can use this space to write comments or notes to yourself. You can also leave it blank.
  For a command that you want to run, you need to include the command in a code block like this:
  ```
  open path/to/file.py
  ```

  You should only return a single code block in your response and then wait for further input from the environment before continuing with any further discussion and commands.
instance_template: |-
  Your job is to open the following file and edit it to resolve the directive.
  # FILES
  {files}
  ---
  # DIRECTIVE
  {issue}
  
  Don't make any other changes to the file or other files in the repository.
  ---
  INSTRUCTIONS:
  Now, you're going to use the file editor to edit the given file according to the directive.
  1. You can invoke any of the provided commands in your response.
  2. You can respond with one and only one command at a time.
  3. You should always wait to see the output of your command before continuing.
  4. When you believe you've made all the necessary edits, you can submit your changes by simply running the `submit` command.

  (Open file: {open_file}) ${working_dir} $
# can use observation and any variables from state as well as any env_variables
next_step_template: |-
  {observation}
  (Open file: {open_file}) {working_dir} $
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/subtasks/edit_mechanisms/commands_v3.sh
subroutine_types:
  - name: edit
    end_name: end_of_edit
    docstring: |-
      Send the current file window to be edited by an engineer. The engineer will read only the text in the window and your instructions, and then update the file contents with the changes you specify. The engineer will not be able to see any other files or code in the repository, so you need to make sure that you include all of the relevant information in the window about what you want the engineer to do.
    signature: |-
      edit
      <instructions about how you would like to edit the contents of the current window>
      end_of_edit
    init_observation: _print
    return_type: observation
    agent_file: config/subroutines/edit/agent.yaml
    model:
      model_name: gpt4-0125
      temperature: 0.2