CONTRIBUTING: Rationalize sections

Mostly this tries to give logical header levels, so the "Fish Style
Guide" section is in the "Code Style" section

Also remove a few unimportant C++-centric sections - I'm not sure iwyu
even runs anymore, and cppcheck isn't great in my experience.
This commit is contained in:
Fabian Boehm 2023-06-02 17:26:35 +02:00
parent 272d123431
commit 756cb15f81

View file

@ -1,3 +1,4 @@
####################
Contributing To Fish Contributing To Fish
#################### ####################
@ -11,7 +12,7 @@ Whether you want to change some of the core rust/C++ source, enhance or add a co
improve the documentation or translate something, this document will tell you how. improve the documentation or translate something, this document will tell you how.
Getting Set Up Getting Set Up
-------------- ==============
Fish is developed on Github, at https://github.com/fish-shell/fish-shell. Fish is developed on Github, at https://github.com/fish-shell/fish-shell.
@ -37,7 +38,7 @@ Of course not everything is required always - if you just want to contribute som
and if the change is very simple and obvious you can just send it in. Use your judgement! and if the change is very simple and obvious you can just send it in. Use your judgement!
Guidelines Guidelines
---------- ==========
In short: In short:
@ -45,7 +46,7 @@ In short:
- Use automated tools to help you (including ``make test``, ``build_tools/style.fish`` and ``make lint``) - Use automated tools to help you (including ``make test``, ``build_tools/style.fish`` and ``make lint``)
Contributing completions Contributing completions
------------------------ ========================
Completion scripts are the most common contribution to fish, and they are very welcome. Completion scripts are the most common contribution to fish, and they are very welcome.
@ -77,7 +78,7 @@ Put your completion script into share/completions/name-of-command.fish. If you h
If you want to add tests, you probably want to add a littlecheck test. See below for details. If you want to add tests, you probably want to add a littlecheck test. See below for details.
Contributing documentation Contributing documentation
-------------------------- ==========================
The documentation is stored in ``doc_src/``, and written in ReStructured Text and built with Sphinx. The documentation is stored in ``doc_src/``, and written in ReStructured Text and built with Sphinx.
@ -90,7 +91,7 @@ which will build the docs as html in /tmp/fish-doc. You can open it in a browser
The builtins and various functions shipped with fish are documented in doc_src/cmds/. The builtins and various functions shipped with fish are documented in doc_src/cmds/.
Contributing to fish's Rust/C++ core Contributing to fish's Rust/C++ core
------------------------------------ ====================================
As of now, fish is in the process of switching from C++11 to Rust, so this is in flux. As of now, fish is in the process of switching from C++11 to Rust, so this is in flux.
@ -100,7 +101,6 @@ Importantly, the initial port strives for fidelity with the existing C++ codebas
so it won't be 100% idiomatic rust - in some cases it'll have some awkward interface code so it won't be 100% idiomatic rust - in some cases it'll have some awkward interface code
in order to interact with the C++. in order to interact with the C++.
Linters Linters
------- -------
@ -118,8 +118,10 @@ help catch mistakes such as using ``wcwidth()`` rather than
``fish_wcwidth()``. Please add a new rule if you find similar mistakes ``fish_wcwidth()``. Please add a new rule if you find similar mistakes
being made. being made.
We use ``clippy`` for Rust.
Code Style Code Style
---------- ==========
To ensure your changes conform to the style rules run To ensure your changes conform to the style rules run
@ -149,6 +151,20 @@ If you want to check the style of the entire code base run
That command will refuse to restyle any files if you have uncommitted That command will refuse to restyle any files if you have uncommitted
changes. changes.
Fish Script Style Guide
-----------------------
1. All fish scripts, such as those in the *share/functions* and *tests*
directories, should be formatted using the ``fish_indent`` command.
2. Function names should be in all lowercase with words separated by
underscores. Private functions should begin with an underscore. The
first word should be ``fish`` if the function is unique to fish.
3. The first word of global variable names should generally be ``fish``
for public vars or ``_fish`` for private vars to minimize the
possibility of name clashes with user defined vars.
Configuring Your Editor for Fish Scripts Configuring Your Editor for Fish Scripts
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
@ -185,20 +201,6 @@ made to run fish_indent via e.g.
(add-hook 'fish-mode-hook (lambda () (add-hook 'fish-mode-hook (lambda ()
(add-hook 'before-save-hook 'fish_indent-before-save))) (add-hook 'before-save-hook 'fish_indent-before-save)))
Fish Script Style Guide
-----------------------
1. All fish scripts, such as those in the *share/functions* and *tests*
directories, should be formatted using the ``fish_indent`` command.
2. Function names should be in all lowercase with words separated by
underscores. Private functions should begin with an underscore. The
first word should be ``fish`` if the function is unique to fish.
3. The first word of global variable names should generally be ``fish``
for public vars or ``_fish`` for private vars to minimize the
possibility of name clashes with user defined vars.
C++ Style Guide C++ Style Guide
--------------- ---------------
@ -248,7 +250,7 @@ Rust Style Guide
Use ``cargo fmt`` and ``cargo clippy``. Clippy warnings can be turned off if there's a good reason to. Use ``cargo fmt`` and ``cargo clippy``. Clippy warnings can be turned off if there's a good reason to.
Testing Testing
------- =======
The source code for fish includes a large collection of tests. If you The source code for fish includes a large collection of tests. If you
are making any changes to fish, running these tests is a good way to make are making any changes to fish, running these tests is a good way to make
@ -273,7 +275,7 @@ fish_tests.cpp is mostly useful for unit tests - if you wish to test that a func
The pexpects are written in python and can simulate input and output to/from a terminal, so they are needed for anything that needs actual interactivity. The runner is in build_tools/pexpect_helper.py, in case you need to modify something there. The pexpects are written in python and can simulate input and output to/from a terminal, so they are needed for anything that needs actual interactivity. The runner is in build_tools/pexpect_helper.py, in case you need to modify something there.
Local testing Local testing
~~~~~~~~~~~~~ -------------
The tests can be run on your local computer on all operating systems. The tests can be run on your local computer on all operating systems.
@ -283,7 +285,7 @@ The tests can be run on your local computer on all operating systems.
make test make test
Git hooks Git hooks
~~~~~~~~~ ---------
Since developers sometimes forget to run the tests, it can be helpful to Since developers sometimes forget to run the tests, it can be helpful to
use git hooks (see githooks(5)) to automate it. use git hooks (see githooks(5)) to automate it.
@ -326,7 +328,7 @@ To install the hook, place the code in a new file
``.git/hooks/pre-push`` and make it executable. ``.git/hooks/pre-push`` and make it executable.
Coverity Scan Coverity Scan
~~~~~~~~~~~~~ -------------
We use Coveritys static analysis tool which offers free access to open We use Coveritys static analysis tool which offers free access to open
source projects. While access to the tool itself is restricted, source projects. While access to the tool itself is restricted,
@ -336,42 +338,8 @@ with their GitHub account. Currently, tests are triggered upon merging
the ``master`` branch into ``coverity_scan_master``. Even if you are not the ``master`` branch into ``coverity_scan_master``. Even if you are not
a fish developer, you can keep an eye on our statistics there. a fish developer, you can keep an eye on our statistics there.
Installing the Required Tools Contributing Translations
----------------------------- =========================
Installing the Linting Tools
~~~~~~~~~~~~~~~~~~~~~~~~~~~~
To install the lint checkers on Mac OS X using Homebrew:
::
brew install cppcheck
To install the lint checkers on Debian-based Linux distributions:
::
sudo apt-get install clang
sudo apt-get install cppcheck
Installing the Formatting Tools
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
Mac OS X:
::
brew install clang-format
Debian-based:
::
sudo apt-get install clang-format
Message Translations
--------------------
Fish uses the GNU gettext library to translate messages from English to Fish uses the GNU gettext library to translate messages from English to
other languages. other languages.
@ -385,7 +353,8 @@ macro:
streams.out.append_format(_(L"%ls: There are no jobs\n"), argv[0]); streams.out.append_format(_(L"%ls: There are no jobs\n"), argv[0]);
All messages in fish script must be enclosed in single or double quote All messages in fish script must be enclosed in single or double quote
characters. They must also be translated via a subcommand. This means characters for the message extraction to find them.
They must also be translated via a command substitution. This means
that the following are **not** valid: that the following are **not** valid:
:: ::
@ -400,9 +369,9 @@ Above should be written like this instead:
echo (_ "hello") echo (_ "hello")
echo (_ "goodbye") echo (_ "goodbye")
Note that you can use either single or double quotes to enclose the You can use either single or double quotes to enclose the
message to be translated. You can also optionally include spaces after message to be translated. You can also optionally include spaces after
the opening parentheses and once again before the closing parentheses. the opening parentheses or before the closing parentheses.
Creating and updating translations requires the Gettext tools, including Creating and updating translations requires the Gettext tools, including
``xgettext``, ``msgfmt`` and ``msgmerge``. Translation sources are ``xgettext``, ``msgfmt`` and ``msgmerge``. Translation sources are
@ -438,44 +407,10 @@ wiki <https://github.com/fish-shell/fish-shell/wiki/Translations>`__ for
more information. more information.
Versioning Versioning
---------- ==========
The fish version is constructed by the *build_tools/git_version_gen.sh* The fish version is constructed by the *build_tools/git_version_gen.sh*
script. For developers the version is the branch name plus the output of script. For developers the version is the branch name plus the output of
``git describe --always --dirty``. Normally the main part of the version ``git describe --always --dirty``. Normally the main part of the version
will be the closest annotated tag. Which itself is usually the most will be the closest annotated tag. Which itself is usually the most
recent release number (e.g., ``2.6.0``). recent release number (e.g., ``2.6.0``).
Include What You Use
--------------------
You should not depend on symbols being visible to a ``*.cpp`` module
from ``#include`` statements inside another header file. In other words
if your module does ``#include "common.h"`` and that header does
``#include "signals.h"`` your module should not assume the sub-include is
present. It should instead directly ``#include "signals.h"`` if it needs
any symbol from that header. That makes the actual dependencies much
clearer. It also makes it easy to modify the headers included by a
specific header file without having to worry that will break any module
(or header) that includes a particular header.
To help enforce this rule the ``make lint`` (and ``make lint-all``)
command will run the
`include-what-you-use <https://include-what-you-use.org/>`__ tool. You
can find the IWYU project on
`github <https://github.com/include-what-you-use/include-what-you-use>`__.
To install the tool on OS X youll need to add a
`formula <https://github.com/jasonmp85/homebrew-iwyu>`__ then install
it:
::
brew tap jasonmp85/iwyu
brew install iwyu
On Ubuntu you can install it via ``apt-get``:
::
sudo apt-get install iwyu