暫無描述

Xingyao Wang da17665cab fix: make max_budget_per_task optional in `run_agent_controller` (#3071) 1 年之前
.github f3c23e8039 CI: Force stop colima (#3053) 1 年之前
agenthub 6b16a5da0b [Eval,Arch] Update GPTQ eval and add `headless_mode` for Controller (#2994) 1 年之前
containers 15697bed5a Update Dockerfile casing (#3045) 1 年之前
dev_config 3a21198424 Remove monologue agent (#3036) 1 年之前
docs 784f644b1d chore(deps): bump react-use from 17.5.0 to 17.5.1 in /docs (#3063) 1 年之前
evaluation da17665cab fix: make max_budget_per_task optional in `run_agent_controller` (#3071) 1 年之前
frontend 78e700ef94 chore(deps-dev): bump jsdom from 24.1.0 to 24.1.1 in /frontend (#3057) 1 年之前
opendevin da17665cab fix: make max_budget_per_task optional in `run_agent_controller` (#3071) 1 年之前
tests 4099e48122 Removed config from agent controller (#3038) 1 年之前
.dockerignore 516c9bf1e0 Revamp docker build process (#1121) 1 年之前
.gitattributes e32d95cb1a lint: simplify hooks already covered by Ruff (#1204) 1 年之前
.gitignore ce8a11a62f [Arch] Shrink runtime image size (#3051) 1 年之前
CODE_OF_CONDUCT.md 46edb4b15b chore: Release 0.8.0 (#2919) 1 年之前
CONTRIBUTING.md b5e4cddce3 fix docs links (#3017) 1 年之前
Development.md fa6c12473e #2220, integrated aider style linting, currently passes related o… (#2489) 1 年之前
ISSUE_TRIAGE.md 214f728d32 docs: Add doc on how issues are triaged (#2928) 1 年之前
LICENSE 39add27f15 Create MIT LICENSE (#8) 2 年之前
Makefile ec2535c57c Ref: Remove make-i18n from makefile (#2905) 1 年之前
README.md b5e4cddce3 fix docs links (#3017) 1 年之前
config.template.toml ff6ddc831f fix: runtime test for mac (#3005) 1 年之前
poetry.lock c3d4f6495f chore(deps-dev): bump ruff from 0.5.3 to 0.5.4 (#3068) 1 年之前
pydoc-markdown.yml cd58194d2a docs(docs): start implementing docs website (#1372) 1 年之前
pyproject.toml c3d4f6495f chore(deps-dev): bump ruff from 0.5.3 to 0.5.4 (#3068) 1 年之前
pytest.ini b6ff201780 Refactor integration test framework and relieve the pain of regeneration (#1818) 1 年之前

README.md

Contributors Forks Stargazers Issues MIT License
Join our Slack community Join our Discord community CodeCov

Logo

OpenDevin: Code Less, Make More

Check out the documentation Evaluation Benchmark

Welcome to OpenDevin, a platform for autonomous software engineers, powered by AI and LLMs.

OpenDevin agents collaborate with human developers to write code, fix bugs, and ship features.

App screenshot

⚡ Getting Started

OpenDevin works best with Docker version 26.0.0+ (Docker Desktop 4.31.0+). You must be using Linux, Mac OS, or WSL on Windows.

To start OpenDevin in a docker container, run the following commands in your terminal:

[!WARNING] When you run the following command, files in ./workspace may be modified or deleted.

WORKSPACE_BASE=$(pwd)/workspace
docker run -it \
    --pull=always \
    -e SANDBOX_USER_ID=$(id -u) \
    -e WORKSPACE_MOUNT_PATH=$WORKSPACE_BASE \
    -v $WORKSPACE_BASE:/opt/workspace_base \
    -v /var/run/docker.sock:/var/run/docker.sock \
    -p 3000:3000 \
    --add-host host.docker.internal:host-gateway \
    --name opendevin-app-$(date +%Y%m%d%H%M%S) \
    ghcr.io/opendevin/opendevin

[!NOTE] By default, this command pulls the latest tag, which represents the most recent release of OpenDevin. You have other options as well:

  • For a specific release version, use ghcr.io/opendevin/opendevin:<OpenDevin_version> (replace with the desired version number).
  • For the most up-to-date development version, use ghcr.io/opendevin/opendevin:main. This version may be (unstable!) and is recommended for testing or development purposes only.
  • Choose the tag that best suits your needs based on stability requirements and desired features.

You'll find OpenDevin running at http://localhost:3000 with access to ./workspace. To have OpenDevin operate on your code, place it in ./workspace. OpenDevin will only have access to this workspace folder. The rest of your system will not be affected as it runs in a secured docker sandbox.

Upon opening OpenDevin, you must select the appropriate Model and enter the API Key within the settings that should pop up automatically. These can be set at any time by selecting the Settings button (gear icon) in the UI. If the required Model does not exist in the list, you can manually enter it in the text box.

For the development workflow, see Development.md.

Are you having trouble? Check out our Troubleshooting Guide.

🚀 Documentation

To learn more about the project, and for tips on using OpenDevin, check out our documentation.

There you'll find resources on how to use different LLM providers (like ollama and Anthropic's Claude), troubleshooting resources, and advanced configuration options.

🤝 How to Contribute

OpenDevin is a community-driven project, and we welcome contributions from everyone. Whether you're a developer, a researcher, or simply enthusiastic about advancing the field of software engineering with AI, there are many ways to get involved:

  • Code Contributions: Help us develop new agents, core functionality, the frontend and other interfaces, or sandboxing solutions.
  • Research and Evaluation: Contribute to our understanding of LLMs in software engineering, participate in evaluating the models, or suggest improvements.
  • Feedback and Testing: Use the OpenDevin toolset, report bugs, suggest features, or provide feedback on usability.

For details, please check CONTRIBUTING.md.

🤖 Join Our Community

Whether you're a developer, a researcher, or simply enthusiastic about OpenDevin, we'd love to have you in our community. Let's make software engineering better together!

  • Slack workspace - Here we talk about research, architecture, and future development.
  • Discord server - This is a community-run server for general discussion, questions, and feedback.

📈 Progress

Star History Chart

📜 License

Distributed under the MIT License. See LICENSE for more information.

📚 Cite

@misc{opendevin2024,
  author       = {{OpenDevin Team}},
  title        = {{OpenDevin: An Open Platform for AI Software Developers as Generalist Agents}},
  year         = {2024},
  version      = {v1.0},
  howpublished = {\url{https://github.com/OpenDevin/OpenDevin}},
  note         = {Accessed: ENTER THE DATE YOU ACCESSED THE PROJECT}
}