File: contributing.rst

package info (click to toggle)
petsc4py 3.23.1-1exp2
  • links: PTS, VCS
  • area: main
  • in suites: experimental
  • size: 3,448 kB
  • sloc: python: 12,503; ansic: 1,697; makefile: 343; f90: 313; sh: 14
file content (54 lines) | stat: -rw-r--r-- 1,775 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
Contributing
============

Contributions from the user community are welcome. See
the `PETSc developers <ind_developers>` documentation for general
information on contributions.

New contributions to petsc4py **must** adhere with the coding standards.
We use cython-lint_ for Cython and ruff_ for Python source codes.
These can be installed using::

  $ python -m pip install -r src/binding/petsc4py/conf/requirements-lint.txt

If you are contributing Cython code, you can check compliance with::

  $ make cython-lint -C src/binding/petsc4py

For Python code, run::

  $ make ruff-lint -C src/binding/petsc4py

Python code can be auto-formatted using::

  $ make ruff-lint RUFF_OPTS='format' -C src/binding/petsc4py

New contributions to petsc4py must be tested.
Tests are located in the :file:`src/binding/petsc4py/test` folder.
To add a new test, either add a new :file:`test_xxx.py` or modify a
pre-existing file according to the
`unittest <https://docs.python.org/3/library/unittest.html>`_
specifications.

If you add a new :file:`test_xxx.py`, you can run the tests using::

  $ cd src/binding/petsc4py
  $ python test/runtests.py -k test_xxx

If instead you are modifying an existing :file:`test_xxx.py`,
you can test your additions by using the fully qualified name of the Python
class or method you are modifying, e.g.::

  $ python test/runtests.py -k test_xxx.class_name.method_name

All new code must include documentation in accordance with the `documentation
standard <documentation_standards>`. To check for compliance, run::

  $ make html SPHINXOPTS='-W' -C src/binding/petsc4py/docs/source

.. warning::

    The docstrings must not cause Sphinx warnings.

.. _cython-lint: https://github.com/MarcoGorelli/cython-lint
.. _ruff: https://docs.astral.sh/ruff