mirror of
https://github.com/Relintai/pandemonium_engine_docs.git
synced 2025-01-08 15:09:50 +01:00
189 lines
7.1 KiB
ReStructuredText
189 lines
7.1 KiB
ReStructuredText
.. _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
|
||
languages, read `doc_editor_and_docs_localization`.
|
||
|
||
Getting started
|
||
---------------
|
||
|
||
To modify or create pages in the reference manual, you need to edit `.rst`
|
||
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
|
||
refer to the `doc_pr_workflow` page. Most of what it describes
|
||
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
|
||
the `Godot API <toc-class-ref>` section of this documentation
|
||
from them. If you want to update the description of a class, its
|
||
methods, or properties, read
|
||
`doc_updating_the_class_reference`.
|
||
|
||
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:
|
||
|
||
1. The `doc_docs_writing_guidelines`. There, you will find rules and
|
||
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
|
||
--------------------
|
||
|
||
**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
|
||
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
|
||
~~~~~~~~~~~~~~~~~~~~~~
|
||
|
||
To edit an existing page, locate its `.rst` source file and open it in your
|
||
favorite text editor. You can then commit the changes, push them to your fork,
|
||
and make a pull request. **Note that the pages in** `classes/` **should not be
|
||
edited here.** They are automatically generated from Godot’s `XML class
|
||
reference <https://github.com/godotengine/godot/tree/master/doc/classes>`__.
|
||
See `doc_updating_the_class_reference` for details.
|
||
|
||
.. seealso:: To build the manual and test changes on your computer, see
|
||
`doc_building_the_manual`.
|
||
|
||
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.
|
||
3. Read our `doc_content_guidelines`.
|
||
|
||
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`.
|
||
|
||
You should then add your page to the relevant "toctree" (table of contents,
|
||
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`.
|
||
|
||
Titles
|
||
~~~~~~
|
||
|
||
Always begin pages with their title and a Sphinx reference name:
|
||
|
||
::
|
||
|
||
.. _doc_insert_your_title_here:
|
||
|
||
Insert your title here
|
||
======================
|
||
|
||
The reference `_doc_insert_your_title_here` and the title should match.
|
||
|
||
The reference allows linking to this page using the ``` format, e.g.
|
||
```doc_insert_your_title_here``` would link to the above example page (note
|
||
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
|
||
table of contents (`.. toctree::`) or cross-referencing pages. Check the
|
||
`official Sphinx documentation
|
||
<https://www.sphinx-doc.org/en/stable/index.html>`__ for more details. To learn
|
||
how to use Sphinx directives like `.. note::` or `.. seealso::`, check out
|
||
the `Sphinx directives documentation
|
||
<https://www.sphinx-doc.org/en/master/usage/restructuredtext/directives.html>`__.
|
||
|
||
Adding images and attachments
|
||
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
||
|
||
To add images, please put them in an `img/` folder next to the `.rst` file with
|
||
a meaningful name and include them in your page with:
|
||
|
||
.. code:: rst
|
||
|
||
.. image:: img/image_name.png
|
||
|
||
Similarly, you can include attachments, like assets as support material for a
|
||
tutorial, by placing them into a `files/` folder next to the `.rst` file, and
|
||
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.
|