Specify what you want it to build, the AI asks for clarification, and then builds it.
GPT Engineer is made to be easy to adapt, extend, and make your agent learn how you want your code to look. It generates an entire codebase based on a prompt.
steps.py
.Choose either stable or development.
For stable release:
python -m pip install gpt-engineer
For development:
git clone https://github.com/AntonOsika/gpt-engineer.git
cd gpt-engineer
python -m pip install -e .
make install && source venv/bin/activate
for a venv)API Key
Choose one of:
export OPENAI_API_KEY=[your api key]
.env.template
named .env
Check the Windows README for windows usage.
There are two ways to work with GPT-engineer: new code mode (the default), and improve existing code mode (the -i
option).
prompt
(no extension) inside your new folder and fill it with instructionsgpt-engineer <project_dir>
with a relative path to your folder
gpt-engineer projects/my-new-project
from the gpt-engineer directory root with your new folder in projects/
prompt
(no extension) inside your new folder and fill it with instructions for how you want to improve the codegpt-engineer <project_dir> -i
with a relative path to your folder
gpt-engineer projects/my-old-project
from the gpt-engineer directory root with your folder in projects/
By running gpt-engineer you agree to our terms.
Results
Check the generated files in projects/my-new-project/workspace
Workflow
gpt-engineer --help
lets you see all available options.
For example:
-i
--steps use_feedback
Alternatives
You can check Docker instructions to use Docker, or simply do everything in your browser:
You can specify the "identity" of the AI agent by editing the files in the preprompts
folder.
Editing the preprompts
, and evolving how you write the project prompt, is how you make the agent remember things between projects.
Each step in steps.py
will have its communication history with GPT4 stored in the logs folder, and can be rerun with scripts/rerun_edited_message_logs.py
.
You can also run with open source models, like WizardCoder. See the documentation for example instructions.
The gpt-engineer community is building the open platform for devs to tinker with and build their personal code-generation toolbox.
If you are interested in contributing to this, we would be interested in having you.
If you want to see our broader ambitions, check out the roadmap, and join discord to get input on how you can contribute to it.
We are currently looking for more maintainers and community organizers. Email anton.osika@gmail.com if you are interested in an official role.
https://github.com/AntonOsika/gpt-engineer/assets/4467025/6e362e45-4a94-4b0d-973d-393a31d92d9b ˛