tools:
  crawl_page:
    description: Crawl the content of the specified URL and return it in Markdown
      format.
    level: 0
    name: crawl_page
    parameters:
      properties:
        output_dir:
          description: Directory to save the Markdown file, under 'upload/', default
            is 'crawled_content'. Optional.
          type: string
        url:
          description: Full URL of the web page to crawl.
          type: string
      required:
      - url
      type: object
    type: tool_call_agent
  dir_create:
    description: Create a new directory. If parent directories do not exist, they
      will be created automatically.
    level: 0
    name: dir_create
    parameters:
      properties:
        dir_path:
          description: Path of the directory to create.
          type: string
      required:
      - dir_path
      type: object
    type: tool_call_agent
  dir_list:
    description: List the contents of the specified directory. Can recursively list
      all subdirectories and files.
    level: 0
    name: dir_list
    parameters:
      properties:
        dir_path:
          description: Directory path to list. If omitted, lists the task root directory.
          type: string
      required: []
      type: object
    type: tool_call_agent
  execute_code:
    description: Execute the specified Python script in an isolated virtual environment
      for the task. By default, the command is initiated from the code_run/ directory,
      but you can execute files from other locations by providing the relative path.
      However, the execution start path is still code_run/.
    level: 0
    name: execute_code
    parameters:
      properties:
        file_path:
          description: Path of the Python script to execute.
          type: string
        timeout:
          default: 300
          description: Execution timeout (seconds).
          type: integer
      required:
      - file_path
      type: object
    type: tool_call_agent
  execute_shell:
    description: Execute a shell command in a secure sandbox environment.
    level: 0
    name: execute_shell
    parameters:
      properties:
        command:
          description: Shell command to execute, e.g., 'ls -la' or 'pip list'.
          type: string
        timeout:
          default: 60
          description: Timeout for command execution (seconds).
          type: integer
        workdir:
          description: Working directory for the command, default is 'code_run/'.
            Optional.
          type: string
      required:
      - command
      type: object
    type: tool_call_agent
  file_delete:
    description: Delete the specified file or directory.
    level: 0
    name: file_delete
    parameters:
      properties:
        file_path:
          description: Path of the file or directory to delete.
          type: string
      required:
      - file_path
      type: object
    type: tool_call_agent
  file_move:
    description: Move or rename a file or directory.
    level: 0
    name: file_move
    parameters:
      properties:
        dest_path:
          description: Destination path for the move.
          type: string
        src_path:
          description: Source path of the file or directory to move.
          type: string
      required:
      - src_path
      - dest_path
      type: object
    type: tool_call_agent
  file_read:
    description: Read the content of the specified file. You can read the entire file
      or specify start and end lines.警告：不要读取二进制文件，如pdf，ppt，图片等。
    level: 0
    name: file_read
    parameters:
      properties:
        end_line:
          description: End line number for reading (inclusive), optional.
          type: integer
        file_path:
          description: Relative path of the file to read, e.g., 'src/main.py'. Only
            text files are allowed; do not read binary files, PDFs, PPTs, or similar
            types.
          type: string
        start_line:
          description: Start line number for reading (starting from 1), optional.
          type: integer
      required:
      - file_path
      type: object
    type: tool_call_agent
  file_replace_lines:
    description: Replace a specified range of lines in a file with new content.
    level: 0
    name: file_replace_lines
    parameters:
      properties:
        end_line:
          description: End line number for replacement.
          type: integer
        file_path:
          description: Path of the file to modify.
          type: string
        new_content:
          description: 'New content for replacement, use ''

            '' for multiple lines.'
          type: string
        start_line:
          description: Start line number for replacement (starting from 1).
          type: integer
      required:
      - file_path
      - start_line
      - end_line
      - new_content
      type: object
    type: tool_call_agent
  file_upload:
    description: Upload one or more files to the workspace. Can be used for code,
      data, or binary files.
    level: 0
    name: file_upload
    parameters:
      properties:
        files:
          description: A list of file objects.
          items:
            properties:
              content:
                description: File content, can be text or Base64-encoded string.
                type: string
              filename:
                description: Filename with relative path, e.g., 'src/utils.py'.
                type: string
              is_base64:
                description: Indicates whether the content is Base64-encoded.
                type: boolean
            required:
            - filename
            - content
            - is_base64
            type: object
          type: array
        target_path:
          description: Target subdirectory for upload, under 'upload/'. Optional.
          type: string
      required:
      - files
      type: object
    type: tool_call_agent
  file_write:
    description: Write content to the specified file. If the file does not exist,
      it will be created automatically; if it exists, you can choose to overwrite
      or append content.
    level: 0
    name: file_write
    parameters:
      properties:
        content:
          description: Text content to write to the file. For binary files, use a
            Base64-encoded string.
          type: string
        file_path:
          description: Relative path of the file to write to, e.g., 'src/main.py'
            or 'data/output.txt'. Do not overwrite files that are not your own! Before
            using, check for files with the same name using the directory listing
            tool.
          type: string
        is_base64:
          default: false
          description: Indicates whether 'content' is a Base64-encoded string for
            writing binary files. Default is false.
          type: boolean
        mode:
          default: overwrite
          description: Write mode. 'overwrite' replaces the entire file, 'append'
            adds content to the end.
          enum:
          - overwrite
          - append
          type: string
      required:
      - file_path
      - content
      type: object
    type: tool_call_agent
  final_output:
    description: Tool for agents to output final results. Call this tool when the
      agent completes the task or needs to terminate execution.
    level: 0
    name: final_output
    parameters:
      properties:
        error_information:
          description: Error information, only required when status is 'error'.
          type: string
        output:
          description: Explanation of success or failure. If your output includes
            files, you must provide their relative paths and descriptions (do not
            repeat content already in the files), and include the judge agent's feedback.
          type: string
        status:
          description: 'Task execution status: ''success'' means completed successfully,
            ''error'' means execution failed.'
          enum:
          - success
          - error
          type: string
        task_id:
          description: Unique ID of the task.
          type: string
      required:
      - task_id
      - status
      - output
      type: object
    type: tool_call_agent
  git_clone:
    description: Clone a Git repository from the specified URL into the workspace.
    level: 0
    name: git_clone
    parameters:
      properties:
        branch:
          description: Specific branch to clone. Optional.
          type: string
        repo_url:
          description: URL of the repository to clone.
          type: string
        target_dir:
          description: Name of the subdirectory under 'upload/' to clone into. Optional.
          type: string
        token:
          description: Personal access token for authenticating private repositories.
            Optional.
          type: string
      required:
      - repo_url
      type: object
    type: tool_call_agent
  github_get_repository_info:
    description: Get detailed information about a specified GitHub repository.
    level: 0
    name: github_get_repository_info
    parameters:
      properties:
        full_name:
          description: Full name of the repository in the format 'owner/repo', e.g.,
            'microsoft/vscode'.
          type: string
        token:
          description: GitHub personal access token for authentication. 必须提供，如无则不用调用此工具
          type: string
      required:
      - full_name
      type: object
    type: tool_call_agent
  github_search_repositories:
    description: Search for repositories on GitHub by keyword.
    level: 0
    name: github_search_repositories
    parameters:
      properties:
        order:
          default: desc
          description: Sort order.
          enum:
          - desc
          - asc
          type: string
        page:
          default: 1
          description: Page number to retrieve.
          type: integer
        per_page:
          default: 10
          description: Number of results per page.
          type: integer
        query:
          description: Keywords to search for in repository names and descriptions.
          type: string
        sort:
          default: stars
          description: Sort criterion.
          enum:
          - stars
          - forks
          - updated
          type: string
        token:
          description: GitHub personal access token for authentication, can increase
            API rate limits. 必须提供，如无则不用调用此工具
          type: string
      required:
      - query
      type: object
    type: tool_call_agent
  google_scholar_search:
    description: Search for academic papers on Google Scholar. Search results are
      saved as md files in the upload/scholar_results/ directory, or you can specify
      a custom file path.
    level: 0
    name: google_scholar_search
    parameters:
      properties:
        output_dir:
          description: Directory to save the search results file, under 'upload/',
            default is 'scholar_results'. Optional.
          type: string
        pages:
          default: 1
          description: Number of search result pages to crawl.
          type: integer
        query:
          description: Keywords or topics to search for.
          type: string
        year_high:
          description: End year for filtering papers. Optional.
          type: integer
        year_low:
          description: Start year for filtering papers. Optional.
          type: integer
      required:
      - query
      type: object
    type: tool_call_agent
  google_search:
    description: Perform a web search using Google.
    level: 0
    name: google_search
    parameters:
      properties:
        num_results:
          default: 10
          description: Number of search results to return.
          type: integer
        query:
          description: Keywords or questions to search for.
          type: string
      required:
      - query
      type: object
    type: tool_call_agent
  human_in_loop:
    description: Create a human task and wait for completion, used for scenarios requiring
      human intervention.
    level: 0
    name: human_in_loop
    parameters:
      properties:
        check_interval:
          default: 5.0
          description: Check interval in seconds, default is 5.0. Optional.
          type: number
        human_task:
          description: Description of the task for human to complete.
          type: string
      required:
      - human_task
      type: object
    type: tool_call_agent
  parse_document:
    description: Parse a document file and extract its text content. Supports PDF,
      Word, PPT, and Markdown formats.
    level: 0
    name: parse_document
    parameters:
      properties:
        file_path:
          description: Path of the document to parse.
          type: string
      required:
      - file_path
      type: object
    type: tool_call_agent
  pip_install:
    description: Install one or more Python packages in the task's virtual environment.
    level: 0
    name: pip_install
    parameters:
      properties:
        packages:
          description: List of Python package names to install.
          items:
            type: string
          type: array
      required:
      - packages
      type: object
    type: tool_call_agent
  tex2pdf_convert:
    description: Compile a directory containing LaTeX source files (main.tex) into
      a PDF file. Currently, only the default compiler is supported.
    level: 0
    name: tex2pdf_convert
    parameters:
      properties:
        clean_aux:
          default: true
          description: Whether to clean up auxiliary files (.aux, .log, etc.) after
            compilation.
          type: boolean
        engine:
          default: pdflatex
          description: LaTeX engine to use for compilation.
          enum:
          - pdflatex
          - xelatex
          - lualatex
          type: string
        input_path:
          description: Path of the directory containing .tex files.
          type: string
        output_path:
          description: Path of the PDF output directory. Optional, defaults to the
            input directory.
          type: string
      required:
      - input_path
      type: object
    type: tool_call_agent
