* Added LangChain integration * Fixed issue created by git checkin process * Added ':' to characters to remove from end of file path * Tested initial migration to LangChain, removed comments and logging used for debugging * Tested initial migration to LangChain, removed comments and logging used for debugging * Converted camelCase to snake_case * Turns out we need the exception handling * Testing Hugging Face Integrations via LangChain * Added LangChain loadable models * Renames "qa" prompt to "clarify", since it's used in the "clarify" step, asking for clarification * Fixed loading model yaml files * Fixed streaming * Added modeldir cli option * Fixed typing * Fixed interaction with token logging * Fix spelling + dependency issues + typing * Fix spelling + tests * Removed unneeded logging which caused test to fail * Cleaned up code * Incorporated feedback - deleted unnecessary functions & logger.info - used LangChain ChatLLM instead of LLM to naturally communicate with gpt-4 - deleted loading model from yaml file, as LC doesn't offer this for ChatModels * Update gpt_engineer/steps.py Co-authored-by: Anton Osika <anton.osika@gmail.com> * Incorporated feedback - Fixed failing test - Removed parsing complexity by using # type: ignore - Replace every ocurence of ai.last_message_content with its content * Fixed test * Update gpt_engineer/steps.py --------- Co-authored-by: H <holden.robbins@gmail.com> Co-authored-by: Anton Osika <anton.osika@gmail.com>
GPT Engineer
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.
Project philosophy
- Simple to get value
- Flexible and easy to add new own "AI steps". See
steps.py. - Incrementally build towards a user experience of:
- high level prompting
- giving feedback to the AI that it will remember over time
- Fast handovers back and forth between AI and human
- Simplicity, all computation is "resumable" and persisted to the filesystem
Usage
Choose either stable or development.
For stable release:
pip install gpt-engineer
For development:
git clone https://github.com/AntonOsika/gpt-engineer.gitcd gpt-engineerpip install -e .- (or:
make install && source venv/bin/activatefor a venv)
- (or:
Setup
With an OpenAI API key (preferably with GPT-4 access) run:
export OPENAI_API_KEY=[your api key]
To set API key on windows check the Windows README.
Run:
- Create an empty folder. If inside the repo, you can run:
cp -r projects/example/ projects/my-new-project
- Fill in the
promptfile in your new folder gpt-engineer projects/my-new-project- (Note,
gpt-engineer --helplets you see all available options. For example--steps use_feedbacklets you improve/fix code in a project)
- (Note,
By running gpt-engineer you agree to our terms.
Results
- Check the generated files in
projects/my-new-project/workspace
To run in the browser you can simply:
Features
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.
Vision
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 organisers. Email anton.osika@gmail.com if you are interested in an official role.
Example
https://github.com/AntonOsika/gpt-engineer/assets/4467025/6e362e45-4a94-4b0d-973d-393a31d92d9b