documentation_guidelines.rst 5.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125
  1. .. _doc_documentation_guidelines:
  2. Documentation guidelines
  3. ========================
  4. This page describes the rules to follow if you want to contribute to Godot
  5. Engine by writing or reviewing documentation, or by translating existing
  6. documentation. Also have a look at README of the
  7. `godot-docs GitHub repository <https://github.com/godotengine/godot-docs>`_
  8. and the `docs front page <https://docs.godotengine.org>`_
  9. on what steps to follow and how to contact the docs team.
  10. How to contribute
  11. -----------------
  12. Creating or modifying documentation pages is mainly done via the
  13. `godot-docs GitHub repository <https://github.com/godotengine/godot-docs>`_.
  14. The HTML (or PDF and EPUB) documentation is generated from the .rst files
  15. (reStructuredText markup language) in that repository. Modifying those pages
  16. in a pull request and getting it merged will trigger a rebuild of the online
  17. documentation.
  18. .. seealso:: For details on Git usage and the pull request workflow, please
  19. refer to the :ref:`doc_pr_workflow` page. Most of what it
  20. describes regarding the main godotengine/godot repository is
  21. also valid for the docs repository.
  22. The README.md file contains all the information you need to get you started,
  23. please read it. In particular, it contains some tips and tricks and links to
  24. reference documentation about the reStructuredText markup language.
  25. .. warning:: If you want to edit the **API reference**, please note that it
  26. should *not* be done in the godot-docs repository. Instead, you
  27. should edit the ``doc/classes/*`` XML files of Godot's
  28. main repository. These files are then later used to generate the
  29. in-editor documentation as well as the API reference of the
  30. online docs. Read more here: :ref:`doc_updating_the_class_reference`.
  31. The 'Edit on Github' link
  32. -------------------------
  33. If you're reading documentation on ``docs.godotengine.org`` you'll see an 'Edit on GitHub' hyperlink at the top right of the page. Once you've created a GitHub account you can propose changes to a page you're reading as follows:
  34. 1. Copy the URL that the GitHub link points to. Part of the URL refers to a version name such as '3.1' or 'latest'. Swap this part for the word 'master' so that the result looks something like this: ``https://github.com/godotengine/godot-docs/blob/master/community/contributing/docs_writing_guidelines.rst``
  35. 2. Load that URL in your browser.
  36. 3. On the GitHub page you're taken to, click the pencil icon. It has the tooltip "Edit the file in a fork of this project".
  37. 4. Complete all the edits you want to make for that page.
  38. 5. Summarise the changes you made in the form at the bottom of the page and click the button labelled 'Propose file change' when done.
  39. 6. On the following screens, click the 'Create pull request' buttons until you see a message like ``Open. yourGitHubUsername wants to merge 1 commit into godotengine:master from yourGitHubUsername:patch-6``
  40. 7. A reviewer will evaluate your changes and incorporate them into the docs if they're judged to improve them. You might also be asked to make modifications to your changes before they're included.
  41. What makes good documentation?
  42. ------------------------------
  43. Documentation should be well written in plain English, using well-formed
  44. sentences and various levels of sections and subsections. It should be clear
  45. and objective. Also have a look at the :ref:`doc_docs_writing_guidelines`.
  46. We differentiate tutorial pages from other documentation pages by these
  47. definitions:
  48. - Tutorial: a page aiming at explaining how to use one or more concepts in
  49. the editor or scripts in order to achieve a specific goal with a learning
  50. purpose (e.g. "Making a simple 2d Pong game", "Applying forces to an
  51. object").
  52. - Documentation: a page describing precisely one and only one concept at a
  53. time, if possible exhaustively (e.g. the list of methods of the
  54. Sprite class, or an overview of the input management in Godot).
  55. You are free to write the kind of documentation you wish, as long as you
  56. respect the following rules (and the ones on the repo).
  57. Titles
  58. ------
  59. Always begin pages with their title and a Sphinx reference name:
  60. ::
  61. .. _doc_insert_your_title_here:
  62. Insert your title here
  63. ======================
  64. The reference allows to link to this page using the ``:ref:`` format, e.g.
  65. ``:ref:`doc_insert_your_title_here``` would link to the above example page
  66. (note the lack of leading underscore in the reference).
  67. Also, avoid American CamelCase titles: title's first word should begin
  68. with a capitalized letter, and every following word should not. Thus,
  69. this is a good example:
  70. - Insert your title here
  71. And this is a bad example:
  72. - Insert Your Title Here
  73. Only project, people and node class names should have capitalized first
  74. letter.
  75. Translating existing pages
  76. --------------------------
  77. You can help to translate the official Godot documentation on our `Hosted Weblate <https://hosted.weblate.org/engage/godot-engine/>`_.
  78. .. image:: https://hosted.weblate.org/widgets/godot-engine/-/godot-docs/287x66-white.png
  79. :alt: Translation state
  80. :align: center
  81. :target: https://hosted.weblate.org/engage/godot-engine/?utm_source=widget
  82. :width: 287
  83. :height: 66
  84. There also is the official
  85. `Godot i18n repository <https://github.com/godotengine/godot-docs-l10n>`_
  86. where you can see when the data was last synchronized.
  87. License
  88. -------
  89. This documentation and every page it contains is published under the terms of
  90. 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".
  91. By contributing to the documentation on the GitHub repository, you agree that
  92. your changes are distributed under this license.