Skip to content
Connor Ward edited this page Oct 24, 2023 · 6 revisions

Docstring and type hinting policy

Following the meeting on 2023-10-18 it was decided that Firedrake needs stricter policies for the style and layout of all future docstrings and documentation. Read new code as any code not on the master branch of Firedrake as of October 2023 and read updated code as code that existed on the master branch of Firedrake before October 2023, but has been modified in a pull request under review from (the 25th) October 2023:

  • All new code must follow PEP8 and PEP257 conventions.
    • This includes the use of imperative mood.
    • Existing code should follow these conventions already, but there are certainly exceptions.
  • All new code must use numpy style docstrings.
  • All new code must use Python type hinting.
    • Python type hints should be imported from typing and not from collections.abc. Eg: Use typing.Callable not collections.abc.Callable. This aims to maintain compatibility with Python 3.8 for as long as possible within its remaining lifetime.
  • Any pull request with updated code that edits the docstrings, or any other documentation, must have the webpage build artefacts viewed and reviewed before merging (as part of the existing code review process).
  • Any pull request with updated code that edits existing docstrings or function calls must update the corresponding code to follow this new policy.

Home

Building locally
Tips

Install Frequently Asked Questions

Running on HPC

Users

Developers Notes

Minutes and agenda of Firedrake meetings


Policies and procedures

Gravity wave scaling

Merge Complex Sprint

Reading Group

Firedrake 2021 Planning Meetings
Clone this wiki locally