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
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
|
.. -*- coding: utf-8 -*-
==============
Contributing
==============
.. _repository:
Repository
----------
Pylint is developed using the git_ distributed version control system.
You can clone Pylint and its dependencies from ::
git clone https://github.com/PyCQA/pylint
git clone https://github.com/PyCQA/astroid
.. _git: https://git-scm.com/
Got a change for Pylint? Below are a few steps you should take to make sure
your patch gets accepted. We recommend using Python 3.8 or higher for development
of Pylint as it gives you access to the latest ``ast`` parser.
- Test your code
For more information on how to use our test suite and write new tests see :ref:`testing`.
- ``pylint`` uses black_ and isort_ among other Python auto-formatters.
We have a pre-commit hook which should take care of the autoformatting for
you. To enable it, do the following:
* install ``pre-commit`` using ``pip install pre-commit``
* then run ``pre-commit install`` in the ``pylint`` root directory to enable the git hooks.
- Add a short entry to the ChangeLog describing the change, except for internal
implementation only changes. Not usually required, but for changes other than small
bugs we also add a couple of sentences in the release document for that release,
(`What's New` section). For the release document we usually write some more details,
and it is also a good place to offer examples on how the new change is supposed to work.
- Add a short entry in :file:`doc/whatsnew/VERSION.rst`.
- If you used multiple emails or multiple names when contributing, add your mails
and preferred name in the ``script/.contributors_aliases.json`` file.
- Write a comprehensive commit message
- Relate your change to an issue in the tracker if such an issue exists (see
`Closing issues via commit messages`_ of the GitHub documentation for more
information on this)
- Document your change, if it is a non-trivial one.
- Send a pull request from GitHub (see `About pull requests`_ for more insight
about this topic)
.. _`Closing issues via commit messages`: https://github.blog/2013-01-22-closing-issues-via-commit-messages/
.. _`About pull requests`: https://support.github.com/features/pull-requests
.. _tox: https://tox.readthedocs.io/en/latest/
.. _pytest: https://docs.pytest.org/en/latest/
.. _black: https://github.com/psf/black
.. _isort: https://github.com/PyCQA/isort
.. _astroid: https://github.com/pycqa/astroid
Tips for Getting Started with Pylint Development
------------------------------------------------
* Read the :ref:`technical-reference`. It gives a short walk through of the pylint
codebase and will help you identify where you will need to make changes
for what you are trying to implement.
* ``astroid.extract_node`` is your friend. Most checkers are AST based,
so you will likely need to interact with ``astroid``.
A short example of how to use ``astroid.extract_node`` is given
:ref:`here <astroid_extract_node>`.
* When fixing a bug for a specific check, search the code for the warning
message to find where the warning is raised,
and therefore where the logic for that code exists.
* When adding a new checker class you can use the :file:`get_unused_message_id_category.py`
script in :file:`./script` to get a message id that is not used by
any of the other checkers.
Building the documentation
----------------------------
You can use the makefile in the doc directory with ``make html`` to build the
documentation. To test smaller changes you can consider ``build-html``, which skips some checks but will be faster::
$ cd doc
$ make install-dependencies
$ make build-html
We're reusing generated files for speed, use ``make clean`` when you want to start from scratch.
How to choose the target version ?
----------------------------------
Choose depending on the kind of change you're doing:
.. include:: patch_release.rst
.. include:: minor_release.rst
.. include:: major_release.rst
|