Skip to main content

A tool to combine code files into a single prompt

Project description

CodePromptForge ToolKit for Agent Development

Overview

The CodePromptForge ToolKit provides a set of LangChain-compatible tools for developing AI agents that can read, analyze, modify, and write code. These tools enable agents to explore a codebase, extract insights, generate new content, and modify files dynamically.

Features

  • File and Directory Inspection: Retrieve file contents, list directory structures, and analyze project organization.
  • Automated Code Processing: Identify and manipulate specific code files based on extensions.
  • Code Modification: Write and update files programmatically.
  • Cleanup and Maintenance: Remove unnecessary files from results folders.
  • Seamless Integration: Designed to work with LangChain's agent framework.
  • Optional Assistant Module: Allows users to create and register AI assistants.

Installation

Core Installation

To install the core functionality of CodePromptForge:

pip install codepromptforge

Installing with Assistant Module

To use the AI Assistant framework, install the package with the assistant extra:

pip install codepromptforge[assistant]

This includes dependencies such as:

  • langchain_ollama
  • langgraph

Available Tools

🔍 1. get_directory_tree

Retrieve the structure of a directory
Returns a list of all files in a specified directory, ignoring files in .gitignore or explicitly excluded.

Usage

tool = GetDirectoryTreeTool()
tool.run(folder_path="src")

Response

["src/main.py", "src/utils/helpers.py", "src/config/settings.json"]

📄 2. get_file_content

Read the content of a specific file
Retrieves the contents of a file for analysis or processing.

Usage

tool = GetFileContentTool()
tool.run(file_path="src/main.py")

Response

"def main():\n    print('Hello, world!')"

📂 3. get_files_in_folder

List all files in a specific folder with their contents
Provides a dictionary where keys are file names and values are their contents.

Usage

tool = GetFilesInFolderTool()
tool.run(folder_path="src")

Response

{
    "main.py": "def main():\n    print('Hello, world!')",
    "config.json": "{'debug': true, 'version': '1.0'}"
}

📁 4. get_files_recursively

Retrieve all files in a folder and its subdirectories
Useful for analyzing an entire project structure.

Usage

tool = GetFilesRecursivelyTool()
tool.run(folder_path="src")

Response

{
    "src/main.py": "def main():\n    print('Hello, world!')",
    "src/utils/helpers.py": "def helper():\n    return 'Helper function'"
}

🔎 5. find_files

Find all files matching specific extensions in the base directory
Helpful for searching for specific types of files, such as Python scripts or Markdown documentation.

Usage

tool = FindFilesTool()
tool.run(extensions=["py", "md"])

Response

["src/main.py", "docs/readme.md"]

✍️ 6. write_file

Write or modify a file
Creates or modifies a file inside the .result folder.

Usage

tool = WriteFileTool()
tool.run(file_path="output.txt", content="New content for the file")

Response

"File written successfully: .result/output.txt"

🧹 7. clean_result_folder

Remove unnecessary files from the .result folder
Ensures that old files don’t clutter the workspace.

Usage

tool = CleanResultFolderTool()
tool.run(excluded_files=["output.txt"])

Response

"Cleaned .result folder. Removed files: ['output.txt']"

🛠 8. forge_prompt

Merge multiple files into a single prompt
Key feature for creating context-rich inputs for LLMs.

Usage

tool = ForgePromptTool()
tool.run(extensions=["py", "md"])

Response

"Merged files: ['src/main.py', 'docs/readme.md']"

🚀 9. run

Runs the forge process on specified file extensions
Automates the process of finding, merging, and generating code prompts.

Usage

tool = RunTool()
tool.run(extensions=["py", "txt"])

Response

"Generated combined prompt in output.txt"

Building AI Agents with the ToolKit

The CodePromptForge ToolKit is designed to be integrated into LangChain agents for intelligent code analysis. Here’s how you can create a React agent that uses these tools:

from langchain.agents import initialize_agent
from langchain.chat_models import ChatOpenAI
from codepromptforge.main import CodePromptForge

# Initialize the CodePromptForge toolkit
forge = CodePromptForge(base_dir=".")

# Create an agent with the tools
agent = initialize_agent(
    tools=forge.get_tools(),
    llm=ChatOpenAI(temperature=0),
    agent="zero-shot-react-description",
    verbose=True
)

# Example: Ask the agent to analyze the project directory
agent.run("List all Python files in the project and summarize their content.")

Expected Behavior

  1. The agent will call get_directory_tree() to explore the project structure.
  2. It will filter files using find_files(["py"]) to locate Python scripts.
  3. It will use get_file_content() to analyze each file.
  4. Based on the retrieved content, it will generate a summary.

Using the Assistant Module

If installed with [assistant], you can leverage AI assistants to process and generate code.

Example Usage

from codepromptforge.assistant import AssistantRegistry

# List available assistants
print(AssistantRegistry.list_assistants())  
# Expected output: ['react_assistant']

from langchain_ollama import ChatOllama

# Initialize an LLM
llm = ChatOllama(
    model="qwen2.5:14b",
    temperature=0,
    num_ctx=80000,
    num_gpu=1,
)

# Retrieve and use the assistant
agent = AssistantRegistry.get_assistant('react_assistant', llm)

def print_stream(stream):
    for s in stream:
        message = s["messages"][-1]
        if isinstance(message, tuple):
            print(message)
        else:
            message.pretty_print()

# Provide a query for the assistant
inputs = {
    "messages": [("user", "This is my package named CodePromptForge. Your job is to describe what needs to be modified to improve the current code")]
}

print_stream(agent.stream(inputs, stream_mode="values"))

Expected Output

The assistant will analyze the package and suggest improvements based on best practices.


Conclusion

The CodePromptForge ToolKit provides a ready-to-use suite of tools that can be seamlessly integrated into AI agents for code reading, modification, and generation. Whether you're building LLM-based code assistants, automated reviewers, or code refactoring agents, these tools simplify and automate complex workflows.


🚀 Start developing with CodePromptForge today! 🚀

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

codepromptforge-1.0.3.tar.gz (20.0 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

codepromptforge-1.0.3-py3-none-any.whl (18.7 kB view details)

Uploaded Python 3

File details

Details for the file codepromptforge-1.0.3.tar.gz.

File metadata

  • Download URL: codepromptforge-1.0.3.tar.gz
  • Upload date:
  • Size: 20.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.8

File hashes

Hashes for codepromptforge-1.0.3.tar.gz
Algorithm Hash digest
SHA256 86808331831ff8f8bd1e668b50994e413a137a8b41dedcd7f989298028847ceb
MD5 b6be9120920630046c04d5149ac99948
BLAKE2b-256 3fb8c5f66017cc4d8db717e51c8414d27812491127ab93667556fa5298040019

See more details on using hashes here.

Provenance

The following attestation bundles were made for codepromptforge-1.0.3.tar.gz:

Publisher: python-publish.yml on RobinsonGarcia/CodePromptForge

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file codepromptforge-1.0.3-py3-none-any.whl.

File metadata

File hashes

Hashes for codepromptforge-1.0.3-py3-none-any.whl
Algorithm Hash digest
SHA256 63dc235810d80021db3e65b55bb0a899d99e967dcff45c0afe69636667869281
MD5 528cc2b02be34cc17a94eb147863459f
BLAKE2b-256 ed84c3339ef0bfb0973f8ab9e027cfd789e4ac6bba5342f0bcf062b74d66af16

See more details on using hashes here.

Provenance

The following attestation bundles were made for codepromptforge-1.0.3-py3-none-any.whl:

Publisher: python-publish.yml on RobinsonGarcia/CodePromptForge

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page