Thanks for your interest in contributing to the community driven GPT-3 Sandbox. We're grateful for your initiative! ❤️
We are Shubham and Sandra, co-founders of Kairos Data Labs. We are very excited to have you here and invite you to contribute towards the development of GPT-3 sandbox to make it accessible and usable for everyone.
In this guide, we'll walk you through ways in which you can contribute.
- 🐞 Bugs and Issues
- 🥇 Adding New Examples
- ☑️ Naming Conventions
- 💥 Testing Sandbox Locally
- 📖 Reference Resources
- 🙏 Thank You
We love to get issue reports. But we love it even more, if they're in the right format. For any bugs you encounter, we need you to:
- Describe your problem: What exactly is the bug. Be as clear and concise as possible
- Why do you think it's happening? If you have any insight, pls share
There are also a couple of nice to haves:
- Environment: Specify the python version you are using within your virtual environment
- Screenshots: If they're relevant
To understand how our issues are labeled, check out our issue label guide.
- Associate your local git config with your github account. If this is your first time using git you can follow the steps.
- Fork the
kairos_gpt3
repo and clone onto your computer. - Create a new branch, for example
fix-kairos-1
,example-kairos-1
- Work on this branch to do the fix/improvement or adding a new example
- If you want to add a new example, you can copy the code from the email_generation folder, modify it as per your use-case and save the folder as
example_name
- Commit the changes with the correct commit style.
- Make a pull request.
- Request reviews from one of the repository owners.
- After review 👍 the PR will get merged and you would have successfully contributed to the project!
Note: If you're just fixing a typo or grammatical issue, you can go straight to a pull request.
- Confirm username and email on your profile page.
- Set git config on your computer.
git config user.name "YOUR GITHUB NAME"
git config user.email "YOUR GITHUB EMAIL"
- (Optional) Reset the commit author if you made commits before you set the git config.
git checkout YOUR-WORKED-BRANCH
git commit --amend --author="YOUR-GITHUB-NAME <YOUR-GITHUB-EMAIL>" --no-edit
git log # to confirm the change is effective
git push --force
For branches, commits, and PRs we recommend you to follow these basic naming conventions:
- Be descriptive
- Use all lower-case
- Limit punctuation
- Be consise with your description (under ~100 characters is best)
- In general, follow the Conventional Commit guidelines
Note: If you don't follow naming conventions, your commit will be automatically flagged to be fixed.
Your branch name should follow the format type-scope(-issue_id)
:
type
is eitherexample
orissue
scope
is optional, and represents the example name that your branch is working on or the brief issue name.issue_id
is the GitHub issue number. Having the correct issue number will automatically link the Pull Request on this branch to that issue.
Good examples:
issue-dashboard_not_loading-127
example-email_assitant
Bad examples:
Branch name | Feedback |
---|---|
MYFIX123 |
Not descriptive enough, all caps, doesn't follow spec |
mybranch-1 |
Not descriptive |
A good commit message helps us track the development of GPT-3 sanbox. A Pull Request with a bad commit message might be rejected due to the lack of clarity.
Commit messages should stick to our naming conventions outlined above, and use the format type(scope?): subject
:
type
is eitherexample
orissue
.scope
and represents the example name that your branch is working on or the brief issue name.subject
should explains the commit in a brief and descriptive way
For example, a commit message that includes a new example should be phrased as: example(email_assistant): Added new example application - GPT-3 powered Email Assistant
We don't enforce naming of PRs and branches, but we recommend you follow the same style as the commit naming convention to make it easy for the community to follow up on the new developments. It can simply be one of your commit messages, just copy/paste it, e.g. example(email_assistant): Added new example application - GPT-3 powered Email Assistant
.
You need to have python 3.7+ installed, and then you can create a python virtual environment using pip or conda depending on your python setup.
After installing and activating the virtual environment (The commands will differ for windows and linux installations which is clearly specified in the respective documentations), you can cd
into the email_generation folder:
cd email_generation
From /email_generation
folder, you can run the following command to install the required dependencies
pip install -r requirements.txt
After installing the required dependencies, you can bring up the main application to validate that its working in your local enviroment. To bring up the application, you can run the following command from the email_generation
folder.
streamlit run gpt_app.py
For your reference, we have created example applications to take inspiration from and come up with new ideas that can be useful for the developer community.
Thanks so much for your interest in contributing to this sandbox. We're excited to see your contributions!