Merge branch 'matthiasc/for-master' into 'master'

Add to the docs README

See merge request GNOME/gtk!1971
This commit is contained in:
Matthias Clasen 2020-05-27 16:36:18 +00:00
commit 194b0be8bf

View File

@ -9,7 +9,7 @@ The GTK documentation is divided in two major components:
In both cases, the contents are parsed, converted into DocBook format, and In both cases, the contents are parsed, converted into DocBook format, and
cross-linked in order to match types, functions, signals, and properties. cross-linked in order to match types, functions, signals, and properties.
From the DocBook output, we generate HTML, which can be used to read the From the DocBook output, we generate HTML, which can be used to read the
documentation both off line and online. documentation both offline and online.
In both cases, contributing to the GTK documentation requires modifying In both cases, contributing to the GTK documentation requires modifying
files tracked in the source control repository, and follows the same steps files tracked in the source control repository, and follows the same steps
@ -76,6 +76,9 @@ New classes require:
1. the `get_type` function added to the `.types` file 1. the `get_type` function added to the `.types` file
1. an `xinclude` element in the `docs.xml` file 1. an `xinclude` element in the `docs.xml` file
The GTK documentation also contains a number of 'freestanding' chapters
for which the source is in .md files in docs/reference/gtk.
## Style guide ## Style guide
Like the [coding style][coding], these rules try to formalize the existing Like the [coding style][coding], these rules try to formalize the existing
@ -85,6 +88,27 @@ unrelated reasons.
[coding]: ../CODING-STYLE.md [coding]: ../CODING-STYLE.md
### Syntax
The input syntax for GTK documentation is markdown, in a flavor that is
similar to what you see on gitlab or github. The markdown support for
fragments that are extracted from sources is more limited than for
freestanding chapters. As an exception, man pages for tools are currently
maintained in docbook, since the conversion from markdown to docbook is
losing too much of the expected formatting.
In addition to typical markdown formatting such as \*emphasis\* or \_italics\_,
gtk-doc supports a few abbreviations for cross-references and formatting:
`#ClassName`
: Creates a link to the docs for a class
`function()`
: Creates a link to the docs for a function
`%constant`
: Generates suitable markup for enum values or constants
### Sections ### Sections
- The "section" of each type must contain a name, to be referenced in the - The "section" of each type must contain a name, to be referenced in the
@ -138,6 +162,21 @@ Checks whether the widget is set to be visible or not.
- If a method is a signal emitter, link the signal in the method's - If a method is a signal emitter, link the signal in the method's
description. description.
### Signals
- While GObject can introspect argument and return types for signals,
you should *always* document them with an explicit gtk-doc stanza.
- The syntax for signal stanzas is similar to functions:
```c
/**
* GtkFoo::signal-name:
* @arg1: ...
* @arg2: ...
*
* ...
```
### Properties ### Properties
- While GObject properties contain text that can be extracted - While GObject properties contain text that can be extracted
@ -148,3 +187,25 @@ Checks whether the widget is set to be visible or not.
purposes. purposes.
- Always note if setting a property has side effects, like causing another - Always note if setting a property has side effects, like causing another
property to change state. property to change state.
- The syntax for property documentation is:
```c
/**
* GtkFoo:property-name:
*
* ...
```
### Actions
- Actions are new in GTK 4, and gtk-doc had to learn a a new syntax
to document them:
```
/**c
* GtkFoo|action-name:
* @arg1: ...
* @arg2: ...
*
* ...
```