2016-08-16 07:07:29 +02:00
|
|
|
Contributing Code
|
|
|
|
==================
|
|
|
|
|
|
|
|
For info on contributing things other than code, such as translations, decks
|
|
|
|
and add-ons, please see http://ankisrs.net/docs/manual.html#contributing
|
|
|
|
|
|
|
|
The goal of Anki 2.1.x is to bring Anki up to date with Python 3 and Qt 5,
|
2017-08-26 07:14:20 +02:00
|
|
|
while maintaining compatibility with Anki 2.0.x. Some users will be stuck on
|
|
|
|
Anki 2.0 for a while due to unported add-ons or old hardware, so it's
|
|
|
|
important that 2.1 doesn't make breaking changes to the file format.
|
2016-08-16 07:07:29 +02:00
|
|
|
|
|
|
|
Also of consideration is that the Anki code is indirectly used by the mobile
|
|
|
|
clients, which try their best to keep as close to the Anki code as possible so
|
|
|
|
that future updates can be ported more easily. Refactoring code makes it
|
|
|
|
harder for the mobile clients to track changes, so refactoring should be
|
|
|
|
limited to times when it is necessary to address an important issue.
|
|
|
|
|
|
|
|
Before sending a pull request or a patch, please check the following to
|
2018-07-10 18:13:10 +02:00
|
|
|
increase your chances of the changes being accepted.
|
2016-08-16 07:07:29 +02:00
|
|
|
|
|
|
|
Primarily Bugfixes
|
|
|
|
-------------------
|
|
|
|
|
|
|
|
Small patches that fix a specific problem and don't affect other functionality
|
|
|
|
are likely to be merged if they meet the other requirements below. Larger
|
|
|
|
changes are less likely to be accepted for 2.1.x - if in doubt, please ask
|
|
|
|
before you begin work on them so your work does not go to waste.
|
|
|
|
|
|
|
|
Examples of changes that are unlikely to be accepted:
|
|
|
|
|
|
|
|
- Altering existing code unnecessarily. Your code may be more elegant than
|
|
|
|
what already exists, but it takes time for us to review the changes, may
|
2017-01-30 08:30:20 +01:00
|
|
|
harbour unnoticed bugs, and makes maintaining the mobile clients more
|
2016-08-16 07:07:29 +02:00
|
|
|
difficult.
|
2018-07-10 18:13:10 +02:00
|
|
|
- Adding code that is not used within Anki but is only for the benefit of
|
2016-08-16 07:07:29 +02:00
|
|
|
add-ons - such code is difficult to test and maintain.
|
|
|
|
- Adding code that addresses niche issues - they are better handled in an
|
|
|
|
add-on.
|
|
|
|
|
2019-12-20 11:52:16 +01:00
|
|
|
Type hints
|
|
|
|
-----------
|
|
|
|
|
|
|
|
Type hints have recently been added to parts of the codebase, mainly using
|
|
|
|
automated tools. Patches that improve the type hints are welcome, but
|
|
|
|
pragmatism is advised. Anki's codebase is old and of varying quality, and
|
|
|
|
there are parts that are difficult to type properly. Don't feel the need to
|
|
|
|
avoid 'Any' when a proper type is impractical.
|
|
|
|
|
|
|
|
When adding type signatures, please avoid refactoring the code, as this is
|
|
|
|
liable to break add-ons or introduce regressions.
|
|
|
|
|
|
|
|
Anki's Makefile invokes two type checkers - mypy and pytype. Mypy is fast, but
|
|
|
|
not very good at type inference, so it is mostly useful for checking code
|
|
|
|
that has type signatures. It is able to read the bundled Qt stubs, and works
|
|
|
|
across the whole Anki codebase.
|
|
|
|
|
|
|
|
pytype is much slower, but is better able to infer types when typing hints
|
|
|
|
are unavailable. It is not able to check the aqt/* code, as it can't read
|
|
|
|
the Qt stubs, and it is not currently compatible with Python 3.8.
|
|
|
|
|
|
|
|
The Qt stubs are not perfect, so you'll find when doing things like connecting
|
|
|
|
signals, you may have to add the following to the end of a line to silence
|
|
|
|
the spurious errors.
|
|
|
|
|
|
|
|
# type: ignore
|
|
|
|
|
2016-08-16 07:07:29 +02:00
|
|
|
Maintaining Style
|
|
|
|
------------------
|
|
|
|
|
|
|
|
For consistency, changes should maintain the existing code style - camelCaps,
|
|
|
|
<80 column lines, succinct variable names and so on.
|
|
|
|
|
|
|
|
Tests Must Pass
|
|
|
|
----------------
|
|
|
|
|
2019-12-18 07:16:44 +01:00
|
|
|
Please make sure 'make check' completes successfully before submitting code.
|
|
|
|
|
|
|
|
If your change is to anki/ and not covered by the existing unit tests, please
|
|
|
|
consider adding a unit test at the same time.
|
|
|
|
|
2016-08-16 07:07:29 +02:00
|
|
|
Do One Thing
|
|
|
|
-------------
|
|
|
|
|
|
|
|
A patch or pull request should be the minimum necessary to address one issue.
|
|
|
|
Please don't make a pull request for a bunch of unrelated changes, as they are
|
|
|
|
difficult to review and will be rejected - split them up into separate
|
|
|
|
requests instead.
|
|
|
|
|
|
|
|
License
|
|
|
|
-------
|
|
|
|
|
|
|
|
As mentioned in the LICENSE file, we are only able to accept non-trivial
|
|
|
|
patches or pull requests from people who have sent us a private message
|
|
|
|
indicating that they license their changes under the BSD license.
|
|
|
|
|
|
|
|
Add-ons
|
|
|
|
========
|
|
|
|
|
|
|
|
If you'd like to make more extensive changes, please consider writing an
|
|
|
|
add-on instead, as add-ons have none of these restrictions and can implement
|
|
|
|
whatever functionality in whatever style you wish.
|