2022-03-18 17:46:08 +01:00
|
|
|
|
.. _doc_contributing_to_the_documentation:
|
|
|
|
|
|
|
|
|
|
Contributing to the documentation
|
|
|
|
|
=================================
|
|
|
|
|
|
|
|
|
|
This guide explains how to contribute to Godot's documentation, be it by
|
|
|
|
|
writing or reviewing pages.
|
|
|
|
|
|
|
|
|
|
.. seealso::
|
|
|
|
|
|
|
|
|
|
If you want to translate pages or the class reference from English to other
|
2023-01-12 19:29:11 +01:00
|
|
|
|
languages, read `doc_editor_and_docs_localization`.
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
|
|
Getting started
|
|
|
|
|
---------------
|
|
|
|
|
|
2023-01-12 19:43:03 +01:00
|
|
|
|
To modify or create pages in the reference manual, you need to edit `.rst`
|
2022-03-18 17:46:08 +01:00
|
|
|
|
files in the `godot-docs GitHub repository
|
|
|
|
|
<https://github.com/godotengine/godot-docs>`_. Modifying those pages in a pull
|
|
|
|
|
request triggers a rebuild of the online documentation upon merging.
|
|
|
|
|
|
|
|
|
|
.. seealso:: For details on Git usage and the pull request workflow, please
|
2023-01-12 19:29:11 +01:00
|
|
|
|
refer to the `doc_pr_workflow` page. Most of what it describes
|
2022-03-18 17:46:08 +01:00
|
|
|
|
regarding the main godotengine/godot repository is also valid for
|
|
|
|
|
the docs repository.
|
|
|
|
|
|
|
|
|
|
.. warning:: The class reference's source files are in the `Godot engine
|
|
|
|
|
repository <https://github.com/godotengine/godot>`_. We generate
|
2023-01-12 19:29:11 +01:00
|
|
|
|
the `Godot API <toc-class-ref>` section of this documentation
|
2022-03-18 17:46:08 +01:00
|
|
|
|
from them. If you want to update the description of a class, its
|
|
|
|
|
methods, or properties, read
|
2023-01-12 19:29:11 +01:00
|
|
|
|
`doc_updating_the_class_reference`.
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
|
|
What is the Godot documentation
|
|
|
|
|
-------------------------------
|
|
|
|
|
|
|
|
|
|
The Godot documentation is intended as a comprehensive reference manual for the
|
|
|
|
|
Godot game engine. It is not meant to contain step-by-step tutorials, except for
|
|
|
|
|
two game creation tutorials in the Getting Started section.
|
|
|
|
|
|
|
|
|
|
We strive to write factual content in an accessible and well-written language. To
|
|
|
|
|
contribute, you should also read:
|
|
|
|
|
|
2023-01-12 19:29:11 +01:00
|
|
|
|
1. The `doc_docs_writing_guidelines`. There, you will find rules and
|
2022-03-18 17:46:08 +01:00
|
|
|
|
recommendations to write in a way that everyone understands.
|
|
|
|
|
2. The content guidelines. They explain the principles we follow to write the
|
|
|
|
|
documentation and the kind of content we accept.
|
|
|
|
|
|
|
|
|
|
Contributing changes
|
|
|
|
|
--------------------
|
|
|
|
|
|
2023-01-12 19:43:03 +01:00
|
|
|
|
**Pull Requests should use the** `master` **branch by default.** Only make Pull
|
|
|
|
|
Requests against other branches (e.g. `2.1` or `3.0`) if your changes only
|
2022-03-18 17:46:08 +01:00
|
|
|
|
apply to that specific version of Godot.
|
|
|
|
|
|
|
|
|
|
Though less convenient to edit than a wiki, this Git repository is where we
|
|
|
|
|
write the documentation. Having direct access to the source files in a revision
|
|
|
|
|
control system is a plus to ensure our documentation quality.
|
|
|
|
|
|
|
|
|
|
Editing existing pages
|
|
|
|
|
~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
|
|
2023-01-12 19:43:03 +01:00
|
|
|
|
To edit an existing page, locate its `.rst` source file and open it in your
|
2022-03-18 17:46:08 +01:00
|
|
|
|
favorite text editor. You can then commit the changes, push them to your fork,
|
2023-01-12 19:43:03 +01:00
|
|
|
|
and make a pull request. **Note that the pages in** `classes/` **should not be
|
2022-03-18 17:46:08 +01:00
|
|
|
|
edited here.** They are automatically generated from Godot’s `XML class
|
|
|
|
|
reference <https://github.com/godotengine/godot/tree/master/doc/classes>`__.
|
2023-01-12 19:29:11 +01:00
|
|
|
|
See `doc_updating_the_class_reference` for details.
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
|
|
.. seealso:: To build the manual and test changes on your computer, see
|
2023-01-12 19:29:11 +01:00
|
|
|
|
`doc_building_the_manual`.
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
|
|
Editing pages online
|
|
|
|
|
--------------------
|
|
|
|
|
|
|
|
|
|
You can edit the documentation online by clicking the **Edit on GitHub** link in
|
|
|
|
|
the top-right of every page.
|
|
|
|
|
|
|
|
|
|
Doing so takes you to the GitHub text editor. You need to have a GitHub account
|
|
|
|
|
and to log in to use it. Once logged in, you can propose change like so:
|
|
|
|
|
|
|
|
|
|
1. Click the **Edit on GitHub** button.
|
|
|
|
|
|
|
|
|
|
2. On the GitHub page you're taken to, click the pencil icon in the top-right
|
|
|
|
|
corner near the **Raw**, **Blame**, and **Delete** buttons. It has the
|
|
|
|
|
tooltip "Fork this project and edit the file".
|
|
|
|
|
|
|
|
|
|
3. Edit the text in the text editor.
|
|
|
|
|
|
|
|
|
|
4. At the bottom of the web page, summarize the changes you made and click the
|
|
|
|
|
button **Propose file change**. Make sure to replace the placeholder "Update file.rst"
|
|
|
|
|
by a short but clear one-line description, as this is the commit title.
|
|
|
|
|
|
|
|
|
|
5. On the following screens, click the **Create pull request** button until you
|
|
|
|
|
see a message like *Username wants to merge 1 commit into godotengine:master
|
|
|
|
|
from Username:patch-1*.
|
|
|
|
|
|
|
|
|
|
Another contributor will review your changes and merge them into the docs if
|
|
|
|
|
they're good. They may also make changes or ask you to do so before merging.
|
|
|
|
|
|
|
|
|
|
Adding new pages
|
|
|
|
|
----------------
|
|
|
|
|
|
|
|
|
|
Before adding a new page, please ensure that it fits in the documentation:
|
|
|
|
|
|
|
|
|
|
1. Look for `existing issues
|
|
|
|
|
<https://github.com/godotengine/godot-docs/issues>`_ or open a new one to see
|
|
|
|
|
if the page is necessary.
|
|
|
|
|
2. Ensure there isn't a page that already covers the topic.
|
2023-01-12 19:29:11 +01:00
|
|
|
|
3. Read our `doc_content_guidelines`.
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
2023-01-12 19:43:03 +01:00
|
|
|
|
To add a new page, create a `.rst` file with a meaningful name in the section you
|
|
|
|
|
want to add a file to, e.g. `tutorials/3d/light_baking.rst`.
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
|
|
You should then add your page to the relevant "toctree" (table of contents,
|
2023-01-12 19:43:03 +01:00
|
|
|
|
e.g. `tutorials/3d/index.rst`). Add your new filename to the list on a new
|
|
|
|
|
line, using a relative path and no extension, e.g. here `light_baking`.
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
|
|
Titles
|
|
|
|
|
~~~~~~
|
|
|
|
|
|
|
|
|
|
Always begin pages with their title and a Sphinx reference name:
|
|
|
|
|
|
|
|
|
|
::
|
|
|
|
|
|
|
|
|
|
.. _doc_insert_your_title_here:
|
|
|
|
|
|
|
|
|
|
Insert your title here
|
|
|
|
|
======================
|
|
|
|
|
|
2023-01-12 19:43:03 +01:00
|
|
|
|
The reference `_doc_insert_your_title_here` and the title should match.
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
2023-01-12 19:43:03 +01:00
|
|
|
|
The reference allows linking to this page using the ``` format, e.g.
|
2023-01-12 19:29:11 +01:00
|
|
|
|
```doc_insert_your_title_here``` would link to the above example page (note
|
2022-03-18 17:46:08 +01:00
|
|
|
|
the lack of leading underscore in the reference).
|
|
|
|
|
|
|
|
|
|
Write your titles like plain sentences, without capitalizing each word:
|
|
|
|
|
|
|
|
|
|
- **Good:** Understanding signals in Godot
|
|
|
|
|
- **Bad:** Understanding Signals In Godot
|
|
|
|
|
|
|
|
|
|
Only propers nouns, projects, people, and node class names should have their
|
|
|
|
|
first letter capitalized.
|
|
|
|
|
|
|
|
|
|
Sphinx and reStructuredText syntax
|
|
|
|
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
|
|
|
|
|
|
Check Sphinx’s `reST Primer <https://www.sphinx-doc.org/en/stable/rest.html>`__
|
|
|
|
|
and the `official reference <http://docutils.sourceforge.net/rst.html>`__ for
|
|
|
|
|
details on the syntax.
|
|
|
|
|
|
|
|
|
|
Sphinx uses specific reST comments to do specific operations, like defining the
|
2023-01-12 19:43:03 +01:00
|
|
|
|
table of contents (`.. toctree::`) or cross-referencing pages. Check the
|
2022-03-18 17:46:08 +01:00
|
|
|
|
`official Sphinx documentation
|
|
|
|
|
<https://www.sphinx-doc.org/en/stable/index.html>`__ for more details. To learn
|
2023-01-12 19:43:03 +01:00
|
|
|
|
how to use Sphinx directives like `.. note::` or `.. seealso::`, check out
|
2022-03-18 17:46:08 +01:00
|
|
|
|
the `Sphinx directives documentation
|
|
|
|
|
<https://www.sphinx-doc.org/en/master/usage/restructuredtext/directives.html>`__.
|
|
|
|
|
|
|
|
|
|
Adding images and attachments
|
|
|
|
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
|
|
2023-01-12 19:43:03 +01:00
|
|
|
|
To add images, please put them in an `img/` folder next to the `.rst` file with
|
2022-03-18 17:46:08 +01:00
|
|
|
|
a meaningful name and include them in your page with:
|
|
|
|
|
|
|
|
|
|
.. code:: rst
|
|
|
|
|
|
2023-01-12 20:16:00 +01:00
|
|
|
|
![](img/image_name.png)
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
|
|
Similarly, you can include attachments, like assets as support material for a
|
2023-01-12 19:43:03 +01:00
|
|
|
|
tutorial, by placing them into a `files/` folder next to the `.rst` file, and
|
2022-03-18 17:46:08 +01:00
|
|
|
|
using this inline markup:
|
|
|
|
|
|
|
|
|
|
.. code:: rst
|
|
|
|
|
|
|
|
|
|
:download:`myfilename.zip <files/myfilename.zip>`
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
License
|
|
|
|
|
-------
|
|
|
|
|
|
|
|
|
|
This documentation and every page it contains is published under the terms of
|
|
|
|
|
the `Creative Commons Attribution 3.0 license (CC-BY-3.0)
|
|
|
|
|
<https://tldrlegal.com/license/creative-commons-attribution-(cc)>`_, with
|
|
|
|
|
attribution to "Juan Linietsky, Ariel Manzur and the Godot community".
|
|
|
|
|
|
|
|
|
|
By contributing to the documentation on the GitHub repository, you agree that
|
|
|
|
|
your changes are distributed under this license.
|