This repository contains a powerful coding assistant application that integrates with the DeepSeek API to process user conversations and generate structured JSON responses. Through an intuitive command-line interface, it can read local file contents, create new files, and apply diff edits to existing files in real time.
-
DeepSeek Client Configuration
- Automatically configures an API client to use the DeepSeek service with a valid DEEPSEEK_API_KEY.
- Connects to the DeepSeek endpoint specified in the environment variable to stream GPT-like completions.
-
Data Models
- Leverages Pydantic for type-safe handling of file operations, including:
• FileToCreate – describes files to be created or updated.
• FileToEdit – describes specific snippet replacements in an existing file.
• AssistantResponse – structures chat responses and potential file operations.
- Leverages Pydantic for type-safe handling of file operations, including:
• FileToCreate – describes files to be created or updated.
-
System Prompt
- A comprehensive system prompt (system_PROMPT) guides conversation, ensuring all replies strictly adhere to JSON output with optional file creations or edits.
-
Helper Functions
- read_local_file: Reads a target filesystem path and returns its content as a string.
- create_file: Creates or overwrites a file with provided content.
- show_diff_table: Presents proposed file changes in a rich, multi-line table.
- apply_diff_edit: Applies snippet-level modifications to existing files.
-
"/add" Command
- Users can type "/add path/to/file" to quickly read a file's content and insert it into the conversation as a system message.
- Users can also type "/add path/to/folder" to add all files in a directory (excluding binaries and hidden files).
- This allows the assistant to reference the file contents for further discussion, code generation, or diff proposals.
-
Conversation Flow
- Maintains a conversation_history list to track messages between user and assistant.
- Streams the assistant's replies via the DeepSeek API, parsing them as JSON to preserve both the textual response and the instructions for file modifications.
-
Interactive Session
- Run the script (for example: "python3 main.py") to start an interactive loop at your terminal.
- Enter your requests or code questions. Enter "/add path/to/file" to add file contents to the conversation.
- When the assistant suggests new or edited files, you can confirm changes directly in your local environment.
- Type "exit" or "quit" to end the session.
-
Prepare a .env file with your DeepSeek API key: DEEPSEEK_API_KEY=your_api_key_here
-
Install dependencies and run (choose one method):
pip install -r requirements.txt python3 main.py
uv venv uv run main.py
-
Enjoy multi-line streaming responses, file read-ins with "/add path/to/file", and precise file edits when approved.
A new script r1.py
has been added that uses DeepSeek's Reasoning Model (deepseek-reasoner
). This version includes Chain of Thought (CoT) reasoning capabilities:
- Shows the AI's reasoning process before providing the final answer
- Maintains all original features (file operations, diff editing, etc.)
- Displays thought process in a dedicated panel
- Only uses final conclusions in conversation history
- Run it with
python3 r1.py
oruv run r1.py
for an enhanced experience with visible reasoning
Note: This is an experimental project developed by Skirano to test the new DeepSeek v3 API capabilities. It was developed as a rapid prototype and should be used accordingly.