Start by cloning the repository to your local machine. You can do this by running the following command in your terminal:
git clone https://github.com/StephanAkkerman/FluentAI
Install the required dev dependencies by running the following command:
pip install -e .[dev]
This project uses Black with default values for automatic code formatting, along with ruff. We also use NumPy-style docstrings for documenting the code. As part of the checks on pull requests, it is checked whether the code still adheres to the code style. To ensure you don't need to worry about formatting and linting when contributing, it is recommended to set up the following:
- Integration in VS Code:
- For Black
- For ruff
- For automated NumPy-style docstrings
- You need to change the
docstringFormat
setting to NumPy (see below)
- You need to change the
- Optional: I suggest to install Mogami to keep your dependencies up to date
To enable organzing the import on save we need to change the settings.
You can find this by pressing F1
or Ctrl+Shift+P
in VS code and typing Preferences: Open User Settings (JSON)
.
Paste the contents of the following JSON document in there.
{
"autoDocstring.docstringFormat": "numpy",
"[python]": {
"editor.codeActionsOnSave": {
"source.organizeImports": "always"
}
}
}
To maintain consistency and clarity when reporting issues, please use the following template:
-
Title: [Clear and concise issue title]
-
Description:
-
Problem: [Briefly describe the issue or gap that needs to be addressed.]
-
Solution: [Outline the proposed action or changes to resolve the problem. If none yet, leave blank]
-
Prerequisites: [List any requirements or dependencies needed before starting.]
-
-
Tasks:
- Task 1
- Task 2
- Task 3
- etc.
-
Search Existing Issues: Before creating a new issue, please check if it has already been reported to avoid duplicates.
-
Use the Template: Fill out all sections of the issue template to provide comprehensive information.
-
Be Clear and Concise: Use straightforward language and provide as much relevant detail as possible.
-
Label Appropriately: Assign appropriate labels (e.g., bug, enhancement, documentation) to categorize the issue.
When submitting a pull request, please follow these guidelines:
- Fork the repository and create your branch from
main
. - Ensure your branch is up to date with the latest
main
branch. - Write clear and descriptive commit messages.
- Include a detailed description of your changes in the pull request and the issues that the PR closes.
- Ensure that your code passes all tests and linter checks.
To ensure a smooth and transparent merging process, we have established the following policy for merging pull requests:
-
Review and Approval:
- Pull requests must be reviewed and approved by at least one project maintainer.
- Reviews from other contributors are encouraged but not required.
-
Passing Checks:
- All pull requests must pass continuous integration (CI) checks, including tests and linters.
- Ensure there are no merge conflicts with the
main
branch.
-
Documentation:
- If your pull request introduces new features or changes existing functionality, update the relevant documentation.
-
Labeling:
- Use appropriate labels (e.g.,
bug
,enhancement
,documentation
) to categorize the pull request.
- Use appropriate labels (e.g.,
-
Merging:
- Once approved, passing all checks, and reviewed by the required number of maintainers, the pull request can be merged.
- Preferably use "Squash and merge" to maintain a clean commit history, unless the commit history is meaningful and should be preserved.
-
Branch Naming Conventions:
- Use descriptive names for your branches to make it clear what feature or fix is being worked on.
- Common prefixes include
feature/
,bugfix/
,hotfix/
, andchore/
. - Example:
feature/add-login-page
,bugfix/fix-navbar-issue
.
-
Creating Branches:
- Always create branches from the latest version of the
main
branch. - Use short-lived branches for new features, bug fixes, or any changes to the codebase.
- Always create branches from the latest version of the
-
Pull Requests:
- Ensure your branch is up-to-date with
main
before opening a pull request. - Provide a clear and detailed description of the changes in your pull request.
- Link to any relevant issues or discussions.
- Ensure your branch is up-to-date with
-
Merging Branches:
- Ensure all CI checks pass before merging.
- Preferably use "Squash and merge" to maintain a clean commit history.
- Obtain necessary approvals from maintainers or reviewers before merging.
-
Deleting Merged Branches:
- After a branch has been successfully merged into
main
, it should be deleted. - This helps keep the repository clean and reduces clutter.
- You can delete the branch directly on GitHub after merging, or use the following Git command:
git branch -d your-branch-name git push origin --delete your-branch-name
- After a branch has been successfully merged into