[pangomm] Regenerate docs.xml and .defs files, using files from pango 1.50.0



commit e764f7ddd861bab5fa34caa4a510aabda6c2c7ad
Author: Kjell Ahlstedt <kjellahlstedt gmail com>
Date:   Mon Dec 6 16:51:44 2021 +0100

    Regenerate docs.xml and .defs files, using files from pango 1.50.0
    
    and update pango_docs_override.xml.

 pango/src/pango_docs.xml          | 7268 +++++++++++++++++++++++--------------
 pango/src/pango_docs_override.xml |    1 +
 pango/src/pango_enums.defs        |  210 +-
 pango/src/pango_methods.defs      |  755 +++-
 4 files changed, 5272 insertions(+), 2962 deletions(-)
---
diff --git a/pango/src/pango_docs.xml b/pango/src/pango_docs.xml
index ceb6892..b5b2d6f 100644
--- a/pango/src/pango_docs.xml
+++ b/pango/src/pango_docs.xml
@@ -1,9 +1,14 @@
 <root>
 <enum name="PangoAlignment">
 <description>
-A #PangoAlignment describes how to align the lines of a #PangoLayout within the
-available space. If the #PangoLayout is set to justify
-using pango_layout_set_justify(), this only has effect for partial lines.
+`PangoAlignment` describes how to align the lines of a `PangoLayout`
+within the available space.
+
+If the `PangoLayout` is set to justify using [method@Pango.Layout.set_justify],
+this only has effect for partial lines.
+
+See [method@Pango.Layout.set_auto_dir] for how text direction affects
+the interpretation of `PangoAlignment values.
 
 </description>
 <parameters>
@@ -24,12 +29,12 @@ using pango_layout_set_justify(), this only has effect for partial lines.
 
 <enum name="PangoAttrType">
 <description>
-The #PangoAttrType
-distinguishes between different types of attributes. Along with the
-predefined values, it is possible to allocate additional values
-for custom attributes using pango_attr_type_register(). The predefined
-values are given below. The type of structure used to store the
-attribute is listed in parentheses after the description.
+The `PangoAttrType` distinguishes between different types of attributes.
+
+Along with the predefined values, it is possible to allocate additional
+values for custom attributes using [func@AttrType.register]. The predefined
+values are given below. The type of structure used to store the attribute is
+listed in parentheses after the description.
 
 </description>
 <parameters>
@@ -38,123 +43,172 @@ attribute is listed in parentheses after the description.
 </parameter_description>
 </parameter>
 <parameter name="PANGO_ATTR_LANGUAGE">
-<parameter_description> language (#PangoAttrLanguage)
+<parameter_description> language ([struct@Pango.AttrLanguage])
 </parameter_description>
 </parameter>
 <parameter name="PANGO_ATTR_FAMILY">
-<parameter_description> font family name list (#PangoAttrString)
+<parameter_description> font family name list ([struct@Pango.AttrString])
 </parameter_description>
 </parameter>
 <parameter name="PANGO_ATTR_STYLE">
-<parameter_description> font slant style (#PangoAttrInt)
+<parameter_description> font slant style ([struct@Pango.AttrInt])
 </parameter_description>
 </parameter>
 <parameter name="PANGO_ATTR_WEIGHT">
-<parameter_description> font weight (#PangoAttrInt)
+<parameter_description> font weight ([struct@Pango.AttrInt])
 </parameter_description>
 </parameter>
 <parameter name="PANGO_ATTR_VARIANT">
-<parameter_description> font variant (normal or small caps) (#PangoAttrInt)
+<parameter_description> font variant (normal or small caps) ([struct@Pango.AttrInt])
 </parameter_description>
 </parameter>
 <parameter name="PANGO_ATTR_STRETCH">
-<parameter_description> font stretch (#PangoAttrInt)
+<parameter_description> font stretch ([struct@Pango.AttrInt])
 </parameter_description>
 </parameter>
 <parameter name="PANGO_ATTR_SIZE">
-<parameter_description> font size in points scaled by %PANGO_SCALE (#PangoAttrInt)
+<parameter_description> font size in points scaled by %PANGO_SCALE ([struct@Pango.AttrInt])
 </parameter_description>
 </parameter>
 <parameter name="PANGO_ATTR_FONT_DESC">
-<parameter_description> font description (#PangoAttrFontDesc)
+<parameter_description> font description ([struct@Pango.AttrFontDesc])
 </parameter_description>
 </parameter>
 <parameter name="PANGO_ATTR_FOREGROUND">
-<parameter_description> foreground color (#PangoAttrColor)
+<parameter_description> foreground color ([struct@Pango.AttrColor])
 </parameter_description>
 </parameter>
 <parameter name="PANGO_ATTR_BACKGROUND">
-<parameter_description> background color (#PangoAttrColor)
+<parameter_description> background color ([struct@Pango.AttrColor])
 </parameter_description>
 </parameter>
 <parameter name="PANGO_ATTR_UNDERLINE">
-<parameter_description> whether the text has an underline (#PangoAttrInt)
+<parameter_description> whether the text has an underline ([struct@Pango.AttrInt])
 </parameter_description>
 </parameter>
 <parameter name="PANGO_ATTR_STRIKETHROUGH">
-<parameter_description> whether the text is struck-through (#PangoAttrInt)
+<parameter_description> whether the text is struck-through ([struct@Pango.AttrInt])
 </parameter_description>
 </parameter>
 <parameter name="PANGO_ATTR_RISE">
-<parameter_description> baseline displacement (#PangoAttrInt)
+<parameter_description> baseline displacement ([struct@Pango.AttrInt])
 </parameter_description>
 </parameter>
 <parameter name="PANGO_ATTR_SHAPE">
-<parameter_description> shape (#PangoAttrShape)
+<parameter_description> shape ([struct@Pango.AttrShape])
 </parameter_description>
 </parameter>
 <parameter name="PANGO_ATTR_SCALE">
-<parameter_description> font size scale factor (#PangoAttrFloat)
+<parameter_description> font size scale factor ([struct@Pango.AttrFloat])
 </parameter_description>
 </parameter>
 <parameter name="PANGO_ATTR_FALLBACK">
-<parameter_description> whether fallback is enabled (#PangoAttrInt)
+<parameter_description> whether fallback is enabled ([struct@Pango.AttrInt])
 </parameter_description>
 </parameter>
 <parameter name="PANGO_ATTR_LETTER_SPACING">
-<parameter_description> letter spacing (#PangoAttrInt)
+<parameter_description> letter spacing ([struct@PangoAttrInt])
 </parameter_description>
 </parameter>
 <parameter name="PANGO_ATTR_UNDERLINE_COLOR">
-<parameter_description> underline color (#PangoAttrColor)
+<parameter_description> underline color ([struct@Pango.AttrColor])
 </parameter_description>
 </parameter>
 <parameter name="PANGO_ATTR_STRIKETHROUGH_COLOR">
-<parameter_description> strikethrough color (#PangoAttrColor)
+<parameter_description> strikethrough color ([struct@Pango.AttrColor])
 </parameter_description>
 </parameter>
 <parameter name="PANGO_ATTR_ABSOLUTE_SIZE">
-<parameter_description> font size in pixels scaled by %PANGO_SCALE (#PangoAttrInt)
+<parameter_description> font size in pixels scaled by %PANGO_SCALE ([struct@Pango.AttrInt])
 </parameter_description>
 </parameter>
 <parameter name="PANGO_ATTR_GRAVITY">
-<parameter_description> base text gravity (#PangoAttrInt)
+<parameter_description> base text gravity ([struct@Pango.AttrInt])
 </parameter_description>
 </parameter>
 <parameter name="PANGO_ATTR_GRAVITY_HINT">
-<parameter_description> gravity hint (#PangoAttrInt)
+<parameter_description> gravity hint ([struct@Pango.AttrInt])
 </parameter_description>
 </parameter>
 <parameter name="PANGO_ATTR_FONT_FEATURES">
-<parameter_description> OpenType font features (#PangoAttrString). Since 1.38
+<parameter_description> OpenType font features ([struct@Pango.AttrFontFeatures]). Since 1.38
 </parameter_description>
 </parameter>
 <parameter name="PANGO_ATTR_FOREGROUND_ALPHA">
-<parameter_description> foreground alpha (#PangoAttrInt). Since 1.38
+<parameter_description> foreground alpha ([struct@Pango.AttrInt]). Since 1.38
 </parameter_description>
 </parameter>
 <parameter name="PANGO_ATTR_BACKGROUND_ALPHA">
-<parameter_description> background alpha (#PangoAttrInt). Since 1.38
+<parameter_description> background alpha ([struct@Pango.AttrInt]). Since 1.38
 </parameter_description>
 </parameter>
 <parameter name="PANGO_ATTR_ALLOW_BREAKS">
-<parameter_description> whether breaks are allowed (#PangoAttrInt). Since 1.44
+<parameter_description> whether breaks are allowed ([struct@Pango.AttrInt]). Since 1.44
 </parameter_description>
 </parameter>
 <parameter name="PANGO_ATTR_SHOW">
-<parameter_description> how to render invisible characters (#PangoAttrInt). Since 1.44
+<parameter_description> how to render invisible characters ([struct@Pango.AttrInt]). Since 1.44
 </parameter_description>
 </parameter>
 <parameter name="PANGO_ATTR_INSERT_HYPHENS">
-<parameter_description> whether to insert hyphens at intra-word line breaks (#PangoAttrInt). Since 1.44
+<parameter_description> whether to insert hyphens at intra-word line breaks ([struct@Pango.AttrInt]). Since 
1.44
 </parameter_description>
 </parameter>
 <parameter name="PANGO_ATTR_OVERLINE">
-<parameter_description> whether the text has an overline (#PangoAttrInt). Since 1.46
+<parameter_description> whether the text has an overline ([struct@Pango.AttrInt]). Since 1.46
 </parameter_description>
 </parameter>
 <parameter name="PANGO_ATTR_OVERLINE_COLOR">
-<parameter_description> overline color (#PangoAttrColor). Since 1.46
+<parameter_description> overline color ([struct@Pango.AttrColor]). Since 1.46
+</parameter_description>
+</parameter>
+<parameter name="PANGO_ATTR_LINE_HEIGHT">
+<parameter_description> line height factor ([struct@Pango.AttrFloat]). Since: 1.50
+</parameter_description>
+</parameter>
+<parameter name="PANGO_ATTR_ABSOLUTE_LINE_HEIGHT">
+<parameter_description> line height ([struct@Pango.AttrInt]). Since: 1.50
+</parameter_description>
+</parameter>
+<parameter name="PANGO_ATTR_WORD">
+<parameter_description> override segmentation to classify the range of the attribute as a single word 
([struct@Pango.AttrInt]). Since 1.50
+</parameter_description>
+</parameter>
+<parameter name="PANGO_ATTR_SENTENCE">
+<parameter_description> override segmentation to classify the range of the attribute as a single sentence 
([struct@Pango.AttrInt]). Since 1.50
+</parameter_description>
+</parameter>
+<parameter name="PANGO_ATTR_BASELINE_SHIFT">
+<parameter_description> baseline displacement ([struct@Pango.AttrInt]). Since 1.50
+</parameter_description>
+</parameter>
+<parameter name="PANGO_ATTR_FONT_SCALE">
+<parameter_description> font-relative size change ([struct@Pango.AttrInt]). Since 1.50
+</parameter_description>
+</parameter>
+</parameters>
+</enum>
+
+<enum name="PangoBaselineShift">
+<description>
+An enumeration that affects baseline shifts between runs.
+
+Since: 1.50
+
+</description>
+<parameters>
+<parameter name="PANGO_BASELINE_SHIFT_NONE">
+<parameter_description> Leave the baseline unchanged
+</parameter_description>
+</parameter>
+<parameter name="PANGO_BASELINE_SHIFT_SUPERSCRIPT">
+<parameter_description> Shift the baseline to the superscript position,
+relative to the previous run
+</parameter_description>
+</parameter>
+<parameter name="PANGO_BASELINE_SHIFT_SUBSCRIPT">
+<parameter_description> Shift the baseline to the subscript position,
+relative to the previous run
 </parameter_description>
 </parameter>
 </parameters>
@@ -162,9 +216,11 @@ attribute is listed in parentheses after the description.
 
 <enum name="PangoBidiType">
 <description>
-The #PangoBidiType type represents the bidirectional character
-type of a Unicode character as specified by the
-&lt;ulink url=&quot;http://www.unicode.org/reports/tr9/&quot;&gt;Unicode bidirectional 
algorithm&lt;/ulink&gt;.
+`PangoBidiType` represents the bidirectional character
+type of a Unicode character.
+
+The values in this enumeration are specified by the
+[Unicode bidirectional algorithm](http://www.unicode.org/reports/tr9/).
 
 Since: 1.22
 Deprecated: 1.44: Use fribidi for this information
@@ -247,13 +303,29 @@ Deprecated: 1.44: Use fribidi for this information
 <parameter_description> Other Neutrals
 </parameter_description>
 </parameter>
+<parameter name="PANGO_BIDI_TYPE_LRI">
+<parameter_description> Left-to-Right isolate. Since 1.48.6
+</parameter_description>
+</parameter>
+<parameter name="PANGO_BIDI_TYPE_RLI">
+<parameter_description> Right-to-Left isolate. Since 1.48.6
+</parameter_description>
+</parameter>
+<parameter name="PANGO_BIDI_TYPE_FSI">
+<parameter_description> First strong isolate. Since 1.48.6
+</parameter_description>
+</parameter>
+<parameter name="PANGO_BIDI_TYPE_PDI">
+<parameter_description> Pop directional isolate. Since 1.48.6
+</parameter_description>
+</parameter>
 </parameters>
 </enum>
 
 <enum name="PangoCoverageLevel">
 <description>
-Used to indicate how well a font can represent a particular Unicode
-character point for a particular script.
+`PangoCoverageLevel` is used to indicate how well a font can
+represent a particular Unicode character for a particular script.
 
 Since 1.44, only %PANGO_COVERAGE_NONE and %PANGO_COVERAGE_EXACT
 will be returned.
@@ -261,24 +333,27 @@ will be returned.
 </description>
 <parameters>
 <parameter name="PANGO_COVERAGE_NONE">
-<parameter_description> The character is not representable with the font.
+<parameter_description> The character is not representable with
+the font.
 </parameter_description>
 </parameter>
 <parameter name="PANGO_COVERAGE_FALLBACK">
-<parameter_description> The character is represented in a way that may be
-comprehensible but is not the correct graphical form.
-For instance, a Hangul character represented as a
-a sequence of Jamos, or a Latin transliteration of a Cyrillic word.
+<parameter_description> The character is represented in a
+way that may be comprehensible but is not the correct
+graphical form. For instance, a Hangul character represented
+as a a sequence of Jamos, or a Latin transliteration of a
+Cyrillic word.
 </parameter_description>
 </parameter>
 <parameter name="PANGO_COVERAGE_APPROXIMATE">
-<parameter_description> The character is represented as basically the correct
-graphical form, but with a stylistic variant inappropriate for
-the current script.
+<parameter_description> The character is represented as
+basically the correct graphical form, but with a stylistic
+variant inappropriate for the current script.
 </parameter_description>
 </parameter>
 <parameter name="PANGO_COVERAGE_EXACT">
-<parameter_description> The character is represented as the correct graphical form.
+<parameter_description> The character is represented as the
+correct graphical form.
 </parameter_description>
 </parameter>
 </parameters>
@@ -286,25 +361,24 @@ the current script.
 
 <enum name="PangoDirection">
 <description>
-The #PangoDirection type represents a direction in the
-Unicode bidirectional algorithm; not every value in this
-enumeration makes sense for every usage of #PangoDirection;
-for example, the return value of pango_unichar_direction()
-and pango_find_base_dir() cannot be %PANGO_DIRECTION_WEAK_LTR
-or %PANGO_DIRECTION_WEAK_RTL, since every character is either
-neutral or has a strong direction; on the other hand
-%PANGO_DIRECTION_NEUTRAL doesn't make sense to pass
-to pango_itemize_with_base_dir().
-
-The %PANGO_DIRECTION_TTB_LTR, %PANGO_DIRECTION_TTB_RTL
-values come from an earlier interpretation of this
-enumeration as the writing direction of a block of
-text and are no longer used; See #PangoGravity for how
+`PangoDirection` represents a direction in the Unicode bidirectional
+algorithm.
+
+Not every value in this enumeration makes sense for every usage of
+`PangoDirection`; for example, the return value of [func@unichar_direction]
+and [func@find_base_dir] cannot be %PANGO_DIRECTION_WEAK_LTR or
+%PANGO_DIRECTION_WEAK_RTL, since every character is either neutral
+or has a strong direction; on the other hand %PANGO_DIRECTION_NEUTRAL
+doesn't make sense to pass to [func@itemize_with_base_dir].
+
+The %PANGO_DIRECTION_TTB_LTR, %PANGO_DIRECTION_TTB_RTL values come from
+an earlier interpretation of this enumeration as the writing direction
+of a block of text and are no longer used; See `PangoGravity` for how
 vertical text is handled in Pango.
 
-If you are interested in text direction, you should
-really use fribidi directly. PangoDirection is only
-retained because it is used in some public apis.
+If you are interested in text direction, you should really use fribidi
+directly. `PangoDirection` is only retained because it is used in some
+public apis.
 
 </description>
 <parameters>
@@ -343,9 +417,10 @@ same as %PANGO_DIRECTION_LTR
 
 <enum name="PangoEllipsizeMode">
 <description>
-The #PangoEllipsizeMode type describes what sort of (if any)
-ellipsization should be applied to a line of text. In
-the ellipsization process characters are removed from the
+`PangoEllipsizeMode` describes what sort of ellipsization
+should be applied to text.
+
+In the ellipsization process characters are removed from the
 text in order to make it fit to a given width and replaced
 with an ellipsis.
 
@@ -370,10 +445,24 @@ with an ellipsis.
 </parameters>
 </enum>
 
+<property name="PangoFcFont:fontmap">
+<description>
+The PangoFc font map this font is associated with.
+
+</description>
+</property>
+
+<property name="PangoFcFont:pattern">
+<description>
+The fontconfig pattern for this font.
+
+</description>
+</property>
+
 <enum name="PangoFontMask">
 <description>
-The bits in a #PangoFontMask correspond to fields in a
-#PangoFontDescription that have been set.
+The bits in a `PangoFontMask` correspond to the set fields in a
+`PangoFontDescription`.
 
 </description>
 <parameters>
@@ -412,37 +501,68 @@ The bits in a #PangoFontMask correspond to fields in a
 </parameters>
 </enum>
 
+<enum name="PangoFontScale">
+<description>
+An enumeration that affects font sizes for superscript
+and subscript positioning and for (emulated) Small Caps.
+
+Since: 1.50
+
+</description>
+<parameters>
+<parameter name="PANGO_FONT_SCALE_NONE">
+<parameter_description> Leave the font size unchanged
+</parameter_description>
+</parameter>
+<parameter name="PANGO_FONT_SCALE_SUPERSCRIPT">
+<parameter_description> Change the font to a size suitable for superscripts
+</parameter_description>
+</parameter>
+<parameter name="PANGO_FONT_SCALE_SUBSCRIPT">
+<parameter_description> Change the font to a size suitable for subscripts
+</parameter_description>
+</parameter>
+<parameter name="PANGO_FONT_SCALE_SMALL_CAPS">
+<parameter_description> Change the font to a size suitable for Small Caps. Since: 1.50
+</parameter_description>
+</parameter>
+</parameters>
+</enum>
+
 <enum name="PangoGravity">
 <description>
-The #PangoGravity type represents the orientation of glyphs in a segment
-of text.  This is useful when rendering vertical text layouts.  In
-those situations, the layout is rotated using a non-identity PangoMatrix,
-and then glyph orientation is controlled using #PangoGravity.
+`PangoGravity` represents the orientation of glyphs in a segment
+of text.
+
+This is useful when rendering vertical text layouts. In those situations,
+the layout is rotated using a non-identity [struct@Pango.Matrix], and then
+glyph orientation is controlled using `PangoGravity`.
+
 Not every value in this enumeration makes sense for every usage of
-#PangoGravity; for example, %PANGO_GRAVITY_AUTO only can be passed to
-pango_context_set_base_gravity() and can only be returned by
-pango_context_get_base_gravity().
+`PangoGravity`; for example, %PANGO_GRAVITY_AUTO only can be passed to
+[method@Pango.Context.set_base_gravity] and can only be returned by
+[method@Pango.Context.get_base_gravity].
 
-See also: #PangoGravityHint
+See also: [enum@Pango.GravityHint]
 
 Since: 1.16
 
 </description>
 <parameters>
 <parameter name="PANGO_GRAVITY_SOUTH">
-<parameter_description> Glyphs stand upright (default)
+<parameter_description> Glyphs stand upright (default) &lt;img align=&quot;right&quot; 
valign=&quot;center&quot; src=&quot;m-south.png&quot;&gt;
 </parameter_description>
 </parameter>
 <parameter name="PANGO_GRAVITY_EAST">
-<parameter_description> Glyphs are rotated 90 degrees clockwise
+<parameter_description> Glyphs are rotated 90 degrees counter-clockwise. &lt;img align=&quot;right&quot; 
valign=&quot;center&quot; src=&quot;m-east.png&quot;&gt;
 </parameter_description>
 </parameter>
 <parameter name="PANGO_GRAVITY_NORTH">
-<parameter_description> Glyphs are upside-down
+<parameter_description> Glyphs are upside-down. &lt;img align=&quot;right&quot; valign=&quot;cener&quot; 
src=&quot;m-north.png&quot;&gt;
 </parameter_description>
 </parameter>
 <parameter name="PANGO_GRAVITY_WEST">
-<parameter_description> Glyphs are rotated 90 degrees counter-clockwise
+<parameter_description> Glyphs are rotated 90 degrees clockwise. &lt;img align=&quot;right&quot; 
valign=&quot;center&quot; src=&quot;m-west.png&quot;&gt;
 </parameter_description>
 </parameter>
 <parameter name="PANGO_GRAVITY_AUTO">
@@ -454,11 +574,12 @@ Since: 1.16
 
 <enum name="PangoGravityHint">
 <description>
-The #PangoGravityHint defines how horizontal scripts should behave in a
-vertical context.  That is, English excerpt in a vertical paragraph for
-example.
+`PangoGravityHint` defines how horizontal scripts should behave in a
+vertical context.
+
+That is, English excerpts in a vertical paragraph for example.
 
-See #PangoGravity.
+See also [enum@Pango.Gravity]
 
 Since: 1.16
 
@@ -477,18 +598,84 @@ the script.
 <parameter name="PANGO_GRAVITY_HINT_LINE">
 <parameter_description> for scripts not in their natural direction (eg.
 Latin in East gravity), choose per-script gravity such that every script
-respects the line progression.  This means, Latin and Arabic will take
+respects the line progression. This means, Latin and Arabic will take
 opposite gravities and both flow top-to-bottom for example.
 </parameter_description>
 </parameter>
 </parameters>
 </enum>
 
+<enum name="PangoLayoutDeserializeError">
+<description>
+Errors that can be returned by [func@Pango.Layout.deserialize].
+
+</description>
+<parameters>
+<parameter name="PANGO_LAYOUT_DESERIALIZE_INVALID">
+<parameter_description> Unspecified error
+</parameter_description>
+</parameter>
+<parameter name="PANGO_LAYOUT_DESERIALIZE_INVALID_VALUE">
+<parameter_description> A JSon value could not be
+interpreted
+</parameter_description>
+</parameter>
+<parameter name="PANGO_LAYOUT_DESERIALIZE_MISSING_VALUE">
+<parameter_description> A required JSon member was
+not found
+</parameter_description>
+</parameter>
+</parameters>
+</enum>
+
+<enum name="PangoLayoutDeserializeFlags">
+<description>
+Flags that influence the behavior of [func@Pango.Layout.deserialize].
+
+New members may be added to this enumeration over time.
+
+</description>
+<parameters>
+<parameter name="PANGO_LAYOUT_DESERIALIZE_DEFAULT">
+<parameter_description> Default behavior
+</parameter_description>
+</parameter>
+<parameter name="PANGO_LAYOUT_DESERIALIZE_CONTEXT">
+<parameter_description> Apply context information
+from the serialization to the `PangoContext`
+</parameter_description>
+</parameter>
+</parameters>
+</enum>
+
+<enum name="PangoLayoutSerializeFlags">
+<description>
+Flags that influence the behavior of [method@Pango.Layout.serialize].
+
+New members may be added to this enumeration over time.
+
+</description>
+<parameters>
+<parameter name="PANGO_LAYOUT_SERIALIZE_DEFAULT">
+<parameter_description> Default behavior
+</parameter_description>
+</parameter>
+<parameter name="PANGO_LAYOUT_SERIALIZE_CONTEXT">
+<parameter_description> Include context information
+</parameter_description>
+</parameter>
+<parameter name="PANGO_LAYOUT_SERIALIZE_OUTPUT">
+<parameter_description> Include information about the formatted output
+</parameter_description>
+</parameter>
+</parameters>
+</enum>
+
 <enum name="PangoOTTableType">
 <description>
-The &lt;type&gt;PangoOTTableType&lt;/type&gt; enumeration values are used to
+The PangoOTTableType enumeration values are used to
 identify the various OpenType tables in the
-&lt;function&gt;pango_ot_info_*&lt;/function&gt; functions.
+pango_ot_info_… functions.
 
 </description>
 <parameters>
@@ -505,9 +692,8 @@ identify the various OpenType tables in the
 
 <enum name="PangoOverline">
 <description>
-The #PangoOverline enumeration is used to specify
-whether text should be overlined, and if so, the type
-of line.
+The `PangoOverline` enumeration is used to specify whether text
+should be overlined, and if so, the type of line.
 
 Since: 1.46
 
@@ -527,7 +713,7 @@ extents of the text being underlined.
 
 <enum name="PangoRenderPart">
 <description>
-#PangoRenderPart defines different items to render for such
+`PangoRenderPart` defines different items to render for such
 purposes as setting colors.
 
 Since: 1.8
@@ -559,16 +745,16 @@ Since: 1.8
 
 <enum name="PangoScript">
 <description>
-The #PangoScript enumeration identifies different writing
-systems. The values correspond to the names as defined in the
-Unicode standard. See &lt;ulink
-url=&quot;http://www.unicode.org/reports/tr24/&quot;&gt;Unicode Standard Annex
-#24: Script names&lt;/ulink&gt;.
+The `PangoScript` enumeration identifies different writing
+systems.
+
+The values correspond to the names as defined in the Unicode standard. See
+[Unicode Standard Annex 24: Script names](http://www.unicode.org/reports/tr24/)
 
 Note that this enumeration is deprecated and will not be updated
 to include values in newer versions of the Unicode standard.
-Applications should use the GUnicodeScript enumeration instead,
-whose values are interchangeable with PangoScript.
+Applications should use the `GUnicodeScript` enumeration instead,
+whose values are interchangeable with `PangoScript`.
 
 </description>
 <parameters>
@@ -1051,7 +1237,10 @@ base glyph to which it is attached
 <enum name="PangoShapeFlags">
 <description>
 Flags influencing the shaping process.
-These can be passed to pango_shape_with_flags().
+
+`PangoShapeFlags` can be passed to [func@Pango.shape_with_flags].
+
+Since: 1.44
 
 </description>
 <parameters>
@@ -1074,6 +1263,8 @@ positioning of glyphs.
 These flags affect how Pango treats characters that are normally
 not visible in the output.
 
+Since: 1.44
+
 </description>
 <parameters>
 <parameter name="PANGO_SHOW_NONE">
@@ -1165,12 +1356,60 @@ An enumeration specifying the various slant styles possible for a font.
 
 <enum name="PangoTabAlign">
 <description>
-A #PangoTabAlign specifies where a tab stop appears relative to the text.
+`PangoTabAlign` specifies where the text appears relative to the tab stop
+position.
+
+Support for tab alignments other than %PANGO_TAB_LEFT was added
+in Pango 1.50.
 
 </description>
 <parameters>
 <parameter name="PANGO_TAB_LEFT">
-<parameter_description> the tab stop appears to the left of the text.
+<parameter_description> the text appears to the right of the tab stop position
+</parameter_description>
+</parameter>
+<parameter name="PANGO_TAB_RIGHT">
+<parameter_description> the text appears to the left of the tab stop position
+until the available space is filled
+</parameter_description>
+</parameter>
+<parameter name="PANGO_TAB_CENTER">
+<parameter_description> the text is centered at the tab stop position
+until the available space is filled
+</parameter_description>
+</parameter>
+<parameter name="PANGO_TAB_DECIMAL">
+<parameter_description> text before the first '.' appears to the left of the
+tab stop position (until the available space is filled), the rest to
+the right
+</parameter_description>
+</parameter>
+</parameters>
+</enum>
+
+<enum name="PangoTextTransform">
+<description>
+An enumeration that affects how Pango treats characters during shaping.
+
+Since: 1.50
+
+</description>
+<parameters>
+<parameter name="PANGO_TEXT_TRANSFORM_NONE">
+<parameter_description> Leave text unchanged
+</parameter_description>
+</parameter>
+<parameter name="PANGO_TEXT_TRANSFORM_LOWERCASE">
+<parameter_description> Display letters and numbers as lowercase
+</parameter_description>
+</parameter>
+<parameter name="PANGO_TEXT_TRANSFORM_UPPERCASE">
+<parameter_description> Display letters and numbers as uppercase
+</parameter_description>
+</parameter>
+<parameter name="PANGO_TEXT_TRANSFORM_CAPITALIZE">
+<parameter_description> Display the first character of a word
+in titlecase
 </parameter_description>
 </parameter>
 </parameters>
@@ -1178,9 +1417,8 @@ A #PangoTabAlign specifies where a tab stop appears relative to the text.
 
 <enum name="PangoUnderline">
 <description>
-The #PangoUnderline enumeration is used to specify
-whether text should be underlined, and if so, the type
-of underlining.
+The `PangoUnderline` enumeration is used to specify whether text
+should be underlined, and if so, the type of underlining.
 
 </description>
 <parameters>
@@ -1206,7 +1444,10 @@ portions of text.
 </parameter_description>
 </parameter>
 <parameter name="PANGO_UNDERLINE_ERROR">
-<parameter_description> a wavy underline should be drawn below.
+<parameter_description> an underline indicating an error should
+be drawn below. The exact style of rendering is up to the
+`PangoRenderer` in use, but typical styles include wavy
+or dotted lines.
 This underline is typically used to indicate an error such
 as a possible mispelling; in some cases a contrasting color
 may automatically be used. This type of underlining is
@@ -1249,13 +1490,47 @@ An enumeration specifying capitalization variant of the font.
 replaced by smaller variants of the capital characters.
 </parameter_description>
 </parameter>
+<parameter name="PANGO_VARIANT_ALL_SMALL_CAPS">
+<parameter_description> A font with all characters
+replaced by smaller variants of the capital characters.
+Since: 1.50
+</parameter_description>
+</parameter>
+<parameter name="PANGO_VARIANT_PETITE_CAPS">
+<parameter_description> A font with the lower case characters
+replaced by smaller variants of the capital characters.
+Petite Caps can be even smaller than Small Caps.
+Since: 1.50
+</parameter_description>
+</parameter>
+<parameter name="PANGO_VARIANT_ALL_PETITE_CAPS">
+<parameter_description> A font with all characters
+replaced by smaller variants of the capital characters.
+Petite Caps can be even smaller than Small Caps.
+Since: 1.50
+</parameter_description>
+</parameter>
+<parameter name="PANGO_VARIANT_UNICASE">
+<parameter_description> A font with the upper case characters
+replaced by smaller variants of the capital letters.
+Since: 1.50
+</parameter_description>
+</parameter>
+<parameter name="PANGO_VARIANT_TITLE_CAPS">
+<parameter_description> A font with capital letters that
+are more suitable for all-uppercase titles.
+Since: 1.50
+</parameter_description>
+</parameter>
 </parameters>
 </enum>
 
 <enum name="PangoWeight">
 <description>
-An enumeration specifying the weight (boldness) of a font. This is a numerical
-value ranging from 100 to 1000, but there are some predefined values:
+An enumeration specifying the weight (boldness) of a font.
+
+This is a numerical value ranging from 100 to 1000, but there
+are some predefined values.
 
 </description>
 <parameters>
@@ -1312,7 +1587,13 @@ value ranging from 100 to 1000, but there are some predefined values:
 
 <enum name="PangoWrapMode">
 <description>
-A #PangoWrapMode describes how to wrap the lines of a #PangoLayout to the desired width.
+`PangoWrapMode` describes how to wrap the lines of a `PangoLayout`
+to the desired width.
+
+For @PANGO_WRAP_WORD, Pango uses break opportunities that are determined
+by the Unicode line breaking algorithm. For @PANGO_WRAP_CHAR, Pango allows
+breaking at grapheme boundaries that are determined by the Unicode text
+segmentation algorithm.
 
 </description>
 <parameters>
@@ -1325,8 +1606,8 @@ A #PangoWrapMode describes how to wrap the lines of a #PangoLayout to the desire
 </parameter_description>
 </parameter>
 <parameter name="PANGO_WRAP_WORD_CHAR">
-<parameter_description> wrap lines at word boundaries, but fall back to character boundaries if there is not
-enough space for a full word.
+<parameter_description> wrap lines at word boundaries, but fall back to
+character boundaries if there is not enough space for a full word.
 </parameter_description>
 </parameter>
 </parameters>
@@ -1348,8 +1629,9 @@ Since: 1.44
 </parameter_description>
 </parameter>
 </parameters>
-<return> the newly allocated #PangoAttribute,
-which should be freed with pango_attribute_destroy()
+<return> the newly allocated
+`PangoAttribute`, which should be freed with
+[method@Pango.Attribute.destroy]
 
 </return>
 </function>
@@ -1367,8 +1649,9 @@ Since: 1.38
 </parameter_description>
 </parameter>
 </parameters>
-<return> the new allocated #PangoAttribute,
-which should be freed with pango_attribute_destroy().
+<return> the newly allocated
+`PangoAttribute`, which should be freed with
+[method@Pango.Attribute.destroy]
 
 </return>
 </function>
@@ -1393,19 +1676,90 @@ Create a new background color attribute.
 </parameter_description>
 </parameter>
 </parameters>
-<return> the newly allocated #PangoAttribute,
-which should be freed with pango_attribute_destroy().
+<return> the newly allocated
+`PangoAttribute`, which should be freed with
+[method@Pango.Attribute.destroy]
+</return>
+</function>
+
+<function name="pango_attr_baseline_shift_new">
+<description>
+Create a new baseline displacement attribute.
+
+The effect of this attribute is to shift the baseline of a run,
+relative to the run of preceding run.
+
+&lt;picture&gt;
+&lt;source srcset=&quot;baseline-shift-dark.png&quot; media=&quot;(prefers-color-scheme: dark)&quot;&gt;
+&lt;img alt=&quot;Baseline Shift&quot; src=&quot;baseline-shift-light.png&quot;&gt;
+&lt;/picture&gt;
+
+Since: 1.50
+
+</description>
+<parameters>
+<parameter name="shift">
+<parameter_description> either a `PangoBaselineShift` enumeration value or an absolute value (&gt; 1024)
+in Pango units, relative to the baseline of the previous run.
+Positive values displace the text upwards.
+</parameter_description>
+</parameter>
+</parameters>
+<return> the newly allocated
+`PangoAttribute`, which should be freed with
+[method@Pango.Attribute.destroy]
+
 </return>
 </function>
 
+<function name="pango_attr_break">
+<description>
+Apply customization from attributes to the breaks in @attrs.
+
+The line breaks are assumed to have been produced
+by [func@Pango.default_break] and [func@Pango.tailor_break].
+
+Since: 1.50
+
+</description>
+<parameters>
+<parameter name="text">
+<parameter_description> text to break. Must be valid UTF-8
+</parameter_description>
+</parameter>
+<parameter name="length">
+<parameter_description> length of text in bytes (may be -1 if @text is nul-terminated)
+</parameter_description>
+</parameter>
+<parameter name="attr_list">
+<parameter_description> `PangoAttrList` to apply
+</parameter_description>
+</parameter>
+<parameter name="offset">
+<parameter_description> Byte offset of @text from the beginning of the paragraph
+</parameter_description>
+</parameter>
+<parameter name="attrs">
+<parameter_description> array with one `PangoLogAttr`
+per character in @text, plus one extra, to be filled in
+</parameter_description>
+</parameter>
+<parameter name="attrs_len">
+<parameter_description> length of @attrs array
+</parameter_description>
+</parameter>
+</parameters>
+<return></return>
+</function>
+
 <function name="pango_attr_fallback_new">
 <description>
 Create a new font fallback attribute.
 
-If fallback is disabled, characters will only be used from the
-closest matching font on the system. No fallback will be done to
-other fonts on the system that might contain the characters in the
-text.
+If fallback is disabled, characters will only be
+used from the closest matching font on the system.
+No fallback will be done to other fonts on the system
+that might contain the characters in the text.
 
 Since: 1.4
 
@@ -1413,12 +1767,13 @@ Since: 1.4
 <parameters>
 <parameter name="enable_fallback">
 <parameter_description> %TRUE if we should fall back on other fonts
-for characters the active font is missing.
+for characters the active font is missing
 </parameter_description>
 </parameter>
 </parameters>
-<return> the newly allocated #PangoAttribute,
-which should be freed with pango_attribute_destroy().
+<return> the newly allocated
+`PangoAttribute`, which should be freed with
+[method@Pango.Attribute.destroy]
 
 </return>
 </function>
@@ -1431,20 +1786,22 @@ Create a new font family attribute.
 </description>
 <parameters>
 <parameter name="family">
-<parameter_description> the family or comma separated list of families
+<parameter_description> the family or comma-separated list of families
 </parameter_description>
 </parameter>
 </parameters>
-<return> the newly allocated #PangoAttribute,
-which should be freed with pango_attribute_destroy().
+<return> the newly allocated
+`PangoAttribute`, which should be freed with
+[method@Pango.Attribute.destroy]
 </return>
 </function>
 
 <function name="pango_attr_font_desc_new">
 <description>
-Create a new font description attribute. This attribute
-allows setting family, style, weight, variant, stretch,
-and size simultaneously.
+Create a new font description attribute.
+
+This attribute allows setting family, style, weight, variant,
+stretch, and size simultaneously.
 
 
 </description>
@@ -1454,8 +1811,9 @@ and size simultaneously.
 </parameter_description>
 </parameter>
 </parameters>
-<return> the newly allocated #PangoAttribute,
-which should be freed with pango_attribute_destroy().
+<return> the newly allocated
+`PangoAttribute`, which should be freed with
+[method@Pango.Attribute.destroy]
 </return>
 </function>
 
@@ -1463,17 +1821,46 @@ which should be freed with pango_attribute_destroy().
 <description>
 Create a new font features tag attribute.
 
+You can use this attribute to select OpenType font features like small-caps,
+alternative glyphs, ligatures, etc. for fonts that support them.
+
 Since: 1.38
 
 </description>
 <parameters>
 <parameter name="features">
-<parameter_description> a string with OpenType font features, in CSS syntax
+<parameter_description> a string with OpenType font features, with the syntax of the [CSS
+font-feature-settings property](https://www.w3.org/TR/css-fonts-4/#font-rend-desc)
+</parameter_description>
+</parameter>
+</parameters>
+<return> the newly allocated
+`PangoAttribute`, which should be freed with
+[method@Pango.Attribute.destroy]
+
+</return>
+</function>
+
+<function name="pango_attr_font_scale_new">
+<description>
+Create a new font scale attribute.
+
+The effect of this attribute is to change the font size of a run,
+relative to the size of preceding run.
+
+Since: 1.50
+
+</description>
+<parameters>
+<parameter name="scale">
+<parameter_description> a `PangoFontScale` value, which indicates font size change relative
+to the size of the previous run.
 </parameter_description>
 </parameter>
 </parameters>
-<return> the newly allocated #PangoAttribute,
-which should be freed with pango_attribute_destroy().
+<return> the newly allocated
+`PangoAttribute`, which should be freed with
+[method@Pango.Attribute.destroy]
 
 </return>
 </function>
@@ -1491,8 +1878,9 @@ Since: 1.38
 </parameter_description>
 </parameter>
 </parameters>
-<return> the new allocated #PangoAttribute,
-which should be freed with pango_attribute_destroy().
+<return> the newly allocated
+`PangoAttribute`, which should be freed with
+[method@Pango.Attribute.destroy]
 
 </return>
 </function>
@@ -1517,8 +1905,9 @@ Create a new foreground color attribute.
 </parameter_description>
 </parameter>
 </parameters>
-<return> the newly allocated #PangoAttribute,
-which should be freed with pango_attribute_destroy().
+<return> the newly allocated
+`PangoAttribute`, which should be freed with
+[method@Pango.Attribute.destroy]
 </return>
 </function>
 
@@ -1531,12 +1920,13 @@ Since: 1.16
 </description>
 <parameters>
 <parameter name="hint">
-<parameter_description> the gravity hint value.
+<parameter_description> the gravity hint value
 </parameter_description>
 </parameter>
 </parameters>
-<return> the newly allocated #PangoAttribute,
-which should be freed with pango_attribute_destroy().
+<return> the newly allocated
+`PangoAttribute`, which should be freed with
+[method@Pango.Attribute.destroy]
 
 </return>
 </function>
@@ -1550,12 +1940,13 @@ Since: 1.16
 </description>
 <parameters>
 <parameter name="gravity">
-<parameter_description> the gravity value; should not be %PANGO_GRAVITY_AUTO.
+<parameter_description> the gravity value; should not be %PANGO_GRAVITY_AUTO
 </parameter_description>
 </parameter>
 </parameters>
-<return> the newly allocated #PangoAttribute,
-which should be freed with pango_attribute_destroy().
+<return> the newly allocated
+`PangoAttribute`, which should be freed with
+[method@Pango.Attribute.destroy]
 
 </return>
 </function>
@@ -1564,8 +1955,9 @@ which should be freed with pango_attribute_destroy().
 <description>
 Create a new insert-hyphens attribute.
 
-Pango will insert hyphens when breaking lines in the middle
-of a word. This attribute can be used to suppress the hyphen.
+Pango will insert hyphens when breaking lines in
+the middle of a word. This attribute can be used
+to suppress the hyphen.
 
 Since: 1.44
 
@@ -1576,38 +1968,39 @@ Since: 1.44
 </parameter_description>
 </parameter>
 </parameters>
-<return> the newly allocated #PangoAttribute,
-which should be freed with pango_attribute_destroy()
+<return> the newly allocated
+`PangoAttribute`, which should be freed with
+[method@Pango.Attribute.destroy]
 
 </return>
 </function>
 
 <function name="pango_attr_iterator_copy">
 <description>
-Copy a #PangoAttrIterator
+Copy a `PangoAttrIterator`.
 
 
 </description>
 <parameters>
 <parameter name="iterator">
-<parameter_description> a #PangoAttrIterator.
+<parameter_description> a `PangoAttrIterator`
 </parameter_description>
 </parameter>
 </parameters>
 <return> the newly allocated
-#PangoAttrIterator, which should be freed with
-pango_attr_iterator_destroy().
+`PangoAttrIterator`, which should be freed with
+[method@Pango.AttrIterator.destroy]
 </return>
 </function>
 
 <function name="pango_attr_iterator_destroy">
 <description>
-Destroy a #PangoAttrIterator and free all associated memory.
+Destroy a `PangoAttrIterator` and free all associated memory.
 
 </description>
 <parameters>
 <parameter name="iterator">
-<parameter_description> a #PangoAttrIterator.
+<parameter_description> a `PangoAttrIterator`
 </parameter_description>
 </parameter>
 </parameters>
@@ -1616,26 +2009,28 @@ Destroy a #PangoAttrIterator and free all associated memory.
 
 <function name="pango_attr_iterator_get">
 <description>
-Find the current attribute of a particular type at the iterator
-location. When multiple attributes of the same type overlap,
-the attribute whose range starts closest to the current location
-is used.
+Find the current attribute of a particular type
+at the iterator location.
+
+When multiple attributes of the same type overlap,
+the attribute whose range starts closest to the
+current location is used.
 
 
 </description>
 <parameters>
 <parameter name="iterator">
-<parameter_description> a #PangoAttrIterator
+<parameter_description> a `PangoAttrIterator`
 </parameter_description>
 </parameter>
 <parameter name="type">
-<parameter_description> the type of attribute to find.
+<parameter_description> the type of attribute to find
 </parameter_description>
 </parameter>
 </parameters>
-<return> the current attribute of the given type,
-or %NULL if no attribute of that type applies to the
-current location.
+<return> the current
+attribute of the given type, or %NULL if no attribute
+of that type applies to the current location.
 </return>
 </function>
 
@@ -1649,49 +2044,51 @@ Since: 1.2
 </description>
 <parameters>
 <parameter name="iterator">
-<parameter_description> a #PangoAttrIterator
+<parameter_description> a `PangoAttrIterator`
 </parameter_description>
 </parameter>
 </parameters>
-<return> a list of
-all attributes for the current range.
-To free this value, call pango_attribute_destroy() on
-each value and g_slist_free() on the list.
+<return>
+a list of all attributes for the current range. To free
+this value, call [method@Pango.Attribute.destroy] on each
+value and g_slist_free() on the list.
 
 </return>
 </function>
 
 <function name="pango_attr_iterator_get_font">
 <description>
-Get the font and other attributes at the current iterator position.
+Get the font and other attributes at the current
+iterator position.
 
 </description>
 <parameters>
 <parameter name="iterator">
-<parameter_description> a #PangoAttrIterator
+<parameter_description> a `PangoAttrIterator`
 </parameter_description>
 </parameter>
 <parameter name="desc">
-<parameter_description> a #PangoFontDescription to fill in with the current values.
-The family name in this structure will be set using
-pango_font_description_set_family_static() using values from
-an attribute in the #PangoAttrList associated with the iterator,
-so if you plan to keep it around, you must call:
-&lt;literal&gt;pango_font_description_set_family (desc, pango_font_description_get_family 
(desc))&lt;/literal&gt;.
+<parameter_description> a `PangoFontDescription` to fill in with the current
+values. The family name in this structure will be set using
+[method@Pango.FontDescription.set_family_static] using
+values from an attribute in the `PangoAttrList` associated
+with the iterator, so if you plan to keep it around, you
+must call:
+`pango_font_description_set_family (desc, pango_font_description_get_family (desc))`.
 </parameter_description>
 </parameter>
 <parameter name="language">
-<parameter_description> if non-%NULL, location to store language tag for item, or %NULL
-if none is found.
+<parameter_description> location to store language tag
+for item, or %NULL if none is found.
 </parameter_description>
 </parameter>
 <parameter name="extra_attrs">
-<parameter_description> if non-%NULL,
-location in which to store a list of non-font
-attributes at the the current position; only the highest priority
-value of each attribute will be added to this list. In order
-to free this value, you must call pango_attribute_destroy() on
-each member.
+<parameter_description>
+location in which to store a list of non-font attributes
+at the the current position; only the highest priority
+value of each attribute will be added to this list. In
+order to free this value, you must call
+[method@Pango.Attribute.destroy] on each member.
 </parameter_description>
 </parameter>
 </parameters>
@@ -1706,26 +2103,28 @@ Advance the iterator until the next change of style.
 </description>
 <parameters>
 <parameter name="iterator">
-<parameter_description> a #PangoAttrIterator
+<parameter_description> a `PangoAttrIterator`
 </parameter_description>
 </parameter>
 </parameters>
-<return> %FALSE if the iterator is at the end of the list, otherwise %TRUE
+<return> %FALSE if the iterator is at the end
+of the list, otherwise %TRUE
 </return>
 </function>
 
 <function name="pango_attr_iterator_range">
 <description>
-Get the range of the current segment. Note that the
-stored return values are signed, not unsigned like
-the values in #PangoAttribute. To deal with this API
+Get the range of the current segment.
+
+Note that the stored return values are signed, not unsigned
+like the values in `PangoAttribute`. To deal with this API
 oversight, stored return values that wouldn't fit into
 a signed integer are clamped to %G_MAXINT.
 
 </description>
 <parameters>
 <parameter name="iterator">
-<parameter_description> a #PangoAttrIterator
+<parameter_description> a PangoAttrIterator
 </parameter_description>
 </parameter>
 <parameter name="start">
@@ -1752,8 +2151,9 @@ Create a new language tag attribute.
 </parameter_description>
 </parameter>
 </parameters>
-<return> the newly allocated #PangoAttribute,
-which should be freed with pango_attribute_destroy().
+<return> the newly allocated
+`PangoAttribute`, which should be freed with
+[method@Pango.Attribute.destroy]
 </return>
 </function>
 
@@ -1766,104 +2166,154 @@ Since: 1.6
 </description>
 <parameters>
 <parameter name="letter_spacing">
-<parameter_description> amount of extra space to add between graphemes
-of the text, in Pango units.
+<parameter_description> amount of extra space to add between
+graphemes of the text, in Pango units
 </parameter_description>
 </parameter>
 </parameters>
-<return> the newly allocated #PangoAttribute,
-which should be freed with pango_attribute_destroy().
+<return> the newly allocated
+`PangoAttribute`, which should be freed with
+[method@Pango.Attribute.destroy]
 
 </return>
 </function>
 
-<function name="pango_attr_list_change">
+<function name="pango_attr_line_height_new">
 <description>
-Insert the given attribute into the #PangoAttrList. It will
-replace any attributes of the same type on that segment
-and be merged with any adjoining attributes that are identical.
+Modify the height of logical line extents by a factor.
+
+This affects the values returned by
+[method@Pango.LayoutLine.get_extents],
+[method@Pango.LayoutLine.get_pixel_extents] and
+[method@Pango.LayoutIter.get_line_extents].
 
-This function is slower than pango_attr_list_insert() for
-creating an attribute list in order (potentially much slower
-for large lists). However, pango_attr_list_insert() is not
-suitable for continually changing a set of attributes
-since it never removes or combines existing attributes.
+
+Since: 1.50
 
 </description>
 <parameters>
-<parameter name="list">
-<parameter_description> a #PangoAttrList
-</parameter_description>
-</parameter>
-<parameter name="attr">
-<parameter_description> the attribute to insert. Ownership of this
-value is assumed by the list.
+<parameter name="factor">
+<parameter_description> the scaling factor to apply to the logical height
 </parameter_description>
 </parameter>
 </parameters>
 <return></return>
 </function>
 
-<function name="pango_attr_list_copy">
+<function name="pango_attr_line_height_new_absolute">
 <description>
-Copy @list and return an identical new list.
+Override the height of logical line extents to be @height.
 
+This affects the values returned by
+[method@Pango.LayoutLine.get_extents],
+[method@Pango.LayoutLine.get_pixel_extents] and
+[method@Pango.LayoutIter.get_line_extents].
+
+Since: 1.50
 
 </description>
 <parameters>
-<parameter name="list">
-<parameter_description> a #PangoAttrList, may be %NULL
+<parameter name="height">
+<parameter_description> the line height, in %PANGO_SCALE-ths of a point
 </parameter_description>
 </parameter>
 </parameters>
-<return> the newly allocated #PangoAttrList, with a
-reference count of one, which should
-be freed with pango_attr_list_unref().
-Returns %NULL if @list was %NULL.
-</return>
+<return></return>
 </function>
 
-<function name="pango_attr_list_equal">
+<function name="pango_attr_list_change">
 <description>
-Checks whether @list and @other_list contain the same attributes and
-whether those attributes apply to the same ranges. Beware that this
-will return wrong values if any list contains duplicates.
+Insert the given attribute into the `PangoAttrList`.
 
-Since: 1.46
+It will replace any attributes of the same type
+on that segment and be merged with any adjoining
+attributes that are identical.
+
+This function is slower than [method@Pango.AttrList.insert]
+for creating an attribute list in order (potentially
+much slower for large lists). However,
+[method@Pango.AttrList.insert] is not suitable for
+continually changing a set of attributes since it
+never removes or combines existing attributes.
 
 </description>
 <parameters>
 <parameter name="list">
-<parameter_description> a #PangoAttrList
+<parameter_description> a `PangoAttrList`
 </parameter_description>
 </parameter>
-<parameter name="other_list">
-<parameter_description> the other #PangoAttrList
+<parameter name="attr">
+<parameter_description> the attribute to insert
 </parameter_description>
 </parameter>
 </parameters>
-<return> %TRUE if the lists are equal, %FALSE if they aren't.
+<return></return>
+</function>
+
+<function name="pango_attr_list_copy">
+<description>
+Copy @list and return an identical new list.
+
+
+</description>
+<parameters>
+<parameter name="list">
+<parameter_description> a `PangoAttrList`
+</parameter_description>
+</parameter>
+</parameters>
+<return> the newly allocated
+`PangoAttrList`, with a reference count of one,
+which should be freed with [method@Pango.AttrList.unref].
+Returns %NULL if @list was %NULL.
+</return>
+</function>
+
+<function name="pango_attr_list_equal">
+<description>
+Checks whether @list and @other_list contain the same
+attributes and whether those attributes apply to the
+same ranges.
+
+Beware that this will return wrong values if any list
+contains duplicates.
+
+Since: 1.46
+
+</description>
+<parameters>
+<parameter name="list">
+<parameter_description> a `PangoAttrList`
+</parameter_description>
+</parameter>
+<parameter name="other_list">
+<parameter_description> the other `PangoAttrList`
+</parameter_description>
+</parameter>
+</parameters>
+<return> %TRUE if the lists are equal, %FALSE if
+they aren't
 
 </return>
 </function>
 
 <function name="pango_attr_list_filter">
 <description>
-Given a #PangoAttrList and callback function, removes any elements
-of @list for which @func returns %TRUE and inserts them into
-a new list.
+Given a `PangoAttrList` and callback function, removes
+any elements of @list for which @func returns %TRUE and
+inserts them into a new list.
 
 Since: 1.2
 
 </description>
 <parameters>
 <parameter name="list">
-<parameter_description> a #PangoAttrList
+<parameter_description> a `PangoAttrList`
 </parameter_description>
 </parameter>
 <parameter name="func">
-<parameter_description> callback function; returns %TRUE
-if an attribute should be filtered out.
+<parameter_description> callback function;
+returns %TRUE if an attribute should be filtered out
 </parameter_description>
 </parameter>
 <parameter name="data">
@@ -1871,9 +2321,30 @@ if an attribute should be filtered out.
 </parameter_description>
 </parameter>
 </parameters>
-<return> the new #PangoAttrList or
-%NULL if no attributes of the given types were found.
+<return> the new
+`PangoAttrList` or %NULL if no attributes of the
+given types were found
+
+</return>
+</function>
+
+<function name="pango_attr_list_from_string">
+<description>
+Deserializes a `PangoAttrList` from a string.
+
+This is the counterpart to [method@Pango.AttrList.to_string].
+See that functions for details about the format.
+
+Since: 1.50
 
+</description>
+<parameters>
+<parameter name="text">
+<parameter_description> a string
+</parameter_description>
+</parameter>
+</parameters>
+<return> a new `PangoAttrList`
 </return>
 </function>
 
@@ -1886,14 +2357,14 @@ Since: 1.44
 </description>
 <parameters>
 <parameter name="list">
-<parameter_description> a #PangoAttrList
+<parameter_description> a `PangoAttrList`
 </parameter_description>
 </parameter>
 </parameters>
 <return>
-a list of all attributes in @list. To free this value, call
-pango_attribute_destroy() on each value and g_slist_free()
-on the list.
+a list of all attributes in @list. To free this value,
+call [method@Pango.Attribute.destroy] on each value and
+g_slist_free() on the list.
 
 </return>
 </function>
@@ -1901,36 +2372,38 @@ on the list.
 <function name="pango_attr_list_get_iterator">
 <description>
 Create a iterator initialized to the beginning of the list.
+
 @list must not be modified until this iterator is freed.
 
 
 </description>
 <parameters>
 <parameter name="list">
-<parameter_description> a #PangoAttrList
+<parameter_description> a `PangoAttrList`
 </parameter_description>
 </parameter>
 </parameters>
-<return> the newly allocated #PangoAttrIterator, which should
-be freed with pango_attr_iterator_destroy().
+<return> the newly allocated
+`PangoAttrIterator`, which should be freed with
+[method@Pango.AttrIterator.destroy]
 </return>
 </function>
 
 <function name="pango_attr_list_insert">
 <description>
-Insert the given attribute into the #PangoAttrList. It will
-be inserted after all other attributes with a matching
-@start_index.
+Insert the given attribute into the `PangoAttrList`.
+
+It will be inserted after all other attributes with a
+matching @start_index.
 
 </description>
 <parameters>
 <parameter name="list">
-<parameter_description> a #PangoAttrList
+<parameter_description> a `PangoAttrList`
 </parameter_description>
 </parameter>
 <parameter name="attr">
-<parameter_description> the attribute to insert. Ownership of this
-value is assumed by the list.
+<parameter_description> the attribute to insert
 </parameter_description>
 </parameter>
 </parameters>
@@ -1939,19 +2412,19 @@ value is assumed by the list.
 
 <function name="pango_attr_list_insert_before">
 <description>
-Insert the given attribute into the #PangoAttrList. It will
-be inserted before all other attributes with a matching
-@start_index.
+Insert the given attribute into the `PangoAttrList`.
+
+It will be inserted before all other attributes with a
+matching @start_index.
 
 </description>
 <parameters>
 <parameter name="list">
-<parameter_description> a #PangoAttrList
+<parameter_description> a `PangoAttrList`
 </parameter_description>
 </parameter>
 <parameter name="attr">
-<parameter_description> the attribute to insert. Ownership of this
-value is assumed by the list.
+<parameter_description> the attribute to insert
 </parameter_description>
 </parameter>
 </parameters>
@@ -1960,27 +2433,30 @@ value is assumed by the list.
 
 <function name="pango_attr_list_new">
 <description>
-Create a new empty attribute list with a reference count of one.
+Create a new empty attribute list with a reference
+count of one.
 
 
 </description>
 <parameters>
 </parameters>
-<return> the newly allocated #PangoAttrList,
-which should be freed with pango_attr_list_unref().
+<return> the newly allocated
+`PangoAttrList`, which should be freed with
+[method@Pango.AttrList.unref]
 </return>
 </function>
 
 <function name="pango_attr_list_ref">
 <description>
-Increase the reference count of the given attribute list by one.
+Increase the reference count of the given attribute
+list by one.
 
 Since: 1.10
 
 </description>
 <parameters>
 <parameter name="list">
-<parameter_description> a #PangoAttrList, may be %NULL
+<parameter_description> a `PangoAttrList`
 </parameter_description>
 </parameter>
 </parameters>
@@ -1991,13 +2467,15 @@ Since: 1.10
 
 <function name="pango_attr_list_splice">
 <description>
-This function opens up a hole in @list, fills it in with attributes from
-the left, and then merges @other on top of the hole.
+This function opens up a hole in @list, fills it
+in with attributes from the left, and then merges
+@other on top of the hole.
 
 This operation is equivalent to stretching every attribute
 that applies at position @pos in @list by an amount @len,
-and then calling pango_attr_list_change() with a copy
-of each attribute in @other in sequence (offset in position by @pos).
+and then calling [method@Pango.AttrList.change] with a copy
+of each attribute in @other in sequence (offset in position
+by @pos).
 
 This operation proves useful for, for instance, inserting
 a pre-edit string in the middle of an edit buffer.
@@ -2005,11 +2483,11 @@ a pre-edit string in the middle of an edit buffer.
 </description>
 <parameters>
 <parameter name="list">
-<parameter_description> a #PangoAttrList
+<parameter_description> a `PangoAttrList`
 </parameter_description>
 </parameter>
 <parameter name="other">
-<parameter_description> another #PangoAttrList
+<parameter_description> another `PangoAttrList`
 </parameter_description>
 </parameter>
 <parameter name="pos">
@@ -2018,24 +2496,50 @@ a pre-edit string in the middle of an edit buffer.
 </parameter>
 <parameter name="len">
 <parameter_description> the length of the spliced segment. (Note that this
-must be specified since the attributes in @other
-may only be present at some subsection of this range)
+must be specified since the attributes in @other may only
+be present at some subsection of this range)
 </parameter_description>
 </parameter>
 </parameters>
 <return></return>
 </function>
 
+<function name="pango_attr_list_to_string">
+<description>
+Serializes a `PangoAttrList` to a string.
+
+No guarantees are made about the format of the string,
+it may change between Pango versions.
+
+The intended use of this function is testing and
+debugging. The format is not meant as a permanent
+storage format.
+
+Since: 1.50
+
+</description>
+<parameters>
+<parameter name="list">
+<parameter_description> a `PangoAttrList`
+</parameter_description>
+</parameter>
+</parameters>
+<return> a newly allocated string
+</return>
+</function>
+
 <function name="pango_attr_list_unref">
 <description>
-Decrease the reference count of the given attribute list by one.
-If the result is zero, free the attribute list and the attributes
-it contains.
+Decrease the reference count of the given attribute
+list by one.
+
+If the result is zero, free the attribute list
+and the attributes it contains.
 
 </description>
 <parameters>
 <parameter name="list">
-<parameter_description> a #PangoAttrList, may be %NULL
+<parameter_description> a `PangoAttrList`
 </parameter_description>
 </parameter>
 </parameters>
@@ -2044,29 +2548,27 @@ it contains.
 
 <function name="pango_attr_list_update">
 <description>
-Update indices of attributes in @list for
-a change in the text they refer to.
+Update indices of attributes in @list for a change in the
+text they refer to.
 
-The change that this function applies is
-removing @remove bytes at position @pos
-and inserting @add bytes instead.
+The change that this function applies is removing @remove
+bytes at position @pos and inserting @add bytes instead.
 
-Attributes that fall entirely in the
-(@pos, @pos + @remove) range are removed.
+Attributes that fall entirely in the (@pos, @pos + @remove)
+range are removed.
 
-Attributes that start or end inside the
-(@pos, @pos + @remove) range are shortened to
-reflect the removal.
+Attributes that start or end inside the (@pos, @pos + @remove)
+range are shortened to reflect the removal.
 
-Attributes start and end positions are updated
-if they are behind @pos + @remove.
+Attributes start and end positions are updated if they are
+behind @pos + @remove.
 
 Since: 1.44
 
 </description>
 <parameters>
 <parameter name="list">
-<parameter_description> a #PangoAttrList
+<parameter_description> a `PangoAttrList`
 </parameter_description>
 </parameter>
 <parameter name="pos">
@@ -2087,9 +2589,10 @@ Since: 1.44
 
 <function name="pango_attr_overline_color_new">
 <description>
-Create a new overline color attribute. This attribute
-modifies the color of overlines. If not set, overlines
-will use the foreground color.
+Create a new overline color attribute.
+
+This attribute modifies the color of overlines.
+If not set, overlines will use the foreground color.
 
 Since: 1.46
 
@@ -2108,8 +2611,9 @@ Since: 1.46
 </parameter_description>
 </parameter>
 </parameters>
-<return> the newly allocated #PangoAttribute,
-which should be freed with pango_attribute_destroy().
+<return> the newly allocated
+`PangoAttribute`, which should be freed with
+[method@Pango.Attribute.destroy]
 
 </return>
 </function>
@@ -2127,8 +2631,9 @@ Since: 1.46
 </parameter_description>
 </parameter>
 </parameters>
-<return> the newly allocated #PangoAttribute,
-which should be freed with pango_attribute_destroy().
+<return> the newly allocated
+`PangoAttribute`, which should be freed with
+[method@Pango.Attribute.destroy]
 
 </return>
 </function>
@@ -2146,15 +2651,18 @@ in Pango units. Positive values displace the text upwards.
 </parameter_description>
 </parameter>
 </parameters>
-<return> the newly allocated #PangoAttribute,
-which should be freed with pango_attribute_destroy().
+<return> the newly allocated
+`PangoAttribute`, which should be freed with
+[method@Pango.Attribute.destroy]
 </return>
 </function>
 
 <function name="pango_attr_scale_new">
 <description>
-Create a new font size scale attribute. The base font for the
-affected text will have its size multiplied by @scale_factor.
+Create a new font size scale attribute.
+
+The base font for the affected text will have
+its size multiplied by @scale_factor.
 
 
 </description>
@@ -2164,23 +2672,45 @@ affected text will have its size multiplied by @scale_factor.
 </parameter_description>
 </parameter>
 </parameters>
-<return> the newly allocated #PangoAttribute,
-which should be freed with pango_attribute_destroy().
+<return> the newly allocated
+`PangoAttribute`, which should be freed with
+[method@Pango.Attribute.destroy]
+</return>
+</function>
+
+<function name="pango_attr_sentence_new">
+<description>
+Marks the range of the attribute as a single sentence.
+
+Note that this may require adjustments to word and
+sentence classification around the range.
+
+Since: 1.50
+
+</description>
+<parameters>
+</parameters>
+<return> the newly allocated
+`PangoAttribute`, which should be freed with
+[method@Pango.Attribute.destroy]
+
 </return>
 </function>
 
 <function name="pango_attr_shape_new">
 <description>
-Create a new shape attribute. A shape is used to impose a
-particular ink and logical rectangle on the result of shaping a
-particular glyph. This might be used, for instance, for
-embedding a picture or a widget inside a #PangoLayout.
+Create a new shape attribute.
+
+A shape is used to impose a particular ink and logical
+rectangle on the result of shaping a particular glyph.
+This might be used, for instance, for embedding a picture
+or a widget inside a `PangoLayout`.
 
 
 </description>
 <parameters>
 <parameter name="ink_rect">
-<parameter_description>     ink rectangle to assign to each character
+<parameter_description> ink rectangle to assign to each character
 </parameter_description>
 </parameter>
 <parameter name="logical_rect">
@@ -2188,15 +2718,18 @@ embedding a picture or a widget inside a #PangoLayout.
 </parameter_description>
 </parameter>
 </parameters>
-<return> the newly allocated #PangoAttribute,
-which should be freed with pango_attribute_destroy().
+<return> the newly allocated
+`PangoAttribute`, which should be freed with
+[method@Pango.Attribute.destroy]
 </return>
 </function>
 
 <function name="pango_attr_shape_new_with_data">
 <description>
-Like pango_attr_shape_new(), but a user data pointer is also
-provided; this pointer can be accessed when later
+Creates a new shape attribute.
+
+Like [func Pango AttrShape new], but a user data pointer
+is also provided; this pointer can be accessed when later
 rendering the glyph.
 
 Since: 1.8
@@ -2204,7 +2737,7 @@ Since: 1.8
 </description>
 <parameters>
 <parameter name="ink_rect">
-<parameter_description>     ink rectangle to assign to each character
+<parameter_description> ink rectangle to assign to each character
 </parameter_description>
 </parameter>
 <parameter name="logical_rect">
@@ -2212,23 +2745,24 @@ Since: 1.8
 </parameter_description>
 </parameter>
 <parameter name="data">
-<parameter_description>         user data pointer
+<parameter_description> user data pointer
 </parameter_description>
 </parameter>
 <parameter name="copy_func">
 <parameter_description> function to copy @data when the
-attribute is copied. If %NULL, @data is simply
-copied as a pointer.
+attribute is copied. If %NULL, @data is simply copied
+as a pointer
 </parameter_description>
 </parameter>
 <parameter name="destroy_func">
 <parameter_description> function to free @data when the
-attribute is freed, or %NULL
+attribute is freed
 </parameter_description>
 </parameter>
 </parameters>
-<return> the newly allocated #PangoAttribute, which should be
-freed with pango_attribute_destroy().
+<return> the newly allocated
+`PangoAttribute`, which should be freed with
+[method@Pango.Attribute.destroy]
 
 </return>
 </function>
@@ -2243,12 +2777,13 @@ Since: 1.44
 </description>
 <parameters>
 <parameter name="flags">
-<parameter_description> #PangoShowFlags to apply
+<parameter_description> `PangoShowFlags` to apply
 </parameter_description>
 </parameter>
 </parameters>
-<return> the newly allocated #PangoAttribute,
-which should be freed with pango_attribute_destroy().
+<return> the newly allocated
+`PangoAttribute`, which should be freed with
+[method@Pango.Attribute.destroy]
 
 </return>
 </function>
@@ -2261,12 +2796,13 @@ Create a new font-size attribute in fractional points.
 </description>
 <parameters>
 <parameter name="size">
-<parameter_description> the font size, in %PANGO_SCALEths of a point.
+<parameter_description> the font size, in %PANGO_SCALE-ths of a point
 </parameter_description>
 </parameter>
 </parameters>
-<return> the newly allocated #PangoAttribute,
-which should be freed with pango_attribute_destroy().
+<return> the newly allocated
+`PangoAttribute`, which should be freed with
+[method@Pango.Attribute.destroy]
 </return>
 </function>
 
@@ -2279,19 +2815,20 @@ Since: 1.8
 </description>
 <parameters>
 <parameter name="size">
-<parameter_description> the font size, in %PANGO_SCALEths of a device unit.
+<parameter_description> the font size, in %PANGO_SCALE-ths of a device unit
 </parameter_description>
 </parameter>
 </parameters>
-<return> the newly allocated #PangoAttribute, which should be
-freed with pango_attribute_destroy().
+<return> the newly allocated
+`PangoAttribute`, which should be freed with
+[method@Pango.Attribute.destroy]
 
 </return>
 </function>
 
 <function name="pango_attr_stretch_new">
 <description>
-Create a new font stretch attribute
+Create a new font stretch attribute.
 
 
 </description>
@@ -2301,16 +2838,18 @@ Create a new font stretch attribute
 </parameter_description>
 </parameter>
 </parameters>
-<return> the newly allocated #PangoAttribute,
-which should be freed with pango_attribute_destroy().
+<return> the newly allocated
+`PangoAttribute`, which should be freed with
+[method@Pango.Attribute.destroy]
 </return>
 </function>
 
 <function name="pango_attr_strikethrough_color_new">
 <description>
-Create a new strikethrough color attribute. This attribute
-modifies the color of strikethrough lines. If not set, strikethrough
-lines will use the foreground color.
+Create a new strikethrough color attribute.
+
+This attribute modifies the color of strikethrough lines.
+If not set, strikethrough lines will use the foreground color.
 
 Since: 1.8
 
@@ -2329,8 +2868,9 @@ Since: 1.8
 </parameter_description>
 </parameter>
 </parameters>
-<return> the newly allocated #PangoAttribute,
-which should be freed with pango_attribute_destroy().
+<return> the newly allocated
+`PangoAttribute`, which should be freed with
+[method@Pango.Attribute.destroy]
 
 </return>
 </function>
@@ -2343,12 +2883,13 @@ Create a new strike-through attribute.
 </description>
 <parameters>
 <parameter name="strikethrough">
-<parameter_description> %TRUE if the text should be struck-through.
+<parameter_description> %TRUE if the text should be struck-through
 </parameter_description>
 </parameter>
 </parameters>
-<return> the newly allocated #PangoAttribute,
-which should be freed with pango_attribute_destroy().
+<return> the newly allocated
+`PangoAttribute`, which should be freed with
+[method@Pango.Attribute.destroy]
 </return>
 </function>
 
@@ -2364,18 +2905,44 @@ Create a new font slant style attribute.
 </parameter_description>
 </parameter>
 </parameters>
-<return> the newly allocated #PangoAttribute,
-which should be freed with pango_attribute_destroy().
+<return> the newly allocated
+`PangoAttribute`, which should be freed with
+[method@Pango.Attribute.destroy]
+</return>
+</function>
+
+<function name="pango_attr_text_transform_new">
+<description>
+Create a new attribute that influences how characters
+are transformed during shaping.
+
+Since: 1.50
+
+</description>
+<parameters>
+<parameter name="transform">
+<parameter_description> `PangoTextTransform` to apply
+</parameter_description>
+</parameter>
+</parameters>
+<return> the newly allocated
+`PangoAttribute`, which should be freed with
+[method@Pango.Attribute.destroy]
+
 </return>
 </function>
 
 <function name="pango_attr_type_get_name">
 <description>
-Fetches the attribute type name passed in when registering the type using
-pango_attr_type_register().
+Fetches the attribute type name.
 
-The returned value is an interned string (see g_intern_string() for what
-that means) that should not be modified or freed.
+The attribute type name is the string passed in
+when registering the type using
+[func@Pango.AttrType.register].
+
+The returned value is an interned string (see
+g_intern_string() for what that means) that should
+not be modified or freed.
 
 Since: 1.22
 
@@ -2386,16 +2953,19 @@ Since: 1.22
 </parameter_description>
 </parameter>
 </parameters>
-<return> the type ID name (which may be %NULL), or
-%NULL if @type is a built-in Pango attribute type or invalid.
+<return> the type ID name (which
+may be %NULL), or %NULL if @type is a built-in Pango
+attribute type or invalid.
 
 </return>
 </function>
 
 <function name="pango_attr_type_register">
 <description>
-Allocate a new attribute type ID.  The attribute type name can be accessed
-later by using pango_attr_type_get_name().
+Allocate a new attribute type ID.
+
+The attribute type name can be accessed later
+by using [func@Pango.AttrType.get_name].
 
 
 </description>
@@ -2411,9 +2981,10 @@ later by using pango_attr_type_get_name().
 
 <function name="pango_attr_underline_color_new">
 <description>
-Create a new underline color attribute. This attribute
-modifies the color of underlines. If not set, underlines
-will use the foreground color.
+Create a new underline color attribute.
+
+This attribute modifies the color of underlines.
+If not set, underlines will use the foreground color.
 
 Since: 1.8
 
@@ -2432,8 +3003,9 @@ Since: 1.8
 </parameter_description>
 </parameter>
 </parameters>
-<return> the newly allocated #PangoAttribute,
-which should be freed with pango_attribute_destroy().
+<return> the newly allocated
+`PangoAttribute`, which should be freed with
+[method@Pango.Attribute.destroy]
 
 </return>
 </function>
@@ -2446,18 +3018,19 @@ Create a new underline-style attribute.
 </description>
 <parameters>
 <parameter name="underline">
-<parameter_description> the underline style.
+<parameter_description> the underline style
 </parameter_description>
 </parameter>
 </parameters>
-<return> the newly allocated #PangoAttribute,
-which should be freed with pango_attribute_destroy().
+<return> the newly allocated
+`PangoAttribute`, which should be freed with
+[method@Pango.Attribute.destroy]
 </return>
 </function>
 
 <function name="pango_attr_variant_new">
 <description>
-Create a new font variant attribute (normal or small caps)
+Create a new font variant attribute (normal or small caps).
 
 
 </description>
@@ -2467,8 +3040,8 @@ Create a new font variant attribute (normal or small caps)
 </parameter_description>
 </parameter>
 </parameters>
-<return> the newly allocated #PangoAttribute,
-which should be freed with pango_attribute_destroy().
+<return> the newly allocated `PangoAttribute`,
+which should be freed with [method@Pango.Attribute.destroy].
 </return>
 </function>
 
@@ -2484,8 +3057,217 @@ Create a new font weight attribute.
 </parameter_description>
 </parameter>
 </parameters>
-<return> the newly allocated #PangoAttribute,
-which should be freed with pango_attribute_destroy().
+<return> the newly allocated
+`PangoAttribute`, which should be freed with
+[method@Pango.Attribute.destroy]
+</return>
+</function>
+
+<function name="pango_attr_word_new">
+<description>
+Marks the range of the attribute as a single word.
+
+Note that this may require adjustments to word and
+sentence classification around the range.
+
+Since: 1.50
+
+</description>
+<parameters>
+</parameters>
+<return> the newly allocated
+`PangoAttribute`, which should be freed with
+[method@Pango.Attribute.destroy]
+
+</return>
+</function>
+
+<function name="pango_attribute_as_color">
+<description>
+Returns the attribute cast to `PangoAttrColor`.
+
+This is mainly useful for language bindings.
+
+Since: 1.50
+
+</description>
+<parameters>
+<parameter name="attr">
+<parameter_description> A `PangoAttribute` such as foreground
+</parameter_description>
+</parameter>
+</parameters>
+<return> The attribute as `PangoAttrColor`,
+or %NULL if it's not a color attribute
+
+</return>
+</function>
+
+<function name="pango_attribute_as_float">
+<description>
+Returns the attribute cast to `PangoAttrFloat`.
+
+This is mainly useful for language bindings.
+
+Since: 1.50
+
+</description>
+<parameters>
+<parameter name="attr">
+<parameter_description> A `PangoAttribute` such as scale
+</parameter_description>
+</parameter>
+</parameters>
+<return> The attribute as `PangoAttrFloat`,
+or %NULL if it's not a floating point attribute
+
+</return>
+</function>
+
+<function name="pango_attribute_as_font_desc">
+<description>
+Returns the attribute cast to `PangoAttrFontDesc`.
+
+This is mainly useful for language bindings.
+
+Since: 1.50
+
+</description>
+<parameters>
+<parameter name="attr">
+<parameter_description> A `PangoAttribute` representing a font description
+</parameter_description>
+</parameter>
+</parameters>
+<return> The attribute as `PangoAttrFontDesc`,
+or %NULL if it's not a font description attribute
+
+</return>
+</function>
+
+<function name="pango_attribute_as_font_features">
+<description>
+Returns the attribute cast to `PangoAttrFontFeatures`.
+
+This is mainly useful for language bindings.
+
+Since: 1.50
+
+</description>
+<parameters>
+<parameter name="attr">
+<parameter_description> A `PangoAttribute` representing font features
+</parameter_description>
+</parameter>
+</parameters>
+<return> The attribute as `PangoAttrFontFeatures`,
+or %NULL if it's not a font features attribute
+
+</return>
+</function>
+
+<function name="pango_attribute_as_int">
+<description>
+Returns the attribute cast to `PangoAttrInt`.
+
+This is mainly useful for language bindings.
+
+Since: 1.50
+
+</description>
+<parameters>
+<parameter name="attr">
+<parameter_description> A `PangoAttribute` such as weight
+</parameter_description>
+</parameter>
+</parameters>
+<return> The attribute as `PangoAttrInt`,
+or %NULL if it's not an integer attribute
+
+</return>
+</function>
+
+<function name="pango_attribute_as_language">
+<description>
+Returns the attribute cast to `PangoAttrLanguage`.
+
+This is mainly useful for language bindings.
+
+Since: 1.50
+
+</description>
+<parameters>
+<parameter name="attr">
+<parameter_description> A `PangoAttribute` representing a language
+</parameter_description>
+</parameter>
+</parameters>
+<return> The attribute as `PangoAttrLanguage`,
+or %NULL if it's not a language attribute
+
+</return>
+</function>
+
+<function name="pango_attribute_as_shape">
+<description>
+Returns the attribute cast to `PangoAttrShape`.
+
+This is mainly useful for language bindings.
+
+Since: 1.50
+
+</description>
+<parameters>
+<parameter name="attr">
+<parameter_description> A `PangoAttribute` representing a shape
+</parameter_description>
+</parameter>
+</parameters>
+<return> The attribute as `PangoAttrShape`,
+or %NULL if it's not a shape attribute
+
+</return>
+</function>
+
+<function name="pango_attribute_as_size">
+<description>
+Returns the attribute cast to `PangoAttrSize`.
+
+This is mainly useful for language bindings.
+
+Since: 1.50
+
+</description>
+<parameters>
+<parameter name="attr">
+<parameter_description> A `PangoAttribute` representing a size
+</parameter_description>
+</parameter>
+</parameters>
+<return> The attribute as `PangoAttrSize`,
+or NULL if it's not a size attribute
+
+</return>
+</function>
+
+<function name="pango_attribute_as_string">
+<description>
+Returns the attribute cast to `PangoAttrString`.
+
+This is mainly useful for language bindings.
+
+Since: 1.50
+
+</description>
+<parameters>
+<parameter name="attr">
+<parameter_description> A `PangoAttribute` such as family
+</parameter_description>
+</parameter>
+</parameters>
+<return> The attribute as `PangoAttrString`,
+or %NULL if it's not a string attribute
+
 </return>
 </function>
 
@@ -2497,23 +3279,24 @@ Make a copy of an attribute.
 </description>
 <parameters>
 <parameter name="attr">
-<parameter_description> a #PangoAttribute
+<parameter_description> a `PangoAttribute`
 </parameter_description>
 </parameter>
 </parameters>
-<return> the newly allocated #PangoAttribute,
-which should be freed with pango_attribute_destroy().
+<return> the newly allocated
+`PangoAttribute`, which should be freed with
+[method@Pango.Attribute.destroy].
 </return>
 </function>
 
 <function name="pango_attribute_destroy">
 <description>
-Destroy a #PangoAttribute and free all associated memory.
+Destroy a `PangoAttribute` and free all associated memory.
 
 </description>
 <parameters>
 <parameter name="attr">
-<parameter_description> a #PangoAttribute.
+<parameter_description> a `PangoAttribute`.
 </parameter_description>
 </parameter>
 </parameters>
@@ -2522,32 +3305,33 @@ Destroy a #PangoAttribute and free all associated memory.
 
 <function name="pango_attribute_equal">
 <description>
-Compare two attributes for equality. This compares only the
-actual value of the two attributes and not the ranges that the
-attributes apply to.
+Compare two attributes for equality.
+
+This compares only the actual value of the two
+attributes and not the ranges that the attributes
+apply to.
 
 
 </description>
 <parameters>
 <parameter name="attr1">
-<parameter_description> a #PangoAttribute
+<parameter_description> a `PangoAttribute`
 </parameter_description>
 </parameter>
 <parameter name="attr2">
-<parameter_description> another #PangoAttribute
+<parameter_description> another `PangoAttribute`
 </parameter_description>
 </parameter>
 </parameters>
-<return> %TRUE if the two attributes have the same value.
+<return> %TRUE if the two attributes have the same value
 </return>
 </function>
 
 <function name="pango_attribute_init">
 <description>
-Initializes @attr's klass to @klass,
-it's start_index to %PANGO_ATTR_INDEX_FROM_TEXT_BEGINNING
-and end_index to %PANGO_ATTR_INDEX_TO_TEXT_END
-such that the attribute applies
+Initializes @attr's klass to @klass, it's start_index to
+%PANGO_ATTR_INDEX_FROM_TEXT_BEGINNING and end_index to
+%PANGO_ATTR_INDEX_TO_TEXT_END such that the attribute applies
 to the entire text by default.
 
 Since: 1.20
@@ -2555,11 +3339,11 @@ Since: 1.20
 </description>
 <parameters>
 <parameter name="attr">
-<parameter_description> a #PangoAttribute
+<parameter_description> a `PangoAttribute`
 </parameter_description>
 </parameter>
 <parameter name="klass">
-<parameter_description> a #PangoAttrClass
+<parameter_description> a `PangoAttrClass`
 </parameter_description>
 </parameter>
 </parameters>
@@ -2568,11 +3352,11 @@ Since: 1.20
 
 <function name="pango_bidi_type_for_unichar">
 <description>
-Determines the normative bidirectional character type of a
-character, as specified in the Unicode Character Database.
+Determines the bidirectional type of a character.
+
+The bidirectional type is specified in the Unicode Character Database.
 
-A simplified version of this function is available as
-pango_unichar_direction().
+A simplified version of this function is available as [func@unichar_direction].
 
 Since: 1.22
 
@@ -2593,27 +3377,29 @@ Unicode bidirectional algorithm.
 <description>
 Determines possible line, word, and character breaks
 for a string of Unicode text with a single analysis.
-For most purposes you may want to use pango_get_log_attrs().
 
-Deprecated: 1.44: Use pango_default_break() and pango_tailor_break()
+For most purposes you may want to use
+[func@Pango.get_log_attrs].
+
+Deprecated: 1.44: Use [func@Pango.default_break],
+[func@Pango.tailor_break] and func@Pango.attr_break].
 
 </description>
 <parameters>
 <parameter name="text">
-<parameter_description>      the text to process. Must be valid UTF-8
+<parameter_description> the text to process. Must be valid UTF-8
 </parameter_description>
 </parameter>
 <parameter name="length">
-<parameter_description>    length of @text in bytes (may be -1 if @text is nul-terminated)
+<parameter_description> length of @text in bytes (may be -1 if @text is nul-terminated)
 </parameter_description>
 </parameter>
 <parameter name="analysis">
-<parameter_description>  #PangoAnalysis structure from pango_itemize()
+<parameter_description> `PangoAnalysis` structure for @text
 </parameter_description>
 </parameter>
 <parameter name="attrs">
-<parameter_description> an array to store character
-information in
+<parameter_description> an array to store character information in
 </parameter_description>
 </parameter>
 <parameter name="attrs_len">
@@ -2627,15 +3413,17 @@ information in
 <function name="pango_cairo_context_get_font_options">
 <description>
 Retrieves any font rendering options previously set with
-pango_cairo_context_set_font_options(). This function does not report options
-that are derived from the target surface by pango_cairo_update_context()
+[func@PangoCairo.context_set_font_options].
+
+This function does not report options that are derived from
+the target surface by [func@update_context].
 
 Since: 1.10
 
 </description>
 <parameters>
 <parameter name="context">
-<parameter_description> a #PangoContext, from a pangocairo font map
+<parameter_description> a `PangoContext`, from a pangocairo font map
 </parameter_description>
 </parameter>
 </parameters>
@@ -2648,14 +3436,16 @@ owned by the context and must not be modified or freed.
 
 <function name="pango_cairo_context_get_resolution">
 <description>
-Gets the resolution for the context. See pango_cairo_context_set_resolution()
+Gets the resolution for the context.
+
+See [func@PangoCairo.context_set_resolution]
 
 Since: 1.10
 
 </description>
 <parameters>
 <parameter name="context">
-<parameter_description> a #PangoContext, from a pangocairo font map
+<parameter_description> a `PangoContext`, from a pangocairo font map
 </parameter_description>
 </parameter>
 </parameters>
@@ -2668,29 +3458,30 @@ be returned if no resolution has previously been set.
 <function name="pango_cairo_context_get_shape_renderer">
 <description>
 Sets callback function for context to use for rendering attributes
-of type %PANGO_ATTR_SHAPE.  See #PangoCairoShapeRendererFunc for
-details.
+of type %PANGO_ATTR_SHAPE.
+
+See `PangoCairoShapeRendererFunc` for details.
 
 Retrieves callback function and associated user data for rendering
 attributes of type %PANGO_ATTR_SHAPE as set by
-pango_cairo_context_set_shape_renderer(), if any.
+[func@PangoCairo.context_set_shape_renderer], if any.
 
 Since: 1.18
 
 </description>
 <parameters>
 <parameter name="context">
-<parameter_description> a #PangoContext, from a pangocairo font map
+<parameter_description> a `PangoContext`, from a pangocairo font map
 </parameter_description>
 </parameter>
 <parameter name="data">
-<parameter_description> Pointer to #gpointer to return user data
+<parameter_description> Pointer to `gpointer` to return user data
 </parameter_description>
 </parameter>
 </parameters>
-<return> the shape rendering callback previously
-set on the context, or %NULL if no shape rendering callback have
-been set.
+<return> the shape rendering callback
+previously set on the context, or %NULL if no shape rendering callback
+have been set.
 
 </return>
 </function>
@@ -2698,7 +3489,8 @@ been set.
 <function name="pango_cairo_context_set_font_options">
 <description>
 Sets the font options used when rendering text with this context.
-These options override any options that pango_cairo_update_context()
+
+These options override any options that [func@update_context]
 derives from the target surface.
 
 Since: 1.10
@@ -2706,11 +3498,11 @@ Since: 1.10
 </description>
 <parameters>
 <parameter name="context">
-<parameter_description> a #PangoContext, from a pangocairo font map
+<parameter_description> a `PangoContext`, from a pangocairo font map
 </parameter_description>
 </parameter>
 <parameter name="options">
-<parameter_description> a #cairo_font_options_t, or %NULL to unset
+<parameter_description> a `cairo_font_options_t`, or %NULL to unset
 any previously set options. A copy is made.
 </parameter_description>
 </parameter>
@@ -2720,17 +3512,18 @@ any previously set options. A copy is made.
 
 <function name="pango_cairo_context_set_resolution">
 <description>
-Sets the resolution for the context. This is a scale factor between
-points specified in a #PangoFontDescription and Cairo units. The
-default value is 96, meaning that a 10 point font will be 13
-units high. (10 * 96. / 72. = 13.3).
+Sets the resolution for the context.
+
+This is a scale factor between points specified in a `PangoFontDescription`
+and Cairo units. The default value is 96, meaning that a 10 point font will
+be 13 units high. (10 * 96. / 72. = 13.3).
 
 Since: 1.10
 
 </description>
 <parameters>
 <parameter name="context">
-<parameter_description> a #PangoContext, from a pangocairo font map
+<parameter_description> a `PangoContext`, from a pangocairo font map
 </parameter_description>
 </parameter>
 <parameter name="dpi">
@@ -2746,15 +3539,16 @@ means to use the resolution from the font map.
 <function name="pango_cairo_context_set_shape_renderer">
 <description>
 Sets callback function for context to use for rendering attributes
-of type %PANGO_ATTR_SHAPE.  See #PangoCairoShapeRendererFunc for
-details.
+of type %PANGO_ATTR_SHAPE.
+
+See `PangoCairoShapeRendererFunc` for details.
 
 Since: 1.18
 
 </description>
 <parameters>
 <parameter name="context">
-<parameter_description> a #PangoContext, from a pangocairo font map
+<parameter_description> a `PangoContext`, from a pangocairo font map
 </parameter_description>
 </parameter>
 <parameter name="func">
@@ -2768,7 +3562,7 @@ type %PANGO_ATTR_SHAPE, or %NULL to disable shape rendering.
 </parameter>
 <parameter name="dnotify">
 <parameter_description> Callback that will be called when the
-context is freed to release @data, or %NULL.
+context is freed to release @data
 </parameter_description>
 </parameter>
 </parameters>
@@ -2778,13 +3572,15 @@ context is freed to release @data, or %NULL.
 <function name="pango_cairo_create_context">
 <description>
 Creates a context object set up to match the current transformation
-and target surface of the Cairo context.  This context can then be
-used to create a layout using pango_layout_new().
+and target surface of the Cairo context.
+
+This context can then be
+used to create a layout using [ctor Pango Layout new].
 
 This function is a convenience function that creates a context using
-the default font map, then updates it to @cr.  If you just need to
-create a layout for use with @cr and do not need to access #PangoContext
-directly, you can use pango_cairo_create_layout() instead.
+the default font map, then updates it to @cr. If you just need to
+create a layout for use with @cr and do not need to access `PangoContext`
+directly, you can use [func@create_layout] instead.
 
 Since: 1.22
 
@@ -2795,8 +3591,7 @@ Since: 1.22
 </parameter_description>
 </parameter>
 </parameters>
-<return> the newly created #PangoContext. Free with
-g_object_unref().
+<return> the newly created `PangoContext`
 
 </return>
 </function>
@@ -2804,15 +3599,16 @@ g_object_unref().
 <function name="pango_cairo_create_layout">
 <description>
 Creates a layout object set up to match the current transformation
-and target surface of the Cairo context.  This layout can then be
-used for text measurement with functions like
-pango_layout_get_size() or drawing with functions like
-pango_cairo_show_layout(). If you change the transformation
-or target surface for @cr, you need to call pango_cairo_update_layout()
+and target surface of the Cairo context.
+
+This layout can then be used for text measurement with functions
+like [method@Pango.Layout.get_size] or drawing with functions like
+[func@show_layout]. If you change the transformation or target
+surface for @cr, you need to call [func@update_layout].
 
 This function is the most convenient way to use Cairo with Pango,
 however it is slightly inefficient since it creates a separate
-#PangoContext object for each layout. This might matter in an
+`PangoContext` object for each layout. This might matter in an
 application that was laying out large amounts of text.
 
 Since: 1.10
@@ -2824,8 +3620,7 @@ Since: 1.10
 </parameter_description>
 </parameter>
 </parameters>
-<return> the newly created #PangoLayout. Free with
-g_object_unref().
+<return> the newly created `PangoLayout`
 
 </return>
 </function>
@@ -2834,9 +3629,10 @@ g_object_unref().
 <description>
 Add a squiggly line to the current path in the specified cairo context that
 approximately covers the given rectangle in the style of an underline used
-to indicate a spelling error.  (The width of the underline is rounded to an
-integer number of up/down segments and the resulting rectangle is centered
-in the original rectangle)
+to indicate a spelling error.
+
+The width of the underline is rounded to an integer number of up/down
+segments and the resulting rectangle is centered in the original rectangle.
 
 Since: 1.14
 
@@ -2868,7 +3664,7 @@ Since: 1.14
 
 <function name="pango_cairo_font_get_scaled_font">
 <description>
-Gets the #cairo_scaled_font_t used by @font.
+Gets the `cairo_scaled_font_t` used by @font.
 The scaled font can be referenced and kept using
 cairo_scaled_font_reference().
 
@@ -2877,19 +3673,19 @@ Since: 1.18
 </description>
 <parameters>
 <parameter name="font">
-<parameter_description> a #PangoFont from a #PangoCairoFontMap
+<parameter_description> a `PangoFont` from a `PangoCairoFontMap`
 </parameter_description>
 </parameter>
 </parameters>
-<return> the #cairo_scaled_font_t used by @font,
-or %NULL if @font is %NULL.
+<return> the `cairo_scaled_font_t`
+used by @font
 
 </return>
 </function>
 
 <function name="pango_cairo_font_map_create_context">
 <description>
-Create a #PangoContext for the given fontmap.
+Create a `PangoContext` for the given fontmap.
 
 Since: 1.10
 
@@ -2898,7 +3694,7 @@ Deprecated: 1.22: Use pango_font_map_create_context() instead.
 </description>
 <parameters>
 <parameter name="fontmap">
-<parameter_description> a #PangoCairoFontMap
+<parameter_description> a `PangoCairoFontMap`
 </parameter_description>
 </parameter>
 </parameters>
@@ -2909,21 +3705,21 @@ Deprecated: 1.22: Use pango_font_map_create_context() instead.
 
 <function name="pango_cairo_font_map_get_default">
 <description>
-Gets a default #PangoCairoFontMap to use with Cairo.
+Gets a default `PangoCairoFontMap` to use with Cairo.
 
-Note that the type of the returned object will depend
-on the particular font backend Cairo was compiled to use;
-You generally should only use the #PangoFontMap and
-#PangoCairoFontMap interfaces on the returned object.
+Note that the type of the returned object will depend on the
+particular font backend Cairo was compiled to use; you generally
+should only use the `PangoFontMap` and `PangoCairoFontMap`
+interfaces on the returned object.
 
 The default Cairo fontmap can be changed by using
-pango_cairo_font_map_set_default().  This can be used to
-change the Cairo font backend that the default fontmap
-uses for example.
+[method@PangoCairo.FontMap.set_default]. This can be used to
+change the Cairo font backend that the default fontmap uses
+for example.
 
 Note that since Pango 1.32.6, the default fontmap is per-thread.
-Each thread gets its own default fontmap.  In this way,
-PangoCairo can be used safely from multiple threads.
+Each thread gets its own default fontmap. In this way, PangoCairo
+can be used safely from multiple threads.
 
 Since: 1.10
 
@@ -2931,39 +3727,42 @@ Since: 1.10
 <parameters>
 </parameters>
 <return> the default PangoCairo fontmap
-for the current thread. This object is owned by Pango and must not be freed.
+for the current thread. This object is owned by Pango and must
+not be freed.
 
 </return>
 </function>
 
 <function name="pango_cairo_font_map_get_font_type">
 <description>
-Gets the type of Cairo font backend that @fontmap uses.  
+Gets the type of Cairo font backend that @fontmap uses.
 
 Since: 1.18
 
 </description>
 <parameters>
 <parameter name="fontmap">
-<parameter_description> a #PangoCairoFontMap
+<parameter_description> a `PangoCairoFontMap`
 </parameter_description>
 </parameter>
 </parameters>
-<return> the #cairo_font_type_t cairo font backend type
+<return> the `cairo_font_type_t` cairo font backend type
 
 </return>
 </function>
 
 <function name="pango_cairo_font_map_get_resolution">
 <description>
-Gets the resolution for the fontmap. See pango_cairo_font_map_set_resolution()
+Gets the resolution for the fontmap.
+
+See [method@PangoCairo.FontMap.set_resolution].
 
 Since: 1.10
 
 </description>
 <parameters>
 <parameter name="fontmap">
-<parameter_description> a #PangoCairoFontMap
+<parameter_description> a `PangoCairoFontMap`
 </parameter_description>
 </parameter>
 </parameters>
@@ -2974,19 +3773,20 @@ Since: 1.10
 
 <function name="pango_cairo_font_map_new">
 <description>
-Creates a new #PangoCairoFontMap object; a fontmap is used
-to cache information about available fonts, and holds
-certain global parameters such as the resolution.
-In most cases, you can use pango_cairo_font_map_get_default()
+Creates a new `PangoCairoFontMap` object.
+
+A fontmap is used to cache information about available fonts,
+and holds certain global parameters such as the resolution.
+In most cases, you can use `func@PangoCairo.font_map_get_default]
 instead.
 
 Note that the type of the returned object will depend
 on the particular font backend Cairo was compiled to use;
-You generally should only use the #PangoFontMap and
-#PangoCairoFontMap interfaces on the returned object.
+You generally should only use the `PangoFontMap` and
+`PangoCairoFontMap` interfaces on the returned object.
 
 You can override the type of backend returned by using an
-environment variable %PANGOCAIRO_BACKEND.  Supported types,
+environment variable %PANGOCAIRO_BACKEND. Supported types,
 based on your build, are fc (fontconfig), win32, and coretext.
 If requested type is not available, NULL is returned. Ie.
 this is only useful for testing, when at least two backends
@@ -2997,7 +3797,7 @@ Since: 1.10
 </description>
 <parameters>
 </parameters>
-<return> the newly allocated #PangoFontMap,
+<return> the newly allocated `PangoFontMap`,
 which should be freed with g_object_unref().
 
 </return>
@@ -3005,12 +3805,11 @@ which should be freed with g_object_unref().
 
 <function name="pango_cairo_font_map_new_for_font_type">
 <description>
-Creates a new #PangoCairoFontMap object of the type suitable
+Creates a new `PangoCairoFontMap` object of the type suitable
 to be used with cairo font backend of type @fonttype.
 
-In most cases one should simply use @pango_cairo_font_map_new(),
-or in fact in most of those cases, just use
-@pango_cairo_font_map_get_default().
+In most cases one should simply use [func PangoCairo FontMap new], or
+in fact in most of those cases, just use [func@PangoCairo.FontMap.get_default].
 
 Since: 1.18
 
@@ -3022,37 +3821,37 @@ Since: 1.18
 </parameter>
 </parameters>
 <return> the newly allocated
-#PangoFontMap of suitable type which should be freed
-with g_object_unref(), or %NULL if the requested
-cairo font backend is not supported / compiled in.
+`PangoFontMap` of suitable type which should be freed with
+g_object_unref(), or %NULL if the requested cairo font backend
+is not supported / compiled in.
 
 </return>
 </function>
 
 <function name="pango_cairo_font_map_set_default">
 <description>
-Sets a default #PangoCairoFontMap to use with Cairo.
+Sets a default `PangoCairoFontMap` to use with Cairo.
 
 This can be used to change the Cairo font backend that the
-default fontmap uses for example.  The old default font map
+default fontmap uses for example. The old default font map
 is unreffed and the new font map referenced.
 
 Note that since Pango 1.32.6, the default fontmap is per-thread.
 This function only changes the default fontmap for
-the current thread.  Default fontmaps of existing threads
+the current thread. Default fontmaps of existing threads
 are not changed. Default fontmaps of any new threads will
-still be created using pango_cairo_font_map_new().
+still be created using [func PangoCairo FontMap new].
 
 A value of %NULL for @fontmap will cause the current default
-font map to be released and a new default font
-map to be created on demand, using pango_cairo_font_map_new().
+font map to be released and a new default font map to be created
+on demand, using [func PangoCairo FontMap new].
 
 Since: 1.22
 
 </description>
 <parameters>
 <parameter name="fontmap">
-<parameter_description> The new default font map, or %NULL
+<parameter_description> The new default font map
 </parameter_description>
 </parameter>
 </parameters>
@@ -3061,8 +3860,10 @@ Since: 1.22
 
 <function name="pango_cairo_font_map_set_resolution">
 <description>
-Sets the resolution for the fontmap. This is a scale factor between
-points specified in a #PangoFontDescription and Cairo units. The
+Sets the resolution for the fontmap.
+
+This is a scale factor between
+points specified in a `PangoFontDescription` and Cairo units. The
 default value is 96, meaning that a 10 point font will be 13
 units high. (10 * 96. / 72. = 13.3).
 
@@ -3071,7 +3872,7 @@ Since: 1.10
 </description>
 <parameters>
 <parameter name="fontmap">
-<parameter_description> a #PangoCairoFontMap
+<parameter_description> a `PangoCairoFontMap`
 </parameter_description>
 </parameter>
 <parameter name="dpi">
@@ -3086,7 +3887,9 @@ involved; the terminology is conventional.)
 <function name="pango_cairo_glyph_string_path">
 <description>
 Adds the glyphs in @glyphs to the current path in the specified
-cairo context. The origin of the glyphs (the left edge of the baseline)
+cairo context.
+
+The origin of the glyphs (the left edge of the baseline)
 will be at the current point of the cairo context.
 
 Since: 1.10
@@ -3098,11 +3901,11 @@ Since: 1.10
 </parameter_description>
 </parameter>
 <parameter name="font">
-<parameter_description> a #PangoFont from a #PangoCairoFontMap
+<parameter_description> a `PangoFont` from a `PangoCairoFontMap`
 </parameter_description>
 </parameter>
 <parameter name="glyphs">
-<parameter_description> a #PangoGlyphString
+<parameter_description> a `PangoGlyphString`
 </parameter_description>
 </parameter>
 </parameters>
@@ -3111,9 +3914,11 @@ Since: 1.10
 
 <function name="pango_cairo_layout_line_path">
 <description>
-Adds the text in #PangoLayoutLine to the current path in the
-specified cairo context.  The origin of the glyphs (the left edge
-of the line) will be at the current point of the cairo context.
+Adds the text in `PangoLayoutLine` to the current path in the
+specified cairo context.
+
+The origin of the glyphs (the left edge of the line) will be
+at the current point of the cairo context.
 
 Since: 1.10
 
@@ -3124,7 +3929,7 @@ Since: 1.10
 </parameter_description>
 </parameter>
 <parameter name="line">
-<parameter_description> a #PangoLayoutLine
+<parameter_description> a `PangoLayoutLine`
 </parameter_description>
 </parameter>
 </parameters>
@@ -3133,9 +3938,11 @@ Since: 1.10
 
 <function name="pango_cairo_layout_path">
 <description>
-Adds the text in a #PangoLayout to the current path in the
-specified cairo context.  The top-left corner of the #PangoLayout
-will be at the current point of the cairo context.
+Adds the text in a `PangoLayout` to the current path in the
+specified cairo context.
+
+The top-left corner of the `PangoLayout` will be at the
+current point of the cairo context.
 
 Since: 1.10
 
@@ -3157,9 +3964,11 @@ Since: 1.10
 <description>
 Draw a squiggly line in the specified cairo context that approximately
 covers the given rectangle in the style of an underline used to indicate a
-spelling error.  (The width of the underline is rounded to an integer
+spelling error.
+
+The width of the underline is rounded to an integer
 number of up/down segments and the resulting rectangle is centered in the
-original rectangle)
+original rectangle.
 
 Since: 1.14
 
@@ -3192,15 +4001,16 @@ Since: 1.14
 <function name="pango_cairo_show_glyph_item">
 <description>
 Draws the glyphs in @glyph_item in the specified cairo context,
+
 embedding the text associated with the glyphs in the output if the
 output format supports it (PDF for example), otherwise it acts
-similar to pango_cairo_show_glyph_string().
+similar to [func@show_glyph_string].
 
 The origin of the glyphs (the left edge of the baseline) will
 be drawn at the current point of the cairo context.
 
 Note that @text is the start of the text for layout, which is then
-indexed by &lt;literal&gt;@glyph_item-&gt;item-&gt;offset&lt;/literal&gt;.
+indexed by `glyph_item-&gt;item-&gt;offset`.
 
 Since: 1.22
 
@@ -3215,7 +4025,7 @@ Since: 1.22
 </parameter_description>
 </parameter>
 <parameter name="glyph_item">
-<parameter_description> a #PangoGlyphItem
+<parameter_description> a `PangoGlyphItem`
 </parameter_description>
 </parameter>
 </parameters>
@@ -3225,6 +4035,7 @@ Since: 1.22
 <function name="pango_cairo_show_glyph_string">
 <description>
 Draws the glyphs in @glyphs in the specified cairo context.
+
 The origin of the glyphs (the left edge of the baseline) will
 be drawn at the current point of the cairo context.
 
@@ -3237,11 +4048,11 @@ Since: 1.10
 </parameter_description>
 </parameter>
 <parameter name="font">
-<parameter_description> a #PangoFont from a #PangoCairoFontMap
+<parameter_description> a `PangoFont` from a `PangoCairoFontMap`
 </parameter_description>
 </parameter>
 <parameter name="glyphs">
-<parameter_description> a #PangoGlyphString
+<parameter_description> a `PangoGlyphString`
 </parameter_description>
 </parameter>
 </parameters>
@@ -3250,8 +4061,9 @@ Since: 1.10
 
 <function name="pango_cairo_show_layout">
 <description>
-Draws a #PangoLayout in the specified cairo context.
-The top-left corner of the #PangoLayout will be drawn
+Draws a `PangoLayout` in the specified cairo context.
+
+The top-left corner of the `PangoLayout` will be drawn
 at the current point of the cairo context.
 
 Since: 1.10
@@ -3272,7 +4084,8 @@ Since: 1.10
 
 <function name="pango_cairo_show_layout_line">
 <description>
-Draws a #PangoLayoutLine in the specified cairo context.
+Draws a `PangoLayoutLine` in the specified cairo context.
+
 The origin of the glyphs (the left edge of the line) will
 be drawn at the current point of the cairo context.
 
@@ -3285,7 +4098,7 @@ Since: 1.10
 </parameter_description>
 </parameter>
 <parameter name="line">
-<parameter_description> a #PangoLayoutLine
+<parameter_description> a `PangoLayoutLine`
 </parameter_description>
 </parameter>
 </parameters>
@@ -3294,11 +4107,12 @@ Since: 1.10
 
 <function name="pango_cairo_update_context">
 <description>
-Updates a #PangoContext previously created for use with Cairo to
+Updates a `PangoContext` previously created for use with Cairo to
 match the current transformation and target surface of a Cairo
-context. If any layouts have been created for the context,
-it's necessary to call pango_layout_context_changed() on those
-layouts.
+context.
+
+If any layouts have been created for the context, it's necessary
+to call [method@Pango.Layout.context_changed] on those layouts.
 
 Since: 1.10
 
@@ -3309,7 +4123,7 @@ Since: 1.10
 </parameter_description>
 </parameter>
 <parameter name="context">
-<parameter_description> a #PangoContext, from a pangocairo font map
+<parameter_description> a `PangoContext`, from a pangocairo font map
 </parameter_description>
 </parameter>
 </parameters>
@@ -3318,9 +4132,9 @@ Since: 1.10
 
 <function name="pango_cairo_update_layout">
 <description>
-Updates the private #PangoContext of a #PangoLayout created with
-pango_cairo_create_layout() to match the current transformation
-and target surface of a Cairo context.
+Updates the private `PangoContext` of a `PangoLayout` created with
+[func@create_layout] to match the current transformation and target
+surface of a Cairo context.
 
 Since: 1.10
 
@@ -3331,7 +4145,7 @@ Since: 1.10
 </parameter_description>
 </parameter>
 <parameter name="layout">
-<parameter_description> a #PangoLayout, from pango_cairo_create_layout()
+<parameter_description> a `PangoLayout`, from [func@create_layout]
 </parameter_description>
 </parameter>
 </parameters>
@@ -3340,33 +4154,34 @@ Since: 1.10
 
 <function name="pango_color_copy">
 <description>
-Creates a copy of @src, which should be freed with
-pango_color_free(). Primarily used by language bindings,
-not that useful otherwise (since colors can just be copied
-by assignment in C).
+Creates a copy of @src.
+
+The copy should be freed with [method Pango Color free].
+Primarily used by language bindings, not that useful
+otherwise (since colors can just be copied by assignment
+in C).
 
 
 </description>
 <parameters>
 <parameter name="src">
-<parameter_description> color to copy, may be %NULL
+<parameter_description> color to copy
 </parameter_description>
 </parameter>
 </parameters>
-<return> the newly allocated #PangoColor, which
-should be freed with pango_color_free(), or %NULL if
-@src was %NULL.
+<return> the newly allocated `PangoColor`,
+which should be freed with [method Pango Color free]
 </return>
 </function>
 
 <function name="pango_color_free">
 <description>
-Frees a color allocated by pango_color_copy().
+Frees a color allocated by [method Pango Color copy].
 
 </description>
 <parameters>
 <parameter name="color">
-<parameter_description> an allocated #PangoColor, may be %NULL
+<parameter_description> an allocated `PangoColor`
 </parameter_description>
 </parameter>
 </parameters>
@@ -3375,21 +4190,22 @@ Frees a color allocated by pango_color_copy().
 
 <function name="pango_color_parse">
 <description>
-Fill in the fields of a color from a string specification. The
-string can either one of a large set of standard names. (Taken
-from the CSS &lt;ulink 
url=&quot;http://dev.w3.org/csswg/css-color/#named-colors&quot;&gt;specification&lt;/ulink&gt;), or it can be 
a hexadecimal
-value in the
-form '&#35;rgb' '&#35;rrggbb' '&#35;rrrgggbbb' or '&#35;rrrrggggbbbb' where
-'r', 'g' and 'b' are hex digits of the red, green, and blue
-components of the color, respectively. (White in the four
-forms is '&#35;fff' '&#35;ffffff' '&#35;fffffffff' and '&#35;ffffffffffff')
+Fill in the fields of a color from a string specification.
+
+The string can either one of a large set of standard names.
+(Taken from the CSS Color [specification](https://www.w3.org/TR/css-color-4/#named-colors),
+or it can be a value in the form `#rgb`, `#rrggbb`,
+`#rrrgggbbb` or `#rrrrggggbbbb`, where `r`, `g` and `b`
+are hex digits of the red, green, and blue components
+of the color, respectively. (White in the four forms is
+`#fff`, `#ffffff`, `#fffffffff` and `#ffffffffffff`.)
 
 
 </description>
 <parameters>
 <parameter name="color">
-<parameter_description> a #PangoColor structure in which to store the
-result, or %NULL
+<parameter_description> a `PangoColor` structure in which
+to store the result
 </parameter_description>
 </parameter>
 <parameter name="spec">
@@ -3398,38 +4214,39 @@ result, or %NULL
 </parameter>
 </parameters>
 <return> %TRUE if parsing of the specifier succeeded,
-otherwise false.
+otherwise %FALSE
 </return>
 </function>
 
 <function name="pango_color_parse_with_alpha">
 <description>
-Fill in the fields of a color from a string specification. The
-string can either one of a large set of standard names. (Taken
-from the CSS &lt;ulink 
url=&quot;http://dev.w3.org/csswg/css-color/#named-colors&quot;&gt;specification&lt;/ulink&gt;), or it can be 
a hexadecimal
-value in the
-form '&#35;rgb' '&#35;rrggbb' '&#35;rrrgggbbb' or '&#35;rrrrggggbbbb' where
-'r', 'g' and 'b' are hex digits of the red, green, and blue
-components of the color, respectively. (White in the four
-forms is '&#35;fff' '&#35;ffffff' '&#35;fffffffff' and '&#35;ffffffffffff')
-
-Additionally, parse strings of the form
-'&#35;rgba', '&#35;rrggbbaa', '&#35;rrrrggggbbbbaaaa',
-if @alpha is not %NULL, and set @alpha to the value specified
-by the hex digits for 'a'. If no alpha component is found
-in @spec, @alpha is set to 0xffff (for a solid color).
+Fill in the fields of a color from a string specification.
+
+The string can either one of a large set of standard names.
+(Taken from the CSS Color [specification](https://www.w3.org/TR/css-color-4/#named-colors),
+or it can be a hexadecimal value in the form `#rgb`,
+`#rrggbb`, `#rrrgggbbb` or `#rrrrggggbbbb` where `r`, `g`
+and `b` are hex digits of the red, green, and blue components
+of the color, respectively. (White in the four forms is
+`#fff`, `#ffffff`, `#fffffffff` and `#ffffffffffff`.)
+
+Additionally, parse strings of the form `#rgba`, `#rrggbbaa`,
+`#rrrrggggbbbbaaaa`, if @alpha is not %NULL, and set @alpha
+to the value specified by the hex digits for `a`. If no alpha
+component is found in @spec, @alpha is set to 0xffff (for a
+solid color).
 
 Since: 1.46
 
 </description>
 <parameters>
 <parameter name="color">
-<parameter_description> a #PangoColor structure in which to store the
-result, or %NULL
+<parameter_description> a `PangoColor` structure in which
+to store the result
 </parameter_description>
 </parameter>
 <parameter name="alpha">
-<parameter_description> return location for alpha, or %NULL
+<parameter_description> return location for alpha
 </parameter_description>
 </parameter>
 <parameter name="spec">
@@ -3438,28 +4255,30 @@ result, or %NULL
 </parameter>
 </parameters>
 <return> %TRUE if parsing of the specifier succeeded,
-otherwise false.
+otherwise %FALSE
 
 </return>
 </function>
 
 <function name="pango_color_to_string">
 <description>
-Returns a textual specification of @color in the hexadecimal form
-&lt;literal&gt;&#35;rrrrggggbbbb&lt;/literal&gt;, where &lt;literal&gt;r&lt;/literal&gt;,
-&lt;literal&gt;g&lt;/literal&gt; and &lt;literal&gt;b&lt;/literal&gt; are hex digits representing
-the red, green, and blue components respectively.
+Returns a textual specification of @color.
+
+The string is in the hexadecimal form `#rrrrggggbbbb`,
+where `r`, `g` and `b` are hex digits representing the
+red, green, and blue components respectively.
 
 Since: 1.16
 
 </description>
 <parameters>
 <parameter name="color">
-<parameter_description> a #PangoColor
+<parameter_description> a `PangoColor`
 </parameter_description>
 </parameter>
 </parameters>
-<return> a newly-allocated text string that must be freed with g_free().
+<return> a newly-allocated text string that must
+be freed with g_free().
 
 </return>
 </function>
@@ -3473,7 +4292,7 @@ Deprecated: 1.38
 </description>
 <parameters>
 <parameter name="key">
-<parameter_description> Key to look up, in the form &quot;SECTION/KEY&quot;.
+<parameter_description> Key to look up, in the form &quot;SECTION/KEY&quot;
 </parameter_description>
 </parameter>
 </parameters>
@@ -3491,7 +4310,7 @@ Deprecated: 1.38
 </description>
 <parameters>
 <parameter name="key">
-<parameter_description> Key to look up, in the form &quot;SECTION/KEY&quot;.
+<parameter_description> Key to look up, in the form &quot;SECTION/KEY&quot;
 </parameter_description>
 </parameter>
 </parameters>
@@ -3502,7 +4321,7 @@ Deprecated: 1.38
 
 <function name="pango_context_changed">
 <description>
-Forces a change in the context, which will cause any #PangoLayout
+Forces a change in the context, which will cause any `PangoLayout`
 using this context to re-layout.
 
 This function is only useful when implementing a new backend
@@ -3515,7 +4334,7 @@ Since: 1.32.4
 </description>
 <parameters>
 <parameter name="context">
-<parameter_description> a #PangoContext
+<parameter_description> a `PangoContext`
 </parameter_description>
 </parameter>
 </parameters>
@@ -3524,14 +4343,15 @@ Since: 1.32.4
 
 <function name="pango_context_get_base_dir">
 <description>
-Retrieves the base direction for the context. See
-pango_context_set_base_dir().
+Retrieves the base direction for the context.
+
+See [method@Pango.Context.set_base_dir].
 
 
 </description>
 <parameters>
 <parameter name="context">
-<parameter_description> a #PangoContext
+<parameter_description> a `PangoContext`
 </parameter_description>
 </parameter>
 </parameters>
@@ -3541,15 +4361,16 @@ pango_context_set_base_dir().
 
 <function name="pango_context_get_base_gravity">
 <description>
-Retrieves the base gravity for the context. See
-pango_context_set_base_gravity().
+Retrieves the base gravity for the context.
+
+See [method@Pango.Context.set_base_gravity].
 
 Since: 1.16
 
 </description>
 <parameters>
 <parameter name="context">
-<parameter_description> a #PangoContext
+<parameter_description> a `PangoContext`
 </parameter_description>
 </parameter>
 </parameters>
@@ -3566,7 +4387,7 @@ Retrieve the default font description for the context.
 </description>
 <parameters>
 <parameter name="context">
-<parameter_description> a #PangoContext
+<parameter_description> a `PangoContext`
 </parameter_description>
 </parameter>
 </parameters>
@@ -3577,18 +4398,18 @@ description. This value must not be modified or freed.
 
 <function name="pango_context_get_font_map">
 <description>
-Gets the #PangoFontMap used to look up fonts for this context.
+Gets the `PangoFontMap` used to look up fonts for this context.
 
 Since: 1.6
 
 </description>
 <parameters>
 <parameter name="context">
-<parameter_description> a #PangoContext
+<parameter_description> a `PangoContext`
 </parameter_description>
 </parameter>
 </parameters>
-<return> the font map for the #PangoContext.
+<return> the font map for the `PangoContext`.
 This value is owned by Pango and should not be unreferenced.
 
 </return>
@@ -3596,17 +4417,19 @@ This value is owned by Pango and should not be unreferenced.
 
 <function name="pango_context_get_gravity">
 <description>
-Retrieves the gravity for the context. This is similar to
-pango_context_get_base_gravity(), except for when the base gravity
-is %PANGO_GRAVITY_AUTO for which pango_gravity_get_for_matrix() is used
-to return the gravity from the current context matrix.
+Retrieves the gravity for the context.
+
+This is similar to [method@Pango.Context.get_base_gravity],
+except for when the base gravity is %PANGO_GRAVITY_AUTO for
+which [func@Pango.Gravity.get_for_matrix] is used to return the
+gravity from the current context matrix.
 
 Since: 1.16
 
 </description>
 <parameters>
 <parameter name="context">
-<parameter_description> a #PangoContext
+<parameter_description> a `PangoContext`
 </parameter_description>
 </parameter>
 </parameters>
@@ -3617,15 +4440,16 @@ Since: 1.16
 
 <function name="pango_context_get_gravity_hint">
 <description>
-Retrieves the gravity hint for the context. See
-pango_context_set_gravity_hint() for details.
+Retrieves the gravity hint for the context.
+
+See [method@Pango.Context.set_gravity_hint] for details.
 
 Since: 1.16
 
 </description>
 <parameters>
 <parameter name="context">
-<parameter_description> a #PangoContext
+<parameter_description> a `PangoContext`
 </parameter_description>
 </parameter>
 </parameters>
@@ -3642,7 +4466,7 @@ Retrieves the global language tag for the context.
 </description>
 <parameters>
 <parameter name="context">
-<parameter_description> a #PangoContext
+<parameter_description> a `PangoContext`
 </parameter_description>
 </parameter>
 </parameters>
@@ -3653,14 +4477,16 @@ Retrieves the global language tag for the context.
 <function name="pango_context_get_matrix">
 <description>
 Gets the transformation matrix that will be applied when
-rendering with this context. See pango_context_set_matrix().
+rendering with this context.
+
+See [method@Pango.Context.set_matrix].
 
 Since: 1.6
 
 </description>
 <parameters>
 <parameter name="context">
-<parameter_description> a #PangoContext
+<parameter_description> a `PangoContext`
 </parameter_description>
 </parameter>
 </parameters>
@@ -3673,28 +4499,27 @@ matrix is owned by Pango and must not be modified or freed.
 
 <function name="pango_context_get_metrics">
 <description>
-Get overall metric information for a particular font
-description.  Since the metrics may be substantially different for
-different scripts, a language tag can be provided to indicate that
-the metrics should be retrieved that correspond to the script(s)
-used by that language.
+Get overall metric information for a particular font description.
+
+Since the metrics may be substantially different for different scripts,
+a language tag can be provided to indicate that the metrics should be
+retrieved that correspond to the script(s) used by that language.
 
-The #PangoFontDescription is interpreted in the same way as
-by pango_itemize(), and the family name may be a comma separated
-list of figures. If characters from multiple of these families
-would be used to render the string, then the returned fonts would
-be a composite of the metrics for the fonts loaded for the
-individual families.
+The `PangoFontDescription` is interpreted in the same way as by [func@itemize],
+and the family name may be a comma separated list of names. If characters
+from multiple of these families would be used to render the string, then
+the returned fonts would be a composite of the metrics for the fonts loaded
+for the individual families.
 
 
 </description>
 <parameters>
 <parameter name="context">
-<parameter_description> a #PangoContext
+<parameter_description> a `PangoContext`
 </parameter_description>
 </parameter>
 <parameter name="desc">
-<parameter_description> a #PangoFontDescription structure.  %NULL means that the
+<parameter_description> a `PangoFontDescription` structure. %NULL means that the
 font description from the context will be used.
 </parameter_description>
 </parameter>
@@ -3702,13 +4527,13 @@ font description from the context will be used.
 <parameter_description> language tag used to determine which script to get
 the metrics for. %NULL means that the language tag from the context
 will be used. If no language tag is set on the context, metrics
-for the default language (as determined by pango_language_get_default())
+for the default language (as determined by [func@Pango.Language.get_default]
 will be returned.
 </parameter_description>
 </parameter>
 </parameters>
-<return> a #PangoFontMetrics object. The caller must call pango_font_metrics_unref()
-when finished using the object.
+<return> a `PangoFontMetrics` object. The caller must call
+[method@Pango.FontMetrics.unref] when finished using the object.
 </return>
 </function>
 
@@ -3722,7 +4547,7 @@ Since: 1.44
 </description>
 <parameters>
 <parameter name="context">
-<parameter_description> a #PangoContext
+<parameter_description> a `PangoContext`
 </parameter_description>
 </parameter>
 </parameters>
@@ -3731,23 +4556,25 @@ Since: 1.44
 
 <function name="pango_context_get_serial">
 <description>
-Returns the current serial number of @context.  The serial number is
-initialized to an small number larger than zero when a new context
-is created and is increased whenever the context is changed using any
-of the setter functions, or the #PangoFontMap it uses to find fonts has
-changed. The serial may wrap, but will never have the value 0. Since it
-can wrap, never compare it with &quot;less than&quot;, always use &quot;not equals&quot;.
+Returns the current serial number of @context.
+
+The serial number is initialized to an small number larger than zero
+when a new context is created and is increased whenever the context
+is changed using any of the setter functions, or the `PangoFontMap` it
+uses to find fonts has changed. The serial may wrap, but will never
+have the value 0. Since it can wrap, never compare it with &quot;less than&quot;,
+always use &quot;not equals&quot;.
 
-This can be used to automatically detect changes to a #PangoContext, and
-is only useful when implementing objects that need update when their
-#PangoContext changes, like #PangoLayout.
+This can be used to automatically detect changes to a `PangoContext`,
+and is only useful when implementing objects that need update when their
+`PangoContext` changes, like `PangoLayout`.
 
 Since: 1.32.4
 
 </description>
 <parameters>
 <parameter name="context">
-<parameter_description> a #PangoContext
+<parameter_description> a `PangoContext`
 </parameter_description>
 </parameter>
 </parameters>
@@ -3763,13 +4590,13 @@ List all families for a context.
 </description>
 <parameters>
 <parameter name="context">
-<parameter_description> a #PangoContext
+<parameter_description> a `PangoContext`
 </parameter_description>
 </parameter>
 <parameter name="families">
-<parameter_description> location to store a pointer to
-an array of #PangoFontFamily *. This array should be freed
-with g_free().
+<parameter_description> location
+to store a pointer to an array of `PangoFontFamily`. This array should
+be freed with g_free().
 </parameter_description>
 </parameter>
 <parameter name="n_families">
@@ -3789,15 +4616,15 @@ that is the closest match for @desc.
 </description>
 <parameters>
 <parameter name="context">
-<parameter_description> a #PangoContext
+<parameter_description> a `PangoContext`
 </parameter_description>
 </parameter>
 <parameter name="desc">
-<parameter_description> a #PangoFontDescription describing the font to load
+<parameter_description> a `PangoFontDescription` describing the font to load
 </parameter_description>
 </parameter>
 </parameters>
-<return> the newly allocated #PangoFont
+<return> the newly allocated `PangoFont`
 that was loaded, or %NULL if no font matched.
 </return>
 </function>
@@ -3811,43 +4638,42 @@ a font matching @desc.
 </description>
 <parameters>
 <parameter name="context">
-<parameter_description> a #PangoContext
+<parameter_description> a `PangoContext`
 </parameter_description>
 </parameter>
 <parameter name="desc">
-<parameter_description> a #PangoFontDescription describing the fonts to load
+<parameter_description> a `PangoFontDescription` describing the fonts to load
 </parameter_description>
 </parameter>
 <parameter name="language">
-<parameter_description> a #PangoLanguage the fonts will be used for
+<parameter_description> a `PangoLanguage` the fonts will be used for
 </parameter_description>
 </parameter>
 </parameters>
 <return> the newly allocated
-#PangoFontset loaded, or %NULL if no font matched.
+`PangoFontset` loaded, or %NULL if no font matched.
 </return>
 </function>
 
 <function name="pango_context_new">
 <description>
-Creates a new #PangoContext initialized to default values.
+Creates a new `PangoContext` initialized to default values.
 
 This function is not particularly useful as it should always
-be followed by a pango_context_set_font_map() call, and the
-function pango_font_map_create_context() does these two steps
+be followed by a [method@Pango.Context.set_font_map] call, and the
+function [method@Pango.FontMap.create_context] does these two steps
 together and hence users are recommended to use that.
 
 If you are using Pango as part of a higher-level system,
-that system may have it's own way of create a #PangoContext.
-For instance, the GTK+ toolkit has, among others,
-gdk_pango_context_get_for_screen(), and
-gtk_widget_get_pango_context().  Use those instead.
+that system may have it's own way of create a `PangoContext`.
+For instance, the GTK toolkit has, among others,
+`gtk_widget_get_pango_context()`. Use those instead.
 
 
 </description>
 <parameters>
 </parameters>
-<return> the newly allocated #PangoContext, which should
+<return> the newly allocated `PangoContext`, which should
 be freed with g_object_unref().
 </return>
 </function>
@@ -3859,14 +4685,14 @@ Sets the base direction for the context.
 The base direction is used in applying the Unicode bidirectional
 algorithm; if the @direction is %PANGO_DIRECTION_LTR or
 %PANGO_DIRECTION_RTL, then the value will be used as the paragraph
-direction in the Unicode bidirectional algorithm.  A value of
+direction in the Unicode bidirectional algorithm. A value of
 %PANGO_DIRECTION_WEAK_LTR or %PANGO_DIRECTION_WEAK_RTL is used only
 for paragraphs that do not contain any strong characters themselves.
 
 </description>
 <parameters>
 <parameter name="context">
-<parameter_description> a #PangoContext
+<parameter_description> a `PangoContext`
 </parameter_description>
 </parameter>
 <parameter name="direction">
@@ -3888,7 +4714,7 @@ Since: 1.16
 </description>
 <parameters>
 <parameter name="context">
-<parameter_description> a #PangoContext
+<parameter_description> a `PangoContext`
 </parameter_description>
 </parameter>
 <parameter name="gravity">
@@ -3906,7 +4732,7 @@ Set the default font description for the context
 </description>
 <parameters>
 <parameter name="context">
-<parameter_description> a #PangoContext
+<parameter_description> a `PangoContext`
 </parameter_description>
 </parameter>
 <parameter name="desc">
@@ -3919,18 +4745,21 @@ Set the default font description for the context
 
 <function name="pango_context_set_font_map">
 <description>
-Sets the font map to be searched when fonts are looked-up in this context.
-This is only for internal use by Pango backends, a #PangoContext obtained
-via one of the recommended methods should already have a suitable font map.
+Sets the font map to be searched when fonts are looked-up
+in this context.
+
+This is only for internal use by Pango backends, a `PangoContext`
+obtained via one of the recommended methods should already have a
+suitable font map.
 
 </description>
 <parameters>
 <parameter name="context">
-<parameter_description> a #PangoContext
+<parameter_description> a `PangoContext`
 </parameter_description>
 </parameter>
 <parameter name="font_map">
-<parameter_description> the #PangoFontMap to set.
+<parameter_description> the `PangoFontMap` to set.
 </parameter_description>
 </parameter>
 </parameters>
@@ -3941,16 +4770,17 @@ via one of the recommended methods should already have a suitable font map.
 <description>
 Sets the gravity hint for the context.
 
-The gravity hint is used in laying vertical text out, and is only relevant
-if gravity of the context as returned by pango_context_get_gravity()
-is set %PANGO_GRAVITY_EAST or %PANGO_GRAVITY_WEST.
+The gravity hint is used in laying vertical text out, and
+is only relevant if gravity of the context as returned by
+[method@Pango.Context.get_gravity] is set to %PANGO_GRAVITY_EAST
+or %PANGO_GRAVITY_WEST.
 
 Since: 1.16
 
 </description>
 <parameters>
 <parameter name="context">
-<parameter_description> a #PangoContext
+<parameter_description> a `PangoContext`
 </parameter_description>
 </parameter>
 <parameter name="hint">
@@ -3963,14 +4793,15 @@ Since: 1.16
 
 <function name="pango_context_set_language">
 <description>
-Sets the global language tag for the context.  The default language
-for the locale of the running process can be found using
-pango_language_get_default().
+Sets the global language tag for the context.
+
+The default language for the locale of the running process
+can be found using [func@Pango.Language.get_default].
 
 </description>
 <parameters>
 <parameter name="context">
-<parameter_description> a #PangoContext
+<parameter_description> a `PangoContext`
 </parameter_description>
 </parameter>
 <parameter name="language">
@@ -3984,22 +4815,24 @@ pango_language_get_default().
 <function name="pango_context_set_matrix">
 <description>
 Sets the transformation matrix that will be applied when rendering
-with this context. Note that reported metrics are in the user space
-coordinates before the application of the matrix, not device-space
-coordinates after the application of the matrix. So, they don't scale
-with the matrix, though they may change slightly for different
-matrices, depending on how the text is fit to the pixel grid.
+with this context.
+
+Note that reported metrics are in the user space coordinates before
+the application of the matrix, not device-space coordinates after the
+application of the matrix. So, they don't scale with the matrix, though
+they may change slightly for different matrices, depending on how the
+text is fit to the pixel grid.
 
 Since: 1.6
 
 </description>
 <parameters>
 <parameter name="context">
-<parameter_description> a #PangoContext
+<parameter_description> a `PangoContext`
 </parameter_description>
 </parameter>
 <parameter name="matrix">
-<parameter_description> a #PangoMatrix, or %NULL to unset any existing
+<parameter_description> a `PangoMatrix`, or %NULL to unset any existing
 matrix. (No matrix set is the same as setting the identity matrix.)
 </parameter_description>
 </parameter>
@@ -4024,7 +4857,7 @@ Since: 1.44
 </description>
 <parameters>
 <parameter name="context">
-<parameter_description> a #PangoContext
+<parameter_description> a `PangoContext`
 </parameter_description>
 </parameter>
 <parameter name="round_positions">
@@ -4044,7 +4877,7 @@ Since: 1.24
 </description>
 <parameters>
 <parameter name="font">
-<parameter_description> A #PangoCoreTextFont
+<parameter_description> A `PangoCoreTextFont`
 </parameter_description>
 </parameter>
 </parameters>
@@ -4055,27 +4888,26 @@ Since: 1.24
 
 <function name="pango_coverage_copy">
 <description>
-Copy an existing #PangoCoverage. (This function may now be unnecessary
-since we refcount the structure. File a bug if you use it.)
+Copy an existing `PangoCoverage`.
 
 
 </description>
 <parameters>
 <parameter name="coverage">
-<parameter_description> a #PangoCoverage
+<parameter_description> a `PangoCoverage`
 </parameter_description>
 </parameter>
 </parameters>
-<return> the newly allocated #PangoCoverage,
-with a reference count of one, which should be freed
-with pango_coverage_unref().
+<return> the newly allocated `PangoCoverage`,
+with a reference count of one, which should be freed with
+[method@Pango.Coverage.unref].
 </return>
 </function>
 
 <function name="pango_coverage_from_bytes">
 <description>
-Convert data generated from pango_coverage_to_bytes() back
-to a #PangoCoverage
+Convert data generated from pango_coverage_to_bytes()
+back to a `PangoCoverage`.
 
 Deprecated: 1.44: This returns %NULL
 
@@ -4083,7 +4915,7 @@ Deprecated: 1.44: This returns %NULL
 <parameters>
 <parameter name="bytes">
 <parameter_description> binary data
-representing a #PangoCoverage
+representing a `PangoCoverage`
 </parameter_description>
 </parameter>
 <parameter name="n_bytes">
@@ -4091,21 +4923,20 @@ representing a #PangoCoverage
 </parameter_description>
 </parameter>
 </parameters>
-<return> a newly allocated
-#PangoCoverage, or %NULL if the data was invalid.
+<return> a newly allocated `PangoCoverage`
 
 </return>
 </function>
 
 <function name="pango_coverage_get">
 <description>
-Determine whether a particular index is covered by @coverage
+Determine whether a particular index is covered by @coverage.
 
 
 </description>
 <parameters>
 <parameter name="coverage">
-<parameter_description> a #PangoCoverage
+<parameter_description> a `PangoCoverage`
 </parameter_description>
 </parameter>
 <parameter name="index_">
@@ -4128,11 +4959,11 @@ Deprecated: 1.44: This function does nothing
 </description>
 <parameters>
 <parameter name="coverage">
-<parameter_description> a #PangoCoverage
+<parameter_description> a `PangoCoverage`
 </parameter_description>
 </parameter>
 <parameter name="other">
-<parameter_description> another #PangoCoverage
+<parameter_description> another `PangoCoverage`
 </parameter_description>
 </parameter>
 </parameters>
@@ -4141,28 +4972,27 @@ Deprecated: 1.44: This function does nothing
 
 <function name="pango_coverage_new">
 <description>
-Create a new #PangoCoverage
+Create a new `PangoCoverage`
 
 
 </description>
 <parameters>
 </parameters>
-<return> the newly allocated #PangoCoverage,
-initialized to %PANGO_COVERAGE_NONE
-with a reference count of one, which
-should be freed with pango_coverage_unref().
+<return> the newly allocated `PangoCoverage`, initialized
+to %PANGO_COVERAGE_NONE with a reference count of one, which
+should be freed with [method@Pango.Coverage.unref].
 </return>
 </function>
 
 <function name="pango_coverage_ref">
 <description>
-Increase the reference count on the #PangoCoverage by one
+Increase the reference count on the `PangoCoverage` by one.
 
 
 </description>
 <parameters>
 <parameter name="coverage">
-<parameter_description> a #PangoCoverage
+<parameter_description> a `PangoCoverage`
 </parameter_description>
 </parameter>
 </parameters>
@@ -4177,7 +5007,7 @@ Modify a particular index within @coverage
 </description>
 <parameters>
 <parameter name="coverage">
-<parameter_description> a #PangoCoverage
+<parameter_description> a `PangoCoverage`
 </parameter_description>
 </parameter>
 <parameter name="index_">
@@ -4194,14 +5024,14 @@ Modify a particular index within @coverage
 
 <function name="pango_coverage_to_bytes">
 <description>
-Convert a #PangoCoverage structure into a flat binary format
+Convert a `PangoCoverage` structure into a flat binary format.
 
 Deprecated: 1.44: This returns %NULL
 
 </description>
 <parameters>
 <parameter name="coverage">
-<parameter_description> a #PangoCoverage
+<parameter_description> a `PangoCoverage`
 </parameter_description>
 </parameter>
 <parameter name="bytes">
@@ -4219,13 +5049,14 @@ location to store result (must be freed with g_free())
 
 <function name="pango_coverage_unref">
 <description>
-Decrease the reference count on the #PangoCoverage by one.
+Decrease the reference count on the `PangoCoverage` by one.
+
 If the result is zero, free the coverage and all associated memory.
 
 </description>
 <parameters>
 <parameter name="coverage">
-<parameter_description> a #PangoCoverage
+<parameter_description> a `PangoCoverage`
 </parameter_description>
 </parameter>
 </parameters>
@@ -4234,11 +5065,15 @@ If the result is zero, free the coverage and all associated memory.
 
 <function name="pango_default_break">
 <description>
-This is the default break algorithm. It applies Unicode
-rules without language-specific tailoring, therefore
-the @analyis argument is unused and can be %NULL.
+This is the default break algorithm.
+
+It applies Unicode rules without language-specific
+tailoring, therefore the @analyis argument is unused
+and can be %NULL.
 
-See pango_tailor_break() for language-specific breaks.
+See [func@Pango.tailor_break] for language-specific breaks.
+
+See [func@Pango.attr_break] for attribute-based customization.
 
 </description>
 <parameters>
@@ -4251,7 +5086,7 @@ See pango_tailor_break() for language-specific breaks.
 </parameter_description>
 </parameter>
 <parameter name="analysis">
-<parameter_description> a #PangoAnalysis for the @text
+<parameter_description> a `PangoAnalysis` structure for the @text
 </parameter_description>
 </parameter>
 <parameter name="attrs">
@@ -4268,19 +5103,21 @@ See pango_tailor_break() for language-specific breaks.
 
 <function name="pango_extents_to_pixels">
 <description>
-Converts extents from Pango units to device units, dividing by the
-%PANGO_SCALE factor and performing rounding.
+Converts extents from Pango units to device units.
+
+The conversion is done by dividing by the %PANGO_SCALE factor and
+performing rounding.
 
-The @inclusive rectangle is converted by flooring the x/y coordinates and extending
-width/height, such that the final rectangle completely includes the original
-rectangle.
+The @inclusive rectangle is converted by flooring the x/y coordinates
+and extending width/height, such that the final rectangle completely
+includes the original rectangle.
 
 The @nearest rectangle is converted by rounding the coordinates
 of the rectangle to the nearest device unit (pixel).
 
 The rule to which argument to use is: if you want the resulting device-space
-rectangle to completely contain the original rectangle, pass it in as @inclusive.
-If you want two touching-but-not-overlapping rectangles stay
+rectangle to completely contain the original rectangle, pass it in as
+@inclusive. If you want two touching-but-not-overlapping rectangles stay
 touching-but-not-overlapping after rounding to device units, pass them in
 as @nearest.
 
@@ -4289,11 +5126,11 @@ Since: 1.16
 </description>
 <parameters>
 <parameter name="inclusive">
-<parameter_description> rectangle to round to pixels inclusively, or %NULL.
+<parameter_description> rectangle to round to pixels inclusively
 </parameter_description>
 </parameter>
 <parameter name="nearest">
-<parameter_description> rectangle to round to nearest pixels, or %NULL.
+<parameter_description> rectangle to round to nearest pixels
 </parameter_description>
 </parameter>
 </parameters>
@@ -4302,9 +5139,11 @@ Since: 1.16
 
 <function name="pango_fc_decoder_get_charset">
 <description>
-Generates an #FcCharSet of supported characters for the fcfont
-given.  The returned #FcCharSet will be a reference to an
-internal value stored by the #PangoFcDecoder and must not
+Generates an `FcCharSet` of supported characters for the @fcfont
+given.
+
+The returned `FcCharSet` will be a reference to an
+internal value stored by the `PangoFcDecoder` and must not
 be modified or freed.
 
 Since: 1.6
@@ -4312,15 +5151,15 @@ Since: 1.6
 </description>
 <parameters>
 <parameter name="decoder">
-<parameter_description> a #PangoFcDecoder
+<parameter_description> a `PangoFcDecoder`
 </parameter_description>
 </parameter>
 <parameter name="fcfont">
-<parameter_description> the #PangoFcFont to query.
+<parameter_description> the `PangoFcFont` to query.
 </parameter_description>
 </parameter>
 </parameters>
-<return> the #FcCharset for @fcfont; must not
+<return> the `FcCharset` for @fcfont; must not
 be modified or freed.
 
 </return>
@@ -4328,8 +5167,10 @@ be modified or freed.
 
 <function name="pango_fc_decoder_get_glyph">
 <description>
-Generates a #PangoGlyph for the given Unicode point using the
-custom decoder. For complex scripts where there can be multiple
+Generates a `PangoGlyph` for the given Unicode point using the
+custom decoder.
+
+For complex scripts where there can be multiple
 glyphs for a single character, the decoder will return whatever
 glyph is most convenient for it. (Usually whatever glyph is directly
 in the fonts character map table.)
@@ -4339,15 +5180,15 @@ Since: 1.6
 </description>
 <parameters>
 <parameter name="decoder">
-<parameter_description> a #PangoFcDecoder
+<parameter_description> a `PangoFcDecoder`
 </parameter_description>
 </parameter>
 <parameter name="fcfont">
-<parameter_description> a #PangoFcFont to query.
+<parameter_description> a `PangoFcFont` to query.
 </parameter_description>
 </parameter>
 <parameter name="wc">
-<parameter_description> the Unicode code point to convert to a single #PangoGlyph.
+<parameter_description> the Unicode code point to convert to a single `PangoGlyph`.
 </parameter_description>
 </parameter>
 </parameters>
@@ -4359,17 +5200,19 @@ covered by the font.
 
 <function name="pango_fc_font_description_from_pattern">
 <description>
-Creates a #PangoFontDescription that matches the specified
-Fontconfig pattern as closely as possible. Many possible Fontconfig
-pattern values, such as %FC_RASTERIZER or %FC_DPI, don't make sense in
-the context of #PangoFontDescription, so will be ignored.
+Creates a `PangoFontDescription` that matches the specified
+Fontconfig pattern as closely as possible.
+
+Many possible Fontconfig pattern values, such as %FC_RASTERIZER
+or %FC_DPI, don't make sense in the context of `PangoFontDescription`,
+so will be ignored.
 
 Since: 1.4
 
 </description>
 <parameters>
 <parameter name="pattern">
-<parameter_description> a #FcPattern
+<parameter_description> a `FcPattern`
 </parameter_description>
 </parameter>
 <parameter name="include_size">
@@ -4379,7 +5222,7 @@ the @pattern; otherwise the resulting pattern will be unsized.
 </parameter_description>
 </parameter>
 </parameters>
-<return> a new #PangoFontDescription. Free with
+<return> a new `PangoFontDescription`. Free with
 pango_font_description_free().
 
 </return>
@@ -4388,15 +5231,17 @@ pango_font_description_free().
 <function name="pango_fc_font_get_glyph">
 <description>
 Gets the glyph index for a given Unicode character
-for @font. If you only want to determine
-whether the font has the glyph, use pango_fc_font_has_char().
+for @font.
+
+If you only want to determine whether the font has
+the glyph, use [method PangoFc Font.has_char].
 
 Since: 1.4
 
 </description>
 <parameters>
 <parameter name="font">
-<parameter_description> a #PangoFcFont
+<parameter_description> a `PangoFcFont`
 </parameter_description>
 </parameter>
 <parameter name="wc">
@@ -4420,16 +5265,17 @@ The returned array is only valid as long as the font
 and its fontmap are valid.
 
 Since: 1.48
+Deprecated: 1.50: Use pango_font_get_language()
 
 </description>
 <parameters>
 <parameter name="font">
-<parameter_description> a #PangoFcFont
+<parameter_description> a `PangoFcFont`
 </parameter_description>
 </parameter>
 </parameters>
 <return> a %NULL-terminated
-array of PangoLanguage*
+array of `PangoLanguage`*
 
 </return>
 </function>
@@ -4443,7 +5289,7 @@ Since: 1.48
 </description>
 <parameters>
 <parameter name="font">
-<parameter_description> a #PangoFcFont
+<parameter_description> a `PangoFcFont`
 </parameter_description>
 </parameter>
 </parameters>
@@ -4454,9 +5300,10 @@ Since: 1.48
 
 <function name="pango_fc_font_get_raw_extents">
 <description>
-Gets the extents of a single glyph from a font. The extents are in
-user space; that is, they are not transformed by any matrix in effect
-for the font.
+Gets the extents of a single glyph from a font.
+
+The extents are in user space; that is, they are not transformed
+by any matrix in effect for the font.
 
 Long term, this functionality probably belongs in the default
 implementation of the get_glyph_extents() virtual function.
@@ -4469,7 +5316,7 @@ Since: 1.6
 </description>
 <parameters>
 <parameter name="fcfont">
-<parameter_description> a #PangoFcFont
+<parameter_description> a `PangoFcFont`
 </parameter_description>
 </parameter>
 <parameter name="glyph">
@@ -4478,12 +5325,12 @@ Since: 1.6
 </parameter>
 <parameter name="ink_rect">
 <parameter_description> location to store ink extents of the
-glyph, or %NULL
+glyph
 </parameter_description>
 </parameter>
 <parameter name="logical_rect">
 <parameter_description> location to store logical extents
-of the glyph or %NULL
+of the glyph
 </parameter_description>
 </parameter>
 </parameters>
@@ -4492,8 +5339,8 @@ of the glyph or %NULL
 
 <function name="pango_fc_font_get_unknown_glyph">
 <description>
-Returns the index of a glyph suitable for drawing @wc as an
-unknown character.
+Returns the index of a glyph suitable for drawing @wc
+as an unknown character.
 
 Use PANGO_GET_UNKNOWN_GLYPH() instead.
 
@@ -4502,7 +5349,7 @@ Since: 1.4
 </description>
 <parameters>
 <parameter name="font">
-<parameter_description> a #PangoFcFont
+<parameter_description> a `PangoFcFont`
 </parameter_description>
 </parameter>
 <parameter name="wc">
@@ -4520,12 +5367,12 @@ Since: 1.4
 Determines whether @font has a glyph for the codepoint @wc.
 
 Since: 1.4
-Deprecated: 1.44: Use pango_font_has_char()
+Deprecated: 1.44: Use [method Pango Font.has_char]
 
 </description>
 <parameters>
 <parameter name="font">
-<parameter_description> a #PangoFcFont
+<parameter_description> a `PangoFcFont`
 </parameter_description>
 </parameter>
 <parameter name="wc">
@@ -4545,18 +5392,17 @@ in @glyphs according to kerning information in @font.
 
 Since 1.44, it does nothing.
 
-
 Since: 1.4
 Deprecated: 1.32
 
 </description>
 <parameters>
 <parameter name="font">
-<parameter_description> a #PangoFcFont
+<parameter_description> a `PangoFcFont`
 </parameter_description>
 </parameter>
 <parameter name="glyphs">
-<parameter_description> a #PangoGlyphString
+<parameter_description> a `PangoGlyphString`
 </parameter_description>
 </parameter>
 </parameters>
@@ -4619,9 +5465,10 @@ Since: 1.24
 
 <function name="pango_fc_font_lock_face">
 <description>
-Gets the FreeType `FT_Face` associated with a font,
+Gets the FreeType `FT_Face` associated with a font.
+
 This face will be kept around until you call
-pango_fc_font_unlock_face().
+[method PangoFc Font.unlock_face].
 
 Since: 1.4
 Deprecated: 1.44: Use pango_font_get_hb_font() instead
@@ -4629,7 +5476,7 @@ Deprecated: 1.44: Use pango_font_get_hb_font() instead
 </description>
 <parameters>
 <parameter name="font">
-<parameter_description> a #PangoFcFont.
+<parameter_description> a `PangoFcFont`.
 </parameter_description>
 </parameter>
 </parameters>
@@ -4640,11 +5487,12 @@ Deprecated: 1.44: Use pango_font_get_hb_font() instead
 
 <function name="pango_fc_font_map_add_decoder_find_func">
 <description>
-This function saves a callback method in the #PangoFcFontMap that
-will be called whenever new fonts are created.  If the
-function returns a #PangoFcDecoder, that decoder will be used to
-determine both coverage via a #FcCharSet and a one-to-one mapping of
-characters to glyphs.  This will allow applications to have
+This function saves a callback method in the `PangoFcFontMap` that
+will be called whenever new fonts are created.
+
+If the function returns a `PangoFcDecoder`, that decoder will be used
+to determine both coverage via a `FcCharSet` and a one-to-one mapping
+of characters to glyphs. This will allow applications to have
 application-specific encodings for various fonts.
 
 Since: 1.6
@@ -4652,11 +5500,11 @@ Since: 1.6
 </description>
 <parameters>
 <parameter name="fcfontmap">
-<parameter_description> The #PangoFcFontMap to add this method to.
+<parameter_description> The `PangoFcFontMap` to add this method to.
 </parameter_description>
 </parameter>
 <parameter name="findfunc">
-<parameter_description> The #PangoFcDecoderFindFunc callback function
+<parameter_description> The `PangoFcDecoderFindFunc` callback function
 </parameter_description>
 </parameter>
 <parameter name="user_data">
@@ -4664,7 +5512,7 @@ Since: 1.6
 </parameter_description>
 </parameter>
 <parameter name="dnotify">
-<parameter_description> A #GDestroyNotify callback that will be called when the
+<parameter_description> A `GDestroyNotify` callback that will be called when the
 fontmap is finalized and the decoder is released.
 </parameter_description>
 </parameter>
@@ -4674,8 +5522,9 @@ fontmap is finalized and the decoder is released.
 
 <function name="pango_fc_font_map_cache_clear">
 <description>
-Clear all cached information and fontsets for this font map;
-this should be called whenever there is a change in the
+Clear all cached information and fontsets for this font map.
+
+This should be called whenever there is a change in the
 output of the default_substitute() virtual function of the
 font map, or if fontconfig has been reinitialized to new
 configuration.
@@ -4685,7 +5534,7 @@ Since: 1.4
 </description>
 <parameters>
 <parameter name="fcfontmap">
-<parameter_description> a #PangoFcFontMap
+<parameter_description> a `PangoFcFontMap`
 </parameter_description>
 </parameter>
 </parameters>
@@ -4694,17 +5543,19 @@ Since: 1.4
 
 <function name="pango_fc_font_map_config_changed">
 <description>
-Informs font map that the fontconfig configuration (ie, FcConfig object)
-used by this font map has changed.  This currently calls
-pango_fc_font_map_cache_clear() which ensures that list of fonts, etc
-will be regenerated using the updated configuration.
+Informs font map that the fontconfig configuration (i.e., FcConfig
+object) used by this font map has changed.
+
+This currently calls [method@PangoFc.FontMap.cache_clear] which
+ensures that list of fonts, etc will be regenerated using the
+updated configuration.
 
 Since: 1.38
 
 </description>
 <parameters>
 <parameter name="fcfontmap">
-<parameter_description> a #PangoFcFontMap
+<parameter_description> a `PangoFcFontMap`
 </parameter_description>
 </parameter>
 </parameters>
@@ -4713,11 +5564,12 @@ Since: 1.38
 
 <function name="pango_fc_font_map_create_context">
 <description>
-Creates a new context for this fontmap. This function is intended
-only for backend implementations deriving from #PangoFcFontMap;
-it is possible that a backend will store additional information
-needed for correct operation on the #PangoContext after calling
-this function.
+Creates a new context for this fontmap.
+
+This function is intended only for backend implementations deriving
+from `PangoFcFontMap`; it is possible that a backend will store
+additional information needed for correct operation on the `PangoContext`
+after calling this function.
 
 Since: 1.4
 
@@ -4726,34 +5578,36 @@ Deprecated: 1.22: Use pango_font_map_create_context() instead.
 </description>
 <parameters>
 <parameter name="fcfontmap">
-<parameter_description> a #PangoFcFontMap
+<parameter_description> a `PangoFcFontMap`
 </parameter_description>
 </parameter>
 </parameters>
-<return> a new #PangoContext
+<return> a new `PangoContext`
 
 </return>
 </function>
 
 <function name="pango_fc_font_map_find_decoder">
 <description>
-Finds the decoder to use for @pattern.  Decoders can be added to
-a font map using pango_fc_font_map_add_decoder_find_func().
+Finds the decoder to use for @pattern.
+
+Decoders can be added to a font map using
+[method@PangoFc.FontMap.add_decoder_find_func].
 
 Since: 1.26
 
 </description>
 <parameters>
 <parameter name="fcfontmap">
-<parameter_description> The #PangoFcFontMap to use.
+<parameter_description> The `PangoFcFontMap` to use.
 </parameter_description>
 </parameter>
 <parameter name="pattern">
-<parameter_description> The #FcPattern to find the decoder for.
+<parameter_description> The `FcPattern` to find the decoder for.
 </parameter_description>
 </parameter>
 </parameters>
-<return> a newly created #PangoFcDecoder
+<return> a newly created `PangoFcDecoder`
 object or %NULL if no decoder is set for @pattern.
 
 </return>
@@ -4763,72 +5617,76 @@ object or %NULL if no decoder is set for @pattern.
 <description>
 Fetches the `FcConfig` attached to a font map.
 
-See also: pango_fc_font_map_set_config()
+See also: [method@PangoFc.FontMap.set_config].
 
 Since: 1.38
 
 </description>
 <parameters>
 <parameter name="fcfontmap">
-<parameter_description> a #PangoFcFontMap
+<parameter_description> a `PangoFcFontMap`
 </parameter_description>
 </parameter>
 </parameters>
-<return> the `FcConfig` object attached to @fcfontmap, which
-might be %NULL.
+<return> the `FcConfig` object attached to
+@fcfontmap, which might be %NULL. The return value is
+owned by Pango and should not be freed.
 
 </return>
 </function>
 
 <function name="pango_fc_font_map_get_hb_face">
 <description>
-Retrieves the `hb_face_t` for the given #PangoFcFont.
+Retrieves the `hb_face_t` for the given `PangoFcFont`.
 
 Since: 1.44
 
 </description>
 <parameters>
 <parameter name="fcfontmap">
-<parameter_description> a #PangoFcFontMap
+<parameter_description> a `PangoFcFontMap`
 </parameter_description>
 </parameter>
 <parameter name="fcfont">
-<parameter_description> a #PangoFcFont
+<parameter_description> a `PangoFcFont`
 </parameter_description>
 </parameter>
 </parameters>
-<return> the `hb_face_t` for the given Pango font
+<return> the `hb_face_t`
+for the given font
 
 </return>
 </function>
 
 <function name="pango_fc_font_map_set_config">
 <description>
-Set the FcConfig for this font map to use.  The default value
+Set the `FcConfig` for this font map to use.
+
+The default value
 is %NULL, which causes Fontconfig to use its global &quot;current config&quot;.
-You can create a new FcConfig object and use this API to attach it
+You can create a new `FcConfig` object and use this API to attach it
 to a font map.
 
 This is particularly useful for example, if you want to use application
-fonts with Pango.  For that, you would create a fresh FcConfig, add your
+fonts with Pango. For that, you would create a fresh `FcConfig`, add your
 app fonts to it, and attach it to a new Pango font map.
 
 If @fcconfig is different from the previous config attached to the font map,
-pango_fc_font_map_config_changed() is called.
+[method@PangoFc.FontMap.config_changed] is called.
 
-This function acquires a reference to the FcConfig object; the caller
-does NOT need to retain a reference.
+This function acquires a reference to the `FcConfig` object; the caller
+does **not** need to retain a reference.
 
 Since: 1.38
 
 </description>
 <parameters>
 <parameter name="fcfontmap">
-<parameter_description> a #PangoFcFontMap
+<parameter_description> a `PangoFcFontMap`
 </parameter_description>
 </parameter>
 <parameter name="fcconfig">
-<parameter_description> a `FcConfig`, or %NULL
+<parameter_description> a `FcConfig`
 </parameter_description>
 </parameter>
 </parameters>
@@ -4838,8 +5696,10 @@ Since: 1.38
 <function name="pango_fc_font_map_set_default_substitute">
 <description>
 Sets a function that will be called to do final configuration
-substitution on a #FcPattern before it is used to load
-the font. This function can be used to do things like set
+substitution on a `FcPattern` before it is used to load
+the font.
+
+This function can be used to do things like set
 hinting and antialiasing options.
 
 Since: 1.48
@@ -4847,12 +5707,11 @@ Since: 1.48
 </description>
 <parameters>
 <parameter name="fontmap">
-<parameter_description> a #PangoFcFontMap
+<parameter_description> a `PangoFcFontMap`
 </parameter_description>
 </parameter>
 <parameter name="func">
-<parameter_description> function to call to to do final config tweaking
-on #FcPattern objects.
+<parameter_description> function to call to to do final config tweaking on `FcPattern` objects
 </parameter_description>
 </parameter>
 <parameter name="data">
@@ -4860,7 +5719,7 @@ on #FcPattern objects.
 </parameter_description>
 </parameter>
 <parameter name="notify">
-<parameter_description> function to call when @data is no longer used.
+<parameter_description> function to call when @data is no longer used
 </parameter_description>
 </parameter>
 </parameters>
@@ -4870,18 +5729,21 @@ on #FcPattern objects.
 <function name="pango_fc_font_map_shutdown">
 <description>
 Clears all cached information for the fontmap and marks
-all fonts open for the fontmap as dead. (See the shutdown()
-virtual function of #PangoFcFont.) This function might be used
-by a backend when the underlying windowing system for the font
-map exits. This function is only intended to be called
-only for backend implementations deriving from #PangoFcFontMap.
+all fonts open for the fontmap as dead.
+
+See the shutdown() virtual function of `PangoFcFont`.
+
+This function might be used by a backend when the underlying
+windowing system for the font map exits. This function is only
+intended to be called only for backend implementations deriving
+from `PangoFcFontMap`.
 
 Since: 1.4
 
 </description>
 <parameters>
 <parameter name="fcfontmap">
-<parameter_description> a #PangoFcFontMap
+<parameter_description> a `PangoFcFontMap`
 </parameter_description>
 </parameter>
 </parameters>
@@ -4890,9 +5752,10 @@ Since: 1.4
 
 <function name="pango_fc_font_map_substitute_changed">
 <description>
-Call this function any time the results of the
-default substitution function set with
-pango_fc_font_map_set_default_substitute() change.
+Call this function any time the results of the default
+substitution function set with
+[method@PangoFc.FontMap.set_default_substitute] change.
+
 That is, if your substitution function will return different
 results for the same input pattern, you must call this function.
 
@@ -4901,7 +5764,7 @@ Since: 1.48
 </description>
 <parameters>
 <parameter name="fontmap">
-<parameter_description> a #PangoFcFontMap
+<parameter_description> a `PangoFcFontMap`
 </parameter_description>
 </parameter>
 </parameters>
@@ -4911,7 +5774,7 @@ Since: 1.48
 <function name="pango_fc_font_unlock_face">
 <description>
 Releases a font previously obtained with
-pango_fc_font_lock_face().
+[method PangoFc Font.lock_face].
 
 Since: 1.4
 Deprecated: 1.44: Use pango_font_get_hb_font() instead
@@ -4919,7 +5782,7 @@ Deprecated: 1.44: Use pango_font_get_hb_font() instead
 </description>
 <parameters>
 <parameter name="font">
-<parameter_description> a #PangoFcFont.
+<parameter_description> a `PangoFcFont`.
 </parameter_description>
 </parameter>
 </parameters>
@@ -4928,8 +5791,9 @@ Deprecated: 1.44: Use pango_font_get_hb_font() instead
 
 <function name="pango_fc_fontset_key_get_absolute_size">
 <description>
-Gets the absolute font size of @key in Pango units.  This is adjusted
-for both resolution and transformation matrix.
+Gets the absolute font size of @key in Pango units.
+
+This is adjusted for both resolution and transformation matrix.
 
 Since: 1.24
 
@@ -5045,7 +5909,7 @@ Since: 1.4
 </description>
 <parameters>
 <parameter name="text">
-<parameter_description>   the text to process. Must be valid UTF-8
+<parameter_description> the text to process. Must be valid UTF-8
 </parameter_description>
 </parameter>
 <parameter name="length">
@@ -5087,16 +5951,20 @@ Deprecated: 1.38
 
 <function name="pango_find_paragraph_boundary">
 <description>
-Locates a paragraph boundary in @text. A boundary is caused by
-delimiter characters, such as a newline, carriage return, carriage
-return-newline pair, or Unicode paragraph separator character.  The
-index of the run of delimiters is returned in
-@paragraph_delimiter_index. The index of the start of the paragraph
-(index after all delimiters) is stored in @next_paragraph_start.
+Locates a paragraph boundary in @text.
+
+A boundary is caused by delimiter characters, such as
+a newline, carriage return, carriage return-newline pair,
+or Unicode paragraph separator character.
 
-If no delimiters are found, both @paragraph_delimiter_index and
-@next_paragraph_start are filled with the length of @text (an index one
-off the end).
+The index of the run of delimiters is returned in
+@paragraph_delimiter_index. The index of the start
+of the paragrap (index after all delimiters) is stored
+in @next_paragraph_start.
+
+If no delimiters are found, both @paragraph_delimiter_index
+and @next_paragraph_start are filled with the length of @text
+(an index one off the end).
 
 </description>
 <parameters>
@@ -5125,37 +5993,39 @@ paragraph
 <function name="pango_font_describe">
 <description>
 Returns a description of the font, with font size set in points.
-Use pango_font_describe_with_absolute_size() if you want the font
-size in device units.
+
+Use [method Pango Font.describe_with_absolute_size] if you want
+the font size in device units.
 
 
 </description>
 <parameters>
 <parameter name="font">
-<parameter_description> a #PangoFont
+<parameter_description> a `PangoFont`
 </parameter_description>
 </parameter>
 </parameters>
-<return> a newly-allocated #PangoFontDescription object.
+<return> a newly-allocated `PangoFontDescription` object.
 </return>
 </function>
 
 <function name="pango_font_describe_with_absolute_size">
 <description>
 Returns a description of the font, with absolute font size set
-(in device units). Use pango_font_describe() if you want the font
-size in points.
+in device units.
+
+Use [method Pango Font.describe] if you want the font size in points.
 
 Since: 1.14
 
 </description>
 <parameters>
 <parameter name="font">
-<parameter_description> a #PangoFont
+<parameter_description> a `PangoFont`
 </parameter_description>
 </parameter>
 </parameters>
-<return> a newly-allocated #PangoFontDescription object.
+<return> a newly-allocated `PangoFontDescription` object.
 
 </return>
 </function>
@@ -5165,12 +6035,12 @@ Since: 1.14
 Determines if the style attributes of @new_match are a closer match
 for @desc than those of @old_match are, or if @old_match is %NULL,
 determines if @new_match is a match at all.
-Approximate matching is done for
-weight and style; other style attributes must match exactly.
-Style attributes are all attributes other than family and size-related
-attributes.  Approximate matching for style considers PANGO_STYLE_OBLIQUE
-and PANGO_STYLE_ITALIC as matches, but not as good a match as when the
-styles are equal.
+
+Approximate matching is done for weight and style; other style attributes
+must match exactly. Style attributes are all attributes other than family
+and size-related attributes. Approximate matching for style considers
+%PANGO_STYLE_OBLIQUE and %PANGO_STYLE_ITALIC as matches, but not as good
+a match as when the styles are equal.
 
 Note that @old_match must match @desc.
 
@@ -5178,15 +6048,15 @@ Note that @old_match must match @desc.
 </description>
 <parameters>
 <parameter name="desc">
-<parameter_description> a #PangoFontDescription
+<parameter_description> a `PangoFontDescription`
 </parameter_description>
 </parameter>
 <parameter name="old_match">
-<parameter_description> a #PangoFontDescription, or %NULL
+<parameter_description> a `PangoFontDescription`, or %NULL
 </parameter_description>
 </parameter>
 <parameter name="new_match">
-<parameter_description> a #PangoFontDescription
+<parameter_description> a `PangoFontDescription`
 </parameter_description>
 </parameter>
 </parameters>
@@ -5196,62 +6066,64 @@ Note that @old_match must match @desc.
 
 <function name="pango_font_description_copy">
 <description>
-Make a copy of a #PangoFontDescription.
+Make a copy of a `PangoFontDescription`.
 
 
 </description>
 <parameters>
 <parameter name="desc">
-<parameter_description> a #PangoFontDescription, may be %NULL
+<parameter_description> a `PangoFontDescription`, may be %NULL
 </parameter_description>
 </parameter>
 </parameters>
-<return> the newly allocated
-#PangoFontDescription, which should be freed with
-pango_font_description_free(), or %NULL if @desc was
-%NULL.
+<return> the newly allocated `PangoFontDescription`,
+which should be freed with [method Pango FontDescription free],
+or %NULL if @desc was %NULL.
 </return>
 </function>
 
 <function name="pango_font_description_copy_static">
 <description>
-Like pango_font_description_copy(), but only a shallow copy is made
-of the family name and other allocated fields. The result can only
-be used until @desc is modified or freed. This is meant to be used
-when the copy is only needed temporarily.
+Make a copy of a `PangoFontDescription`, but don't duplicate
+allocated fields.
+
+This is like [method Pango FontDescription copy], but only a shallow
+copy is made of the family name and other allocated fields. The result
+can only be used until @desc is modified or freed. This is meant
+to be used when the copy is only needed temporarily.
 
 
 </description>
 <parameters>
 <parameter name="desc">
-<parameter_description> a #PangoFontDescription, may be %NULL
+<parameter_description> a `PangoFontDescription`, may be %NULL
 </parameter_description>
 </parameter>
 </parameters>
-<return> the newly allocated
-#PangoFontDescription, which should be freed with
-pango_font_description_free(), or %NULL if @desc was
-%NULL.
+<return> the newly allocated `PangoFontDescription`,
+which should be freed with [method Pango FontDescription free],
+or %NULL if @desc was %NULL.
 </return>
 </function>
 
 <function name="pango_font_description_equal">
 <description>
-Compares two font descriptions for equality. Two font descriptions
-are considered equal if the fonts they describe are provably identical.
-This means that their masks do not have to match, as long as other fields
-are all the same. (Two font descriptions may result in identical fonts
-being loaded, but still compare %FALSE.)
+Compares two font descriptions for equality.
+
+Two font descriptions are considered equal if the fonts they describe
+are provably identical. This means that their masks do not have to match,
+as long as other fields are all the same. (Two font descriptions may
+result in identical fonts being loaded, but still compare %FALSE.)
 
 
 </description>
 <parameters>
 <parameter name="desc1">
-<parameter_description> a #PangoFontDescription
+<parameter_description> a `PangoFontDescription`
 </parameter_description>
 </parameter>
 <parameter name="desc2">
-<parameter_description> another #PangoFontDescription
+<parameter_description> another `PangoFontDescription`
 </parameter_description>
 </parameter>
 </parameters>
@@ -5267,7 +6139,7 @@ Frees a font description.
 </description>
 <parameters>
 <parameter name="desc">
-<parameter_description> a #PangoFontDescription, may be %NULL
+<parameter_description> a `PangoFontDescription`, may be %NULL
 </parameter_description>
 </parameter>
 </parameters>
@@ -5276,8 +6148,9 @@ Frees a font description.
 
 <function name="pango_font_description_from_string">
 <description>
-Creates a new font description from a string representation in the
-form
+Creates a new font description from a string representation.
+
+The string must have the form
 
 &quot;\[FAMILY-LIST] \[STYLE-OPTIONS] \[SIZE] \[VARIATIONS]&quot;,
 
@@ -5293,7 +6166,8 @@ The following words are understood as styles:
 &quot;Normal&quot;, &quot;Roman&quot;, &quot;Oblique&quot;, &quot;Italic&quot;.
 
 The following words are understood as variants:
-&quot;Small-Caps&quot;.
+&quot;Small-Caps&quot;, &quot;All-Small-Caps&quot;, &quot;Petite-Caps&quot;, &quot;All-Petite-Caps&quot;,
+&quot;Unicase&quot;, &quot;Title-Caps&quot;.
 
 The following words are understood as weights:
 &quot;Thin&quot;, &quot;Ultra-Light&quot;, &quot;Extra-Light&quot;, &quot;Light&quot;, 
&quot;Semi-Light&quot;,
@@ -5327,47 +6201,48 @@ A typical example:
 </parameter_description>
 </parameter>
 </parameters>
-<return> a new #PangoFontDescription.
+<return> a new `PangoFontDescription`.
 </return>
 </function>
 
 <function name="pango_font_description_get_family">
 <description>
-Gets the family name field of a font description. See
-pango_font_description_set_family().
+Gets the family name field of a font description.
+
+See [method@Pango.FontDescription.set_family].
 
 
 </description>
 <parameters>
 <parameter name="desc">
-<parameter_description> a #PangoFontDescription.
+<parameter_description> a `PangoFontDescription`.
 </parameter_description>
 </parameter>
 </parameters>
 <return> the family name field for the font
-description, or %NULL if not previously set.  This
-has the same life-time as the font description itself
-and should not be freed.
+description, or %NULL if not previously set. This has the same
+life-time as the font description itself and should not be freed.
 </return>
 </function>
 
 <function name="pango_font_description_get_gravity">
 <description>
-Gets the gravity field of a font description. See
-pango_font_description_set_gravity().
+Gets the gravity field of a font description.
+
+See [method@Pango.FontDescription.set_gravity].
 
 Since: 1.16
 
 </description>
 <parameters>
 <parameter name="desc">
-<parameter_description> a #PangoFontDescription
+<parameter_description> a `PangoFontDescription`
 </parameter_description>
 </parameter>
 </parameters>
-<return> the gravity field for the font description. Use
-pango_font_description_get_set_fields() to find out if
-the field was explicitly set or not.
+<return> the gravity field for the font description.
+Use [method@Pango.FontDescription.get_set_fields] to find out
+if the field was explicitly set or not.
 
 </return>
 </function>
@@ -5380,7 +6255,7 @@ Determines which fields in a font description have been set.
 </description>
 <parameters>
 <parameter name="desc">
-<parameter_description> a #PangoFontDescription
+<parameter_description> a `PangoFontDescription`
 </parameter_description>
 </parameter>
 </parameters>
@@ -5392,42 +6267,48 @@ fields in @desc that have been set.
 <function name="pango_font_description_get_size">
 <description>
 Gets the size field of a font description.
-See pango_font_description_set_size().
+
+See [method@Pango.FontDescription.set_size].
 
 
 </description>
 <parameters>
 <parameter name="desc">
-<parameter_description> a #PangoFontDescription
+<parameter_description> a `PangoFontDescription`
 </parameter_description>
 </parameter>
 </parameters>
-<return> the size field for the font description in points or device units.
-You must call pango_font_description_get_size_is_absolute()
-to find out which is the case. Returns 0 if the size field has not
-previously been set or it has been set to 0 explicitly.
-Use pango_font_description_get_set_fields() to
-find out if the field was explicitly set or not.
+<return> the size field for the font description in points
+or device units. You must call
+[method@Pango.FontDescription.get_size_is_absolute] to find out
+which is the case. Returns 0 if the size field has not previously
+been set or it has been set to 0 explicitly.
+Use [method@Pango.FontDescription.get_set_fields] to find out
+if the field was explicitly set or not.
 </return>
 </function>
 
 <function name="pango_font_description_get_size_is_absolute">
 <description>
-Determines whether the size of the font is in points (not absolute) or device units (absolute).
-See pango_font_description_set_size() and pango_font_description_set_absolute_size().
+Determines whether the size of the font is in points (not absolute)
+or device units (absolute).
+
+See [method@Pango.FontDescription.set_size]
+and [method@Pango.FontDescription.set_absolute_size].
 
 Since: 1.8
 
 </description>
 <parameters>
 <parameter name="desc">
-<parameter_description> a #PangoFontDescription
+<parameter_description> a `PangoFontDescription`
 </parameter_description>
 </parameter>
 </parameters>
 <return> whether the size for the font description is in
-points or device units.  Use pango_font_description_get_set_fields() to
-find out if the size field of the font description was explicitly set or not.
+points or device units. Use [method@Pango.FontDescription.get_set_fields]
+to find out if the size field of the font description was explicitly
+set or not.
 
 </return>
 </function>
@@ -5435,112 +6316,117 @@ find out if the size field of the font description was explicitly set or not.
 <function name="pango_font_description_get_stretch">
 <description>
 Gets the stretch field of a font description.
-See pango_font_description_set_stretch().
+
+See [method@Pango.FontDescription.set_stretch].
 
 
 </description>
 <parameters>
 <parameter name="desc">
-<parameter_description> a #PangoFontDescription.
+<parameter_description> a `PangoFontDescription`.
 </parameter_description>
 </parameter>
 </parameters>
-<return> the stretch field for the font description. Use
-pango_font_description_get_set_fields() to find out if
-the field was explicitly set or not.
+<return> the stretch field for the font description.
+Use [method@Pango.FontDescription.get_set_fields] to find
+out if the field was explicitly set or not.
 </return>
 </function>
 
 <function name="pango_font_description_get_style">
 <description>
-Gets the style field of a #PangoFontDescription. See
-pango_font_description_set_style().
+Gets the style field of a `PangoFontDescription`.
+
+See [method@Pango.FontDescription.set_style].
 
 
 </description>
 <parameters>
 <parameter name="desc">
-<parameter_description> a #PangoFontDescription
+<parameter_description> a `PangoFontDescription`
 </parameter_description>
 </parameter>
 </parameters>
 <return> the style field for the font description.
-Use pango_font_description_get_set_fields() to find out if
-the field was explicitly set or not.
+Use [method@Pango.FontDescription.get_set_fields] to
+find out if the field was explicitly set or not.
 </return>
 </function>
 
 <function name="pango_font_description_get_variant">
 <description>
-Gets the variant field of a #PangoFontDescription. See
-pango_font_description_set_variant().
+Gets the variant field of a `PangoFontDescription`.
+
+See [method@Pango.FontDescription.set_variant].
 
 
 </description>
 <parameters>
 <parameter name="desc">
-<parameter_description> a #PangoFontDescription.
+<parameter_description> a `PangoFontDescription`.
 </parameter_description>
 </parameter>
 </parameters>
-<return> the variant field for the font description. Use
-pango_font_description_get_set_fields() to find out if
-the field was explicitly set or not.
+<return> the variant field for the font description.
+Use [method@Pango.FontDescription.get_set_fields] to find
+out if the field was explicitly set or not.
 </return>
 </function>
 
 <function name="pango_font_description_get_variations">
 <description>
-Gets the variations field of a font description. See
-pango_font_description_set_variations().
+Gets the variations field of a font description.
+
+See [method@Pango.FontDescription.set_variations].
 
 Since: 1.42
 
 </description>
 <parameters>
 <parameter name="desc">
-<parameter_description> a #PangoFontDescription
+<parameter_description> a `PangoFontDescription`
 </parameter_description>
 </parameter>
 </parameters>
-<return> the varitions field for the font
-description, or %NULL if not previously set.  This
-has the same life-time as the font description itself
-and should not be freed.
+<return> the variations field for the font
+description, or %NULL if not previously set. This has the same
+life-time as the font description itself and should not be freed.
 
 </return>
 </function>
 
 <function name="pango_font_description_get_weight">
 <description>
-Gets the weight field of a font description. See
-pango_font_description_set_weight().
+Gets the weight field of a font description.
+
+See [method@Pango.FontDescription.set_weight].
 
 
 </description>
 <parameters>
 <parameter name="desc">
-<parameter_description> a #PangoFontDescription
+<parameter_description> a `PangoFontDescription`
 </parameter_description>
 </parameter>
 </parameters>
-<return> the weight field for the font description. Use
-pango_font_description_get_set_fields() to find out if
-the field was explicitly set or not.
+<return> the weight field for the font description.
+Use [method@Pango.FontDescription.get_set_fields] to find
+out if the field was explicitly set or not.
 </return>
 </function>
 
 <function name="pango_font_description_hash">
 <description>
-Computes a hash of a #PangoFontDescription structure suitable
-to be used, for example, as an argument to g_hash_table_new().
-The hash value is independent of @desc-&gt;mask.
+Computes a hash of a `PangoFontDescription` structure.
+
+This is suitable to be used, for example, as an argument
+to g_hash_table_new(). The hash value is independent of @desc-&gt;mask.
 
 
 </description>
 <parameters>
 <parameter name="desc">
-<parameter_description> a #PangoFontDescription
+<parameter_description> a `PangoFontDescription`
 </parameter_description>
 </parameter>
 </parameters>
@@ -5551,7 +6437,9 @@ The hash value is independent of @desc-&gt;mask.
 <function name="pango_font_description_merge">
 <description>
 Merges the fields that are set in @desc_to_merge into the fields in
-@desc.  If @replace_existing is %FALSE, only fields in @desc that
+@desc.
+
+If @replace_existing is %FALSE, only fields in @desc that
 are not already set are affected. If %TRUE, then fields that are
 already set will be replaced as well.
 
@@ -5560,11 +6448,12 @@ If @desc_to_merge is %NULL, this function performs nothing.
 </description>
 <parameters>
 <parameter name="desc">
-<parameter_description> a #PangoFontDescription
+<parameter_description> a `PangoFontDescription`
 </parameter_description>
 </parameter>
 <parameter name="desc_to_merge">
-<parameter_description> the #PangoFontDescription to merge from, or %NULL
+<parameter_description> the `PangoFontDescription` to merge from,
+or %NULL
 </parameter_description>
 </parameter>
 <parameter name="replace_existing">
@@ -5579,19 +6468,22 @@ are already exist.
 
 <function name="pango_font_description_merge_static">
 <description>
-Like pango_font_description_merge(), but only a shallow copy is made
-of the family name and other allocated fields. @desc can only be
-used until @desc_to_merge is modified or freed. This is meant
-to be used when the merged font description is only needed temporarily.
+Merges the fields that are set in @desc_to_merge into the fields in
+@desc, without copying allocated fields.
+
+This is like [method@Pango.FontDescription.merge], but only a shallow copy
+is made of the family name and other allocated fields. @desc can only
+be used until @desc_to_merge is modified or freed. This is meant to
+be used when the merged font description is only needed temporarily.
 
 </description>
 <parameters>
 <parameter name="desc">
-<parameter_description> a #PangoFontDescription
+<parameter_description> a `PangoFontDescription`
 </parameter_description>
 </parameter>
 <parameter name="desc_to_merge">
-<parameter_description> the #PangoFontDescription to merge from
+<parameter_description> the `PangoFontDescription` to merge from
 </parameter_description>
 </parameter>
 <parameter name="replace_existing">
@@ -5612,29 +6504,30 @@ Creates a new font description structure with all fields unset.
 </description>
 <parameters>
 </parameters>
-<return> the newly allocated #PangoFontDescription, which
-should be freed using pango_font_description_free().
+<return> the newly allocated `PangoFontDescription`, which
+should be freed using [method Pango FontDescription free].
 </return>
 </function>
 
 <function name="pango_font_description_set_absolute_size">
 <description>
-Sets the size field of a font description, in device units. This is mutually
-exclusive with pango_font_description_set_size() which sets the font size
-in points.
+Sets the size field of a font description, in device units.
+
+This is mutually exclusive with [method@Pango.FontDescription.set_size]
+which sets the font size in points.
 
 Since: 1.8
 
 </description>
 <parameters>
 <parameter name="desc">
-<parameter_description> a #PangoFontDescription
+<parameter_description> a `PangoFontDescription`
 </parameter_description>
 </parameter>
 <parameter name="size">
-<parameter_description> the new size, in Pango units. There are %PANGO_SCALE Pango units in one
-device unit. For an output backend where a device unit is a pixel, a @size
-value of 10 * PANGO_SCALE gives a 10 pixel font.
+<parameter_description> the new size, in Pango units. There are %PANGO_SCALE Pango units
+in one device unit. For an output backend where a device unit is a pixel,
+a @size value of 10 * PANGO_SCALE gives a 10 pixel font.
 </parameter_description>
 </parameter>
 </parameters>
@@ -5643,16 +6536,18 @@ value of 10 * PANGO_SCALE gives a 10 pixel font.
 
 <function name="pango_font_description_set_family">
 <description>
-Sets the family name field of a font description. The family
+Sets the family name field of a font description.
+
+The family
 name represents a family of related font styles, and will
-resolve to a particular #PangoFontFamily. In some uses of
-#PangoFontDescription, it is also possible to use a comma
+resolve to a particular `PangoFontFamily`. In some uses of
+`PangoFontDescription`, it is also possible to use a comma
 separated list of family names for this field.
 
 </description>
 <parameters>
 <parameter name="desc">
-<parameter_description> a #PangoFontDescription.
+<parameter_description> a `PangoFontDescription`.
 </parameter_description>
 </parameter>
 <parameter name="family">
@@ -5665,21 +6560,22 @@ separated list of family names for this field.
 
 <function name="pango_font_description_set_family_static">
 <description>
-Like pango_font_description_set_family(), except that no
+Sets the family name field of a font description, without copying the string.
+
+This is like [method@Pango.FontDescription.set_family], except that no
 copy of @family is made. The caller must make sure that the
-string passed in stays around until @desc has been freed
-or the name is set again. This function can be used if
-@family is a static string such as a C string literal, or
-if @desc is only needed temporarily.
+string passed in stays around until @desc has been freed or the
+name is set again. This function can be used if @family is a static
+string such as a C string literal, or if @desc is only needed temporarily.
 
 </description>
 <parameters>
 <parameter name="desc">
-<parameter_description> a #PangoFontDescription
+<parameter_description> a `PangoFontDescription`
 </parameter_description>
 </parameter>
 <parameter name="family">
-<parameter_description> a string representing the family name.
+<parameter_description> a string representing the family name
 </parameter_description>
 </parameter>
 </parameters>
@@ -5688,20 +6584,22 @@ if @desc is only needed temporarily.
 
 <function name="pango_font_description_set_gravity">
 <description>
-Sets the gravity field of a font description. The gravity field
-specifies how the glyphs should be rotated.  If @gravity is
+Sets the gravity field of a font description.
+
+The gravity field
+specifies how the glyphs should be rotated. If @gravity is
 %PANGO_GRAVITY_AUTO, this actually unsets the gravity mask on
 the font description.
 
-This function is seldom useful to the user.  Gravity should normally
-be set on a #PangoContext.
+This function is seldom useful to the user. Gravity should normally
+be set on a `PangoContext`.
 
 Since: 1.16
 
 </description>
 <parameters>
 <parameter name="desc">
-<parameter_description> a #PangoFontDescription
+<parameter_description> a `PangoFontDescription`
 </parameter_description>
 </parameter>
 <parameter name="gravity">
@@ -5714,22 +6612,25 @@ Since: 1.16
 
 <function name="pango_font_description_set_size">
 <description>
-Sets the size field of a font description in fractional points. This is mutually
-exclusive with pango_font_description_set_absolute_size().
+Sets the size field of a font description in fractional points.
+
+This is mutually exclusive with
+[method@Pango.FontDescription.set_absolute_size].
 
 </description>
 <parameters>
 <parameter name="desc">
-<parameter_description> a #PangoFontDescription
+<parameter_description> a `PangoFontDescription`
 </parameter_description>
 </parameter>
 <parameter name="size">
-<parameter_description> the size of the font in points, scaled by PANGO_SCALE. (That is,
-a @size value of 10 * PANGO_SCALE is a 10 point font. The conversion
-factor between points and device units depends on system configuration
-and the output device. For screen display, a logical DPI of 96 is
-common, in which case a 10 point font corresponds to a 10 * (96 / 72) = 13.3
-pixel font. Use pango_font_description_set_absolute_size() if you need
+<parameter_description> the size of the font in points, scaled by %PANGO_SCALE.
+(That is, a @size value of 10 * PANGO_SCALE is a 10 point font.
+The conversion factor between points and device units depends on
+system configuration and the output device. For screen display, a
+logical DPI of 96 is common, in which case a 10 point font corresponds
+to a 10 * (96 / 72) = 13.3 pixel font.
+Use [method@Pango.FontDescription.set_absolute_size] if you need
 a particular size in device units.
 </parameter_description>
 </parameter>
@@ -5739,13 +6640,15 @@ a particular size in device units.
 
 <function name="pango_font_description_set_stretch">
 <description>
-Sets the stretch field of a font description. The stretch field
-specifies how narrow or wide the font should be.
+Sets the stretch field of a font description.
+
+The [enum@Pango.Stretch] field specifies how narrow or
+wide the font should be.
 
 </description>
 <parameters>
 <parameter name="desc">
-<parameter_description> a #PangoFontDescription
+<parameter_description> a `PangoFontDescription`
 </parameter_description>
 </parameter>
 <parameter name="stretch">
@@ -5758,19 +6661,21 @@ specifies how narrow or wide the font should be.
 
 <function name="pango_font_description_set_style">
 <description>
-Sets the style field of a #PangoFontDescription. The
-#PangoStyle enumeration describes whether the font is slanted and
-the manner in which it is slanted; it can be either
-#PANGO_STYLE_NORMAL, #PANGO_STYLE_ITALIC, or #PANGO_STYLE_OBLIQUE.
-Most fonts will either have a italic style or an oblique
-style, but not both, and font matching in Pango will
-match italic specifications with oblique fonts and vice-versa
-if an exact match is not found.
+Sets the style field of a `PangoFontDescription`.
+
+The [enum@Pango.Style] enumeration describes whether the font is
+slanted and the manner in which it is slanted; it can be either
+%PANGO_STYLE_NORMAL, %PANGO_STYLE_ITALIC, or %PANGO_STYLE_OBLIQUE.
+
+Most fonts will either have a italic style or an oblique style,
+but not both, and font matching in Pango will match italic
+specifications with oblique fonts and vice-versa if an exact
+match is not found.
 
 </description>
 <parameters>
 <parameter name="desc">
-<parameter_description> a #PangoFontDescription
+<parameter_description> a `PangoFontDescription`
 </parameter_description>
 </parameter>
 <parameter name="style">
@@ -5783,13 +6688,15 @@ if an exact match is not found.
 
 <function name="pango_font_description_set_variant">
 <description>
-Sets the variant field of a font description. The #PangoVariant
-can either be %PANGO_VARIANT_NORMAL or %PANGO_VARIANT_SMALL_CAPS.
+Sets the variant field of a font description.
+
+The [enum@Pango.Variant] can either be %PANGO_VARIANT_NORMAL
+or %PANGO_VARIANT_SMALL_CAPS.
 
 </description>
 <parameters>
 <parameter name="desc">
-<parameter_description> a #PangoFontDescription
+<parameter_description> a `PangoFontDescription`
 </parameter_description>
 </parameter>
 <parameter name="variant">
@@ -5802,11 +6709,15 @@ can either be %PANGO_VARIANT_NORMAL or %PANGO_VARIANT_SMALL_CAPS.
 
 <function name="pango_font_description_set_variations">
 <description>
-Sets the variations field of a font description. OpenType
-font variations allow to select a font instance by specifying
-values for a number of axes, such as width or weight.
+Sets the variations field of a font description.
+
+OpenType font variations allow to select a font instance by
+specifying values for a number of axes, such as width or weight.
+
+The format of the variations string is
+
+AXIS1=VALUE,AXIS2=VALUE...
 
-The format of the variations string is AXIS1=VALUE,AXIS2=VALUE...,
 with each AXIS a 4 character tag that identifies a font axis,
 and each VALUE a floating point number. Unknown axes are ignored,
 and values are clamped to their allowed range.
@@ -5819,7 +6730,7 @@ Since: 1.42
 </description>
 <parameters>
 <parameter name="desc">
-<parameter_description> a #PangoFontDescription.
+<parameter_description> a `PangoFontDescription`.
 </parameter_description>
 </parameter>
 <parameter name="variations">
@@ -5832,19 +6743,21 @@ Since: 1.42
 
 <function name="pango_font_description_set_variations_static">
 <description>
-Like pango_font_description_set_variations(), except that no
-copy of @variations is made. The caller must make sure that the
-string passed in stays around until @desc has been freed
+Sets the variations field of a font description.
+
+This is like [method@Pango.FontDescription.set_variations], except
+that no copy of @variations is made. The caller must make sure that
+the string passed in stays around until @desc has been freed
 or the name is set again. This function can be used if
-@variations is a static string such as a C string literal, or
-if @desc is only needed temporarily.
+@variations is a static string such as a C string literal,
+or if @desc is only needed temporarily.
 
 Since: 1.42
 
 </description>
 <parameters>
 <parameter name="desc">
-<parameter_description> a #PangoFontDescription
+<parameter_description> a `PangoFontDescription`
 </parameter_description>
 </parameter>
 <parameter name="variations">
@@ -5857,15 +6770,17 @@ Since: 1.42
 
 <function name="pango_font_description_set_weight">
 <description>
-Sets the weight field of a font description. The weight field
+Sets the weight field of a font description.
+
+The weight field
 specifies how bold or light the font should be. In addition
-to the values of the #PangoWeight enumeration, other intermediate
-numeric values are possible.
+to the values of the [enum@Pango.Weight] enumeration, other
+intermediate numeric values are possible.
 
 </description>
 <parameters>
 <parameter name="desc">
-<parameter_description> a #PangoFontDescription
+<parameter_description> a `PangoFontDescription`
 </parameter_description>
 </parameter>
 <parameter name="weight">
@@ -5878,16 +6793,18 @@ numeric values are possible.
 
 <function name="pango_font_description_to_filename">
 <description>
-Creates a filename representation of a font description. The
-filename is identical to the result from calling
-pango_font_description_to_string(), but with underscores instead of
-characters that are untypical in filenames, and in lower case only.
+Creates a filename representation of a font description.
+
+The filename is identical to the result from calling
+[method@Pango.FontDescription.to_string], but with underscores
+instead of characters that are untypical in filenames, and in
+lower case only.
 
 
 </description>
 <parameters>
 <parameter name="desc">
-<parameter_description> a #PangoFontDescription
+<parameter_description> a `PangoFontDescription`
 </parameter_description>
 </parameter>
 </parameters>
@@ -5897,17 +6814,18 @@ characters that are untypical in filenames, and in lower case only.
 
 <function name="pango_font_description_to_string">
 <description>
-Creates a string representation of a font description. See
-pango_font_description_from_string() for a description of the
-format of the string representation. The family list in the
-string description will only have a terminating comma if the
-last word of the list is a valid style option.
+Creates a string representation of a font description.
+
+See [func@Pango.FontDescription.from_string] for a description
+of the format of the string representation. The family list in
+the string description will only have a terminating comma if
+the last word of the list is a valid style option.
 
 
 </description>
 <parameters>
 <parameter name="desc">
-<parameter_description> a #PangoFontDescription
+<parameter_description> a `PangoFontDescription`
 </parameter_description>
 </parameter>
 </parameters>
@@ -5917,13 +6835,14 @@ last word of the list is a valid style option.
 
 <function name="pango_font_description_unset_fields">
 <description>
-Unsets some of the fields in a #PangoFontDescription.  The unset
-fields will get back to their default values.
+Unsets some of the fields in a `PangoFontDescription`.
+
+The unset fields will get back to their default values.
 
 </description>
 <parameters>
 <parameter name="desc">
-<parameter_description> a #PangoFontDescription
+<parameter_description> a `PangoFontDescription`
 </parameter_description>
 </parameter>
 <parameter name="to_unset">
@@ -5942,7 +6861,7 @@ Frees an array of font descriptions.
 <parameters>
 <parameter name="descs">
 <parameter_description> a pointer
-to an array of #PangoFontDescription, may be %NULL
+to an array of `PangoFontDescription`, may be %NULL
 </parameter_description>
 </parameter>
 <parameter name="n_descs">
@@ -5953,22 +6872,54 @@ to an array of #PangoFontDescription, may be %NULL
 <return></return>
 </function>
 
+<function name="pango_font_deserialize">
+<description>
+Loads data previously created via [method Pango Font.serialize].
+
+For a discussion of the supported format, see that function.
+
+Note: to verify that the returned font is identical to
+the one that was serialized, you can compare @bytes to the
+result of serializing the font again.
+
+Since: 1.50
+
+</description>
+<parameters>
+<parameter name="context">
+<parameter_description> a `PangoContext`
+</parameter_description>
+</parameter>
+<parameter name="bytes">
+<parameter_description> the bytes containing the data
+</parameter_description>
+</parameter>
+<parameter name="error">
+<parameter_description> return location for an error
+</parameter_description>
+</parameter>
+</parameters>
+<return> a new `PangoFont`
+
+</return>
+</function>
+
 <function name="pango_font_face_describe">
 <description>
 Returns the family, style, variant, weight and stretch of
-a #PangoFontFace. The size field of the resulting font description
+a `PangoFontFace`. The size field of the resulting font description
 will be unset.
 
 
 </description>
 <parameters>
 <parameter name="face">
-<parameter_description> a #PangoFontFace
+<parameter_description> a `PangoFontFace`
 </parameter_description>
 </parameter>
 </parameters>
-<return> a newly-created #PangoFontDescription structure
-holding the description of the face. Use pango_font_description_free()
+<return> a newly-created `PangoFontDescription` structure
+holding the description of the face. Use [method Pango FontDescription free]
 to free the result.
 </return>
 </function>
@@ -5976,15 +6927,14 @@ to free the result.
 <function name="pango_font_face_get_face_name">
 <description>
 Gets a name representing the style of this face among the
-different faces in the #PangoFontFamily for the face. This
-name is unique among all faces in the family and is suitable
-for displaying to users.
+different faces in the `PangoFontFamily` for the face. The
+name is suitable for displaying to users.
 
 
 </description>
 <parameters>
 <parameter name="face">
-<parameter_description> a #PangoFontFace.
+<parameter_description> a `PangoFontFace`.
 </parameter_description>
 </parameter>
 </parameters>
@@ -5995,26 +6945,25 @@ owned by the face object and must not be modified or freed.
 
 <function name="pango_font_face_get_family">
 <description>
-Gets the #PangoFontFamily that @face
-belongs to.
+Gets the `PangoFontFamily` that @face belongs to.
 
 Since: 1.46
 
 </description>
 <parameters>
 <parameter name="face">
-<parameter_description> a #PangoFontFace
+<parameter_description> a `PangoFontFace`
 </parameter_description>
 </parameter>
 </parameters>
-<return> the #PangoFontFamily
+<return> the `PangoFontFamily`
 
 </return>
 </function>
 
 <function name="pango_font_face_is_synthesized">
 <description>
-Returns whether a #PangoFontFace is synthesized by the underlying
+Returns whether a `PangoFontFace` is synthesized by the underlying
 font rendering engine from another face, perhaps by shearing, emboldening,
 or lightening it.
 
@@ -6023,7 +6972,7 @@ Since: 1.18
 </description>
 <parameters>
 <parameter name="face">
-<parameter_description> a #PangoFontFace
+<parameter_description> a `PangoFontFace`
 </parameter_description>
 </parameter>
 </parameters>
@@ -6034,17 +6983,19 @@ Since: 1.18
 
 <function name="pango_font_face_list_sizes">
 <description>
-List the available sizes for a font. This is only applicable to bitmap
-fonts. For scalable fonts, stores %NULL at the location pointed to by
-@sizes and 0 at the location pointed to by @n_sizes. The sizes returned
-are in Pango units and are sorted in ascending order.
+List the available sizes for a font.
+
+This is only applicable to bitmap fonts. For scalable fonts, stores
+%NULL at the location pointed to by @sizes and 0 at the location pointed
+to by @n_sizes. The sizes returned are in Pango units and are sorted
+in ascending order.
 
 Since: 1.4
 
 </description>
 <parameters>
 <parameter name="face">
-<parameter_description> a #PangoFontFace.
+<parameter_description> a `PangoFontFace`.
 </parameter_description>
 </parameter>
 <parameter name="sizes">
@@ -6063,14 +7014,14 @@ should be freed with g_free().
 
 <function name="pango_font_family_get_face">
 <description>
-Gets the #PangoFontFace of @family with the given name.
+Gets the `PangoFontFace` of @family with the given name.
 
 Since: 1.46
 
 </description>
 <parameters>
 <parameter name="family">
-<parameter_description> a #PangoFontFamily
+<parameter_description> a `PangoFontFamily`
 </parameter_description>
 </parameter>
 <parameter name="name">
@@ -6080,7 +7031,7 @@ will be returned.
 </parameter_description>
 </parameter>
 </parameters>
-<return> the #PangoFontFace,
+<return> the `PangoFontFace`,
 or %NULL if no face with the given name exists.
 
 </return>
@@ -6088,15 +7039,17 @@ or %NULL if no face with the given name exists.
 
 <function name="pango_font_family_get_name">
 <description>
-Gets the name of the family. The name is unique among all
-fonts for the font backend and can be used in a #PangoFontDescription
-to specify that a face from this family is desired.
+Gets the name of the family.
+
+The name is unique among all fonts for the font backend and can
+be used in a `PangoFontDescription` to specify that a face from
+this family is desired.
 
 
 </description>
 <parameters>
 <parameter name="family">
-<parameter_description> a #PangoFontFamily
+<parameter_description> a `PangoFontFamily`
 </parameter_description>
 </parameter>
 </parameters>
@@ -6108,7 +7061,9 @@ by the family object and must not be modified or freed.
 <function name="pango_font_family_is_monospace">
 <description>
 A monospace font is a font designed for text display where the the
-characters form a regular grid. For Western languages this would
+characters form a regular grid.
+
+For Western languages this would
 mean that the advance width of all characters are the same, but
 this categorization also includes Asian fonts which include
 double-width characters: characters that occupy two grid cells.
@@ -6116,16 +7071,16 @@ g_unichar_iswide() returns a result that indicates whether a
 character is typically double-width in a monospace font.
 
 The best way to find out the grid-cell size is to call
-pango_font_metrics_get_approximate_digit_width(), since the results
-of pango_font_metrics_get_approximate_char_width() may be affected
-by double-width characters.
+[method@Pango.FontMetrics.get_approximate_digit_width], since the
+results of [method@Pango.FontMetrics.get_approximate_char_width] may
+be affected by double-width characters.
 
 Since: 1.4
 
 </description>
 <parameters>
 <parameter name="family">
-<parameter_description> a #PangoFontFamily
+<parameter_description> a `PangoFontFamily`
 </parameter_description>
 </parameter>
 </parameters>
@@ -6144,7 +7099,7 @@ Since: 1.44
 </description>
 <parameters>
 <parameter name="family">
-<parameter_description> a #PangoFontFamily
+<parameter_description> a `PangoFontFamily`
 </parameter_description>
 </parameter>
 </parameters>
@@ -6155,19 +7110,20 @@ Since: 1.44
 
 <function name="pango_font_family_list_faces">
 <description>
-Lists the different font faces that make up @family. The faces
-in a family share a common design, but differ in slant, weight,
+Lists the different font faces that make up @family.
+
+The faces in a family share a common design, but differ in slant, weight,
 width and other aspects.
 
 </description>
 <parameters>
 <parameter name="family">
-<parameter_description> a #PangoFontFamily
+<parameter_description> a `PangoFontFamily`
 </parameter_description>
 </parameter>
 <parameter name="faces">
 <parameter_description>
-location to store an array of pointers to #PangoFontFace objects,
+location to store an array of pointers to `PangoFontFace` objects,
 or %NULL. This array should be freed with g_free() when it is no
 longer needed.
 </parameter_description>
@@ -6190,7 +7146,7 @@ Deprecated: Shape engines are no longer used
 </description>
 <parameters>
 <parameter name="font">
-<parameter_description> a #PangoFont
+<parameter_description> a `PangoFont`
 </parameter_description>
 </parameter>
 <parameter name="language">
@@ -6214,7 +7170,7 @@ Computes the coverage map for a given font and language tag.
 </description>
 <parameters>
 <parameter name="font">
-<parameter_description> a #PangoFont
+<parameter_description> a `PangoFont`
 </parameter_description>
 </parameter>
 <parameter name="language">
@@ -6222,25 +7178,25 @@ Computes the coverage map for a given font and language tag.
 </parameter_description>
 </parameter>
 </parameters>
-<return> a newly-allocated #PangoCoverage
+<return> a newly-allocated `PangoCoverage`
 object.
 </return>
 </function>
 
 <function name="pango_font_get_face">
 <description>
-Gets the #PangoFontFace to which @font belongs.
+Gets the `PangoFontFace` to which @font belongs.
 
 Since: 1.46
 
 </description>
 <parameters>
 <parameter name="font">
-<parameter_description> a #PangoFont
+<parameter_description> a `PangoFont`
 </parameter_description>
 </parameter>
 </parameters>
-<return> the #PangoFontFace
+<return> the `PangoFontFace`
 
 </return>
 </function>
@@ -6248,6 +7204,7 @@ Since: 1.46
 <function name="pango_font_get_features">
 <description>
 Obtain the OpenType features that are provided by the font.
+
 These are passed to the rendering system, together with features
 that have been explicitly set via attributes.
 
@@ -6259,7 +7216,7 @@ Since: 1.44
 </description>
 <parameters>
 <parameter name="font">
-<parameter_description> a #PangoFont
+<parameter_description> a `PangoFont`
 </parameter_description>
 </parameter>
 <parameter name="features">
@@ -6282,33 +7239,36 @@ Since: 1.44
 <description>
 Gets the font map for which the font was created.
 
-Note that the font maintains a &lt;firstterm&gt;weak&lt;/firstterm&gt; reference
-to the font map, so if all references to font map are dropped, the font
-map will be finalized even if there are fonts created with the font
-map that are still alive.  In that case this function will return %NULL.
-It is the responsibility of the user to ensure that the font map is kept
-alive.  In most uses this is not an issue as a #PangoContext holds
-a reference to the font map.
+Note that the font maintains a *weak* reference to
+the font map, so if all references to font map are
+dropped, the font map will be finalized even if there
+are fonts created with the font map that are still alive.
+In that case this function will return %NULL.
+
+It is the responsibility of the user to ensure that the
+font map is kept alive. In most uses this is not an issue
+as a `PangoContext` holds a reference to the font map.
 
 Since: 1.10
 
 </description>
 <parameters>
 <parameter name="font">
-<parameter_description> a #PangoFont, or %NULL
+<parameter_description> a `PangoFont`
 </parameter_description>
 </parameter>
 </parameters>
-<return> the #PangoFontMap for the
-font, or %NULL if @font is %NULL.
+<return> the `PangoFontMap`
+for the font
 
 </return>
 </function>
 
 <function name="pango_font_get_glyph_extents">
 <description>
-Gets the logical and ink extents of a glyph within a font. The
-coordinate system for each rectangle has its origin at the
+Gets the logical and ink extents of a glyph within a font.
+
+The coordinate system for each rectangle has its origin at the
 base line and horizontal origin of the character with increasing
 coordinates extending to the right and down. The macros PANGO_ASCENT(),
 PANGO_DESCENT(), PANGO_LBEARING(), and PANGO_RBEARING() can be used to convert
@@ -6321,7 +7281,7 @@ output variables and returns.
 </description>
 <parameters>
 <parameter name="font">
-<parameter_description> a #PangoFont
+<parameter_description> a `PangoFont`
 </parameter_description>
 </parameter>
 <parameter name="glyph">
@@ -6329,13 +7289,11 @@ output variables and returns.
 </parameter_description>
 </parameter>
 <parameter name="ink_rect">
-<parameter_description> rectangle used to store the extents of the glyph
-as drawn or %NULL to indicate that the result is not needed.
+<parameter_description> rectangle used to store the extents of the glyph as drawn
 </parameter_description>
 </parameter>
 <parameter name="logical_rect">
-<parameter_description> rectangle used to store the logical extents of
-the glyph or %NULL to indicate that the result is not needed.
+<parameter_description> rectangle used to store the logical extents of the glyph
 </parameter_description>
 </parameter>
 </parameters>
@@ -6344,33 +7302,59 @@ the glyph or %NULL to indicate that the result is not needed.
 
 <function name="pango_font_get_hb_font">
 <description>
-Get a hb_font_t object backing this font.
+Get a `hb_font_t` object backing this font.
 
-Note that the objects returned by this function
-are cached and immutable. If you need to make
-changes to the hb_font_t, use hb_font_create_sub_font().
+Note that the objects returned by this function are cached
+and immutable. If you need to make changes to the `hb_font_t`,
+use hb_font_create_sub_font().
 
 Since: 1.44
 
 </description>
 <parameters>
 <parameter name="font">
-<parameter_description> a #PangoFont
+<parameter_description> a `PangoFont`
+</parameter_description>
+</parameter>
+</parameters>
+<return> the `hb_font_t` object
+backing the font
+
+</return>
+</function>
+
+<function name="pango_font_get_languages">
+<description>
+Returns the languages that are supported by @font.
+
+If the font backend does not provide this information,
+%NULL is returned. For the fontconfig backend, this
+corresponds to the FC_LANG member of the FcPattern.
+
+The returned array is only valid as long as the font
+and its fontmap are valid.
+
+Since: 1.50
+
+</description>
+<parameters>
+<parameter name="font">
+<parameter_description> a `PangoFont`
 </parameter_description>
 </parameter>
 </parameters>
-<return> the hb_font_t object backing the
-font, or %NULL if the font does not have one
+<return> an array of `PangoLanguage`
 
 </return>
 </function>
 
 <function name="pango_font_get_metrics">
 <description>
-Gets overall metric information for a font. Since the metrics may be
-substantially different for different scripts, a language tag can
-be provided to indicate that the metrics should be retrieved that
-correspond to the script(s) used by that language.
+Gets overall metric information for a font.
+
+Since the metrics may be substantially different for different scripts,
+a language tag can be provided to indicate that the metrics should be
+retrieved that correspond to the script(s) used by that language.
 
 If @font is %NULL, this function gracefully sets some sane values in the
 output variables and returns.
@@ -6379,17 +7363,18 @@ output variables and returns.
 </description>
 <parameters>
 <parameter name="font">
-<parameter_description> a #PangoFont
+<parameter_description> a `PangoFont`
 </parameter_description>
 </parameter>
 <parameter name="language">
-<parameter_description> language tag used to determine which script to get the metrics
-for, or %NULL to indicate to get the metrics for the entire font.
+<parameter_description> language tag used to determine which script
+to get the metrics for, or %NULL to indicate to get the metrics for
+the entire font.
 </parameter_description>
 </parameter>
 </parameters>
-<return> a #PangoFontMetrics object. The caller must call pango_font_metrics_unref()
-when finished using the object.
+<return> a `PangoFontMetrics` object. The caller must call
+[method@Pango.FontMetrics.unref] when finished using the object.
 </return>
 </function>
 
@@ -6402,7 +7387,7 @@ Since: 1.44
 </description>
 <parameters>
 <parameter name="font">
-<parameter_description> a #PangoFont
+<parameter_description> a `PangoFont`
 </parameter_description>
 </parameter>
 <parameter name="wc">
@@ -6417,20 +7402,20 @@ Since: 1.44
 
 <function name="pango_font_map_changed">
 <description>
-Forces a change in the context, which will cause any #PangoContext
+Forces a change in the context, which will cause any `PangoContext`
 using this fontmap to change.
 
 This function is only useful when implementing a new backend
 for Pango, something applications won't do. Backends should
-call this function if they have attached extra data to the context
-and such data is changed.
+call this function if they have attached extra data to the
+context and such data is changed.
 
 Since: 1.34
 
 </description>
 <parameters>
 <parameter name="fontmap">
-<parameter_description> a #PangoFontMap
+<parameter_description> a `PangoFontMap`
 </parameter_description>
 </parameter>
 </parameters>
@@ -6439,25 +7424,26 @@ Since: 1.34
 
 <function name="pango_font_map_create_context">
 <description>
-Creates a #PangoContext connected to @fontmap.  This is equivalent
-to pango_context_new() followed by pango_context_set_font_map().
+Creates a `PangoContext` connected to @fontmap.
+
+This is equivalent to [ctor Pango Context new] followed by
+[method@Pango.Context.set_font_map].
 
 If you are using Pango as part of a higher-level system,
-that system may have it's own way of create a #PangoContext.
-For instance, the GTK+ toolkit has, among others,
-gdk_pango_context_get_for_screen(), and
-gtk_widget_get_pango_context().  Use those instead.
+that system may have it's own way of create a `PangoContext`.
+For instance, the GTK toolkit has, among others,
+gtk_widget_get_pango_context(). Use those instead.
 
 Since: 1.22
 
 </description>
 <parameters>
 <parameter name="fontmap">
-<parameter_description> a #PangoFontMap
+<parameter_description> a `PangoFontMap`
 </parameter_description>
 </parameter>
 </parameters>
-<return> the newly allocated #PangoContext,
+<return> the newly allocated `PangoContext`,
 which should be freed with g_object_unref().
 
 </return>
@@ -6472,7 +7458,7 @@ Since: 1.46
 </description>
 <parameters>
 <parameter name="fontmap">
-<parameter_description> a #PangoFontMap
+<parameter_description> a `PangoFontMap`
 </parameter_description>
 </parameter>
 <parameter name="name">
@@ -6480,31 +7466,32 @@ Since: 1.46
 </parameter_description>
 </parameter>
 </parameters>
-<return> the #PangoFontFamily
+<return> the `PangoFontFamily`
 
 </return>
 </function>
 
 <function name="pango_font_map_get_serial">
 <description>
-Returns the current serial number of @fontmap.  The serial number is
-initialized to an small number larger than zero when a new fontmap
-is created and is increased whenever the fontmap is changed. It may
-wrap, but will never have the value 0. Since it can wrap, never compare
-it with &quot;less than&quot;, always use &quot;not equals&quot;.
+Returns the current serial number of @fontmap.
+
+The serial number is initialized to an small number larger than zero
+when a new fontmap is created and is increased whenever the fontmap
+is changed. It may wrap, but will never have the value 0. Since it can
+wrap, never compare it with &quot;less than&quot;, always use &quot;not equals&quot;.
 
 The fontmap can only be changed using backend-specific API, like changing
 fontmap resolution.
 
-This can be used to automatically detect changes to a #PangoFontMap, like
-in #PangoContext.
+This can be used to automatically detect changes to a `PangoFontMap`,
+like in `PangoContext`.
 
 Since: 1.32.4
 
 </description>
 <parameters>
 <parameter name="fontmap">
-<parameter_description> a #PangoFontMap
+<parameter_description> a `PangoFontMap`
 </parameter_description>
 </parameter>
 </parameters>
@@ -6516,8 +7503,7 @@ Since: 1.32.4
 <function name="pango_font_map_get_shape_engine_type">
 <description>
 Returns the render ID for shape engines for this fontmap.
-See the &lt;structfield&gt;render_type&lt;/structfield&gt; field of
-#PangoEngineInfo.
+See the `render_type` field of `PangoEngineInfo`.
 
 Since: 1.4
 Deprecated: 1.38
@@ -6525,13 +7511,12 @@ Deprecated: 1.38
 </description>
 <parameters>
 <parameter name="fontmap">
-<parameter_description> a #PangoFontMap
+<parameter_description> a `PangoFontMap`
 </parameter_description>
 </parameter>
 </parameters>
-<return> the ID string for shape engines for
-this fontmap. Owned by Pango, should not be modified
-or freed.
+<return> the ID string for shape engines
+for this fontmap
 
 </return>
 </function>
@@ -6543,11 +7528,12 @@ List all families for a fontmap.
 </description>
 <parameters>
 <parameter name="fontmap">
-<parameter_description> a #PangoFontMap
+<parameter_description> a `PangoFontMap`
 </parameter_description>
 </parameter>
 <parameter name="families">
-<parameter_description> location to store a pointer to an array of #PangoFontFamily *.
+<parameter_description> location to
+store a pointer to an array of `PangoFontFamily` *.
 This array should be freed with g_free().
 </parameter_description>
 </parameter>
@@ -6567,19 +7553,19 @@ Load the font in the fontmap that is the closest match for @desc.
 </description>
 <parameters>
 <parameter name="fontmap">
-<parameter_description> a #PangoFontMap
+<parameter_description> a `PangoFontMap`
 </parameter_description>
 </parameter>
 <parameter name="context">
-<parameter_description> the #PangoContext the font will be used with
+<parameter_description> the `PangoContext` the font will be used with
 </parameter_description>
 </parameter>
 <parameter name="desc">
-<parameter_description> a #PangoFontDescription describing the font to load
+<parameter_description> a `PangoFontDescription` describing the font to load
 </parameter_description>
 </parameter>
 </parameters>
-<return> the newly allocated #PangoFont
+<return> the newly allocated `PangoFont`
 loaded, or %NULL if no font matched.
 </return>
 </function>
@@ -6593,30 +7579,31 @@ a font matching @desc.
 </description>
 <parameters>
 <parameter name="fontmap">
-<parameter_description> a #PangoFontMap
+<parameter_description> a `PangoFontMap`
 </parameter_description>
 </parameter>
 <parameter name="context">
-<parameter_description> the #PangoContext the font will be used with
+<parameter_description> the `PangoContext` the font will be used with
 </parameter_description>
 </parameter>
 <parameter name="desc">
-<parameter_description> a #PangoFontDescription describing the font to load
+<parameter_description> a `PangoFontDescription` describing the font to load
 </parameter_description>
 </parameter>
 <parameter name="language">
-<parameter_description> a #PangoLanguage the fonts will be used for
+<parameter_description> a `PangoLanguage` the fonts will be used for
 </parameter_description>
 </parameter>
 </parameters>
 <return> the newly allocated
-#PangoFontset loaded, or %NULL if no font matched.
+`PangoFontset` loaded, or %NULL if no font matched.
 </return>
 </function>
 
 <function name="pango_font_metrics_get_approximate_char_width">
 <description>
 Gets the approximate character width for a font metrics structure.
+
 This is merely a representative value useful, for example, for
 determining the initial size for a window. Actual characters in
 text will be wider and narrower than this.
@@ -6625,7 +7612,7 @@ text will be wider and narrower than this.
 </description>
 <parameters>
 <parameter name="metrics">
-<parameter_description> a #PangoFontMetrics structure
+<parameter_description> a `PangoFontMetrics` structure
 </parameter_description>
 </parameter>
 </parameters>
@@ -6636,6 +7623,7 @@ text will be wider and narrower than this.
 <function name="pango_font_metrics_get_approximate_digit_width">
 <description>
 Gets the approximate digit width for a font metrics structure.
+
 This is merely a representative value useful, for example, for
 determining the initial size for a window. Actual digits in
 text can be wider or narrower than this, though this value
@@ -6646,7 +7634,7 @@ pango_font_metrics_get_approximate_char_width() for digits.
 </description>
 <parameters>
 <parameter name="metrics">
-<parameter_description> a #PangoFontMetrics structure
+<parameter_description> a `PangoFontMetrics` structure
 </parameter_description>
 </parameter>
 </parameters>
@@ -6656,17 +7644,18 @@ pango_font_metrics_get_approximate_char_width() for digits.
 
 <function name="pango_font_metrics_get_ascent">
 <description>
-Gets the ascent from a font metrics structure. The ascent is
-the distance from the baseline to the logical top of a line
-of text. (The logical top may be above or below the top of the
-actual drawn ink. It is necessary to lay out the text to figure
-where the ink will be.)
+Gets the ascent from a font metrics structure.
+
+The ascent is the distance from the baseline to the logical top
+of a line of text. (The logical top may be above or below the top
+of the actual drawn ink. It is necessary to lay out the text to
+figure where the ink will be.)
 
 
 </description>
 <parameters>
 <parameter name="metrics">
-<parameter_description> a #PangoFontMetrics structure
+<parameter_description> a `PangoFontMetrics` structure
 </parameter_description>
 </parameter>
 </parameters>
@@ -6676,17 +7665,18 @@ where the ink will be.)
 
 <function name="pango_font_metrics_get_descent">
 <description>
-Gets the descent from a font metrics structure. The descent is
-the distance from the baseline to the logical bottom of a line
-of text. (The logical bottom may be above or below the bottom of the
-actual drawn ink. It is necessary to lay out the text to figure
-where the ink will be.)
+Gets the descent from a font metrics structure.
+
+The descent is the distance from the baseline to the logical bottom
+of a line of text. (The logical bottom may be above or below the
+bottom of the actual drawn ink. It is necessary to lay out the text
+to figure where the ink will be.)
 
 
 </description>
 <parameters>
 <parameter name="metrics">
-<parameter_description> a #PangoFontMetrics structure
+<parameter_description> a `PangoFontMetrics` structure
 </parameter_description>
 </parameter>
 </parameters>
@@ -6696,9 +7686,10 @@ where the ink will be.)
 
 <function name="pango_font_metrics_get_height">
 <description>
-Gets the line height from a font metrics structure. The
-line height is the distance between successive baselines
-in wrapped text.
+Gets the line height from a font metrics structure.
+
+The line height is the recommended distance between successive
+baselines in wrapped text using this font.
 
 If the line height is not available, 0 is returned.
 
@@ -6707,7 +7698,7 @@ Since: 1.44
 </description>
 <parameters>
 <parameter name="metrics">
-<parameter_description> a #PangoFontMetrics structure
+<parameter_description> a `PangoFontMetrics` structure
 </parameter_description>
 </parameter>
 </parameters>
@@ -6719,7 +7710,8 @@ Since: 1.44
 <function name="pango_font_metrics_get_strikethrough_position">
 <description>
 Gets the suggested position to draw the strikethrough.
-The value returned is the distance &lt;emphasis&gt;above&lt;/emphasis&gt; the
+
+The value returned is the distance *above* the
 baseline of the top of the strikethrough.
 
 Since: 1.6
@@ -6727,7 +7719,7 @@ Since: 1.6
 </description>
 <parameters>
 <parameter name="metrics">
-<parameter_description> a #PangoFontMetrics structure
+<parameter_description> a `PangoFontMetrics` structure
 </parameter_description>
 </parameter>
 </parameters>
@@ -6745,7 +7737,7 @@ Since: 1.6
 </description>
 <parameters>
 <parameter name="metrics">
-<parameter_description> a #PangoFontMetrics structure
+<parameter_description> a `PangoFontMetrics` structure
 </parameter_description>
 </parameter>
 </parameters>
@@ -6757,17 +7749,17 @@ Since: 1.6
 <function name="pango_font_metrics_get_underline_position">
 <description>
 Gets the suggested position to draw the underline.
-The value returned is the distance &lt;emphasis&gt;above&lt;/emphasis&gt; the
-baseline of the top of the underline. Since most fonts have
-underline positions beneath the baseline, this value is typically
-negative.
+
+The value returned is the distance *above* the baseline of the top
+of the underline. Since most fonts have underline positions beneath
+the baseline, this value is typically negative.
 
 Since: 1.6
 
 </description>
 <parameters>
 <parameter name="metrics">
-<parameter_description> a #PangoFontMetrics structure
+<parameter_description> a `PangoFontMetrics` structure
 </parameter_description>
 </parameter>
 </parameters>
@@ -6785,7 +7777,7 @@ Since: 1.6
 </description>
 <parameters>
 <parameter name="metrics">
-<parameter_description> a #PangoFontMetrics structure
+<parameter_description> a `PangoFontMetrics` structure
 </parameter_description>
 </parameter>
 </parameters>
@@ -6796,15 +7788,16 @@ Since: 1.6
 
 <function name="pango_font_metrics_new">
 <description>
-Creates a new #PangoFontMetrics structure. This is only for
-internal use by Pango backends and there is no public way
-to set the fields of the structure.
+Creates a new `PangoFontMetrics` structure.
+
+This is only for internal use by Pango backends and there is
+no public way to set the fields of the structure.
 
 
 </description>
 <parameters>
 </parameters>
-<return> a newly-created #PangoFontMetrics structure
+<return> a newly-created `PangoFontMetrics` structure
 with a reference count of 1.
 </return>
 </function>
@@ -6817,7 +7810,7 @@ Increase the reference count of a font metrics structure by one.
 </description>
 <parameters>
 <parameter name="metrics">
-<parameter_description> a #PangoFontMetrics structure, may be %NULL
+<parameter_description> a `PangoFontMetrics` structure, may be %NULL
 </parameter_description>
 </parameter>
 </parameters>
@@ -6827,31 +7820,56 @@ Increase the reference count of a font metrics structure by one.
 
 <function name="pango_font_metrics_unref">
 <description>
-Decrease the reference count of a font metrics structure by one. If
-the result is zero, frees the structure and any associated
-memory.
+Decrease the reference count of a font metrics structure by one.
+If the result is zero, frees the structure and any associated memory.
 
 </description>
 <parameters>
 <parameter name="metrics">
-<parameter_description> a #PangoFontMetrics structure, may be %NULL
+<parameter_description> a `PangoFontMetrics` structure, may be %NULL
 </parameter_description>
 </parameter>
 </parameters>
 <return></return>
 </function>
 
+<function name="pango_font_serialize">
+<description>
+Serializes the @font in a way that can be uniquely identified.
+
+There are no guarantees about the format of the output across different
+versions of Pango.
+
+The intended use of this function is testing, benchmarking and debugging.
+The format is not meant as a permanent storage format.
+
+Since: 1.50
+
+</description>
+<parameters>
+<parameter name="font">
+<parameter_description> a `PangoFont`
+</parameter_description>
+</parameter>
+</parameters>
+<return> a `GBytes` containing the serialized form of @font
+
+</return>
+</function>
+
 <function name="pango_fontset_foreach">
 <description>
 Iterates through all the fonts in a fontset, calling @func for
-each one. If @func returns %TRUE, that stops the iteration.
+each one.
+
+If @func returns %TRUE, that stops the iteration.
 
 Since: 1.4
 
 </description>
 <parameters>
 <parameter name="fontset">
-<parameter_description> a #PangoFontset
+<parameter_description> a `PangoFontset`
 </parameter_description>
 </parameter>
 <parameter name="func">
@@ -6868,14 +7886,14 @@ Since: 1.4
 
 <function name="pango_fontset_get_font">
 <description>
-Returns the font in the fontset that contains the best glyph for the
-Unicode character @wc.
+Returns the font in the fontset that contains the best glyph for a
+Unicode character.
 
 
 </description>
 <parameters>
 <parameter name="fontset">
-<parameter_description> a #PangoFontset
+<parameter_description> a `PangoFontset`
 </parameter_description>
 </parameter>
 <parameter name="wc">
@@ -6883,8 +7901,7 @@ Unicode character @wc.
 </parameter_description>
 </parameter>
 </parameters>
-<return> a #PangoFont. The caller must call
-g_object_unref when finished with the font.
+<return> a `PangoFont`
 </return>
 </function>
 
@@ -6896,12 +7913,11 @@ Get overall metric information for the fonts in the fontset.
 </description>
 <parameters>
 <parameter name="fontset">
-<parameter_description> a #PangoFontset
+<parameter_description> a `PangoFontset`
 </parameter_description>
 </parameter>
 </parameters>
-<return> a #PangoFontMetrics object. The caller must call pango_font_metrics_unref()
-when finished using the object.
+<return> a `PangoFontMetrics` object
 </return>
 </function>
 
@@ -6909,14 +7925,16 @@ when finished using the object.
 <description>
 Adds a font to the fontset.
 
+The fontset takes ownership of @font.
+
 </description>
 <parameters>
 <parameter name="fontset">
-<parameter_description> a #PangoFontsetSimple.
+<parameter_description> a `PangoFontsetSimple`.
 </parameter_description>
 </parameter>
 <parameter name="font">
-<parameter_description> a #PangoFont.
+<parameter_description> a `PangoFont`.
 </parameter_description>
 </parameter>
 </parameters>
@@ -6925,18 +7943,17 @@ Adds a font to the fontset.
 
 <function name="pango_fontset_simple_new">
 <description>
-Creates a new #PangoFontsetSimple for the given language.
+Creates a new `PangoFontsetSimple` for the given language.
 
 
 </description>
 <parameters>
 <parameter name="language">
-<parameter_description> a #PangoLanguage tag
+<parameter_description> a `PangoLanguage` tag
 </parameter_description>
 </parameter>
 </parameters>
-<return> the newly allocated #PangoFontsetSimple, which should
-be freed with g_object_unref().
+<return> the newly allocated `PangoFontsetSimple`
 </return>
 </function>
 
@@ -6948,18 +7965,19 @@ Returns the number of fonts in the fontset.
 </description>
 <parameters>
 <parameter name="fontset">
-<parameter_description> a #PangoFontsetSimple.
+<parameter_description> a `PangoFontsetSimple`.
 </parameter_description>
 </parameter>
 </parameters>
-<return> the size of @fontset.
+<return> the size of @fontset
 </return>
 </function>
 
 <function name="pango_ft2_font_get_coverage">
 <description>
-Gets the #PangoCoverage for a `PangoFT2Font`. Use
-pango_font_get_coverage() instead.
+Gets the `PangoCoverage` for a `PangoFT2Font`.
+
+Use [method Pango Font.get_coverage] instead.
 
 
 </description>
@@ -6973,29 +7991,32 @@ pango_font_get_coverage() instead.
 </parameter_description>
 </parameter>
 </parameters>
-<return> a #PangoCoverage.
+<return> a `PangoCoverage`
 </return>
 </function>
 
 <function name="pango_ft2_font_get_face">
 <description>
-Returns the native FreeType2 `FT_Face` structure used for this #PangoFont.
-This may be useful if you want to use FreeType2 functions directly.
+Returns the native FreeType2 `FT_Face` structure
+used for this `PangoFont`.
+
+This may be useful if you want to use FreeType2
+functions directly.
 
-Use pango_fc_font_lock_face() instead; when you are done with a
-face from pango_fc_font_lock_face() you must call
-pango_fc_font_unlock_face().
+Use [method PangoFc Font.lock_face] instead; when you are
+done with a face from [method PangoFc Font.lock_face], you
+must call [method PangoFc Font.unlock_face].
 
 
 </description>
 <parameters>
 <parameter name="font">
-<parameter_description> a #PangoFont
+<parameter_description> a `PangoFont`
 </parameter_description>
 </parameter>
 </parameters>
-<return> a pointer to a `FT_Face` structure, with the
-size set correctly, or %NULL if @font is %NULL.
+<return> a pointer to a `FT_Face` structure,
+with the size set correctly
 </return>
 </function>
 
@@ -7009,35 +8030,35 @@ Use pango_fc_font_kern_glyphs() instead.
 </description>
 <parameters>
 <parameter name="font">
-<parameter_description> a #PangoFont
+<parameter_description> a `PangoFont`
 </parameter_description>
 </parameter>
 <parameter name="left">
-<parameter_description> the left #PangoGlyph
+<parameter_description> the left `PangoGlyph`
 </parameter_description>
 </parameter>
 <parameter name="right">
-<parameter_description> the right #PangoGlyph
+<parameter_description> the right `PangoGlyph`
 </parameter_description>
 </parameter>
 </parameters>
-<return> The amount of kerning (in Pango units) to apply for
-the given combination of glyphs.
+<return> The amount of kerning (in Pango units) to
+apply for the given combination of glyphs.
 </return>
 </function>
 
 <function name="pango_ft2_font_map_create_context">
 <description>
-Create a #PangoContext for the given fontmap.
+Create a `PangoContext` for the given fontmap.
 
 Since: 1.2
 
-Deprecated: 1.22: Use pango_font_map_create_context() instead.
+Deprecated: 1.22: Use [method@Pango.FontMap.create_context] instead.
 
 </description>
 <parameters>
 <parameter name="fontmap">
-<parameter_description> a #PangoFT2FontMap
+<parameter_description> a `PangoFT2FontMap`
 </parameter_description>
 </parameter>
 </parameters>
@@ -7049,7 +8070,9 @@ g_object_unref().
 
 <function name="pango_ft2_font_map_for_display">
 <description>
-Returns a #PangoFT2FontMap. This font map is cached and should
+Returns a `PangoFT2FontMap`.
+
+This font map is cached and should
 not be freed. If the font map is no longer needed, it can
 be released with pango_ft2_shutdown_display(). Use of the
 global PangoFT2 fontmap is deprecated; use pango_ft2_font_map_new()
@@ -7059,17 +8082,18 @@ instead.
 </description>
 <parameters>
 </parameters>
-<return> a #PangoFT2FontMap.
+<return> a `PangoFT2FontMap`.
 </return>
 </function>
 
 <function name="pango_ft2_font_map_new">
 <description>
-Create a new #PangoFT2FontMap object; a fontmap is used
-to cache information about available fonts, and holds
-certain global parameters such as the resolution and
+Create a new `PangoFT2FontMap` object.
+
+A fontmap is used to cache information about available fonts,
+and holds certain global parameters such as the resolution and
 the default substitute function (see
-pango_ft2_font_map_set_default_substitute()).
+[method@PangoFT2.FontMap.set_default_substitute]).
 
 Since: 1.2
 
@@ -7085,11 +8109,13 @@ with g_object_unref() when you are finished with it.
 <function name="pango_ft2_font_map_set_default_substitute">
 <description>
 Sets a function that will be called to do final configuration
-substitution on a #FcPattern before it is used to load
-the font. This function can be used to do things like set
+substitution on a `FcPattern` before it is used to load
+the font.
+
+This function can be used to do things like set
 hinting and antialiasing options.
 
-Deprecated: 1.46: Use pango_fc_font_map_set_default_substitute()
+Deprecated: 1.46: Use [method@PangoFc.FontMap.set_default_substitute]
 instead.
 
 Since: 1.2
@@ -7097,7 +8123,7 @@ Since: 1.2
 </description>
 <parameters>
 <parameter name="fontmap">
-<parameter_description> a #PangoFT2FontMap
+<parameter_description> a `PangoFT2FontMap`
 </parameter_description>
 </parameter>
 <parameter name="func">
@@ -7126,7 +8152,7 @@ Since: 1.2
 </description>
 <parameters>
 <parameter name="fontmap">
-<parameter_description> a #PangoFT2FontMap
+<parameter_description> a `PangoFT2FontMap`
 </parameter_description>
 </parameter>
 <parameter name="dpi_x">
@@ -7146,10 +8172,11 @@ Since: 1.2
 Call this function any time the results of the
 default substitution function set with
 pango_ft2_font_map_set_default_substitute() change.
+
 That is, if your substitution function will return different
 results for the same input pattern, you must call this function.
 
-Deprecated: 1.46: Use pango_fc_font_map_substitute_changed()
+Deprecated: 1.46: Use [method@PangoFc.FontMap.substitute_changed]
 instead.
 
 Since: 1.2
@@ -7157,7 +8184,7 @@ Since: 1.2
 </description>
 <parameters>
 <parameter name="fontmap">
-<parameter_description> a #PangoFT2FontMap
+<parameter_description> a `PangoFT2FontMap`
 </parameter_description>
 </parameter>
 </parameters>
@@ -7166,11 +8193,11 @@ Since: 1.2
 
 <function name="pango_ft2_get_context">
 <description>
-Retrieves a #PangoContext for the default PangoFT2 fontmap
+Retrieves a `PangoContext` for the default PangoFT2 fontmap
 (see pango_ft2_font_map_for_display()) and sets the resolution
 for the default fontmap to @dpi_x by @dpi_y.
 
-Deprecated: 1.22: Use pango_font_map_create_context() instead.
+Deprecated: 1.22: Use [method@Pango.FontMap.create_context] instead.
 
 </description>
 <parameters>
@@ -7183,25 +8210,26 @@ Deprecated: 1.22: Use pango_font_map_create_context() instead.
 </parameter_description>
 </parameter>
 </parameters>
-<return> the new #PangoContext
+<return> the new `PangoContext`
 
 </return>
 </function>
 
 <function name="pango_ft2_get_unknown_glyph">
 <description>
-Return the index of a glyph suitable for drawing unknown characters with
-@font, or %PANGO_GLYPH_EMPTY if no suitable glyph found.
+Return the index of a glyph suitable for drawing unknown
+characters with @font, or %PANGO_GLYPH_EMPTY if no suitable
+glyph found.
 
-If you want to draw an unknown-box for a character that is not covered
-by the font,
-use PANGO_GET_UNKNOWN_GLYPH() instead.
+If you want to draw an unknown-box for a character that
+is not covered by the font, use PANGO_GET_UNKNOWN_GLYPH()
+instead.
 
 
 </description>
 <parameters>
 <parameter name="font">
-<parameter_description> a #PangoFont
+<parameter_description> a `PangoFont`
 </parameter_description>
 </parameter>
 </parameters>
@@ -7211,28 +8239,28 @@ use PANGO_GET_UNKNOWN_GLYPH() instead.
 
 <function name="pango_ft2_render">
 <description>
-Renders a #PangoGlyphString onto a FreeType2 bitmap.
+Renders a `PangoGlyphString` onto a FreeType2 bitmap.
 
 </description>
 <parameters>
 <parameter name="bitmap">
-<parameter_description>  the FreeType2 bitmap onto which to draw the string
+<parameter_description> the FreeType2 bitmap onto which to draw the string
 </parameter_description>
 </parameter>
 <parameter name="font">
-<parameter_description>    the font in which to draw the string
+<parameter_description> the font in which to draw the string
 </parameter_description>
 </parameter>
 <parameter name="glyphs">
-<parameter_description>  the glyph string to draw
+<parameter_description> the glyph string to draw
 </parameter_description>
 </parameter>
 <parameter name="x">
-<parameter_description>       the x position of the start of the string (in pixels)
+<parameter_description> the x position of the start of the string (in pixels)
 </parameter_description>
 </parameter>
 <parameter name="y">
-<parameter_description>       the y position of the baseline (in pixels)
+<parameter_description> the y position of the baseline (in pixels)
 </parameter_description>
 </parameter>
 </parameters>
@@ -7241,24 +8269,24 @@ Renders a #PangoGlyphString onto a FreeType2 bitmap.
 
 <function name="pango_ft2_render_layout">
 <description>
-Render a #PangoLayout onto a FreeType2 bitmap
+Render a `PangoLayout` onto a FreeType2 bitmap
 
 </description>
 <parameters>
 <parameter name="bitmap">
-<parameter_description>    a &lt;type&gt;FT_Bitmap&lt;/type&gt; to render the layout onto
+<parameter_description> a FT_Bitmap to render the layout onto
 </parameter_description>
 </parameter>
 <parameter name="layout">
-<parameter_description>    a #PangoLayout
+<parameter_description> a `PangoLayout`
 </parameter_description>
 </parameter>
 <parameter name="x">
-<parameter_description>         the X position of the left of the layout (in pixels)
+<parameter_description> the X position of the left of the layout (in pixels)
 </parameter_description>
 </parameter>
 <parameter name="y">
-<parameter_description>         the Y position of the top of the layout (in pixels)
+<parameter_description> the Y position of the top of the layout (in pixels)
 </parameter_description>
 </parameter>
 </parameters>
@@ -7267,24 +8295,24 @@ Render a #PangoLayout onto a FreeType2 bitmap
 
 <function name="pango_ft2_render_layout_line">
 <description>
-Render a #PangoLayoutLine onto a FreeType2 bitmap
+Render a `PangoLayoutLine` onto a FreeType2 bitmap
 
 </description>
 <parameters>
 <parameter name="bitmap">
-<parameter_description>    a &lt;type&gt;FT_Bitmap&lt;/type&gt; to render the line onto
+<parameter_description> a FT_Bitmap to render the line onto
 </parameter_description>
 </parameter>
 <parameter name="line">
-<parameter_description>      a #PangoLayoutLine
+<parameter_description> a `PangoLayoutLine`
 </parameter_description>
 </parameter>
 <parameter name="x">
-<parameter_description>         the x position of start of string (in pixels)
+<parameter_description> the x position of start of string (in pixels)
 </parameter_description>
 </parameter>
 <parameter name="y">
-<parameter_description>         the y position of baseline (in pixels)
+<parameter_description> the y position of baseline (in pixels)
 </parameter_description>
 </parameter>
 </parameters>
@@ -7293,30 +8321,32 @@ Render a #PangoLayoutLine onto a FreeType2 bitmap
 
 <function name="pango_ft2_render_layout_line_subpixel">
 <description>
-Render a #PangoLayoutLine onto a FreeType2 bitmap, with he
+Render a `PangoLayoutLine` onto a FreeType2 bitmap, with he
 location specified in fixed-point Pango units rather than
-pixels. (Using this will avoid extra inaccuracies from
-rounding to integer pixels multiple times, even if the
-final glyph positions are integers.)
+pixels.
+
+(Using this will avoid extra inaccuracies from rounding
+to integer pixels multiple times, even if the final glyph
+positions are integers.)
 
 Since: 1.6
 
 </description>
 <parameters>
 <parameter name="bitmap">
-<parameter_description>    a &lt;type&gt;FT_Bitmap&lt;/type&gt; to render the line onto
+<parameter_description> a FT_Bitmap to render the line onto
 </parameter_description>
 </parameter>
 <parameter name="line">
-<parameter_description>      a #PangoLayoutLine
+<parameter_description> a `PangoLayoutLine`
 </parameter_description>
 </parameter>
 <parameter name="x">
-<parameter_description>         the x position of start of string (in Pango units)
+<parameter_description> the x position of start of string (in Pango units)
 </parameter_description>
 </parameter>
 <parameter name="y">
-<parameter_description>         the y position of baseline (in Pango units)
+<parameter_description> the y position of baseline (in Pango units)
 </parameter_description>
 </parameter>
 </parameters>
@@ -7325,30 +8355,32 @@ Since: 1.6
 
 <function name="pango_ft2_render_layout_subpixel">
 <description>
-Render a #PangoLayout onto a FreeType2 bitmap, with he
+Render a `PangoLayout` onto a FreeType2 bitmap, with he
 location specified in fixed-point Pango units rather than
-pixels. (Using this will avoid extra inaccuracies from
-rounding to integer pixels multiple times, even if the
-final glyph positions are integers.)
+pixels.
+
+(Using this will avoid extra inaccuracies from rounding
+to integer pixels multiple times, even if the final glyph
+positions are integers.)
 
 Since: 1.6
 
 </description>
 <parameters>
 <parameter name="bitmap">
-<parameter_description>    a &lt;type&gt;FT_Bitmap&lt;/type&gt; to render the layout onto
+<parameter_description> a FT_Bitmap to render the layout onto
 </parameter_description>
 </parameter>
 <parameter name="layout">
-<parameter_description>    a #PangoLayout
+<parameter_description> a `PangoLayout`
 </parameter_description>
 </parameter>
 <parameter name="x">
-<parameter_description>         the X position of the left of the layout (in Pango units)
+<parameter_description> the X position of the left of the layout (in Pango units)
 </parameter_description>
 </parameter>
 <parameter name="y">
-<parameter_description>         the Y position of the top of the layout (in Pango units)
+<parameter_description> the Y position of the top of the layout (in Pango units)
 </parameter_description>
 </parameter>
 </parameters>
@@ -7357,11 +8389,13 @@ Since: 1.6
 
 <function name="pango_ft2_render_transformed">
 <description>
-Renders a #PangoGlyphString onto a FreeType2 bitmap, possibly
+Renders a `PangoGlyphString` onto a FreeType2 bitmap, possibly
 transforming the layed-out coordinates through a transformation
-matrix. Note that the transformation matrix for @font is not
+matrix.
+
+Note that the transformation matrix for @font is not
 changed, so to produce correct rendering results, the @font
-must have been loaded using a #PangoContext with an identical
+must have been loaded using a `PangoContext` with an identical
 transformation matrix to that passed in to this function.
 
 Since: 1.6
@@ -7369,29 +8403,28 @@ Since: 1.6
 </description>
 <parameters>
 <parameter name="bitmap">
-<parameter_description>  the FreeType2 bitmap onto which to draw the string
+<parameter_description> the FreeType2 bitmap onto which to draw the string
 </parameter_description>
 </parameter>
 <parameter name="font">
-<parameter_description>    the font in which to draw the string
+<parameter_description> the font in which to draw the string
 </parameter_description>
 </parameter>
 <parameter name="matrix">
-<parameter_description> a #PangoMatrix, or %NULL to use an identity
-transformation
+<parameter_description> a `PangoMatrix`
 </parameter_description>
 </parameter>
 <parameter name="glyphs">
-<parameter_description>  the glyph string to draw
+<parameter_description> the glyph string to draw
 </parameter_description>
 </parameter>
 <parameter name="x">
-<parameter_description>       the x position of the start of the string (in Pango
+<parameter_description> the x position of the start of the string (in Pango
 units in user space coordinates)
 </parameter_description>
 </parameter>
 <parameter name="y">
-<parameter_description>       the y position of the baseline (in Pango units
+<parameter_description> the y position of the baseline (in Pango units
 in user space coordinates)
 </parameter_description>
 </parameter>
@@ -7428,13 +8461,15 @@ not be freed.
 
 <function name="pango_get_log_attrs">
 <description>
-Computes a #PangoLogAttr for each character in @text. The @log_attrs
-array must have one #PangoLogAttr for each position in @text; if
-@text contains N characters, it has N+1 positions, including the
-last position at the end of the text. @text should be an entire
-paragraph; logical attributes can't be computed without context
-(for example you need to see spaces on either side of a word to know
-the word is a word).
+Computes a `PangoLogAttr` for each character in @text.
+
+The @attrs array must have one `PangoLogAttr` for
+each position in @text; if @text contains N characters,
+it has N+1 positions, including the last position at the
+end of the text. @text should be an entire paragraph;
+logical attributes can't be computed without context
+(for example you need to see spaces on either side of
+a word to know the word is a word).
 
 </description>
 <parameters>
@@ -7454,13 +8489,13 @@ the word is a word).
 <parameter_description> language tag
 </parameter_description>
 </parameter>
-<parameter name="log_attrs">
-<parameter_description> array with one #PangoLogAttr
+<parameter name="attrs">
+<parameter_description> array with one `PangoLogAttr`
 per character in @text, plus one extra, to be filled in
 </parameter_description>
 </parameter>
 <parameter name="attrs_len">
-<parameter_description> length of @log_attrs array
+<parameter_description> length of @attrs array
 </parameter_description>
 </parameter>
 </parameters>
@@ -7469,13 +8504,12 @@ per character in @text, plus one extra, to be filled in
 
 <function name="pango_get_mirror_char">
 <description>
-If @ch has the Unicode mirrored property and there is another Unicode
-character that typically has a glyph that is the mirror image of @ch's
-glyph, puts that character in the address pointed to by @mirrored_ch.
+Returns the mirrored character of a Unicode character.
 
-Use g_unichar_get_mirror_char() instead; the docs for that function
-provide full details.
+Mirror characters are determined by the Unicode mirrored property.
 
+Deprecated: 1.30: Use g_unichar_get_mirror_char() instead; the docs for that function
+provide full details.
 
 </description>
 <parameters>
@@ -7490,6 +8524,7 @@ provide full details.
 </parameters>
 <return> %TRUE if @ch has a mirrored character and @mirrored_ch is
 filled in, %FALSE otherwise
+
 </return>
 </function>
 
@@ -7511,18 +8546,19 @@ not be freed.
 
 <function name="pango_glyph_item_apply_attrs">
 <description>
-Splits a shaped item (PangoGlyphItem) into multiple items based
-on an attribute list. The idea is that if you have attributes
-that don't affect shaping, such as color or underline, to avoid
-affecting shaping, you filter them out (pango_attr_list_filter()),
-apply the shaping process and then reapply them to the result using
-this function.
+Splits a shaped item (`PangoGlyphItem`) into multiple items based
+on an attribute list.
+
+The idea is that if you have attributes that don't affect shaping,
+such as color or underline, to avoid affecting shaping, you filter
+them out ([method@Pango.AttrList.filter]), apply the shaping process
+and then reapply them to the result using this function.
 
 All attributes that start or end inside a cluster are applied
 to that cluster; for instance, if half of a cluster is underlined
 and the other-half strikethrough, then the cluster will end
 up with both underline and strikethrough attributes. In these
-cases, it may happen that item-&gt;extra_attrs for some of the
+cases, it may happen that @item-&gt;extra_attrs for some of the
 result items can have multiple attributes of the same type.
 
 This function takes ownership of @glyph_item; it will be reused
@@ -7541,13 +8577,13 @@ Since: 1.2
 </parameter_description>
 </parameter>
 <parameter name="list">
-<parameter_description> a #PangoAttrList
+<parameter_description> a `PangoAttrList`
 </parameter_description>
 </parameter>
 </parameters>
 <return> a
 list of glyph items resulting from splitting @glyph_item. Free
-the elements using pango_glyph_item_free(), the list using
+the elements using [method Pango GlyphItem free], the list using
 g_slist_free().
 
 </return>
@@ -7555,34 +8591,32 @@ g_slist_free().
 
 <function name="pango_glyph_item_copy">
 <description>
-Make a deep copy of an existing #PangoGlyphItem structure.
+Make a deep copy of an existing `PangoGlyphItem` structure.
 
 Since: 1.20
 
 </description>
 <parameters>
 <parameter name="orig">
-<parameter_description> a #PangoGlyphItem, may be %NULL
+<parameter_description> a `PangoGlyphItem`
 </parameter_description>
 </parameter>
 </parameters>
-<return> the newly allocated #PangoGlyphItem, which should
-be freed with pango_glyph_item_free(), or %NULL
-if @orig was %NULL.
+<return> the newly allocated `PangoGlyphItem`
 
 </return>
 </function>
 
 <function name="pango_glyph_item_free">
 <description>
-Frees a #PangoGlyphItem and resources to which it points.
+Frees a `PangoGlyphItem` and resources to which it points.
 
 Since: 1.6
 
 </description>
 <parameters>
 <parameter name="glyph_item">
-<parameter_description> a #PangoGlyphItem, may be %NULL
+<parameter_description> a `PangoGlyphItem`
 </parameter_description>
 </parameter>
 </parameters>
@@ -7591,19 +8625,20 @@ Since: 1.6
 
 <function name="pango_glyph_item_get_logical_widths">
 <description>
-Given a #PangoGlyphItem and the corresponding
-text, determine the screen width corresponding to each character. When
-multiple characters compose a single cluster, the width of the entire
-cluster is divided equally among the characters.
+Given a `PangoGlyphItem` and the corresponding text, determine the
+width corresponding to each character.
+
+When multiple characters compose a single cluster, the width of the
+entire cluster is divided equally among the characters.
 
-See also pango_glyph_string_get_logical_widths().
+See also [method@Pango.GlyphString.get_logical_widths].
 
 Since: 1.26
 
 </description>
 <parameters>
 <parameter name="glyph_item">
-<parameter_description> a #PangoGlyphItem
+<parameter_description> a `PangoGlyphItem`
 </parameter_description>
 </parameter>
 <parameter name="text">
@@ -7614,9 +8649,8 @@ start of @text)
 </parameter>
 <parameter name="logical_widths">
 <parameter_description> an array whose length is the number of
-characters in glyph_item (equal to
-glyph_item-&gt;item-&gt;num_chars) to be filled in with
-the resulting character widths.
+characters in glyph_item (equal to glyph_item-&gt;item-&gt;num_chars)
+to be filled in with the resulting character widths.
 </parameter_description>
 </parameter>
 </parameters>
@@ -7625,34 +8659,32 @@ the resulting character widths.
 
 <function name="pango_glyph_item_iter_copy">
 <description>
-Make a shallow copy of an existing #PangoGlyphItemIter structure.
+Make a shallow copy of an existing `PangoGlyphItemIter` structure.
 
 Since: 1.22
 
 </description>
 <parameters>
 <parameter name="orig">
-<parameter_description> a #PangoGlyphItemIter, may be %NULL
+<parameter_description> a `PangoGlyphItem`Iter
 </parameter_description>
 </parameter>
 </parameters>
-<return> the newly allocated #PangoGlyphItemIter, which should
-be freed with pango_glyph_item_iter_free(), or %NULL
-if @orig was %NULL.
+<return> the newly allocated `PangoGlyphItemIter`
 
 </return>
 </function>
 
 <function name="pango_glyph_item_iter_free">
 <description>
-Frees a #PangoGlyphItemIter created by pango_glyph_item_iter_copy().
+Frees a `PangoGlyphItem`Iter.
 
 Since: 1.22
 
 </description>
 <parameters>
 <parameter name="iter">
-<parameter_description> a #PangoGlyphItemIter, may be %NULL
+<parameter_description> a `PangoGlyphItemIter`
 </parameter_description>
 </parameter>
 </parameters>
@@ -7661,16 +8693,17 @@ Since: 1.22
 
 <function name="pango_glyph_item_iter_init_end">
 <description>
-Initializes a #PangoGlyphItemIter structure to point to the
+Initializes a `PangoGlyphItemIter` structure to point to the
 last cluster in a glyph item.
-See #PangoGlyphItemIter for details of cluster orders.
+
+See `PangoGlyphItemIter` for details of cluster orders.
 
 Since: 1.22
 
 </description>
 <parameters>
 <parameter name="iter">
-<parameter_description> a #PangoGlyphItemIter
+<parameter_description> a `PangoGlyphItemIter`
 </parameter_description>
 </parameter>
 <parameter name="glyph_item">
@@ -7689,16 +8722,17 @@ Since: 1.22
 
 <function name="pango_glyph_item_iter_init_start">
 <description>
-Initializes a #PangoGlyphItemIter structure to point to the
+Initializes a `PangoGlyphItemIter` structure to point to the
 first cluster in a glyph item.
-See #PangoGlyphItemIter for details of cluster orders.
+
+See `PangoGlyphItemIter` for details of cluster orders.
 
 Since: 1.22
 
 </description>
 <parameters>
 <parameter name="iter">
-<parameter_description> a #PangoGlyphItemIter
+<parameter_description> a `PangoGlyphItemIter`
 </parameter_description>
 </parameter>
 <parameter name="glyph_item">
@@ -7718,19 +8752,20 @@ Since: 1.22
 <function name="pango_glyph_item_iter_next_cluster">
 <description>
 Advances the iterator to the next cluster in the glyph item.
-See #PangoGlyphItemIter for details of cluster orders.
+
+See `PangoGlyphItemIter` for details of cluster orders.
 
 Since: 1.22
 
 </description>
 <parameters>
 <parameter name="iter">
-<parameter_description> a #PangoGlyphItemIter
+<parameter_description> a `PangoGlyphItemIter`
 </parameter_description>
 </parameter>
 </parameters>
-<return> %TRUE if the iterator was advanced, %FALSE if we were already on the
-last cluster.
+<return> %TRUE if the iterator was advanced,
+%FALSE if we were already on the  last cluster.
 
 </return>
 </function>
@@ -7738,19 +8773,19 @@ last cluster.
 <function name="pango_glyph_item_iter_prev_cluster">
 <description>
 Moves the iterator to the preceding cluster in the glyph item.
-See #PangoGlyphItemIter for details of cluster orders.
+See `PangoGlyphItemIter` for details of cluster orders.
 
 Since: 1.22
 
 </description>
 <parameters>
 <parameter name="iter">
-<parameter_description> a #PangoGlyphItemIter
+<parameter_description> a `PangoGlyphItemIter`
 </parameter_description>
 </parameter>
 </parameters>
-<return> %TRUE if the iterator was moved, %FALSE if we were already on the
-first cluster.
+<return> %TRUE if the iterator was moved,
+%FALSE if we were already on the first cluster.
 
 </return>
 </function>
@@ -7765,7 +8800,7 @@ Since: 1.6
 </description>
 <parameters>
 <parameter name="glyph_item">
-<parameter_description> a #PangoGlyphItem
+<parameter_description> a `PangoGlyphItem`
 </parameter_description>
 </parameter>
 <parameter name="text">
@@ -7794,11 +8829,12 @@ negative values will give ugly results.
 <description>
 Modifies @orig to cover only the text after @split_index, and
 returns a new item that covers the text before @split_index that
-used to be in @orig. You can think of @split_index as the length of
-the returned item. @split_index may not be 0, and it may not be
-greater than or equal to the length of @orig (that is, there must
-be at least one byte assigned to each item, you can't create a
-zero-length item).
+used to be in @orig.
+
+You can think of @split_index as the length of the returned item.
+@split_index may not be 0, and it may not be greater than or equal
+to the length of @orig (that is, there must be at least one byte
+assigned to each item, you can't create a zero-length item).
 
 This function is similar in function to pango_item_split() (and uses
 it internally.)
@@ -7808,7 +8844,7 @@ Since: 1.2
 </description>
 <parameters>
 <parameter name="orig">
-<parameter_description> a #PangoItem
+<parameter_description> a `PangoItem`
 </parameter_description>
 </parameter>
 <parameter name="text">
@@ -7816,7 +8852,8 @@ Since: 1.2
 </parameter_description>
 </parameter>
 <parameter name="split_index">
-<parameter_description> byte index of position to split item, relative to the start of the item
+<parameter_description> byte index of position to split item, relative to the
+start of the item
 </parameter_description>
 </parameter>
 </parameters>
@@ -7835,21 +8872,20 @@ Copy a glyph string and associated storage.
 </description>
 <parameters>
 <parameter name="string">
-<parameter_description> a #PangoGlyphString, may be %NULL
+<parameter_description> a `PangoGlyphString`
 </parameter_description>
 </parameter>
 </parameters>
-<return> the newly allocated #PangoGlyphString,
-which should be freed with pango_glyph_string_free(),
-or %NULL if @string was %NULL.
+<return> the newly allocated `PangoGlyphString`
 </return>
 </function>
 
 <function name="pango_glyph_string_extents">
 <description>
-Compute the logical and ink extents of a glyph string. See the documentation
-for pango_font_get_glyph_extents() for details about the interpretation
-of the rectangles.
+Compute the logical and ink extents of a glyph string.
+
+See the documentation for [method Pango Font.get_glyph_extents] for details
+about the interpretation of the rectangles.
 
 Examples of logical (red) and ink (green) rects:
 
@@ -7858,21 +8894,19 @@ Examples of logical (red) and ink (green) rects:
 </description>
 <parameters>
 <parameter name="glyphs">
-<parameter_description>   a #PangoGlyphString
+<parameter_description> a `PangoGlyphString`
 </parameter_description>
 </parameter>
 <parameter name="font">
-<parameter_description>     a #PangoFont
+<parameter_description> a `PangoFont`
 </parameter_description>
 </parameter>
 <parameter name="ink_rect">
-<parameter_description> rectangle used to store the extents of the glyph string
-as drawn or %NULL to indicate that the result is not needed.
+<parameter_description> rectangle used to store the extents of the glyph string as drawn
 </parameter_description>
 </parameter>
 <parameter name="logical_rect">
-<parameter_description> rectangle used to store the logical extents of the
-glyph string or %NULL to indicate that the result is not needed.
+<parameter_description> rectangle used to store the logical extents of the glyph string
 </parameter_description>
 </parameter>
 </parameters>
@@ -7881,40 +8915,39 @@ glyph string or %NULL to indicate that the result is not needed.
 
 <function name="pango_glyph_string_extents_range">
 <description>
-Computes the extents of a sub-portion of a glyph string. The extents are
-relative to the start of the glyph string range (the origin of their
-coordinate system is at the start of the range, not at the start of the entire
-glyph string).
+Computes the extents of a sub-portion of a glyph string.
+
+The extents are relative to the start of the glyph string range
+(the origin of their coordinate system is at the start of the range,
+not at the start of the entire glyph string).
 
 </description>
 <parameters>
 <parameter name="glyphs">
-<parameter_description>   a #PangoGlyphString
+<parameter_description> a `PangoGlyphString`
 </parameter_description>
 </parameter>
 <parameter name="start">
-<parameter_description>    start index
+<parameter_description> start index
 </parameter_description>
 </parameter>
 <parameter name="end">
-<parameter_description>      end index (the range is the set of bytes with
-             indices such that start &lt;= index &lt; end)
+<parameter_description> end index (the range is the set of bytes with
+indices such that start &lt;= index &lt; end)
 </parameter_description>
 </parameter>
 <parameter name="font">
-<parameter_description>     a #PangoFont
+<parameter_description> a `PangoFont`
 </parameter_description>
 </parameter>
 <parameter name="ink_rect">
 <parameter_description> rectangle used to
-store the extents of the glyph string range as drawn or
-%NULL to indicate that the result is not needed.
+store the extents of the glyph string range as drawn
 </parameter_description>
 </parameter>
 <parameter name="logical_rect">
 <parameter_description> rectangle used to
-store the logical extents of the glyph string range or
-%NULL to indicate that the result is not needed.
+store the logical extents of the glyph string range
 </parameter_description>
 </parameter>
 </parameters>
@@ -7928,7 +8961,7 @@ Free a glyph string and associated storage.
 </description>
 <parameters>
 <parameter name="string">
-<parameter_description> a #PangoGlyphString, may be %NULL
+<parameter_description> a `PangoGlyphString`, may be %NULL
 </parameter_description>
 </parameter>
 </parameters>
@@ -7937,17 +8970,18 @@ Free a glyph string and associated storage.
 
 <function name="pango_glyph_string_get_logical_widths">
 <description>
-Given a #PangoGlyphString resulting from pango_shape() and the corresponding
-text, determine the screen width corresponding to each character. When
-multiple characters compose a single cluster, the width of the entire
-cluster is divided equally among the characters.
+Given a `PangoGlyphString` and corresponding text, determine the width
+corresponding to each character.
 
-See also pango_glyph_item_get_logical_widths().
+When multiple characters compose a single cluster, the width of the
+entire cluster is divided equally among the characters.
+
+See also [method@Pango.GlyphItem.get_logical_widths].
 
 </description>
 <parameters>
 <parameter name="glyphs">
-<parameter_description> a #PangoGlyphString
+<parameter_description> a `PangoGlyphString`
 </parameter_description>
 </parameter>
 <parameter name="text">
@@ -7964,9 +8998,8 @@ See also pango_glyph_item_get_logical_widths().
 </parameter>
 <parameter name="logical_widths">
 <parameter_description> an array whose length is the number of
-characters in text (equal to g_utf8_strlen (text,
-length) unless text has NUL bytes) to be filled in
-with the resulting character widths.
+characters in text (equal to `g_utf8_strlen (text, length)` unless
+text has `NUL` bytes) to be filled in with the resulting character widths.
 </parameter_description>
 </parameter>
 </parameters>
@@ -7975,17 +9008,19 @@ with the resulting character widths.
 
 <function name="pango_glyph_string_get_width">
 <description>
-Computes the logical width of the glyph string as can also be computed
-using pango_glyph_string_extents().  However, since this only computes the
-width, it's much faster.  This is in fact only a convenience function that
-computes the sum of geometry.width for each glyph in the @glyphs.
+Computes the logical width of the glyph string.
+
+This can also be computed using [method@Pango.GlyphString.extents].
+However, since this only computes the width, it's much faster. This
+is in fact only a convenience function that computes the sum of
+@geometry.width for each glyph in the @glyphs.
 
 Since: 1.14
 
 </description>
 <parameters>
 <parameter name="glyphs">
-<parameter_description>   a #PangoGlyphString
+<parameter_description>  a `PangoGlyphString`
 </parameter_description>
 </parameter>
 </parameters>
@@ -7996,34 +9031,92 @@ Since: 1.14
 
 <function name="pango_glyph_string_index_to_x">
 <description>
-Converts from character position to x position. (X position
-is measured from the left edge of the run). Character positions
-are computed by dividing up each cluster into equal portions.
+Converts from character position to x position.
+
+The X position is measured from the left edge of the run.
+Character positions are obtained using font metrics for ligatures
+where available, and computed by dividing up each cluster
+into equal portions, otherwise.
+
+&lt;picture&gt;
+&lt;source srcset=&quot;glyphstring-positions-dark.png&quot; media=&quot;(prefers-color-scheme: 
dark)&quot;&gt;
+&lt;img alt=&quot;Glyph positions&quot; src=&quot;glyphstring-positions-light.png&quot;&gt;
+&lt;/picture&gt;
+
+</description>
+<parameters>
+<parameter name="glyphs">
+<parameter_description> the glyphs return from [func@shape]
+</parameter_description>
+</parameter>
+<parameter name="text">
+<parameter_description> the text for the run
+</parameter_description>
+</parameter>
+<parameter name="length">
+<parameter_description> the number of bytes (not characters) in @text.
+</parameter_description>
+</parameter>
+<parameter name="analysis">
+<parameter_description> the analysis information return from [func@itemize]
+</parameter_description>
+</parameter>
+<parameter name="index_">
+<parameter_description> the byte index within @text
+</parameter_description>
+</parameter>
+<parameter name="trailing">
+<parameter_description> whether we should compute the result for the beginning (%FALSE)
+or end (%TRUE) of the character.
+</parameter_description>
+</parameter>
+<parameter name="x_pos">
+<parameter_description> location to store result
+</parameter_description>
+</parameter>
+</parameters>
+<return></return>
+</function>
+
+<function name="pango_glyph_string_index_to_x_full">
+<description>
+Converts from character position to x position.
+
+This variant of [method@Pango.GlyphString.index_to_x] additionally
+accepts a `PangoLogAttr` array. The grapheme boundary information
+in it can be used to disambiguate positioning inside some complex
+clusters.
+
+Since: 1.50
 
 </description>
 <parameters>
 <parameter name="glyphs">
-<parameter_description>    the glyphs return from pango_shape()
+<parameter_description> the glyphs return from [func@shape]
 </parameter_description>
 </parameter>
 <parameter name="text">
-<parameter_description>      the text for the run
+<parameter_description> the text for the run
 </parameter_description>
 </parameter>
 <parameter name="length">
-<parameter_description>    the number of bytes (not characters) in @text.
+<parameter_description> the number of bytes (not characters) in @text.
 </parameter_description>
 </parameter>
 <parameter name="analysis">
-<parameter_description>  the analysis information return from pango_itemize()
+<parameter_description> the analysis information return from [func@itemize]
+</parameter_description>
+</parameter>
+<parameter name="attrs">
+<parameter_description> `PangoLogAttr` array for @text
 </parameter_description>
 </parameter>
 <parameter name="index_">
-<parameter_description>    the byte index within @text
+<parameter_description> the byte index within @text
 </parameter_description>
 </parameter>
 <parameter name="trailing">
-<parameter_description>  whether we should compute the result for the beginning (%FALSE)
+<parameter_description> whether we should compute the result for the beginning (%FALSE)
 or end (%TRUE) of the character.
 </parameter_description>
 </parameter>
@@ -8037,14 +9130,14 @@ or end (%TRUE) of the character.
 
 <function name="pango_glyph_string_new">
 <description>
-Create a new #PangoGlyphString.
+Create a new `PangoGlyphString`.
 
 
 </description>
 <parameters>
 </parameters>
-<return> the newly allocated #PangoGlyphString, which
-should be freed with pango_glyph_string_free().
+<return> the newly allocated `PangoGlyphString`, which
+should be freed with [method Pango GlyphString free].
 </return>
 </function>
 
@@ -8055,11 +9148,11 @@ Resize a glyph string to the given length.
 </description>
 <parameters>
 <parameter name="string">
-<parameter_description>    a #PangoGlyphString.
+<parameter_description> a `PangoGlyphString`.
 </parameter_description>
 </parameter>
 <parameter name="new_len">
-<parameter_description>   the new length of the string.
+<parameter_description> the new length of the string
 </parameter_description>
 </parameter>
 </parameters>
@@ -8068,33 +9161,34 @@ Resize a glyph string to the given length.
 
 <function name="pango_glyph_string_x_to_index">
 <description>
-Convert from x offset to character position. Character positions
-are computed by dividing up each cluster into equal portions.
-In scripts where positioning within a cluster is not allowed
-(such as Thai), the returned value may not be a valid cursor
-position; the caller must combine the result with the logical
+Convert from x offset to character position.
+
+Character positions are computed by dividing up each cluster into
+equal portions. In scripts where positioning within a cluster is
+not allowed (such as Thai), the returned value may not be a valid
+cursor position; the caller must combine the result with the logical
 attributes for the text to compute the valid cursor position.
 
 </description>
 <parameters>
 <parameter name="glyphs">
-<parameter_description>    the glyphs returned from pango_shape()
+<parameter_description> the glyphs returned from [func@shape]
 </parameter_description>
 </parameter>
 <parameter name="text">
-<parameter_description>      the text for the run
+<parameter_description> the text for the run
 </parameter_description>
 </parameter>
 <parameter name="length">
-<parameter_description>    the number of bytes (not characters) in text.
+<parameter_description> the number of bytes (not characters) in text.
 </parameter_description>
 </parameter>
 <parameter name="analysis">
-<parameter_description>  the analysis information return from pango_itemize()
+<parameter_description> the analysis information return from [func@itemize]
 </parameter_description>
 </parameter>
 <parameter name="x_pos">
-<parameter_description>     the x offset (in Pango units)
+<parameter_description> the x offset (in Pango units)
 </parameter_description>
 </parameter>
 <parameter name="index_">
@@ -8102,9 +9196,8 @@ attributes for the text to compute the valid cursor position.
 </parameter_description>
 </parameter>
 <parameter name="trailing">
-<parameter_description> location to store a boolean indicating
-whether the user clicked on the leading or trailing
-edge of the character.
+<parameter_description> location to store a boolean indicating whether the
+user clicked on the leading or trailing edge of the character
 </parameter_description>
 </parameter>
 </parameters>
@@ -8114,14 +9207,14 @@ edge of the character.
 <function name="pango_gravity_get_for_matrix">
 <description>
 Finds the gravity that best matches the rotation component
-in a #PangoMatrix.
+in a `PangoMatrix`.
 
 Since: 1.16
 
 </description>
 <parameters>
 <parameter name="matrix">
-<parameter_description> a #PangoMatrix
+<parameter_description> a `PangoMatrix`
 </parameter_description>
 </parameter>
 </parameters>
@@ -8133,8 +9226,9 @@ Since: 1.16
 
 <function name="pango_gravity_get_for_script">
 <description>
-Based on the script, base gravity, and hint, returns actual gravity
-to use in laying out a single #PangoItem.
+Returns the gravity to use in laying out a `PangoItem`.
+
+The gravity is determined based on the script, base gravity, and hint.
 
 If @base_gravity is %PANGO_GRAVITY_AUTO, it is first replaced with the
 preferred gravity of @script.  To get the preferred gravity of a script,
@@ -8145,7 +9239,7 @@ Since: 1.16
 </description>
 <parameters>
 <parameter name="script">
-<parameter_description> #PangoScript to query
+<parameter_description> `PangoScript` to query
 </parameter_description>
 </parameter>
 <parameter name="base_gravity">
@@ -8158,21 +9252,23 @@ Since: 1.16
 </parameter>
 </parameters>
 <return> resolved gravity suitable to use for a run of text
-with @script.
+with @script
 
 </return>
 </function>
 
 <function name="pango_gravity_get_for_script_and_width">
 <description>
-Based on the script, East Asian width, base gravity, and hint,
-returns actual gravity to use in laying out a single character
-or #PangoItem.
+Returns the gravity to use in laying out a single character
+or `PangoItem`.
 
-This function is similar to pango_gravity_get_for_script() except
+The gravity is determined based on the script, East Asian width,
+base gravity, and hint,
+
+This function is similar to [func@Pango.Gravity.get_for_script] except
 that this function makes a distinction between narrow/half-width and
-wide/full-width characters also.  Wide/full-width characters always
-stand &lt;emphasis&gt;upright&lt;/emphasis&gt;, that is, they always take the base gravity,
+wide/full-width characters also. Wide/full-width characters always
+stand *upright*, that is, they always take the base gravity,
 whereas narrow/full-width characters are always rotated in vertical
 context.
 
@@ -8184,7 +9280,7 @@ Since: 1.26
 </description>
 <parameters>
 <parameter name="script">
-<parameter_description> #PangoScript to query
+<parameter_description> `PangoScript` to query
 </parameter_description>
 </parameter>
 <parameter name="wide">
@@ -8208,11 +9304,10 @@ with @script and @wide.
 
 <function name="pango_gravity_to_rotation">
 <description>
-Converts a #PangoGravity value to its natural rotation in radians.
-@gravity should not be %PANGO_GRAVITY_AUTO.
+Converts a `PangoGravity` value to its natural rotation in radians.
 
-Note that pango_matrix_rotate() takes angle in degrees, not radians.
-So, to call pango_matrix_rotate() with the output of this function
+Note that [method@Pango.Matrix.rotate] takes angle in degrees, not radians.
+So, to call [method@Pango.Matrix,rotate] with the output of this function
 you should multiply it by (180. / G_PI).
 
 Since: 1.16
@@ -8220,7 +9315,7 @@ Since: 1.16
 </description>
 <parameters>
 <parameter name="gravity">
-<parameter_description> gravity to query
+<parameter_description> gravity to query, should not be %PANGO_GRAVITY_AUTO
 </parameter_description>
 </parameter>
 </parameters>
@@ -8231,11 +9326,11 @@ Since: 1.16
 
 <function name="pango_is_zero_width">
 <description>
-Checks @ch to see if it is a character that should not be
-normally rendered on the screen.  This includes all Unicode characters
-with &quot;ZERO WIDTH&quot; in their name, as well as &lt;firstterm&gt;bidi&lt;/firstterm&gt; formatting 
characters, and
-a few other ones.  This is totally different from g_unichar_iszerowidth()
-and is at best misnamed.
+Checks if a character that should not be normally rendered.
+
+This includes all Unicode characters with &quot;ZERO WIDTH&quot; in their name,
+as well as *bidi* formatting characters, and a few other ones.  This is
+totally different from g_unichar_iszerowidth() and is at best misnamed.
 
 Since: 1.10
 
@@ -8253,11 +9348,12 @@ Since: 1.10
 
 <function name="pango_item_apply_attrs">
 <description>
-Add attributes to a PangoItem. The idea is that you have
-attributes that don't affect itemization, such as font features,
-so you filter them out using pango_attr_list_filter(), itemize
-your text, then reapply the attributes to the resulting items
-using this function.
+Add attributes to a `PangoItem`.
+
+The idea is that you have attributes that don't affect itemization,
+such as font features, so you filter them out using
+[method@Pango.AttrList.filter], itemize your text, then reapply the
+attributes to the resulting items using this function.
 
 The @iter should be positioned before the range of the item,
 and will be advanced past it. This function is meant to be called
@@ -8269,11 +9365,11 @@ Since: 1.44
 </description>
 <parameters>
 <parameter name="item">
-<parameter_description> a #PangoItem
+<parameter_description> a `PangoItem`
 </parameter_description>
 </parameter>
 <parameter name="iter">
-<parameter_description> a #PangoAttrIterator
+<parameter_description> a `PangoAttrIterator`
 </parameter_description>
 </parameter>
 </parameters>
@@ -8282,30 +9378,28 @@ Since: 1.44
 
 <function name="pango_item_copy">
 <description>
-Copy an existing #PangoItem structure.
+Copy an existing `PangoItem` structure.
 
 
 </description>
 <parameters>
 <parameter name="item">
-<parameter_description> a #PangoItem, may be %NULL
+<parameter_description> a `PangoItem`
 </parameter_description>
 </parameter>
 </parameters>
-<return> the newly allocated #PangoItem, which
-should be freed with pango_item_free(), or %NULL if
-@item was %NULL.
+<return> the newly allocated `PangoItem`
 </return>
 </function>
 
 <function name="pango_item_free">
 <description>
-Free a #PangoItem and all associated memory.
+Free a `PangoItem` and all associated memory.
 
 </description>
 <parameters>
 <parameter name="item">
-<parameter_description> a #PangoItem, may be %NULL
+<parameter_description> a `PangoItem`, may be %NULL
 </parameter_description>
 </parameter>
 </parameters>
@@ -8314,14 +9408,14 @@ Free a #PangoItem and all associated memory.
 
 <function name="pango_item_new">
 <description>
-Creates a new #PangoItem structure initialized to default values.
+Creates a new `PangoItem` structure initialized to default values.
 
 
 </description>
 <parameters>
 </parameters>
-<return> the newly allocated #PangoItem, which should
-be freed with pango_item_free().
+<return> the newly allocated `PangoItem`, which should
+be freed with [method Pango Item free].
 </return>
 </function>
 
@@ -8329,24 +9423,27 @@ be freed with pango_item_free().
 <description>
 Modifies @orig to cover only the text after @split_index, and
 returns a new item that covers the text before @split_index that
-used to be in @orig. You can think of @split_index as the length of
-the returned item. @split_index may not be 0, and it may not be
-greater than or equal to the length of @orig (that is, there must
-be at least one byte assigned to each item, you can't create a
-zero-length item). @split_offset is the length of the first item in
-chars, and must be provided because the text used to generate the
-item isn't available, so pango_item_split() can't count the char
-length of the split items itself.
+used to be in @orig.
+
+You can think of @split_index as the length of the returned item.
+@split_index may not be 0, and it may not be greater than or equal
+to the length of @orig (that is, there must be at least one byte
+assigned to each item, you can't create a zero-length item).
+@split_offset is the length of the first item in chars, and must be
+provided because the text used to generate the item isn't available,
+so `pango_item_split()` can't count the char length of the split items
+itself.
 
 
 </description>
 <parameters>
 <parameter name="orig">
-<parameter_description> a #PangoItem
+<parameter_description> a `PangoItem`
 </parameter_description>
 </parameter>
 <parameter name="split_index">
-<parameter_description> byte index of position to split item, relative to the start of the item
+<parameter_description> byte index of position to split item, relative to the
+start of the item
 </parameter_description>
 </parameter>
 <parameter name="split_offset">
@@ -8355,33 +9452,35 @@ length of the split items itself.
 </parameter>
 </parameters>
 <return> new item representing text before @split_index, which
-should be freed with pango_item_free().
+should be freed with [method Pango Item free].
 </return>
 </function>
 
 <function name="pango_itemize">
 <description>
-Breaks a piece of text into segments with consistent
-directional level and shaping engine. Each byte of @text will
-be contained in exactly one of the items in the returned list;
-the generated list of items will be in logical order (the start
-offsets of the items are ascending).
+Breaks a piece of text into segments with consistent directional
+level and font.
 
-@cached_iter should be an iterator over @attrs currently positioned at a
-range before or containing @start_index; @cached_iter will be advanced to
-the range covering the position just after @start_index + @length.
-(i.e. if itemizing in a loop, just keep passing in the same @cached_iter).
+Each byte of @text will be contained in exactly one of the items in the
+returned list; the generated list of items will be in logical order (the
+start offsets of the items are ascending).
+
+@cached_iter should be an iterator over @attrs currently positioned
+at a range before or containing @start_index; @cached_iter will be
+advanced to the range covering the position just after
+@start_index + @length. (i.e. if itemizing in a loop, just keep passing
+in the same @cached_iter).
 
 
 </description>
 <parameters>
 <parameter name="context">
-<parameter_description>   a structure holding information that affects
-              the itemization process.
+<parameter_description> a structure holding information that affects
+the itemization process.
 </parameter_description>
 </parameter>
 <parameter name="text">
-<parameter_description>      the text to itemize. Must be valid UTF-8
+<parameter_description> the text to itemize. Must be valid UTF-8
 </parameter_description>
 </parameter>
 <parameter name="start_index">
@@ -8389,48 +9488,48 @@ the range covering the position just after @start_index + @length.
 </parameter_description>
 </parameter>
 <parameter name="length">
-<parameter_description>    the number of bytes (not characters) to process
-after @start_index.
-This must be &gt;= 0.
+<parameter_description> the number of bytes (not characters) to process
+after @start_index. This must be &gt;= 0.
 </parameter_description>
 </parameter>
 <parameter name="attrs">
-<parameter_description>     the set of attributes that apply to @text.
+<parameter_description> the set of attributes that apply to @text.
 </parameter_description>
 </parameter>
 <parameter name="cached_iter">
-<parameter_description> Cached attribute iterator, or %NULL
+<parameter_description> Cached attribute iterator
 </parameter_description>
 </parameter>
 </parameters>
-<return> a #GList of #PangoItem
-structures. The items should be freed using pango_item_free()
-probably in combination with g_list_foreach(), and the list itself
-using g_list_free().
+<return> a `GList` of
+[struct Pango Item] structures. The items should be freed using
+[method Pango Item free] probably in combination with g_list_free_full().
 </return>
 </function>
 
 <function name="pango_itemize_with_base_dir">
 <description>
-Like pango_itemize(), but the base direction to use when
-computing bidirectional levels (see pango_context_set_base_dir ()),
-is specified explicitly rather than gotten from the #PangoContext.
+Like `pango_itemize()`, but with an explicitly specified base direction.
+
+The base direction is used when computing bidirectional levels.
+(see [method@Pango.Context.set_base_dir]). [func@itemize] gets the
+base direction from the `PangoContext`.
 
 Since: 1.4
 
 </description>
 <parameters>
 <parameter name="context">
-<parameter_description>   a structure holding information that affects
+<parameter_description> a structure holding information that affects
 the itemization process.
 </parameter_description>
 </parameter>
 <parameter name="base_dir">
-<parameter_description>  base direction to use for bidirectional processing
+<parameter_description> base direction to use for bidirectional processing
 </parameter_description>
 </parameter>
 <parameter name="text">
-<parameter_description>      the text to itemize.
+<parameter_description> the text to itemize.
 </parameter_description>
 </parameter>
 <parameter name="start_index">
@@ -8438,63 +9537,59 @@ the itemization process.
 </parameter_description>
 </parameter>
 <parameter name="length">
-<parameter_description>    the number of bytes (not characters) to process
+<parameter_description> the number of bytes (not characters) to process
 after @start_index. This must be &gt;= 0.
 </parameter_description>
 </parameter>
 <parameter name="attrs">
-<parameter_description>     the set of attributes that apply to @text.
+<parameter_description> the set of attributes that apply to @text.
 </parameter_description>
 </parameter>
 <parameter name="cached_iter">
-<parameter_description> Cached attribute iterator, or %NULL
+<parameter_description> Cached attribute iterator
 </parameter_description>
 </parameter>
 </parameters>
-<return> a #GList of
-#PangoItem structures.  The items should be freed using
-pango_item_free() probably in combination with
-g_list_foreach(), and the list itself using g_list_free().
+<return> a `GList` of
+[struct Pango Item] structures. The items should be freed using
+[method Pango Item free] probably in combination with g_list_free_full().
 
 </return>
 </function>
 
 <function name="pango_language_from_string">
 <description>
-Take a RFC-3066 format language tag as a string and convert it to a
-#PangoLanguage pointer that can be efficiently copied (copy the
-pointer) and compared with other language tags (compare the
-pointer.)
+Convert a language tag to a `PangoLanguage`.
+
+The language tag must be in a RFC-3066 format. `PangoLanguage` pointers
+can be efficiently copied (copy the pointer) and compared with other
+language tags (compare the pointer.)
 
 This function first canonicalizes the string by converting it to
 lowercase, mapping '_' to '-', and stripping all characters other
 than letters and '-'.
 
-Use pango_language_get_default() if you want to get the #PangoLanguage for
-the current locale of the process.
+Use [func@Pango.Language.get_default] if you want to get the
+`PangoLanguage` for the current locale of the process.
 
 
 </description>
 <parameters>
 <parameter name="language">
-<parameter_description> a string representing a language tag, or %NULL
+<parameter_description> a string representing a language tag
 </parameter_description>
 </parameter>
 </parameters>
-<return> an opaque pointer to a
-#PangoLanguage structure, or %NULL if @language was
-%NULL.  The returned pointer will be valid forever
-after, and should not be freed.
+<return> a `PangoLanguage`
 </return>
 </function>
 
 <function name="pango_language_get_default">
 <description>
-Returns the #PangoLanguage for the current locale of the process.
-Note that this can change over the life of an application.
+Returns the `PangoLanguage` for the current locale of the process.
 
 On Unix systems, this is the return value is derived from
-&lt;literal&gt;setlocale(LC_CTYPE, NULL)&lt;/literal&gt;, and the user can
+`setlocale (LC_CTYPE, NULL)`, and the user can
 affect this through the environment variables LC_ALL, LC_CTYPE or
 LANG (checked in that order). The locale string typically is in
 the form lang_COUNTRY, where lang is an ISO-639 language code, and
@@ -8512,41 +9607,48 @@ However, this function does check the above environment
 variables, and does return a Unix-style locale string based on
 either said environment variables or the thread's current locale.
 
-Your application should call &lt;literal&gt;setlocale(LC_ALL, &quot;&quot;);&lt;/literal&gt;
-for the user settings to take effect.  Gtk+ does this in its initialization
+Your application should call `setlocale(LC_ALL, &quot;&quot;)` for the user
+settings to take effect. GTK does this in its initialization
 functions automatically (by calling gtk_set_locale()).
-See &lt;literal&gt;man setlocale&lt;/literal&gt; for more details.
+See the setlocale() manpage for more details.
+
+Note that the default language can change over the life of an application.
+
+Also note that this function will not do the right thing if you
+use per-thread locales with uselocale(). In that case, you should
+just call pango_language_from_string() yourself.
 
 Since: 1.16
 
 </description>
 <parameters>
 </parameters>
-<return> the default language as a
-#PangoLanguage, must not be freed.
+<return> the default language as a `PangoLanguage`
 
 </return>
 </function>
 
 <function name="pango_language_get_preferred">
 <description>
-Returns the list of languages that the user prefers, as specified
-by the PANGO_LANGUAGE or LANGUAGE environment variables, in order
-of preference. Note that this list does not necessarily include
-the language returned by pango_language_get_default().
+Returns the list of languages that the user prefers.
+
+The list is specified by the `PANGO_LANGUAGE` or `LANGUAGE`
+environment variables, in order of preference. Note that this
+list does not necessarily include the language returned by
+[func@Pango.Language.get_default].
 
 When choosing language-specific resources, such as the sample
-text returned by pango_language_get_sample_string(), you should
-first try the default language, followed by the languages returned
-by this function.
+text returned by [method@Pango.Language.get_sample_string],
+you should first try the default language, followed by the
+languages returned by this function.
 
 Since: 1.48
 
 </description>
 <parameters>
 </parameters>
-<return> a %NULL-terminated array of
-PangoLanguage*
+<return> a %NULL-terminated array
+of `PangoLanguage`*
 
 </return>
 </function>
@@ -8556,38 +9658,39 @@ PangoLanguage*
 Get a string that is representative of the characters needed to
 render a particular language.
 
-The sample text may be a pangram, but is not necessarily.  It is chosen to
-be demonstrative of normal text in the language, as well as exposing font
-feature requirements unique to the language.  It is suitable for use
+The sample text may be a pangram, but is not necessarily. It is chosen
+to be demonstrative of normal text in the language, as well as exposing
+font feature requirements unique to the language. It is suitable for use
 as sample text in a font selection dialog.
 
 If @language is %NULL, the default language as found by
-pango_language_get_default() is used.
+[func@Pango.Language.get_default] is used.
 
 If Pango does not have a sample string for @language, the classic
 &quot;The quick brown fox...&quot; is returned.  This can be detected by
 comparing the returned pointer value to that returned for (non-existent)
 language code &quot;xx&quot;.  That is, compare to:
-&lt;informalexample&gt;&lt;programlisting&gt;
+
+```
 pango_language_get_sample_string (pango_language_from_string (&quot;xx&quot;))
-&lt;/programlisting&gt;&lt;/informalexample&gt;
+```
 
 
 </description>
 <parameters>
 <parameter name="language">
-<parameter_description> a #PangoLanguage, or %NULL
+<parameter_description> a `PangoLanguage`
 </parameter_description>
 </parameter>
 </parameters>
-<return> the sample string. This value is owned by Pango
-and should not be freed.
+<return> the sample string
 </return>
 </function>
 
 <function name="pango_language_get_scripts">
 <description>
 Determines the scripts used to to write @language.
+
 If nothing is known about the language tag @language,
 or if @language is %NULL, then %NULL is returned.
 The list of scripts returned starts with the script that the
@@ -8598,16 +9701,16 @@ of scripts in the returned array (or zero if %NULL is returned).
 
 Most languages use only one script for writing, but there are
 some that use two (Latin and Cyrillic for example), and a few
-use three (Japanese for example).  Applications should not make
+use three (Japanese for example). Applications should not make
 any assumptions on the maximum number of scripts returned
 though, except that it is positive if the return value is not
 %NULL, and it is a small number.
 
-The pango_language_includes_script() function uses this function
-internally.
+The [method@Pango.Language.includes_script] function uses this
+function internally.
 
-Note: while the return value is declared as PangoScript, the
-returned values are from the GUnicodeScript enumeration, which
+Note: while the return value is declared as `PangoScript`, the
+returned values are from the `GUnicodeScript` enumeration, which
 may have more values. Callers need to handle unknown values.
 
 Since: 1.22
@@ -8615,74 +9718,74 @@ Since: 1.22
 </description>
 <parameters>
 <parameter name="language">
-<parameter_description> a #PangoLanguage, or %NULL
+<parameter_description> a `PangoLanguage`
 </parameter_description>
 </parameter>
 <parameter name="num_scripts">
-<parameter_description> location to return number of scripts,
-or %NULL
+<parameter_description> location to
+return number of scripts
 </parameter_description>
 </parameter>
 </parameters>
-<return> An array of
-#PangoScript values, with the number of entries in the array stored
-in @num_scripts, or %NULL if Pango does not have any information
-about this particular language tag (also the case if @language is
-%NULL).  The returned array is owned by Pango and should not be
-modified or freed.
- 
+<return>
+An array of `PangoScript` values, with the number of entries in
+the array stored in @num_scripts, or %NULL if Pango does not have
+any information about this particular language tag (also the case
+if @language is %NULL).
+
 </return>
 </function>
 
 <function name="pango_language_includes_script">
 <description>
 Determines if @script is one of the scripts used to
-write @language. The returned value is conservative;
-if nothing is known about the language tag @language,
-%TRUE will be returned, since, as far as Pango knows,
-@script might be used to write @language.
+write @language.
+
+The returned value is conservative; if nothing is known about
+the language tag @language, %TRUE will be returned, since, as
+far as Pango knows, @script might be used to write @language.
 
 This routine is used in Pango's itemization process when
 determining if a supplied language tag is relevant to
-a particular section of text. It probably is not useful for
-applications in most circumstances.
+a particular section of text. It probably is not useful
+for applications in most circumstances.
 
-This function uses pango_language_get_scripts() internally.
+This function uses [method@Pango.Language.get_scripts] internally.
 
 Since: 1.4
 
 </description>
 <parameters>
 <parameter name="language">
-<parameter_description> a #PangoLanguage, or %NULL
+<parameter_description> a `PangoLanguage`
 </parameter_description>
 </parameter>
 <parameter name="script">
-<parameter_description> a #PangoScript
+<parameter_description> a `PangoScript`
 </parameter_description>
 </parameter>
 </parameters>
 <return> %TRUE if @script is one of the scripts used
 to write @language or if nothing is known about @language
-(including the case that @language is %NULL),
-%FALSE otherwise.
- 
+(including the case that @language is %NULL), %FALSE otherwise.
+
 </return>
 </function>
 
 <function name="pango_language_matches">
 <description>
 Checks if a language tag matches one of the elements in a list of
-language ranges. A language tag is considered to match a range
-in the list if the range is '*', the range is exactly the tag,
-or the range is a prefix of the tag, and the character after it
-in the tag is '-'.
+language ranges.
+
+A language tag is considered to match a range in the list if the
+range is '*', the range is exactly the tag, or the range is a prefix
+of the tag, and the character after it in the tag is '-'.
 
 
 </description>
 <parameters>
 <parameter name="language">
-<parameter_description> a language tag (see pango_language_from_string()),
+<parameter_description> a language tag (see [func@Pango.Language.from_string]),
 %NULL is allowed and matches nothing but '*'
 </parameter_description>
 </parameter>
@@ -8690,17 +9793,17 @@ in the tag is '-'.
 <parameter_description> a list of language ranges, separated by ';', ':',
 ',', or space characters.
 Each element must either be '*', or a RFC 3066 language range
-canonicalized as by pango_language_from_string()
+canonicalized as by [func@Pango.Language.from_string]
 </parameter_description>
 </parameter>
 </parameters>
-<return> %TRUE if a match was found.
+<return> %TRUE if a match was found
 </return>
 </function>
 
 <function name="pango_language_to_string">
 <description>
-Gets the RFC-3066 format string representing the given language tag. 
+Gets the RFC-3066 format string representing the given language tag.
 
 
 </description>
@@ -8710,22 +9813,22 @@ Gets the RFC-3066 format string representing the given language tag.
 </parameter_description>
 </parameter>
 </parameters>
-<return> a string representing the language tag.  This is owned by
-Pango and should not be freed.
+<return> a string representing the language tag
 </return>
 </function>
 
 <function name="pango_layout_context_changed">
 <description>
-Forces recomputation of any state in the #PangoLayout that
-might depend on the layout's context. This function should
-be called if you make changes to the context subsequent
-to creating the layout.
+Forces recomputation of any state in the `PangoLayout` that
+might depend on the layout's context.
+
+This function should be called if you make changes to the context
+subsequent to creating the layout.
 
 </description>
 <parameters>
 <parameter name="layout">
-<parameter_description> a #PangoLayout
+<parameter_description> a `PangoLayout`
 </parameter_description>
 </parameter>
 </parameters>
@@ -8734,21 +9837,56 @@ to creating the layout.
 
 <function name="pango_layout_copy">
 <description>
-Does a deep copy-by-value of the @src layout. The attribute list,
-tab array, and text from the original layout are all copied by
-value.
+Creates a deep copy-by-value of the layout.
+
+The attribute list, tab array, and text from the original layout
+are all copied by value.
 
 
 </description>
 <parameters>
 <parameter name="src">
-<parameter_description> a #PangoLayout
+<parameter_description> a `PangoLayout`
+</parameter_description>
+</parameter>
+</parameters>
+<return> the newly allocated `PangoLayout`
+</return>
+</function>
+
+<function name="pango_layout_deserialize">
+<description>
+Loads data previously created via [method@Pango.Layout.serialize].
+
+For a discussion of the supported format, see that function.
+
+Note: to verify that the returned layout is identical to
+the one that was serialized, you can compare @bytes to the
+result of serializing the layout again.
+
+Since: 1.50
+
+</description>
+<parameters>
+<parameter name="context">
+<parameter_description> a `PangoContext`
+</parameter_description>
+</parameter>
+<parameter name="flags">
+<parameter_description> `PangoLayoutDeserializeFlags`
+</parameter_description>
+</parameter>
+<parameter name="bytes">
+<parameter_description> the bytes containing the data
+</parameter_description>
+</parameter>
+<parameter name="error">
+<parameter_description> return location for an error
 </parameter_description>
 </parameter>
 </parameters>
-<return> the newly allocated #PangoLayout,
-with a reference count of one, which should be freed
-with g_object_unref().
+<return> a new `PangoLayout`
+
 </return>
 </function>
 
@@ -8761,11 +9899,11 @@ positioned within the horizontal space available.
 </description>
 <parameters>
 <parameter name="layout">
-<parameter_description> a #PangoLayout
+<parameter_description> a `PangoLayout`
 </parameter_description>
 </parameter>
 </parameters>
-<return> the alignment.
+<return> the alignment
 </return>
 </function>
 
@@ -8777,32 +9915,32 @@ Gets the attribute list for the layout, if any.
 </description>
 <parameters>
 <parameter name="layout">
-<parameter_description> a #PangoLayout
+<parameter_description> a `PangoLayout`
 </parameter_description>
 </parameter>
 </parameters>
-<return> a #PangoAttrList or %NULL
-if none was set.
+<return> a `PangoAttrList`
 </return>
 </function>
 
 <function name="pango_layout_get_auto_dir">
 <description>
-Gets whether to calculate the bidirectional base direction
-for the layout according to the contents of the layout.
-See pango_layout_set_auto_dir().
+Gets whether to calculate the base direction for the layout
+according to its contents.
+
+See [method@Pango.Layout.set_auto_dir].
 
 Since: 1.4
 
 </description>
 <parameters>
 <parameter name="layout">
-<parameter_description> a #PangoLayout
+<parameter_description> a `PangoLayout`
 </parameter_description>
 </parameter>
 </parameters>
 <return> %TRUE if the bidirectional base direction
-is computed from the layout's contents, %FALSE otherwise.
+is computed from the layout's contents, %FALSE otherwise
 
 </return>
 </function>
@@ -8816,15 +9954,53 @@ Since: 1.22
 </description>
 <parameters>
 <parameter name="layout">
-<parameter_description> a #PangoLayout
+<parameter_description> a `PangoLayout`
 </parameter_description>
 </parameter>
 </parameters>
-<return> baseline of first line, from top of @layout.
+<return> baseline of first line, from top of @layout
 
 </return>
 </function>
 
+<function name="pango_layout_get_caret_pos">
+<description>
+Given an index within a layout, determines the positions that of the
+strong and weak cursors if the insertion point is at that index.
+
+This is a variant of [method@Pango.Layout.get_cursor_pos] that applies
+font metric information about caret slope and offset to the positions
+it returns.
+
+&lt;picture&gt;
+&lt;source srcset=&quot;caret-metrics-dark.png&quot; media=&quot;(prefers-color-scheme: dark)&quot;&gt;
+&lt;img alt=&quot;Caret metrics&quot; src=&quot;caret-metrics-light.png&quot;&gt;
+&lt;/picture&gt;
+
+Since: 1.50
+
+</description>
+<parameters>
+<parameter name="layout">
+<parameter_description> a `PangoLayout`
+</parameter_description>
+</parameter>
+<parameter name="index_">
+<parameter_description> the byte index of the cursor
+</parameter_description>
+</parameter>
+<parameter name="strong_pos">
+<parameter_description> location to store the strong cursor position
+</parameter_description>
+</parameter>
+<parameter name="weak_pos">
+<parameter_description> location to store the weak cursor position
+</parameter_description>
+</parameter>
+</parameters>
+<return></return>
+</function>
+
 <function name="pango_layout_get_character_count">
 <description>
 Returns the number of Unicode characters in the
@@ -8835,7 +10011,7 @@ Since: 1.30
 </description>
 <parameters>
 <parameter name="layout">
-<parameter_description> a #PangoLayout
+<parameter_description> a `PangoLayout`
 </parameter_description>
 </parameter>
 </parameters>
@@ -8847,37 +10023,54 @@ in the text of @layout
 
 <function name="pango_layout_get_context">
 <description>
-Retrieves the #PangoContext used for this layout.
+Retrieves the `PangoContext` used for this layout.
 
 
 </description>
 <parameters>
 <parameter name="layout">
-<parameter_description> a #PangoLayout
+<parameter_description> a `PangoLayout`
 </parameter_description>
 </parameter>
 </parameters>
-<return> the #PangoContext for the layout.
-This does not have an additional refcount added, so if you want to
-keep a copy of this around, you must reference it yourself.
+<return> the `PangoContext` for the layout
 </return>
 </function>
 
 <function name="pango_layout_get_cursor_pos">
 <description>
 Given an index within a layout, determines the positions that of the
-strong and weak cursors if the insertion point is at that
-index. The position of each cursor is stored as a zero-width
-rectangle. The strong cursor location is the location where
-characters of the directionality equal to the base direction of the
-layout are inserted.  The weak cursor location is the location
-where characters of the directionality opposite to the base
-direction of the layout are inserted.
+strong and weak cursors if the insertion point is at that index.
+
+The position of each cursor is stored as a zero-width rectangle
+with the height of the run extents.
+
+&lt;picture&gt;
+&lt;source srcset=&quot;cursor-positions-dark.png&quot; media=&quot;(prefers-color-scheme: dark)&quot;&gt;
+&lt;img alt=&quot;Cursor positions&quot; src=&quot;cursor-positions-light.png&quot;&gt;
+&lt;/picture&gt;
+
+The strong cursor location is the location where characters of the
+directionality equal to the base direction of the layout are inserted.
+The weak cursor location is the location where characters of the
+directionality opposite to the base direction of the layout are inserted.
+
+The following example shows text with both a strong and a weak cursor.
+
+&lt;picture&gt;
+&lt;source srcset=&quot;split-cursor-dark.png&quot; media=&quot;(prefers-color-scheme: dark)&quot;&gt;
+&lt;img alt=&quot;Strong and weak cursors&quot; src=&quot;split-cursor-light.png&quot;&gt;
+&lt;/picture&gt;
+
+The strong cursor has a little arrow pointing to the right, the weak
+cursor to the left. Typing a 'c' in this situation will insert the
+character after the 'b', and typing another Hebrew character, like 'ג',
+will insert it at the end.
 
 </description>
 <parameters>
 <parameter name="layout">
-<parameter_description> a #PangoLayout
+<parameter_description> a `PangoLayout`
 </parameter_description>
 </parameter>
 <parameter name="index_">
@@ -8886,11 +10079,10 @@ direction of the layout are inserted.
 </parameter>
 <parameter name="strong_pos">
 <parameter_description> location to store the strong cursor position
-(may be %NULL)
 </parameter_description>
 </parameter>
 <parameter name="weak_pos">
-<parameter_description> location to store the weak cursor position (may be %NULL)
+<parameter_description> location to store the weak cursor position
 </parameter_description>
 </parameter>
 </parameters>
@@ -8899,15 +10091,14 @@ direction of the layout are inserted.
 
 <function name="pango_layout_get_direction">
 <description>
-Gets the text direction at the given character
-position in @layout.
+Gets the text direction at the given character position in @layout.
 
 Since: 1.46
 
 </description>
 <parameters>
 <parameter name="layout">
-<parameter_description> a #PangoLayout
+<parameter_description> a `PangoLayout`
 </parameter_description>
 </parameter>
 <parameter name="index">
@@ -8923,33 +10114,35 @@ Since: 1.46
 <function name="pango_layout_get_ellipsize">
 <description>
 Gets the type of ellipsization being performed for @layout.
-See pango_layout_set_ellipsize()
+
+See [method@Pango.Layout.set_ellipsize].
+
+Use [method@Pango.Layout.is_ellipsized] to query whether any
+paragraphs were actually ellipsized.
 
 Since: 1.6
 
 </description>
 <parameters>
 <parameter name="layout">
-<parameter_description> a #PangoLayout
+<parameter_description> a `PangoLayout`
 </parameter_description>
 </parameter>
 </parameters>
-<return> the current ellipsization mode for @layout.
-
-Use pango_layout_is_ellipsized() to query whether any paragraphs
-were actually ellipsized.
+<return> the current ellipsization mode for @layout
 
 </return>
 </function>
 
 <function name="pango_layout_get_extents">
 <description>
-Computes the logical and ink extents of @layout. Logical extents
-are usually what you want for positioning things.  Note that both extents
-may have non-zero x and y.  You may want to use those to offset where you
-render the layout.  Not doing that is a very typical bug that shows up as
-right-to-left layouts not being correctly positioned in a layout with
-a set width.
+Computes the logical and ink extents of @layout.
+
+Logical extents are usually what you want for positioning things. Note
+that both extents may have non-zero x and y. You may want to use those
+to offset where you render the layout. Not doing that is a very typical
+bug that shows up as right-to-left layouts not being correctly positioned
+in a layout with a set width.
 
 The extents are given in layout coordinates and in Pango units; layout
 coordinates begin at the top left corner of the layout.
@@ -8957,19 +10150,17 @@ coordinates begin at the top left corner of the layout.
 </description>
 <parameters>
 <parameter name="layout">
-<parameter_description>   a #PangoLayout
+<parameter_description> a `PangoLayout`
 </parameter_description>
 </parameter>
 <parameter name="ink_rect">
 <parameter_description> rectangle used to store the extents of the
-layout as drawn or %NULL to indicate that the result is
-not needed.
+layout as drawn
 </parameter_description>
 </parameter>
 <parameter name="logical_rect">
 <parameter_description>rectangle used to store the logical
-extents of the layout or %NULL to indicate that the
-result is not needed.
+extents of the layout
 </parameter_description>
 </parameter>
 </parameters>
@@ -8985,52 +10176,53 @@ Since: 1.8
 </description>
 <parameters>
 <parameter name="layout">
-<parameter_description> a #PangoLayout
+<parameter_description> a `PangoLayout`
 </parameter_description>
 </parameter>
 </parameters>
-<return> a pointer to the layout's font
-description, or %NULL if the font description from the layout's
-context is inherited. This value is owned by the layout and must
-not be modified or freed.
+<return> a pointer to the
+layout's font description, or %NULL if the font description
+from the layout's context is inherited.
 
 </return>
 </function>
 
 <function name="pango_layout_get_height">
 <description>
-Gets the height of layout used for ellipsization.  See
-pango_layout_set_height() for details.
+Gets the height of layout used for ellipsization.
+
+See [method@Pango.Layout.set_height] for details.
 
 Since: 1.20
 
 </description>
 <parameters>
 <parameter name="layout">
-<parameter_description> a #PangoLayout
+<parameter_description> a `PangoLayout`
 </parameter_description>
 </parameter>
 </parameters>
-<return> the height, in Pango units if positive, or
-number of lines if negative.
+<return> the height, in Pango units if positive,
+or number of lines if negative.
 
 </return>
 </function>
 
 <function name="pango_layout_get_indent">
 <description>
-Gets the paragraph indent width in Pango units. A negative value
-indicates a hanging indentation.
+Gets the paragraph indent width in Pango units.
+
+A negative value indicates a hanging indentation.
 
 
 </description>
 <parameters>
 <parameter name="layout">
-<parameter_description> a #PangoLayout
+<parameter_description> a `PangoLayout`
 </parameter_description>
 </parameter>
 </parameters>
-<return> the indent in Pango units.
+<return> the indent in Pango units
 </return>
 </function>
 
@@ -9042,12 +10234,11 @@ Returns an iterator to iterate over the visual extents of the layout.
 </description>
 <parameters>
 <parameter name="layout">
-<parameter_description> a #PangoLayout
+<parameter_description> a `PangoLayout`
 </parameter_description>
 </parameter>
 </parameters>
-<return> the new #PangoLayoutIter that should be freed using
-pango_layout_iter_free().
+<return> the new `PangoLayoutIter`
 </return>
 </function>
 
@@ -9060,39 +10251,57 @@ width of the layout.
 </description>
 <parameters>
 <parameter name="layout">
-<parameter_description> a #PangoLayout
+<parameter_description> a `PangoLayout`
+</parameter_description>
+</parameter>
+</parameters>
+<return> the justify value
+</return>
+</function>
+
+<function name="pango_layout_get_justify_last_line">
+<description>
+Gets whether the last line should be stretched
+to fill the entire width of the layout.
+
+Since: 1.50
+
+</description>
+<parameters>
+<parameter name="layout">
+<parameter_description> a `PangoLayout`
 </parameter_description>
 </parameter>
 </parameters>
-<return> the justify.
+<return> the justify value
+
 </return>
 </function>
 
 <function name="pango_layout_get_line">
 <description>
-Retrieves a particular line from a #PangoLayout.
+Retrieves a particular line from a `PangoLayout`.
 
-Use the faster pango_layout_get_line_readonly() if you do not plan
-to modify the contents of the line (glyphs, glyph widths, etc.).
+Use the faster [method@Pango.Layout.get_line_readonly] if you do not
+plan to modify the contents of the line (glyphs, glyph widths, etc.).
 
 
 </description>
 <parameters>
 <parameter name="layout">
-<parameter_description> a #PangoLayout
+<parameter_description> a `PangoLayout`
 </parameter_description>
 </parameter>
 <parameter name="line">
 <parameter_description> the index of a line, which must be between 0 and
-&lt;literal&gt;pango_layout_get_line_count(layout) - 1&lt;/literal&gt;, inclusive.
+`pango_layout_get_line_count(layout) - 1`, inclusive.
 </parameter_description>
 </parameter>
 </parameters>
-<return> the requested
-#PangoLayoutLine, or %NULL if the index is out of
-range. This layout line can be ref'ed and retained,
-but will become invalid if changes are made to the
-#PangoLayout.
+<return> the requested `PangoLayoutLine`,
+or %NULL if the index is out of range. This layout line can be ref'ed
+and retained, but will become invalid if changes are made to the
+`PangoLayout`.
 </return>
 </function>
 
@@ -9104,56 +10313,56 @@ Retrieves the count of lines for the @layout.
 </description>
 <parameters>
 <parameter name="layout">
-<parameter_description> #PangoLayout
+<parameter_description> `PangoLayout`
 </parameter_description>
 </parameter>
 </parameters>
-<return> the line count.
+<return> the line count
 </return>
 </function>
 
 <function name="pango_layout_get_line_readonly">
 <description>
-Retrieves a particular line from a #PangoLayout.
+Retrieves a particular line from a `PangoLayout`.
 
-This is a faster alternative to pango_layout_get_line(),
-but the user is not expected
-to modify the contents of the line (glyphs, glyph widths, etc.).
+This is a faster alternative to [method@Pango.Layout.get_line],
+but the user is not expected to modify the contents of the line
+(glyphs, glyph widths, etc.).
 
 Since: 1.16
 
 </description>
 <parameters>
 <parameter name="layout">
-<parameter_description> a #PangoLayout
+<parameter_description> a `PangoLayout`
 </parameter_description>
 </parameter>
 <parameter name="line">
 <parameter_description> the index of a line, which must be between 0 and
-&lt;literal&gt;pango_layout_get_line_count(layout) - 1&lt;/literal&gt;, inclusive.
+`pango_layout_get_line_count(layout) - 1`, inclusive.
 </parameter_description>
 </parameter>
 </parameters>
-<return> the requested
-#PangoLayoutLine, or %NULL if the index is out of
-range. This layout line can be ref'ed and retained,
-but will become invalid if changes are made to the
-#PangoLayout.  No changes should be made to the line.
+<return> the requested `PangoLayoutLine`,
+or %NULL if the index is out of range. This layout line can be ref'ed
+and retained, but will become invalid if changes are made to the
+`PangoLayout`. No changes should be made to the line.
 
 </return>
 </function>
 
 <function name="pango_layout_get_line_spacing">
 <description>
-Gets the value that has been
-set with pango_layout_set_line_spacing().
+Gets the line spacing factor of @layout.
+
+See [method@Pango.Layout.set_line_spacing].
 
 Since: 1.44
 
 </description>
 <parameters>
 <parameter name="layout">
-<parameter_description> a #PangoLayout
+<parameter_description> a `PangoLayout`
 </parameter_description>
 </parameter>
 </parameters>
@@ -9164,21 +10373,21 @@ Since: 1.44
 <description>
 Returns the lines of the @layout as a list.
 
-Use the faster pango_layout_get_lines_readonly() if you do not plan
-to modify the contents of the lines (glyphs, glyph widths, etc.).
+Use the faster [method@Pango.Layout.get_lines_readonly] if you do not
+plan to modify the contents of the lines (glyphs, glyph widths, etc.).
 
 
 </description>
 <parameters>
 <parameter name="layout">
-<parameter_description> a #PangoLayout
+<parameter_description> a `PangoLayout`
 </parameter_description>
 </parameter>
 </parameters>
-<return> a #GSList containing
-the lines in the layout. This points to internal data of the #PangoLayout
-and must be used with care. It will become invalid on any change to the layout's
-text or properties.
+<return> a `GSList`
+containing the lines in the layout. This points to internal data of the
+`PangoLayout` and must be used with care. It will become invalid on any
+change to the layout's text or properties.
 </return>
 </function>
 
@@ -9186,23 +10395,24 @@ text or properties.
 <description>
 Returns the lines of the @layout as a list.
 
-This is a faster alternative to pango_layout_get_lines(),
-but the user is not expected
-to modify the contents of the lines (glyphs, glyph widths, etc.).
+This is a faster alternative to [method@Pango.Layout.get_lines],
+but the user is not expected to modify the contents of the lines
+(glyphs, glyph widths, etc.).
 
 Since: 1.16
 
 </description>
 <parameters>
 <parameter name="layout">
-<parameter_description> a #PangoLayout
+<parameter_description> a `PangoLayout`
 </parameter_description>
 </parameter>
 </parameters>
-<return> a #GSList containing
-the lines in the layout. This points to internal data of the #PangoLayout and
-must be used with care. It will become invalid on any change to the layout's
-text or properties.  No changes should be made to the lines.
+<return> a `GSList`
+containing the lines in the layout. This points to internal data of the
+`PangoLayout` and must be used with care. It will become invalid on any
+change to the layout's text or properties. No changes should be made to
+the lines.
 
 </return>
 </function>
@@ -9215,12 +10425,12 @@ the @layout.
 </description>
 <parameters>
 <parameter name="layout">
-<parameter_description> a #PangoLayout
+<parameter_description> a `PangoLayout`
 </parameter_description>
 </parameter>
 <parameter name="attrs">
 <parameter_description>
-location to store a pointer to an array of logical attributes
+location to store a pointer to an array of logical attributes.
 This value must be freed with g_free().
 </parameter_description>
 </parameter>
@@ -9241,7 +10451,7 @@ and the position after the last character.)
 Retrieves an array of logical attributes for each character in
 the @layout.
 
-This is a faster alternative to pango_layout_get_log_attrs().
+This is a faster alternative to [method@Pango.Layout.get_log_attrs].
 The returned array is part of @layout and must not be modified.
 Modifying the layout will invalidate the returned array.
 
@@ -9255,7 +10465,7 @@ Since: 1.30
 </description>
 <parameters>
 <parameter name="layout">
-<parameter_description> a #PangoLayout
+<parameter_description> a `PangoLayout`
 </parameter_description>
 </parameter>
 <parameter name="n_attrs">
@@ -9272,27 +10482,26 @@ the array
 <function name="pango_layout_get_pixel_extents">
 <description>
 Computes the logical and ink extents of @layout in device units.
-This function just calls pango_layout_get_extents() followed by
-two pango_extents_to_pixels() calls, rounding @ink_rect and @logical_rect
+
+This function just calls [method@Pango.Layout.get_extents] followed by
+two [func@extents_to_pixels] calls, rounding @ink_rect and @logical_rect
 such that the rounded rectangles fully contain the unrounded one (that is,
-passes them as first argument to pango_extents_to_pixels()).
+passes them as first argument to [func@Pango.extents_to_pixels]).
 
 </description>
 <parameters>
 <parameter name="layout">
-<parameter_description>   a #PangoLayout
+<parameter_description> a `PangoLayout`
 </parameter_description>
 </parameter>
 <parameter name="ink_rect">
 <parameter_description> rectangle used to store the extents of the
-layout as drawn or %NULL to indicate that the result is
-not needed.
+layout as drawn
 </parameter_description>
 </parameter>
 <parameter name="logical_rect">
 <parameter_description> rectangle used to store the logical
-extents of the layout or %NULL to indicate that the
-result is not needed.
+extents of the layout
 </parameter_description>
 </parameter>
 </parameters>
@@ -9301,24 +10510,25 @@ result is not needed.
 
 <function name="pango_layout_get_pixel_size">
 <description>
-Determines the logical width and height of a #PangoLayout
-in device units. (pango_layout_get_size() returns the width
-and height scaled by %PANGO_SCALE.) This
-is simply a convenience function around
-pango_layout_get_pixel_extents().
+Determines the logical width and height of a `PangoLayout` in device
+units.
+
+[method@Pango.Layout.get_size] returns the width and height
+scaled by %PANGO_SCALE. This is simply a convenience function
+around [method@Pango.Layout.get_pixel_extents].
 
 </description>
 <parameters>
 <parameter name="layout">
-<parameter_description> a #PangoLayout
+<parameter_description> a `PangoLayout`
 </parameter_description>
 </parameter>
 <parameter name="width">
-<parameter_description> location to store the logical width, or %NULL
+<parameter_description> location to store the logical width
 </parameter_description>
 </parameter>
 <parameter name="height">
-<parameter_description> location to store the logical height, or %NULL
+<parameter_description> location to store the logical height
 </parameter_description>
 </parameter>
 </parameters>
@@ -9327,23 +10537,25 @@ pango_layout_get_pixel_extents().
 
 <function name="pango_layout_get_serial">
 <description>
-Returns the current serial number of @layout.  The serial number is
-initialized to an small number  larger than zero when a new layout
-is created and is increased whenever the layout is changed using any
-of the setter functions, or the #PangoContext it uses has changed.
-The serial may wrap, but will never have the value 0. Since it
-can wrap, never compare it with &quot;less than&quot;, always use &quot;not equals&quot;.
+Returns the current serial number of @layout.
+
+The serial number is initialized to an small number larger than zero
+when a new layout is created and is increased whenever the layout is
+changed using any of the setter functions, or the `PangoContext` it
+uses has changed. The serial may wrap, but will never have the value 0.
+Since it can wrap, never compare it with &quot;less than&quot;, always use &quot;not equals&quot;.
 
-This can be used to automatically detect changes to a #PangoLayout, and
-is useful for example to decide whether a layout needs redrawing.
-To force the serial to be increased, use pango_layout_context_changed().
+This can be used to automatically detect changes to a `PangoLayout`,
+and is useful for example to decide whether a layout needs redrawing.
+To force the serial to be increased, use
+[method@Pango.Layout.context_changed].
 
 Since: 1.32.4
 
 </description>
 <parameters>
 <parameter name="layout">
-<parameter_description> a #PangoLayout
+<parameter_description> a `PangoLayout`
 </parameter_description>
 </parameter>
 </parameters>
@@ -9354,39 +10566,42 @@ Since: 1.32.4
 
 <function name="pango_layout_get_single_paragraph_mode">
 <description>
-Obtains the value set by pango_layout_set_single_paragraph_mode().
+Obtains whether @layout is in single paragraph mode.
+
+See [method@Pango.Layout.set_single_paragraph_mode].
 
 
 </description>
 <parameters>
 <parameter name="layout">
-<parameter_description> a #PangoLayout
+<parameter_description> a `PangoLayout`
 </parameter_description>
 </parameter>
 </parameters>
-<return> %TRUE if the layout does not break paragraphs at
-paragraph separator characters, %FALSE otherwise.
+<return> %TRUE if the layout does not break paragraphs
+at paragraph separator characters, %FALSE otherwise
 </return>
 </function>
 
 <function name="pango_layout_get_size">
 <description>
-Determines the logical width and height of a #PangoLayout
-in Pango units (device units scaled by %PANGO_SCALE). This
-is simply a convenience function around pango_layout_get_extents().
+Determines the logical width and height of a `PangoLayout` in Pango
+units.
+
+This is simply a convenience function around [method@Pango.Layout.get_extents].
 
 </description>
 <parameters>
 <parameter name="layout">
-<parameter_description> a #PangoLayout
+<parameter_description> a `PangoLayout`
 </parameter_description>
 </parameter>
 <parameter name="width">
-<parameter_description> location to store the logical width, or %NULL
+<parameter_description> location to store the logical width
 </parameter_description>
 </parameter>
 <parameter name="height">
-<parameter_description> location to store the logical height, or %NULL
+<parameter_description> location to store the logical height
 </parameter_description>
 </parameter>
 </parameters>
@@ -9401,56 +10616,56 @@ Gets the amount of spacing between the lines of the layout.
 </description>
 <parameters>
 <parameter name="layout">
-<parameter_description> a #PangoLayout
+<parameter_description> a `PangoLayout`
 </parameter_description>
 </parameter>
 </parameters>
-<return> the spacing in Pango units.
+<return> the spacing in Pango units
 </return>
 </function>
 
 <function name="pango_layout_get_tabs">
 <description>
-Gets the current #PangoTabArray used by this layout. If no
-#PangoTabArray has been set, then the default tabs are in use
-and %NULL is returned. Default tabs are every 8 spaces.
-The return value should be freed with pango_tab_array_free().
+Gets the current `PangoTabArray` used by this layout.
+
+If no `PangoTabArray` has been set, then the default tabs are
+in use and %NULL is returned. Default tabs are every 8 spaces.
+
+The return value should be freed with [method Pango TabArray free].
 
 
 </description>
 <parameters>
 <parameter name="layout">
-<parameter_description> a #PangoLayout
+<parameter_description> a `PangoLayout`
 </parameter_description>
 </parameter>
 </parameters>
-<return> a copy of the tabs for this layout, or
-%NULL.
+<return> a copy of the tabs for this layout
 </return>
 </function>
 
 <function name="pango_layout_get_text">
 <description>
-Gets the text in the layout. The returned text should not
-be freed or modified.
+Gets the text in the layout.
+
+The returned text should not be freed or modified.
 
 
 </description>
 <parameters>
 <parameter name="layout">
-<parameter_description> a #PangoLayout
+<parameter_description> a `PangoLayout`
 </parameter_description>
 </parameter>
 </parameters>
-<return> the text in the @layout.
+<return> the text in the @layout
 </return>
 </function>
 
 <function name="pango_layout_get_unknown_glyphs_count">
 <description>
-Counts the number unknown glyphs in @layout.  That is, zero if
-glyphs for all characters in the layout text were found, or more
-than zero otherwise.
+Counts the number of unknown glyphs in @layout.
 
 This function can be used to determine if there are any fonts
 available to render all characters in a certain string, or when
@@ -9462,24 +10677,24 @@ Since: 1.16
 </description>
 <parameters>
 <parameter name="layout">
-<parameter_description> a #PangoLayout
+<parameter_description> a `PangoLayout`
 </parameter_description>
 </parameter>
 </parameters>
-<return> The number of unknown glyphs in @layout.
+<return> The number of unknown glyphs in @layout
 
 </return>
 </function>
 
 <function name="pango_layout_get_width">
 <description>
-Gets the width to which the lines of the #PangoLayout should wrap.
+Gets the width to which the lines of the `PangoLayout` should wrap.
 
 
 </description>
 <parameters>
 <parameter name="layout">
-<parameter_description> a #PangoLayout
+<parameter_description> a `PangoLayout`
 </parameter_description>
 </parameter>
 </parameters>
@@ -9491,14 +10706,14 @@ Gets the width to which the lines of the #PangoLayout should wrap.
 <description>
 Gets the wrap mode for the layout.
 
-Use pango_layout_is_wrapped() to query whether any paragraphs
-were actually wrapped.
+Use [method@Pango.Layout.is_wrapped] to query whether
+any paragraphs were actually wrapped.
 
 
 </description>
 <parameters>
 <parameter name="layout">
-<parameter_description> a #PangoLayout
+<parameter_description> a `PangoLayout`
 </parameter_description>
 </parameter>
 </parameters>
@@ -9509,32 +10724,33 @@ were actually wrapped.
 <function name="pango_layout_index_to_line_x">
 <description>
 Converts from byte @index_ within the @layout to line and X position.
-(X position is measured from the left edge of the line)
+
+The X position is measured from the left edge of the line.
 
 </description>
 <parameters>
 <parameter name="layout">
-<parameter_description>    a #PangoLayout
+<parameter_description> a `PangoLayout`
 </parameter_description>
 </parameter>
 <parameter name="index_">
-<parameter_description>    the byte index of a grapheme within the layout.
+<parameter_description> the byte index of a grapheme within the layout
 </parameter_description>
 </parameter>
 <parameter name="trailing">
-<parameter_description>  an integer indicating the edge of the grapheme to retrieve the
+<parameter_description> an integer indicating the edge of the grapheme to retrieve the
 position of. If &gt; 0, the trailing edge of the grapheme, if 0,
-the leading of the grapheme.
+the leading of the grapheme
 </parameter_description>
 </parameter>
 <parameter name="line">
 <parameter_description> location to store resulting line index. (which will
-between 0 and pango_layout_get_line_count(layout) - 1), or %NULL
+between 0 and pango_layout_get_line_count(layout) - 1)
 </parameter_description>
 </parameter>
 <parameter name="x_pos">
 <parameter_description> location to store resulting position within line
-(%PANGO_SCALE units per device unit), or %NULL
+(%PANGO_SCALE units per device unit)
 </parameter_description>
 </parameter>
 </parameters>
@@ -9543,17 +10759,18 @@ between 0 and pango_layout_get_line_count(layout) - 1), or %NULL
 
 <function name="pango_layout_index_to_pos">
 <description>
-Converts from an index within a #PangoLayout to the onscreen position
-corresponding to the grapheme at that index, which is represented
-as rectangle.  Note that &lt;literal&gt;pos-&gt;x&lt;/literal&gt; is always the leading
-edge of the grapheme and &lt;literal&gt;pos-&gt;x + pos-&gt;width&lt;/literal&gt; the trailing
-edge of the grapheme. If the directionality of the grapheme is right-to-left,
-then &lt;literal&gt;pos-&gt;width&lt;/literal&gt; will be negative.
+Converts from an index within a `PangoLayout` to the onscreen position
+corresponding to the grapheme at that index.
+
+The return value is represented as rectangle. Note that `pos-&gt;x` is
+always the leading edge of the grapheme and `pos-&gt;x + pos-&gt;width` the
+trailing edge of the grapheme. If the directionality of the grapheme
+is right-to-left, then `pos-&gt;width` will be negative.
 
 </description>
 <parameters>
 <parameter name="layout">
-<parameter_description> a #PangoLayout
+<parameter_description> a `PangoLayout`
 </parameter_description>
 </parameter>
 <parameter name="index_">
@@ -9582,12 +10799,12 @@ Since: 1.16
 </description>
 <parameters>
 <parameter name="layout">
-<parameter_description> a #PangoLayout
+<parameter_description> a `PangoLayout`
 </parameter_description>
 </parameter>
 </parameters>
-<return> %TRUE if any paragraphs had to be ellipsized, %FALSE
-otherwise.
+<return> %TRUE if any paragraphs had to be ellipsized,
+%FALSE otherwise
 
 </return>
 </function>
@@ -9606,12 +10823,12 @@ Since: 1.16
 </description>
 <parameters>
 <parameter name="layout">
-<parameter_description> a #PangoLayout
+<parameter_description> a `PangoLayout`
 </parameter_description>
 </parameter>
 </parameters>
 <return> %TRUE if any paragraphs had to be wrapped, %FALSE
-otherwise.
+otherwise
 
 </return>
 </function>
@@ -9624,30 +10841,28 @@ Determines whether @iter is on the last line of the layout.
 </description>
 <parameters>
 <parameter name="iter">
-<parameter_description> a #PangoLayoutIter
+<parameter_description> a `PangoLayoutIter`
 </parameter_description>
 </parameter>
 </parameters>
-<return> %TRUE if @iter is on the last line.
+<return> %TRUE if @iter is on the last line
 </return>
 </function>
 
 <function name="pango_layout_iter_copy">
 <description>
-Copies a #PangoLayoutIter.
+Copies a `PangoLayoutIter`.
 
 Since: 1.20
 
 </description>
 <parameters>
 <parameter name="iter">
-<parameter_description> a #PangoLayoutIter, may be %NULL
+<parameter_description> a `PangoLayoutIter`
 </parameter_description>
 </parameter>
 </parameters>
-<return> the newly allocated #PangoLayoutIter,
-which should be freed with pango_layout_iter_free(),
-or %NULL if @iter was %NULL.
+<return> the newly allocated `PangoLayoutIter`
 
 </return>
 </function>
@@ -9659,7 +10874,7 @@ Frees an iterator that's no longer in use.
 </description>
 <parameters>
 <parameter name="iter">
-<parameter_description> a #PangoLayoutIter, may be %NULL
+<parameter_description> a `PangoLayoutIter`, may be %NULL
 </parameter_description>
 </parameter>
 </parameters>
@@ -9669,32 +10884,35 @@ Frees an iterator that's no longer in use.
 <function name="pango_layout_iter_get_baseline">
 <description>
 Gets the Y position of the current line's baseline, in layout
-coordinates (origin at top left of the entire layout).
+coordinates.
+
+Layout coordinates have the origin at the top left of the entire layout.
 
 
 </description>
 <parameters>
 <parameter name="iter">
-<parameter_description> a #PangoLayoutIter
+<parameter_description> a `PangoLayoutIter`
 </parameter_description>
 </parameter>
 </parameters>
-<return> baseline of current line.
+<return> baseline of current line
 </return>
 </function>
 
 <function name="pango_layout_iter_get_char_extents">
 <description>
-Gets the extents of the current character, in layout coordinates
-(origin is the top left of the entire layout). Only logical extents
-can sensibly be obtained for characters; ink extents make sense only
-down to the level of clusters.
+Gets the extents of the current character, in layout coordinates.
 
+Layout coordinates have the origin at the top left of the entire layout.
+
+Only logical extents can sensibly be obtained for characters;
+ink extents make sense only down to the level of clusters.
 
 </description>
 <parameters>
 <parameter name="iter">
-<parameter_description> a #PangoLayoutIter
+<parameter_description> a `PangoLayoutIter`
 </parameter_description>
 </parameter>
 <parameter name="logical_rect">
@@ -9708,22 +10926,22 @@ logical extents
 
 <function name="pango_layout_iter_get_cluster_extents">
 <description>
-Gets the extents of the current cluster, in layout coordinates
-(origin is the top left of the entire layout).
+Gets the extents of the current cluster, in layout coordinates.
 
+Layout coordinates have the origin at the top left of the entire layout.
 
 </description>
 <parameters>
 <parameter name="iter">
-<parameter_description> a #PangoLayoutIter
+<parameter_description> a `PangoLayoutIter`
 </parameter_description>
 </parameter>
 <parameter name="ink_rect">
-<parameter_description> rectangle to fill with ink extents, or %NULL
+<parameter_description> rectangle to fill with ink extents
 </parameter_description>
 </parameter>
 <parameter name="logical_rect">
-<parameter_description> rectangle to fill with logical extents, or %NULL
+<parameter_description> rectangle to fill with logical extents
 </parameter_description>
 </parameter>
 </parameters>
@@ -9732,62 +10950,59 @@ Gets the extents of the current cluster, in layout coordinates
 
 <function name="pango_layout_iter_get_index">
 <description>
-Gets the current byte index. Note that iterating forward by char
-moves in visual order, not logical order, so indexes may not be
-sequential. Also, the index may be equal to the length of the text
-in the layout, if on the %NULL run (see pango_layout_iter_get_run()).
+Gets the current byte index.
+
+Note that iterating forward by char moves in visual order,
+not logical order, so indexes may not be sequential. Also,
+the index may be equal to the length of the text in the
+layout, if on the %NULL run (see [method@Pango.LayoutIter.get_run]).
 
 
 </description>
 <parameters>
 <parameter name="iter">
-<parameter_description> a #PangoLayoutIter
+<parameter_description> a `PangoLayoutIter`
 </parameter_description>
 </parameter>
 </parameters>
-<return> current byte index.
+<return> current byte index
 </return>
 </function>
 
 <function name="pango_layout_iter_get_layout">
 <description>
-Gets the layout associated with a #PangoLayoutIter.
+Gets the layout associated with a `PangoLayoutIter`.
 
 Since: 1.20
 
 </description>
 <parameters>
 <parameter name="iter">
-<parameter_description> a #PangoLayoutIter
+<parameter_description> a `PangoLayoutIter`
 </parameter_description>
 </parameter>
 </parameters>
-<return> the layout associated with @iter.
+<return> the layout associated with @iter
 
 </return>
 </function>
 
 <function name="pango_layout_iter_get_layout_extents">
 <description>
-Obtains the extents of the #PangoLayout being iterated
-over. @ink_rect or @logical_rect can be %NULL if you
-aren't interested in them.
-
+Obtains the extents of the `PangoLayout` being iterated over.
 
 </description>
 <parameters>
 <parameter name="iter">
-<parameter_description> a #PangoLayoutIter
+<parameter_description> a `PangoLayoutIter`
 </parameter_description>
 </parameter>
 <parameter name="ink_rect">
-<parameter_description> rectangle to fill with ink extents,
-or %NULL
+<parameter_description> rectangle to fill with ink extents
 </parameter_description>
 </parameter>
 <parameter name="logical_rect">
-<parameter_description> rectangle to fill with logical
-extents, or %NULL
+<parameter_description> rectangle to fill with logical extents
 </parameter_description>
 </parameter>
 </parameters>
@@ -9798,43 +11013,43 @@ extents, or %NULL
 <description>
 Gets the current line.
 
-Use the faster pango_layout_iter_get_line_readonly() if you do not plan
-to modify the contents of the line (glyphs, glyph widths, etc.).
+Use the faster [method@Pango.LayoutIter.get_line_readonly] if
+you do not plan to modify the contents of the line (glyphs,
+glyph widths, etc.).
 
 
 </description>
 <parameters>
 <parameter name="iter">
-<parameter_description> a #PangoLayoutIter
+<parameter_description> a `PangoLayoutIter`
 </parameter_description>
 </parameter>
 </parameters>
-<return> the current line.
+<return> the current line
 </return>
 </function>
 
 <function name="pango_layout_iter_get_line_extents">
 <description>
-Obtains the extents of the current line. @ink_rect or @logical_rect
-can be %NULL if you aren't interested in them. Extents are in layout
-coordinates (origin is the top-left corner of the entire
-#PangoLayout).  Thus the extents returned by this function will be
-the same width/height but not at the same x/y as the extents
-returned from pango_layout_line_get_extents().
+Obtains the extents of the current line.
 
+Extents are in layout coordinates (origin is the top-left corner
+of the entire `PangoLayout`). Thus the extents returned by this
+function will be the same width/height but not at the same x/y
+as the extents returned from [method@Pango.LayoutLine.get_extents].
 
 </description>
 <parameters>
 <parameter name="iter">
-<parameter_description> a #PangoLayoutIter
+<parameter_description> a `PangoLayoutIter`
 </parameter_description>
 </parameter>
 <parameter name="ink_rect">
-<parameter_description> rectangle to fill with ink extents, or %NULL
+<parameter_description> rectangle to fill with ink extents
 </parameter_description>
 </parameter>
 <parameter name="logical_rect">
-<parameter_description> rectangle to fill with logical extents, or %NULL
+<parameter_description> rectangle to fill with logical extents
 </parameter_description>
 </parameter>
 </parameters>
@@ -9845,51 +11060,51 @@ returned from pango_layout_line_get_extents().
 <description>
 Gets the current line for read-only access.
 
-This is a faster alternative to pango_layout_iter_get_line(),
-but the user is not expected
-to modify the contents of the line (glyphs, glyph widths, etc.).
+This is a faster alternative to [method@Pango.LayoutIter.get_line],
+but the user is not expected to modify the contents of the line
+(glyphs, glyph widths, etc.).
 
 Since: 1.16
 
 </description>
 <parameters>
 <parameter name="iter">
-<parameter_description> a #PangoLayoutIter
+<parameter_description> a `PangoLayoutIter`
 </parameter_description>
 </parameter>
 </parameters>
 <return> the current line, that should not be
-modified.
+modified
 
 </return>
 </function>
 
 <function name="pango_layout_iter_get_line_yrange">
 <description>
-Divides the vertical space in the #PangoLayout being iterated over
+Divides the vertical space in the `PangoLayout` being iterated over
 between the lines in the layout, and returns the space belonging to
-the current line.  A line's range includes the line's logical
-extents, plus half of the spacing above and below the line, if
-pango_layout_set_spacing() has been called to set layout spacing.
-The Y positions are in layout coordinates (origin at top left of the
-entire layout).
+the current line.
+
+A line's range includes the line's logical extents. plus half of the
+spacing above and below the line, if [method@Pango.Layout.set_spacing]
+has been called to set layout spacing. The Y positions are in layout
+coordinates (origin at top left of the entire layout).
 
-Note: Since 1.44, Pango uses line heights for placing lines,
-and there may be gaps between the ranges returned by this
-function.
+Note: Since 1.44, Pango uses line heights for placing lines, and there
+may be gaps between the ranges returned by this function.
 
 </description>
 <parameters>
 <parameter name="iter">
-<parameter_description> a #PangoLayoutIter
+<parameter_description> a `PangoLayoutIter`
 </parameter_description>
 </parameter>
 <parameter name="y0_">
-<parameter_description> start of line, or %NULL
+<parameter_description> start of line
 </parameter_description>
 </parameter>
 <parameter name="y1_">
-<parameter_description> end of line, or %NULL
+<parameter_description> end of line
 </parameter_description>
 </parameter>
 </parameters>
@@ -9898,44 +11113,68 @@ function.
 
 <function name="pango_layout_iter_get_run">
 <description>
-Gets the current run. When iterating by run, at the end of each
-line, there's a position with a %NULL run, so this function can return
-%NULL. The %NULL run at the end of each line ensures that all lines have
-at least one run, even lines consisting of only a newline.
+Gets the current run.
 
-Use the faster pango_layout_iter_get_run_readonly() if you do not plan
-to modify the contents of the run (glyphs, glyph widths, etc.).
+When iterating by run, at the end of each line, there's a position
+with a %NULL run, so this function can return %NULL. The %NULL run
+at the end of each line ensures that all lines have at least one run,
+even lines consisting of only a newline.
+
+Use the faster [method@Pango.LayoutIter.get_run_readonly] if you do not
+plan to modify the contents of the run (glyphs, glyph widths, etc.).
 
 
 </description>
 <parameters>
 <parameter name="iter">
-<parameter_description> a #PangoLayoutIter
+<parameter_description> a `PangoLayoutIter`
 </parameter_description>
 </parameter>
 </parameters>
-<return> the current run.
+<return> the current run
 </return>
 </function>
 
+<function name="pango_layout_iter_get_run_baseline">
+<description>
+Gets the Y position of the current run's baseline, in layout
+coordinates.
+
+Layout coordinates have the origin at the top left of the entire layout.
+
+The run baseline can be different from the line baseline, for
+example due to superscript or subscript positioning.
+
+Since: 1.50
+
+</description>
+<parameters>
+<parameter name="iter">
+<parameter_description> a `PangoLayoutIter`
+</parameter_description>
+</parameter>
+</parameters>
+<return></return>
+</function>
+
 <function name="pango_layout_iter_get_run_extents">
 <description>
-Gets the extents of the current run in layout coordinates
-(origin is the top left of the entire layout).
+Gets the extents of the current run in layout coordinates.
 
+Layout coordinates have the origin at the top left of the entire layout.
 
 </description>
 <parameters>
 <parameter name="iter">
-<parameter_description> a #PangoLayoutIter
+<parameter_description> a `PangoLayoutIter`
 </parameter_description>
 </parameter>
 <parameter name="ink_rect">
-<parameter_description> rectangle to fill with ink extents, or %NULL
+<parameter_description> rectangle to fill with ink extents
 </parameter_description>
 </parameter>
 <parameter name="logical_rect">
-<parameter_description> rectangle to fill with logical extents, or %NULL
+<parameter_description> rectangle to fill with logical extents
 </parameter_description>
 </parameter>
 </parameters>
@@ -9944,118 +11183,125 @@ Gets the extents of the current run in layout coordinates
 
 <function name="pango_layout_iter_get_run_readonly">
 <description>
-Gets the current run. When iterating by run, at the end of each
-line, there's a position with a %NULL run, so this function can return
-%NULL. The %NULL run at the end of each line ensures that all lines have
-at least one run, even lines consisting of only a newline.
+Gets the current run for read-only access.
+
+When iterating by run, at the end of each line, there's a position
+with a %NULL run, so this function can return %NULL. The %NULL run
+at the end of each line ensures that all lines have at least one run,
+even lines consisting of only a newline.
 
-This is a faster alternative to pango_layout_iter_get_run(),
-but the user is not expected
-to modify the contents of the run (glyphs, glyph widths, etc.).
+This is a faster alternative to [method@Pango.LayoutIter.get_run],
+but the user is not expected to modify the contents of the run (glyphs,
+glyph widths, etc.).
 
 Since: 1.16
 
 </description>
 <parameters>
 <parameter name="iter">
-<parameter_description> a #PangoLayoutIter
+<parameter_description> a `PangoLayoutIter`
 </parameter_description>
 </parameter>
 </parameters>
 <return> the current run, that
-should not be modified.
+should not be modified
 
 </return>
 </function>
 
 <function name="pango_layout_iter_next_char">
 <description>
-Moves @iter forward to the next character in visual order. If @iter was already at
-the end of the layout, returns %FALSE.
+Moves @iter forward to the next character in visual order.
+
+If @iter was already at the end of the layout, returns %FALSE.
 
 
 </description>
 <parameters>
 <parameter name="iter">
-<parameter_description> a #PangoLayoutIter
+<parameter_description> a `PangoLayoutIter`
 </parameter_description>
 </parameter>
 </parameters>
-<return> whether motion was possible.
+<return> whether motion was possible
 </return>
 </function>
 
 <function name="pango_layout_iter_next_cluster">
 <description>
-Moves @iter forward to the next cluster in visual order. If @iter
-was already at the end of the layout, returns %FALSE.
+Moves @iter forward to the next cluster in visual order.
+
+If @iter was already at the end of the layout, returns %FALSE.
 
 
 </description>
 <parameters>
 <parameter name="iter">
-<parameter_description> a #PangoLayoutIter
+<parameter_description> a `PangoLayoutIter`
 </parameter_description>
 </parameter>
 </parameters>
-<return> whether motion was possible.
+<return> whether motion was possible
 </return>
 </function>
 
 <function name="pango_layout_iter_next_line">
 <description>
-Moves @iter forward to the start of the next line. If @iter is
-already on the last line, returns %FALSE.
+Moves @iter forward to the start of the next line.
+
+If @iter is already on the last line, returns %FALSE.
 
 
 </description>
 <parameters>
 <parameter name="iter">
-<parameter_description> a #PangoLayoutIter
+<parameter_description> a `PangoLayoutIter`
 </parameter_description>
 </parameter>
 </parameters>
-<return> whether motion was possible.
+<return> whether motion was possible
 </return>
 </function>
 
 <function name="pango_layout_iter_next_run">
 <description>
-Moves @iter forward to the next run in visual order. If @iter was
-already at the end of the layout, returns %FALSE.
+Moves @iter forward to the next run in visual order.
+
+If @iter was already at the end of the layout, returns %FALSE.
 
 
 </description>
 <parameters>
 <parameter name="iter">
-<parameter_description> a #PangoLayoutIter
+<parameter_description> a `PangoLayoutIter`
 </parameter_description>
 </parameter>
 </parameters>
-<return> whether motion was possible.
+<return> whether motion was possible
 </return>
 </function>
 
 <function name="pango_layout_line_get_extents">
 <description>
-Computes the logical and ink extents of a layout line. See
-pango_font_get_glyph_extents() for details about the interpretation
-of the rectangles.
+Computes the logical and ink extents of a layout line.
+
+See [method Pango Font.get_glyph_extents] for details
+about the interpretation of the rectangles.
 
 </description>
 <parameters>
 <parameter name="line">
-<parameter_description>     a #PangoLayoutLine
+<parameter_description> a `PangoLayoutLine`
 </parameter_description>
 </parameter>
 <parameter name="ink_rect">
 <parameter_description> rectangle used to store the extents of
-the glyph string as drawn, or %NULL
+the glyph string as drawn
 </parameter_description>
 </parameter>
 <parameter name="logical_rect">
-<parameter_description>rectangle used to store the logical
-extents of the glyph string, or %NULL
+<parameter_description> rectangle used to store the logical
+extents of the glyph string
 </parameter_description>
 </parameter>
 </parameters>
@@ -10064,15 +11310,20 @@ extents of the glyph string, or %NULL
 
 <function name="pango_layout_line_get_height">
 <description>
-Computes the height of the line, ie the distance between
-this and the previous lines baseline.
+Computes the height of the line, as the maximum of the heights
+of fonts used in this line.
+
+Note that the actual baseline-to-baseline distance between lines
+of text is influenced by other factors, such as
+[method@Pango.Layout.set_spacing] and
+[method@Pango.Layout.set_line_spacing].
 
 Since: 1.44
 
 </description>
 <parameters>
 <parameter name="line">
-<parameter_description>     a #PangoLayoutLine
+<parameter_description> a `PangoLayoutLine`
 </parameter_description>
 </parameter>
 <parameter name="height">
@@ -10083,37 +11334,94 @@ Since: 1.44
 <return></return>
 </function>
 
+<function name="pango_layout_line_get_length">
+<description>
+Returns the length of the line, in bytes.
+
+Since: 1.50
+
+</description>
+<parameters>
+<parameter name="line">
+<parameter_description> a `PangoLayoutLine`
+</parameter_description>
+</parameter>
+</parameters>
+<return> the length of the line
+
+</return>
+</function>
+
 <function name="pango_layout_line_get_pixel_extents">
 <description>
 Computes the logical and ink extents of @layout_line in device units.
-This function just calls pango_layout_line_get_extents() followed by
-two pango_extents_to_pixels() calls, rounding @ink_rect and @logical_rect
+
+This function just calls [method@Pango.LayoutLine.get_extents] followed by
+two [func@extents_to_pixels] calls, rounding @ink_rect and @logical_rect
 such that the rounded rectangles fully contain the unrounded one (that is,
-passes them as first argument to pango_extents_to_pixels()).
+passes them as first argument to [func@extents_to_pixels]).
 
 </description>
 <parameters>
 <parameter name="layout_line">
-<parameter_description> a #PangoLayoutLine
+<parameter_description> a `PangoLayoutLine`
 </parameter_description>
 </parameter>
 <parameter name="ink_rect">
 <parameter_description> rectangle used to store the extents of
-the glyph string as drawn, or %NULL
+the glyph string as drawn
 </parameter_description>
 </parameter>
 <parameter name="logical_rect">
 <parameter_description> rectangle used to store the logical
-extents of the glyph string, or %NULL
+extents of the glyph string
 </parameter_description>
 </parameter>
 </parameters>
 <return></return>
 </function>
 
+<function name="pango_layout_line_get_resolved_direction">
+<description>
+Returns the resolved direction of the line.
+
+Since: 1.50
+
+</description>
+<parameters>
+<parameter name="line">
+<parameter_description> a `PangoLayoutLine`
+</parameter_description>
+</parameter>
+</parameters>
+<return> the resolved direction of the line
+
+</return>
+</function>
+
+<function name="pango_layout_line_get_start_index">
+<description>
+Returns the start index of the line, as byte index
+into the text of the layout.
+
+Since: 1.50
+
+</description>
+<parameters>
+<parameter name="line">
+<parameter_description> a `PangoLayoutLine`
+</parameter_description>
+</parameter>
+</parameters>
+<return> the start index of the line
+
+</return>
+</function>
+
 <function name="pango_layout_line_get_x_ranges">
 <description>
 Gets a list of visual ranges corresponding to a given logical range.
+
 This list is not necessarily minimal - there may be consecutive
 ranges which are adjacent. The ranges will be sorted from left to
 right. The ranges are with respect to the left edge of the entire
@@ -10122,37 +11430,34 @@ layout, not with respect to the line.
 </description>
 <parameters>
 <parameter name="line">
-<parameter_description>        a #PangoLayoutLine
+<parameter_description> a `PangoLayoutLine`
 </parameter_description>
 </parameter>
 <parameter name="start_index">
 <parameter_description> Start byte index of the logical range. If this value
-is less than the start index for the line, then
-the first range will extend all the way to the leading
-edge of the layout. Otherwise it will start at the
-leading edge of the first character.
+is less than the start index for the line, then the first range
+will extend all the way to the leading edge of the layout. Otherwise,
+it will start at the leading edge of the first character.
 </parameter_description>
 </parameter>
 <parameter name="end_index">
-<parameter_description>   Ending byte index of the logical range. If this value
-is greater than the end index for the line, then
-the last range will extend all the way to the trailing
-edge of the layout. Otherwise, it will end at the
-trailing edge of the last character.
+<parameter_description> Ending byte index of the logical range. If this value is
+greater than the end index for the line, then the last range will
+extend all the way to the trailing edge of the layout. Otherwise,
+it will end at the trailing edge of the last character.
 </parameter_description>
 </parameter>
 <parameter name="ranges">
-<parameter_description>
-location to store a pointer to an array of ranges.
-The array will be of length &lt;literal&gt;2*n_ranges&lt;/literal&gt;,
-with each range starting at &lt;literal&gt;(*ranges)[2*n]&lt;/literal&gt;
-and of width &lt;literal&gt;(*ranges)[2*n + 1] - (*ranges)[2*n]&lt;/literal&gt;.
-This array must be freed with g_free(). The coordinates are relative
-to the layout and are in Pango units.
+<parameter_description> location to
+store a pointer to an array of ranges. The array will be of length
+`2*n_ranges`, with each range starting at `(*ranges)[2*n]` and of
+width `(*ranges)[2*n + 1] - (*ranges)[2*n]`. This array must be freed
+with g_free(). The coordinates are relative to the layout and are in
+Pango units.
 </parameter_description>
 </parameter>
 <parameter name="n_ranges">
-<parameter_description> The number of ranges stored in @ranges.
+<parameter_description> The number of ranges stored in @ranges
 </parameter_description>
 </parameter>
 </parameters>
@@ -10163,41 +11468,58 @@ to the layout and are in Pango units.
 <description>
 Converts an index within a line to a X position.
 
-
 </description>
 <parameters>
 <parameter name="line">
-<parameter_description>     a #PangoLayoutLine
+<parameter_description> a `PangoLayoutLine`
 </parameter_description>
 </parameter>
 <parameter name="index_">
-<parameter_description>   byte offset of a grapheme within the layout
+<parameter_description> byte offset of a grapheme within the layout
 </parameter_description>
 </parameter>
 <parameter name="trailing">
 <parameter_description> an integer indicating the edge of the grapheme to retrieve
 the position of. If &gt; 0, the trailing edge of the grapheme,
-if 0, the leading of the grapheme.
+if 0, the leading of the grapheme
 </parameter_description>
 </parameter>
 <parameter name="x_pos">
-<parameter_description> location to store the x_offset (in Pango unit)
+<parameter_description> location to store the x_offset (in Pango units)
 </parameter_description>
 </parameter>
 </parameters>
 <return></return>
 </function>
 
+<function name="pango_layout_line_is_paragraph_start">
+<description>
+Returns whether this is the first line of the paragraph.
+
+Since: 1.50
+
+</description>
+<parameters>
+<parameter name="line">
+<parameter_description> a `PangoLayoutLine`
+</parameter_description>
+</parameter>
+</parameters>
+<return> %TRUE if this is the first line
+
+</return>
+</function>
+
 <function name="pango_layout_line_ref">
 <description>
-Increase the reference count of a #PangoLayoutLine by one.
+Increase the reference count of a `PangoLayoutLine` by one.
 
 Since: 1.10
 
 </description>
 <parameters>
 <parameter name="line">
-<parameter_description> a #PangoLayoutLine, may be %NULL
+<parameter_description> a `PangoLayoutLine`
 </parameter_description>
 </parameter>
 </parameters>
@@ -10208,14 +11530,15 @@ Since: 1.10
 
 <function name="pango_layout_line_unref">
 <description>
-Decrease the reference count of a #PangoLayoutLine by one.
+Decrease the reference count of a `PangoLayoutLine` by one.
+
 If the result is zero, the line and all associated memory
 will be freed.
 
 </description>
 <parameters>
 <parameter name="line">
-<parameter_description> a #PangoLayoutLine
+<parameter_description> a `PangoLayoutLine`
 </parameter_description>
 </parameter>
 </parameters>
@@ -10224,39 +11547,38 @@ will be freed.
 
 <function name="pango_layout_line_x_to_index">
 <description>
-Converts from x offset to the byte index of the corresponding
-character within the text of the layout. If @x_pos is outside the line,
-@index_ and @trailing will point to the very first or very last position
-in the line. This determination is based on the resolved direction
-of the paragraph; for example, if the resolved direction is
-right-to-left, then an X position to the right of the line (after it)
+Converts from x offset to the byte index of the corresponding character
+within the text of the layout.
+
+If @x_pos is outside the line, @index_ and @trailing will point to the very
+first or very last position in the line. This determination is based on the
+resolved direction of the paragraph; for example, if the resolved direction
+is right-to-left, then an X position to the right of the line (after it)
 results in 0 being stored in @index_ and @trailing. An X position to the
-left of the line results in @index_ pointing to the (logical) last
-grapheme in the line and @trailing being set to the number of characters
-in that grapheme. The reverse is true for a left-to-right line.
+left of the line results in @index_ pointing to the (logical) last grapheme
+in the line and @trailing being set to the number of characters in that
+grapheme. The reverse is true for a left-to-right line.
 
 
 </description>
 <parameters>
 <parameter name="line">
-<parameter_description>      a #PangoLayoutLine
+<parameter_description> a `PangoLayoutLine`
 </parameter_description>
 </parameter>
 <parameter name="x_pos">
-<parameter_description>     the X offset (in Pango units)
-from the left edge of the line.
+<parameter_description> the X offset (in Pango units) from the left edge of the line.
 </parameter_description>
 </parameter>
 <parameter name="index_">
-<parameter_description>   location to store calculated byte index for
-the grapheme in which the user clicked.
+<parameter_description> location to store calculated byte index for the grapheme
+in which the user clicked
 </parameter_description>
 </parameter>
 <parameter name="trailing">
-<parameter_description> location to store an integer indicating where
-in the grapheme the user clicked. It will either
-be zero, or the number of characters in the
-grapheme. 0 represents the leading edge of the grapheme.
+<parameter_description> location to store an integer indicating where in the
+grapheme the user clicked. It will either be zero, or the number of
+characters in the grapheme. 0 represents the leading edge of the grapheme.
 </parameter_description>
 </parameter>
 </parameters>
@@ -10266,37 +11588,36 @@ grapheme. 0 represents the leading edge of the grapheme.
 
 <function name="pango_layout_move_cursor_visually">
 <description>
-Computes a new cursor position from an old position and
-a count of positions to move visually. If @direction is positive,
-then the new strong cursor position will be one position
-to the right of the old cursor position. If @direction is negative,
-then the new strong cursor position will be one position
-to the left of the old cursor position.
+Computes a new cursor position from an old position and a direction.
+
+If @direction is positive, then the new position will cause the strong
+or weak cursor to be displayed one position to right of where it was
+with the old cursor position. If @direction is negative, it will be
+moved to the left.
 
-In the presence of bidirectional text, the correspondence
-between logical and visual order will depend on the direction
-of the current run, and there may be jumps when the cursor
-is moved off of the end of a run.
+In the presence of bidirectional text, the correspondence between
+logical and visual order will depend on the direction of the current
+run, and there may be jumps when the cursor is moved off of the end
+of a run.
 
-Motion here is in cursor positions, not in characters, so a
-single call to pango_layout_move_cursor_visually() may move the
-cursor over multiple characters when multiple characters combine
-to form a single grapheme.
+Motion here is in cursor positions, not in characters, so a single
+call to this function may move the cursor over multiple characters
+when multiple characters combine to form a single grapheme.
 
 </description>
 <parameters>
 <parameter name="layout">
-<parameter_description>       a #PangoLayout.
+<parameter_description> a `PangoLayout`
 </parameter_description>
 </parameter>
 <parameter name="strong">
-<parameter_description>       whether the moving cursor is the strong cursor or the
+<parameter_description> whether the moving cursor is the strong cursor or the
 weak cursor. The strong cursor is the cursor corresponding
 to text insertion in the base direction for the layout.
 </parameter_description>
 </parameter>
 <parameter name="old_index">
-<parameter_description>    the byte index of the grapheme for the old index
+<parameter_description> the byte index of the current cursor position
 </parameter_description>
 </parameter>
 <parameter name="old_trailing">
@@ -10306,25 +11627,24 @@ was at the trailing edge.
 </parameter_description>
 </parameter>
 <parameter name="direction">
-<parameter_description>    direction to move cursor. A negative
-value indicates motion to the left.
+<parameter_description> direction to move cursor. A negative
+value indicates motion to the left
 </parameter_description>
 </parameter>
 <parameter name="new_index">
-<parameter_description> location to store the new cursor byte index. A value of -1
-indicates that the cursor has been moved off the beginning
-of the layout. A value of %G_MAXINT indicates that
+<parameter_description> location to store the new cursor byte index.
+A value of -1 indicates that the cursor has been moved off the
+beginning of the layout. A value of %G_MAXINT indicates that
 the cursor has been moved off the end of the layout.
 </parameter_description>
 </parameter>
 <parameter name="new_trailing">
-<parameter_description> number of characters to move forward from the
-location returned for @new_index to get the position
-where the cursor should be displayed. This allows
-distinguishing the position at the beginning of one
-line from the position at the end of the preceding
-line. @new_index is always on the line where the
-cursor should be displayed.
+<parameter_description> number of characters to move forward from
+the location returned for @new_index to get the position where
+the cursor should be displayed. This allows distinguishing the
+position at the beginning of one line from the position at the
+end of the preceding line. @new_index is always on the line where
+the cursor should be displayed.
 </parameter_description>
 </parameter>
 </parameters>
@@ -10333,20 +11653,47 @@ cursor should be displayed.
 
 <function name="pango_layout_new">
 <description>
-Create a new #PangoLayout object with attributes initialized to
-default values for a particular #PangoContext.
+Create a new `PangoLayout` object with attributes initialized to
+default values for a particular `PangoContext`.
 
 
 </description>
 <parameters>
 <parameter name="context">
-<parameter_description> a #PangoContext
+<parameter_description> a `PangoContext`
 </parameter_description>
 </parameter>
 </parameters>
-<return> the newly allocated #PangoLayout, with a reference
-count of one, which should be freed with
-g_object_unref().
+<return> the newly allocated `PangoLayout`
+</return>
+</function>
+
+<function name="pango_layout_serialize">
+<description>
+Serializes the @layout for later deserialization via [func@Pango.Layout.deserialize].
+
+There are no guarantees about the format of the output across different
+versions of Pango and [func@Pango.Layout.deserialize] will reject data
+that it cannot parse.
+
+The intended use of this function is testing, benchmarking and debugging.
+The format is not meant as a permanent storage format.
+
+Since: 1.50
+
+</description>
+<parameters>
+<parameter name="layout">
+<parameter_description> a `PangoLayout`
+</parameter_description>
+</parameter>
+<parameter name="flags">
+<parameter_description> `PangoLayoutSerializeFlags`
+</parameter_description>
+</parameter>
+</parameters>
+<return> a `GBytes` containing the serialized form of @layout
+
 </return>
 </function>
 
@@ -10355,10 +11702,12 @@ g_object_unref().
 Sets the alignment for the layout: how partial lines are
 positioned within the horizontal space available.
 
+The default alignment is %PANGO_ALIGN_LEFT.
+
 </description>
 <parameters>
 <parameter name="layout">
-<parameter_description> a #PangoLayout
+<parameter_description> a `PangoLayout`
 </parameter_description>
 </parameter>
 <parameter name="alignment">
@@ -10372,16 +11721,17 @@ positioned within the horizontal space available.
 <function name="pango_layout_set_attributes">
 <description>
 Sets the text attributes for a layout object.
+
 References @attrs, so the caller can unref its reference.
 
 </description>
 <parameters>
 <parameter name="layout">
-<parameter_description> a #PangoLayout
+<parameter_description> a `PangoLayout`
 </parameter_description>
 </parameter>
 <parameter name="attrs">
-<parameter_description> a #PangoAttrList, can be %NULL
+<parameter_description> a `PangoAttrList`
 </parameter_description>
 </parameter>
 </parameters>
@@ -10390,18 +11740,18 @@ References @attrs, so the caller can unref its reference.
 
 <function name="pango_layout_set_auto_dir">
 <description>
-Sets whether to calculate the bidirectional base direction
-for the layout according to the contents of the layout;
-when this flag is on (the default), then paragraphs in
-   @layout that begin with strong right-to-left characters
-(Arabic and Hebrew principally), will have right-to-left
-layout, paragraphs with letters from other scripts will
-have left-to-right layout. Paragraphs with only neutral
-characters get their direction from the surrounding paragraphs.
+Sets whether to calculate the base direction
+for the layout according to its contents.
+
+When this flag is on (the default), then paragraphs in @layout that
+begin with strong right-to-left characters (Arabic and Hebrew principally),
+will have right-to-left layout, paragraphs with letters from other scripts
+will have left-to-right layout. Paragraphs with only neutral characters
+get their direction from the surrounding paragraphs.
 
-When %FALSE, the choice between left-to-right and
-right-to-left layout is done according to the base direction
-of the layout's #PangoContext. (See pango_context_set_base_dir()).
+When %FALSE, the choice between left-to-right and right-to-left
+layout is done according to the base direction of the layout's
+`PangoContext`. (See [method@Pango.Context.set_base_dir]).
 
 When the auto-computed direction of a paragraph differs from the
 base direction of the context, the interpretation of
@@ -10412,12 +11762,12 @@ Since: 1.4
 </description>
 <parameters>
 <parameter name="layout">
-<parameter_description> a #PangoLayout
+<parameter_description> a `PangoLayout`
 </parameter_description>
 </parameter>
 <parameter name="auto_dir">
 <parameter_description> if %TRUE, compute the bidirectional base direction
-from the layout's contents.
+from the layout's contents
 </parameter_description>
 </parameter>
 </parameters>
@@ -10427,23 +11777,27 @@ from the layout's contents.
 <function name="pango_layout_set_ellipsize">
 <description>
 Sets the type of ellipsization being performed for @layout.
+
 Depending on the ellipsization mode @ellipsize text is
 removed from the start, middle, or end of text so they
 fit within the width and height of layout set with
-pango_layout_set_width() and pango_layout_set_height().
+[method@Pango.Layout.set_width] and [method@Pango.Layout.set_height].
 
 If the layout contains characters such as newlines that
 force it to be layed out in multiple paragraphs, then whether
 each paragraph is ellipsized separately or the entire layout
 is ellipsized as a whole depends on the set height of the layout.
-See pango_layout_set_height() for details.
+
+The default value is %PANGO_ELLIPSIZE_NONE.
+
+See [method@Pango.Layout.set_height] for details.
 
 Since: 1.6
 
 </description>
 <parameters>
 <parameter name="layout">
-<parameter_description> a #PangoLayout
+<parameter_description> a `PangoLayout`
 </parameter_description>
 </parameter>
 <parameter name="ellipsize">
@@ -10456,19 +11810,20 @@ Since: 1.6
 
 <function name="pango_layout_set_font_description">
 <description>
-Sets the default font description for the layout. If no font
-description is set on the layout, the font description from
-the layout's context is used.
+Sets the default font description for the layout.
+
+If no font description is set on the layout, the
+font description from the layout's context is used.
 
 </description>
 <parameters>
 <parameter name="layout">
-<parameter_description> a #PangoLayout
+<parameter_description> a `PangoLayout`
 </parameter_description>
 </parameter>
 <parameter name="desc">
-<parameter_description> the new #PangoFontDescription, or %NULL to unset the
-current font description
+<parameter_description> the new `PangoFontDescription`
+to unset the current font description
 </parameter_description>
 </parameter>
 </parameters>
@@ -10477,24 +11832,25 @@ current font description
 
 <function name="pango_layout_set_height">
 <description>
-Sets the height to which the #PangoLayout should be ellipsized at.  There
-are two different behaviors, based on whether @height is positive or
-negative.
+Sets the height to which the `PangoLayout` should be ellipsized at.
 
-If @height is positive, it will be the maximum height of the layout.  Only
+There are two different behaviors, based on whether @height is positive
+or negative.
+
+If @height is positive, it will be the maximum height of the layout. Only
 lines would be shown that would fit, and if there is any text omitted,
-an ellipsis added.  At least one line is included in each paragraph regardless
-of how small the height value is.  A value of zero will render exactly one
+an ellipsis added. At least one line is included in each paragraph regardless
+of how small the height value is. A value of zero will render exactly one
 line for the entire layout.
 
-If @height is negative, it will be the (negative of) maximum number of lines per
-paragraph.  That is, the total number of lines shown may well be more than
+If @height is negative, it will be the (negative of) maximum number of lines
+per paragraph. That is, the total number of lines shown may well be more than
 this value if the layout contains multiple paragraphs of text.
-The default value of -1 means that first line of each paragraph is ellipsized.
-This behvaior may be changed in the future to act per layout instead of per
-paragraph.  File a bug against pango at &lt;ulink
-url=&quot;http://bugzilla.gnome.org/&quot;&gt;http://bugzilla.gnome.org/&lt;/ulink&gt; if your
-code relies on this behavior.
+The default value of -1 means that the first line of each paragraph is ellipsized.
+This behavior may be changed in the future to act per layout instead of per
+paragraph. File a bug against pango at
+[https://gitlab.gnome.org/gnome/pango](https://gitlab.gnome.org/gnome/pango)
+if your code relies on this behavior.
 
 Height setting only has effect if a positive width is set on
 @layout and ellipsization mode of @layout is not %PANGO_ELLIPSIZE_NONE.
@@ -10507,7 +11863,7 @@ Since: 1.20
 </description>
 <parameters>
 <parameter name="layout">
-<parameter_description> a #PangoLayout.
+<parameter_description> a `PangoLayout`.
 </parameter_description>
 </parameter>
 <parameter name="height">
@@ -10521,22 +11877,25 @@ or desired number of lines if negative.
 
 <function name="pango_layout_set_indent">
 <description>
-Sets the width in Pango units to indent each paragraph. A negative value
-of @indent will produce a hanging indentation. That is, the first line will
-have the full width, and subsequent lines will be indented by the
-absolute value of @indent.
+Sets the width in Pango units to indent each paragraph.
+
+A negative value of @indent will produce a hanging indentation.
+That is, the first line will have the full width, and subsequent
+lines will be indented by the absolute value of @indent.
 
 The indent setting is ignored if layout alignment is set to
 %PANGO_ALIGN_CENTER.
 
+The default value is 0.
+
 </description>
 <parameters>
 <parameter name="layout">
-<parameter_description> a #PangoLayout.
+<parameter_description> a `PangoLayout`
 </parameter_description>
 </parameter>
 <parameter name="indent">
-<parameter_description> the amount by which to indent.
+<parameter_description> the amount by which to indent
 </parameter_description>
 </parameter>
 </parameters>
@@ -10545,23 +11904,58 @@ The indent setting is ignored if layout alignment is set to
 
 <function name="pango_layout_set_justify">
 <description>
-Sets whether each complete line should be stretched to
-fill the entire width of the layout. This stretching is typically
-done by adding whitespace, but for some scripts (such as Arabic),
-the justification may be done in more complex ways, like extending
-the characters.
+Sets whether each complete line should be stretched to fill the
+entire width of the layout.
+
+Stretching is typically done by adding whitespace, but for some scripts
+(such as Arabic), the justification may be done in more complex ways,
+like extending the characters.
+
+Note that this setting is not implemented and so is ignored in
+Pango older than 1.18.
+
+Note that tabs and justification conflict with each other:
+Justification will move content away from its tab-aligned
+positions.
+
+The default value is %FALSE.
+
+Also see [method@Pango.Layout.set_justify_last_line].
+
+</description>
+<parameters>
+<parameter name="layout">
+<parameter_description> a `PangoLayout`
+</parameter_description>
+</parameter>
+<parameter name="justify">
+<parameter_description> whether the lines in the layout should be justified
+</parameter_description>
+</parameter>
+</parameters>
+<return></return>
+</function>
+
+<function name="pango_layout_set_justify_last_line">
+<description>
+Sets whether the last line should be stretched to fill the
+entire width of the layout.
 
-Note that this setting is not implemented and so is ignored in Pango
-older than 1.18.
+This only has an effect if [method@Pango.Layout.set_justify] has
+been called as well.
+
+The default value is %FALSE.
+
+Since: 1.50
 
 </description>
 <parameters>
 <parameter name="layout">
-<parameter_description> a #PangoLayout
+<parameter_description> a `PangoLayout`
 </parameter_description>
 </parameter>
 <parameter name="justify">
-<parameter_description> whether the lines in the layout should be justified.
+<parameter_description> whether the last line in the layout should be justified
 </parameter_description>
 </parameter>
 </parameters>
@@ -10571,28 +11965,28 @@ older than 1.18.
 <function name="pango_layout_set_line_spacing">
 <description>
 Sets a factor for line spacing.
-Typical values are: 0, 1, 1.5, 2.
-The default values is 0.
 
-If @factor is non-zero, lines are placed
-so that
+Typical values are: 0, 1, 1.5, 2. The default values is 0.
+
+If @factor is non-zero, lines are placed so that
 
 baseline2 = baseline1 + factor * height2
 
-where height2 is the line height of the
-second line (as determined by the font(s)).
-In this case, the spacing set with
-pango_layout_set_spacing() is ignored.
+where height2 is the line height of the second line
+(as determined by the font(s)). In this case, the spacing
+set with [method@Pango.Layout.set_spacing] is ignored.
+
+If @factor is zero (the default), spacing is applied as before.
 
-If @factor is zero, spacing is applied as
-before.
+Note: for semantics that are closer to the CSS line-height
+property, see [func@Pango.attr_line_height_new].
 
 Since: 1.44
 
 </description>
 <parameters>
 <parameter name="layout">
-<parameter_description> a #PangoLayout
+<parameter_description> a `PangoLayout`
 </parameter_description>
 </parameter>
 <parameter name="factor">
@@ -10605,14 +11999,19 @@ Since: 1.44
 
 <function name="pango_layout_set_markup">
 <description>
-Same as pango_layout_set_markup_with_accel(), but
-the markup text isn't scanned for accelerators.
+Sets the layout text and attribute list from marked-up text.
 
+See [Pango Markup](pango_markup.html)).
+
+Replaces the current text and attribute list.
+
+This is the same as [method@Pango.Layout.set_markup_with_accel],
+but the markup text isn't scanned for accelerators.
 
 </description>
 <parameters>
 <parameter name="layout">
-<parameter_description> a #PangoLayout
+<parameter_description> a `PangoLayout`
 </parameter_description>
 </parameter>
 <parameter name="markup">
@@ -10621,7 +12020,7 @@ the markup text isn't scanned for accelerators.
 </parameter>
 <parameter name="length">
 <parameter_description> length of marked-up text in bytes, or -1 if @markup is
-null-terminated
+`NUL`-terminated
 </parameter_description>
 </parameter>
 </parameters>
@@ -10630,9 +12029,11 @@ null-terminated
 
 <function name="pango_layout_set_markup_with_accel">
 <description>
-Sets the layout text and attribute list from marked-up text (see
-&lt;link linkend=&quot;PangoMarkupFormat&quot;&gt;markup format&lt;/link&gt;). Replaces
-the current text and attribute list.
+Sets the layout text and attribute list from marked-up text.
+
+See [Pango Markup](pango_markup.html)).
+
+Replaces the current text and attribute list.
 
 If @accel_marker is nonzero, the given character will mark the
 character following it as an accelerator. For example, @accel_marker
@@ -10645,17 +12046,16 @@ literal @accel_marker character.
 </description>
 <parameters>
 <parameter name="layout">
-<parameter_description> a #PangoLayout
+<parameter_description> a `PangoLayout`
 </parameter_description>
 </parameter>
 <parameter name="markup">
-<parameter_description> marked-up text
-(see &lt;link linkend=&quot;PangoMarkupFormat&quot;&gt;markup format&lt;/link&gt;)
+<parameter_description> marked-up text (see [Pango Markup](pango_markup.html))
 </parameter_description>
 </parameter>
 <parameter name="length">
 <parameter_description> length of marked-up text in bytes, or -1 if @markup is
-null-terminated
+`NUL`-terminated
 </parameter_description>
 </parameter>
 <parameter name="accel_marker">
@@ -10664,7 +12064,7 @@ null-terminated
 </parameter>
 <parameter name="accel_char">
 <parameter_description> return location
-for first located accelerator, or %NULL
+for first located accelerator
 </parameter_description>
 </parameter>
 </parameters>
@@ -10673,15 +12073,19 @@ for first located accelerator, or %NULL
 
 <function name="pango_layout_set_single_paragraph_mode">
 <description>
+Sets the single paragraph mode of @layout.
+
 If @setting is %TRUE, do not treat newlines and similar characters
 as paragraph separators; instead, keep all text in a single paragraph,
 and display a glyph for paragraph separator characters. Used when
 you want to allow editing of newlines on a single text line.
 
+The default value is %FALSE.
+
 </description>
 <parameters>
 <parameter name="layout">
-<parameter_description> a #PangoLayout
+<parameter_description> a `PangoLayout`
 </parameter_description>
 </parameter>
 <parameter name="setting">
@@ -10694,22 +12098,27 @@ you want to allow editing of newlines on a single text line.
 
 <function name="pango_layout_set_spacing">
 <description>
-Sets the amount of spacing in Pango unit between
-the lines of the layout. When placing lines with
-spacing, Pango arranges things so that
+Sets the amount of spacing in Pango units between
+the lines of the layout.
+
+When placing lines with spacing, Pango arranges things so that
 
 line2.top = line1.bottom + spacing
 
-Note: Since 1.44, Pango defaults to using the
-line height (as determined by the font) for placing
-lines. The @spacing set with this function is only
-taken into account when the line-height factor is
-set to zero with pango_layout_set_line_spacing().
+The default value is 0.
+
+Note: Since 1.44, Pango is using the line height (as determined
+by the font) for placing lines when the line spacing factor is set
+to a non-zero value with [method@Pango.Layout.set_line_spacing].
+In that case, the @spacing set with this function is ignored.
+
+Note: for semantics that are closer to the CSS line-height
+property, see [func@Pango.attr_line_height_new].
 
 </description>
 <parameters>
 <parameter name="layout">
-<parameter_description> a #PangoLayout.
+<parameter_description> a `PangoLayout`
 </parameter_description>
 </parameter>
 <parameter name="spacing">
@@ -10722,19 +12131,28 @@ set to zero with pango_layout_set_line_spacing().
 
 <function name="pango_layout_set_tabs">
 <description>
-Sets the tabs to use for @layout, overriding the default tabs
-(by default, tabs are every 8 spaces). If @tabs is %NULL, the default
-tabs are reinstated. @tabs is copied into the layout; you must
-free your copy of @tabs yourself.
+Sets the tabs to use for @layout, overriding the default tabs.
+
+`PangoLayout` will place content at the next tab position
+whenever it meets a Tab character (U+0009).
+
+By default, tabs are every 8 spaces. If @tabs is %NULL, the
+default tabs are reinstated. @tabs is copied into the layout;
+you must free your copy of @tabs yourself.
+
+Note that tabs and justification conflict with each other:
+Justification will move content away from its tab-aligned
+positions. The same is true for alignments other than
+%PANGO_ALIGN_LEFT.
 
 </description>
 <parameters>
 <parameter name="layout">
-<parameter_description> a #PangoLayout
+<parameter_description> a `PangoLayout`
 </parameter_description>
 </parameter>
 <parameter name="tabs">
-<parameter_description> a #PangoTabArray, or %NULL
+<parameter_description> a `PangoTabArray`
 </parameter_description>
 </parameter>
 </parameters>
@@ -10748,16 +12166,16 @@ Sets the text of the layout.
 This function validates @text and renders invalid UTF-8
 with a placeholder glyph.
 
-Note that if you have used pango_layout_set_markup() or
-pango_layout_set_markup_with_accel() on @layout before, you may
-want to call pango_layout_set_attributes() to clear the attributes
-set on the layout from the markup as this function does not clear
-attributes.
+Note that if you have used [method@Pango.Layout.set_markup] or
+[method@Pango.Layout.set_markup_with_accel] on @layout before, you
+may want to call [method@Pango.Layout.set_attributes] to clear the
+attributes set on the layout from the markup as this function does
+not clear attributes.
 
 </description>
 <parameters>
 <parameter name="layout">
-<parameter_description> a #PangoLayout
+<parameter_description> a `PangoLayout`
 </parameter_description>
 </parameter>
 <parameter name="text">
@@ -10766,10 +12184,9 @@ attributes.
 </parameter>
 <parameter name="length">
 <parameter_description> maximum length of @text, in bytes. -1 indicates that
-the string is nul-terminated and the length should be
-calculated.  The text will also be truncated on
-encountering a nul-termination even when @length is
-positive.
+the string is nul-terminated and the length should be calculated.
+The text will also be truncated on encountering a nul-termination
+even when @length is positive.
 </parameter_description>
 </parameter>
 </parameters>
@@ -10778,13 +12195,15 @@ positive.
 
 <function name="pango_layout_set_width">
 <description>
-Sets the width to which the lines of the #PangoLayout should wrap or
-ellipsized.  The default value is -1: no width set.
+Sets the width to which the lines of the `PangoLayout` should wrap or
+ellipsized.
+
+The default value is -1: no width set.
 
 </description>
 <parameters>
 <parameter name="layout">
-<parameter_description> a #PangoLayout.
+<parameter_description> a `PangoLayout`.
 </parameter_description>
 </parameter>
 <parameter name="width">
@@ -10798,72 +12217,113 @@ wrapping or ellipsization should be performed.
 
 <function name="pango_layout_set_wrap">
 <description>
-Sets the wrap mode; the wrap mode only has effect if a width
-is set on the layout with pango_layout_set_width().
-To turn off wrapping, set the width to -1.
+Sets the wrap mode.
+
+The wrap mode only has effect if a width is set on the layout
+with [method@Pango.Layout.set_width]. To turn off wrapping,
+set the width to -1.
+
+The default value is %PANGO_WRAP_WORD.
+
+</description>
+<parameters>
+<parameter name="layout">
+<parameter_description> a `PangoLayout`
+</parameter_description>
+</parameter>
+<parameter name="wrap">
+<parameter_description> the wrap mode
+</parameter_description>
+</parameter>
+</parameters>
+<return></return>
+</function>
+
+<function name="pango_layout_write_to_file">
+<description>
+This function is equivalent to calling [method@Pango.Layout.serialize]
+followed by g_file_set_contents().
+
+See those two functions for details on the arguments.
+
+It is mostly intended for use inside a debugger to quickly dump
+a layout to a file for later inspection.
+
+Since: 1.50
 
 </description>
 <parameters>
 <parameter name="layout">
-<parameter_description> a #PangoLayout
+<parameter_description> a `PangoLayout`
+</parameter_description>
+</parameter>
+<parameter name="flags">
+<parameter_description> `PangoLayoutSerializeFlags`
+</parameter_description>
+</parameter>
+<parameter name="filename">
+<parameter_description> the file to save it to
 </parameter_description>
 </parameter>
-<parameter name="wrap">
-<parameter_description> the wrap mode
+<parameter name="error">
+<parameter_description> Return location for a potential error
 </parameter_description>
 </parameter>
 </parameters>
-<return></return>
+<return> %TRUE if saving was successful
+
+</return>
 </function>
 
 <function name="pango_layout_xy_to_index">
 <description>
-Converts from X and Y position within a layout to the byte
-index to the character at that logical position. If the
-Y position is not inside the layout, the closest position is chosen
-(the position will be clamped inside the layout). If the
-X position is not within the layout, then the start or the
-end of the line is chosen as described for pango_layout_line_x_to_index().
-If either the X or Y positions were not inside the layout, then the
-function returns %FALSE; on an exact hit, it returns %TRUE.
+Converts from X and Y position within a layout to the byte index to the
+character at that logical position.
+
+If the Y position is not inside the layout, the closest position is
+chosen (the position will be clamped inside the layout). If the X position
+is not within the layout, then the start or the end of the line is
+chosen as described for [method@Pango.LayoutLine.x_to_index]. If either
+the X or Y positions were not inside the layout, then the function returns
+%FALSE; on an exact hit, it returns %TRUE.
 
 
 </description>
 <parameters>
 <parameter name="layout">
-<parameter_description>    a #PangoLayout
+<parameter_description> a `PangoLayout`
 </parameter_description>
 </parameter>
 <parameter name="x">
-<parameter_description>         the X offset (in Pango units)
-from the left edge of the layout.
+<parameter_description> the X offset (in Pango units) from the left edge of the layout
 </parameter_description>
 </parameter>
 <parameter name="y">
-<parameter_description>         the Y offset (in Pango units)
-from the top edge of the layout
+<parameter_description> the Y offset (in Pango units) from the top edge of the layout
 </parameter_description>
 </parameter>
 <parameter name="index_">
-<parameter_description>   location to store calculated byte index
+<parameter_description> location to store calculated byte index
 </parameter_description>
 </parameter>
 <parameter name="trailing">
 <parameter_description> location to store a integer indicating where
-in the grapheme the user clicked. It will either
-be zero, or the number of characters in the
-grapheme. 0 represents the leading edge of the grapheme.
+in the grapheme the user clicked. It will either be zero, or the
+number of characters in the grapheme. 0 represents the leading edge
+of the grapheme.
 </parameter_description>
 </parameter>
 </parameters>
-<return> %TRUE if the coordinates were inside text, %FALSE otherwise.
+<return> %TRUE if the coordinates were inside text, %FALSE otherwise
 </return>
 </function>
 
 <function name="pango_log2vis_get_embedding_levels">
 <description>
-This will return the bidirectional embedding levels of the input paragraph
-as defined by the Unicode Bidirectional Algorithm available at:
+Return the bidirectional embedding levels of the input paragraph.
+
+The bidirectional embedding levels are defined by the Unicode Bidirectional
+Algorithm available at:
 
 http://www.unicode.org/reports/tr9/
 
@@ -10875,11 +12335,11 @@ Since: 1.4
 </description>
 <parameters>
 <parameter name="text">
-<parameter_description>      the text to itemize.
+<parameter_description> the text to itemize.
 </parameter_description>
 </parameter>
 <parameter name="length">
-<parameter_description>    the number of bytes (not characters) to process, or -1
+<parameter_description> the number of bytes (not characters) to process, or -1
 if @text is nul-terminated and the length should be calculated.
 </parameter_description>
 </parameter>
@@ -10889,7 +12349,7 @@ if @text is nul-terminated and the length should be calculated.
 </parameter>
 </parameters>
 <return> a newly allocated array of embedding levels, one item per
-character (not byte), that should be freed using g_free.
+character (not byte), that should be freed using g_free().
 
 </return>
 </function>
@@ -10897,6 +12357,7 @@ character (not byte), that should be freed using g_free.
 <function name="pango_lookup_aliases">
 <description>
 Look up all user defined aliases for the alias @fontname.
+
 The resulting font family names will be stored in @families,
 and the number of families in @n_families.
 
@@ -10905,16 +12366,16 @@ Deprecated: 1.32: This function is not thread-safe.
 </description>
 <parameters>
 <parameter name="fontname">
-<parameter_description> an ascii string
+<parameter_description> an ASCII string
 </parameter_description>
 </parameter>
 <parameter name="families">
-<parameter_description> will be set to an array of font family names.
-this array is owned by pango and should not be freed.
+<parameter_description> will be set to an array of
+font family names. This array is owned by Pango and should not be freed
 </parameter_description>
 </parameter>
 <parameter name="n_families">
-<parameter_description> will be set to the length of the @families array.
+<parameter_description> will be set to the length of the @families array
 </parameter_description>
 </parameter>
 </parameters>
@@ -10930,11 +12391,11 @@ Deprecated: 1.38
 </description>
 <parameters>
 <parameter name="map">
-<parameter_description> a #PangoMap
+<parameter_description> a `PangoMap`
 </parameter_description>
 </parameter>
 <parameter name="script">
-<parameter_description> a #PangoScript
+<parameter_description> a `PangoScript`
 </parameter_description>
 </parameter>
 </parameters>
@@ -10953,11 +12414,11 @@ Deprecated: 1.38
 </description>
 <parameters>
 <parameter name="map">
-<parameter_description> a #PangoMap
+<parameter_description> a `PangoMap`
 </parameter_description>
 </parameter>
 <parameter name="script">
-<parameter_description> a #PangoScript
+<parameter_description> a `PangoScript`
 </parameter_description>
 </parameter>
 <parameter name="exact_engines">
@@ -10976,8 +12437,10 @@ approximately handle this script.
 
 <function name="pango_markup_parser_finish">
 <description>
-After feeding a pango markup parser some data with g_markup_parse_context_parse(),
-use this function to get the list of pango attributes and text out of the
+Finishes parsing markup.
+
+After feeding a Pango markup parser some data with g_markup_parse_context_parse(),
+use this function to get the list of attributes and text out of the
 markup. This function will not free @context, use g_markup_parse_context_free()
 to do so.
 
@@ -10986,23 +12449,23 @@ Since: 1.31.0
 </description>
 <parameters>
 <parameter name="context">
-<parameter_description> A valid parse context that was returned from pango_markup_parser_new()
+<parameter_description> A valid parse context that was returned from [func@markup_parser_new]
 </parameter_description>
 </parameter>
 <parameter name="attr_list">
-<parameter_description> address of return location for a #PangoAttrList, or %NULL
+<parameter_description> address of return location for a `PangoAttrList`
 </parameter_description>
 </parameter>
 <parameter name="text">
-<parameter_description> address of return location for text with tags stripped, or %NULL
+<parameter_description> address of return location for text with tags stripped
 </parameter_description>
 </parameter>
 <parameter name="accel_char">
-<parameter_description> address of return location for accelerator char, or %NULL
+<parameter_description> address of return location for accelerator char
 </parameter_description>
 </parameter>
 <parameter name="error">
-<parameter_description> address of return location for errors, or %NULL
+<parameter_description> address of return location for errors
 </parameter_description>
 </parameter>
 </parameters>
@@ -11013,26 +12476,28 @@ Since: 1.31.0
 
 <function name="pango_markup_parser_new">
 <description>
-Parses marked-up text (see
-&lt;link linkend=&quot;PangoMarkupFormat&quot;&gt;markup format&lt;/link&gt;) to create
-a plain-text string and an attribute list.
+Incrementally parses marked-up text to create a plain-text string
+and an attribute list.
+
+See the [Pango Markup](pango_markup.html) docs for details about the
+supported markup.
 
 If @accel_marker is nonzero, the given character will mark the
 character following it as an accelerator. For example, @accel_marker
 might be an ampersand or underscore. All characters marked
 as an accelerator will receive a %PANGO_UNDERLINE_LOW attribute,
 and the first character so marked will be returned in @accel_char,
-when calling finish(). Two @accel_marker characters following each
-other produce a single literal @accel_marker character.
+when calling [func@markup_parser_finish]. Two @accel_marker characters
+following each other produce a single literal @accel_marker character.
 
 To feed markup to the parser, use g_markup_parse_context_parse()
-on the returned #GMarkupParseContext. When done with feeding markup
-to the parser, use pango_markup_parser_finish() to get the data out
+on the returned `GMarkupParseContext`. When done with feeding markup
+to the parser, use [func@markup_parser_finish] to get the data out
 of it, and then use g_markup_parse_context_free() to free it.
 
-This function is designed for applications that read pango markup
-from streams. To simply parse a string containing pango markup,
-the simpler pango_parse_markup() API is recommended instead.
+This function is designed for applications that read Pango markup
+from streams. To simply parse a string containing Pango markup,
+the [func@parse_markup] API is recommended instead.
 
 Since: 1.31.0
 
@@ -11043,7 +12508,7 @@ Since: 1.31.0
 </parameter_description>
 </parameter>
 </parameters>
-<return> a #GMarkupParseContext that should be
+<return> a `GMarkupParseContext` that should be
 destroyed with g_markup_parse_context_free().
 
 </return>
@@ -11060,11 +12525,11 @@ Since: 1.6
 </description>
 <parameters>
 <parameter name="matrix">
-<parameter_description> a #PangoMatrix
+<parameter_description> a `PangoMatrix`
 </parameter_description>
 </parameter>
 <parameter name="new_matrix">
-<parameter_description> a #PangoMatrix
+<parameter_description> a `PangoMatrix`
 </parameter_description>
 </parameter>
 </parameters>
@@ -11073,34 +12538,32 @@ Since: 1.6
 
 <function name="pango_matrix_copy">
 <description>
-Copies a #PangoMatrix.
+Copies a `PangoMatrix`.
 
 Since: 1.6
 
 </description>
 <parameters>
 <parameter name="matrix">
-<parameter_description> a #PangoMatrix, may be %NULL
+<parameter_description> a `PangoMatrix`
 </parameter_description>
 </parameter>
 </parameters>
-<return> the newly allocated #PangoMatrix, which
-should be freed with pango_matrix_free(), or %NULL if
-@matrix was %NULL.
+<return> the newly allocated `PangoMatrix`
 
 </return>
 </function>
 
 <function name="pango_matrix_free">
 <description>
-Free a #PangoMatrix created with pango_matrix_copy().
+Free a `PangoMatrix`.
 
 Since: 1.6
 
 </description>
 <parameters>
 <parameter name="matrix">
-<parameter_description> a #PangoMatrix, may be %NULL
+<parameter_description> a `PangoMatrix`, may be %NULL
 </parameter_description>
 </parameter>
 </parameters>
@@ -11110,16 +12573,17 @@ Since: 1.6
 <function name="pango_matrix_get_font_scale_factor">
 <description>
 Returns the scale factor of a matrix on the height of the font.
+
 That is, the scale factor in the direction perpendicular to the
 vector that the X coordinate is mapped to.  If the scale in the X
-coordinate is needed as well, use pango_matrix_get_font_scale_factors().
+coordinate is needed as well, use [method@Pango.Matrix.get_font_scale_factors].
 
 Since: 1.12
 
 </description>
 <parameters>
 <parameter name="matrix">
-<parameter_description> a #PangoMatrix, may be %NULL
+<parameter_description> a `PangoMatrix`, may be %NULL
 </parameter_description>
 </parameter>
 </parameters>
@@ -11132,6 +12596,7 @@ or 1.0 if @matrix is %NULL.
 <function name="pango_matrix_get_font_scale_factors">
 <description>
 Calculates the scale factor of a matrix on the width and height of the font.
+
 That is, @xscale is the scale factor in the direction of the X coordinate,
 and @yscale is the scale factor in the direction perpendicular to the
 vector that the X coordinate is mapped to.
@@ -11143,15 +12608,15 @@ Since: 1.38
 </description>
 <parameters>
 <parameter name="matrix">
-<parameter_description> a #PangoMatrix, or %NULL
+<parameter_description> a `PangoMatrix`
 </parameter_description>
 </parameter>
 <parameter name="xscale">
-<parameter_description> output scale factor in the x direction, or %NULL
+<parameter_description> output scale factor in the x direction
 </parameter_description>
 </parameter>
 <parameter name="yscale">
-<parameter_description> output scale factor perpendicular to the x direction, or %NULL
+<parameter_description> output scale factor perpendicular to the x direction
 </parameter_description>
 </parameter>
 </parameters>
@@ -11169,7 +12634,7 @@ Since: 1.6
 </description>
 <parameters>
 <parameter name="matrix">
-<parameter_description> a #PangoMatrix
+<parameter_description> a `PangoMatrix`
 </parameter_description>
 </parameter>
 <parameter name="degrees">
@@ -11192,7 +12657,7 @@ Since: 1.6
 </description>
 <parameters>
 <parameter name="matrix">
-<parameter_description> a #PangoMatrix
+<parameter_description> a `PangoMatrix`
 </parameter_description>
 </parameter>
 <parameter name="scale_x">
@@ -11209,15 +12674,16 @@ Since: 1.6
 
 <function name="pango_matrix_transform_distance">
 <description>
-Transforms the distance vector (@dx,@dy) by @matrix. This is
-similar to pango_matrix_transform_point() except that the translation
-components of the transformation are ignored. The calculation of
-the returned vector is as follows:
+Transforms the distance vector (@dx,@dy) by @matrix.
+
+This is similar to [method@Pango.Matrix.transform_point],
+except that the translation components of the transformation
+are ignored. The calculation of the returned vector is as follows:
 
-&lt;programlisting&gt;
+```
 dx2 = dx1 * xx + dy1 * xy;
 dy2 = dx1 * yx + dy1 * yy;
-&lt;/programlisting&gt;
+```
 
 Affine transformations are position invariant, so the same vector
 always transforms to the same vector. If (@x1,@y1) transforms
@@ -11229,7 +12695,7 @@ Since: 1.16
 </description>
 <parameters>
 <parameter name="matrix">
-<parameter_description> a #PangoMatrix, or %NULL
+<parameter_description> a `PangoMatrix`
 </parameter_description>
 </parameter>
 <parameter name="dx">
@@ -11247,27 +12713,26 @@ Since: 1.16
 <function name="pango_matrix_transform_pixel_rectangle">
 <description>
 First transforms the @rect using @matrix, then calculates the bounding box
-of the transformed rectangle.  The rectangle should be in device units
-(pixels).
+of the transformed rectangle.
 
 This function is useful for example when you want to draw a rotated
 @PangoLayout to an image buffer, and want to know how large the image
 should be and how much you should shift the layout when rendering.
 
-For better accuracy, you should use pango_matrix_transform_rectangle() on
-original rectangle in Pango units and convert to pixels afterward
-using pango_extents_to_pixels()'s first argument.
+For better accuracy, you should use [method@Pango.Matrix.transform_rectangle]
+on original rectangle in Pango units and convert to pixels afterward
+using [func@extents_to_pixels]'s first argument.
 
 Since: 1.16
 
 </description>
 <parameters>
 <parameter name="matrix">
-<parameter_description> a #PangoMatrix, or %NULL
+<parameter_description> a `PangoMatrix`
 </parameter_description>
 </parameter>
 <parameter name="rect">
-<parameter_description> in/out bounding box in device units, or %NULL
+<parameter_description> in/out bounding box in device units
 </parameter_description>
 </parameter>
 </parameters>
@@ -11283,7 +12748,7 @@ Since: 1.16
 </description>
 <parameters>
 <parameter name="matrix">
-<parameter_description> a #PangoMatrix, or %NULL
+<parameter_description> a `PangoMatrix`
 </parameter_description>
 </parameter>
 <parameter name="x">
@@ -11301,14 +12766,14 @@ Since: 1.16
 <function name="pango_matrix_transform_rectangle">
 <description>
 First transforms @rect using @matrix, then calculates the bounding box
-of the transformed rectangle.  The rectangle should be in Pango units.
+of the transformed rectangle.
 
 This function is useful for example when you want to draw a rotated
 @PangoLayout to an image buffer, and want to know how large the image
 should be and how much you should shift the layout when rendering.
 
 If you have a rectangle in device units (pixels), use
-pango_matrix_transform_pixel_rectangle().
+[method@Pango.Matrix.transform_pixel_rectangle].
 
 If you have the rectangle in Pango units and want to convert to
 transformed pixel bounding box, it is more accurate to transform it first
@@ -11324,11 +12789,11 @@ Since: 1.16
 </description>
 <parameters>
 <parameter name="matrix">
-<parameter_description> a #PangoMatrix, or %NULL
+<parameter_description> a `PangoMatrix`
 </parameter_description>
 </parameter>
 <parameter name="rect">
-<parameter_description> in/out bounding box in Pango units, or %NULL
+<parameter_description> in/out bounding box in Pango units
 </parameter_description>
 </parameter>
 </parameters>
@@ -11346,7 +12811,7 @@ Since: 1.6
 </description>
 <parameters>
 <parameter name="matrix">
-<parameter_description> a #PangoMatrix
+<parameter_description> a `PangoMatrix`
 </parameter_description>
 </parameter>
 <parameter name="tx">
@@ -11370,7 +12835,7 @@ Deprecated: 1.38
 </description>
 <parameters>
 <parameter name="module">
-<parameter_description> a #PangoIncludedModule
+<parameter_description> a `PangoIncludedModule`
 </parameter_description>
 </parameter>
 </parameters>
@@ -11379,19 +12844,21 @@ Deprecated: 1.38
 
 <function name="pango_ot_buffer_add_glyph">
 <description>
-Appends a glyph to a #PangoOTBuffer, with @properties identifying which
-features should be applied on this glyph.  See pango_ot_ruleset_add_feature().
+Appends a glyph to a `PangoOTBuffer`, with @properties identifying which
+features should be applied on this glyph.
+
+See [method@PangoOT.Ruleset.add_feature].
 
 Since: 1.4
 
 </description>
 <parameters>
 <parameter name="buffer">
-<parameter_description> a #PangoOTBuffer
+<parameter_description> a `PangoOTBuffer`
 </parameter_description>
 </parameter>
 <parameter name="glyph">
-<parameter_description> the glyph index to add, like a #PangoGlyph
+<parameter_description> the glyph index to add, like a `PangoGlyph`
 </parameter_description>
 </parameter>
 <parameter name="properties">
@@ -11408,14 +12875,14 @@ Since: 1.4
 
 <function name="pango_ot_buffer_clear">
 <description>
-Empties a #PangoOTBuffer, make it ready to add glyphs to.
+Empties a `PangoOTBuffer`, make it ready to add glyphs to.
 
 Since: 1.4
 
 </description>
 <parameters>
 <parameter name="buffer">
-<parameter_description> a #PangoOTBuffer
+<parameter_description> a `PangoOTBuffer`
 </parameter_description>
 </parameter>
 </parameters>
@@ -11424,14 +12891,14 @@ Since: 1.4
 
 <function name="pango_ot_buffer_destroy">
 <description>
-Destroys a #PangoOTBuffer and free all associated memory.
+Destroys a `PangoOTBuffer` and free all associated memory.
 
 Since: 1.4
 
 </description>
 <parameters>
 <parameter name="buffer">
-<parameter_description> a #PangoOTBuffer
+<parameter_description> a `PangoOTBuffer`
 </parameter_description>
 </parameter>
 </parameters>
@@ -11440,26 +12907,26 @@ Since: 1.4
 
 <function name="pango_ot_buffer_get_glyphs">
 <description>
-Gets the glyph array contained in a #PangoOTBuffer.  The glyphs are
-owned by the buffer and should not be freed, and are only valid as long
-as buffer is not modified.
+Gets the glyph array contained in a `PangoOTBuffer`.
+
+The glyphs are owned by the buffer and should not be freed,
+and are only valid as long as buffer is not modified.
 
 Since: 1.4
 
 </description>
 <parameters>
 <parameter name="buffer">
-<parameter_description> a #PangoOTBuffer
+<parameter_description> a `PangoOTBuffer`
 </parameter_description>
 </parameter>
 <parameter name="glyphs">
 <parameter_description> location to
-store the array of glyphs, or %NULL
+store the array of glyphs
 </parameter_description>
 </parameter>
 <parameter name="n_glyphs">
-<parameter_description> location to store the number of
-glyphs, or %NULL
+<parameter_description> location to store the number of glyphs
 </parameter_description>
 </parameter>
 </parameters>
@@ -11468,39 +12935,41 @@ glyphs, or %NULL
 
 <function name="pango_ot_buffer_new">
 <description>
-Creates a new #PangoOTBuffer for the given OpenType font.
+Creates a new `PangoOTBuffer` for the given OpenType font.
 
 Since: 1.4
 
 </description>
 <parameters>
 <parameter name="font">
-<parameter_description> a #PangoFcFont
+<parameter_description> a `PangoFcFont`
 </parameter_description>
 </parameter>
 </parameters>
-<return> the newly allocated #PangoOTBuffer, which should
-be freed with pango_ot_buffer_destroy().
+<return> the newly allocated `PangoOTBuffer`, which should
+be freed with [method@PangoOT.Buffer.destroy].
 
 </return>
 </function>
 
 <function name="pango_ot_buffer_output">
 <description>
-Exports the glyphs in a #PangoOTBuffer into a #PangoGlyphString.  This is
-typically used after the OpenType layout processing is over, to convert the
-resulting glyphs into a generic Pango glyph string.
+Exports the glyphs in a `PangoOTBuffer` into a `PangoGlyphString`.
+
+This is typically used after the OpenType layout processing
+is over, to convert the resulting glyphs into a generic Pango
+glyph string.
 
 Since: 1.4
 
 </description>
 <parameters>
 <parameter name="buffer">
-<parameter_description> a #PangoOTBuffer
+<parameter_description> a `PangoOTBuffer`
 </parameter_description>
 </parameter>
 <parameter name="glyphs">
-<parameter_description> a #PangoGlyphString
+<parameter_description> a `PangoGlyphString`
 </parameter_description>
 </parameter>
 </parameters>
@@ -11509,15 +12978,17 @@ Since: 1.4
 
 <function name="pango_ot_buffer_set_rtl">
 <description>
-Sets whether glyphs will be rendered right-to-left.  This setting
-is needed for proper horizontal positioning of right-to-left scripts.
+Sets whether glyphs will be rendered right-to-left.
+
+This setting is needed for proper horizontal positioning
+of right-to-left scripts.
 
 Since: 1.4
 
 </description>
 <parameters>
 <parameter name="buffer">
-<parameter_description> a #PangoOTBuffer
+<parameter_description> a `PangoOTBuffer`
 </parameter_description>
 </parameter>
 <parameter name="rtl">
@@ -11531,6 +13002,7 @@ Since: 1.4
 <function name="pango_ot_buffer_set_zero_width_marks">
 <description>
 Sets whether characters with a mark class should be forced to zero width.
+
 This setting is needed for proper positioning of Arabic accents,
 but will produce incorrect results with standard OpenType Indic
 fonts.
@@ -11540,12 +13012,12 @@ Since: 1.6
 </description>
 <parameters>
 <parameter name="buffer">
-<parameter_description> a #PangoOTBuffer
+<parameter_description> a `PangoOTBuffer`
 </parameter_description>
 </parameter>
 <parameter name="zero_width_marks">
 <parameter_description> %TRUE if characters with a mark class should
-be forced to zero width.
+be forced to zero width
 </parameter_description>
 </parameter>
 </parameters>
@@ -11554,101 +13026,104 @@ be forced to zero width.
 
 <function name="pango_ot_info_find_feature">
 <description>
-Finds the index of a feature.  If the feature is not found, sets
-@feature_index to PANGO_OT_NO_FEATURE, which is safe to pass to
-pango_ot_ruleset_add_feature() and similar functions.
+Finds the index of a feature.
+
+If the feature is not found, sets @feature_index to PANGO_OT_NO_FEATURE,
+which is safe to pass to [method@PangoOT.Ruleset.add_feature] and similar
+functions.
 
-In the future, this may set @feature_index to an special value that if used
-in pango_ot_ruleset_add_feature() will ask Pango to synthesize the
-requested feature based on Unicode properties and data.  However, this
-function will still return %FALSE in those cases.  So, users may want to
+In the future, this may set @feature_index to an special value that if
+used in [method@PangoOT.Ruleset.add_feature] will ask Pango to synthesize
+the requested feature based on Unicode properties and data. However, this
+function will still return %FALSE in those cases. So, users may want to
 ignore the return value of this function in certain cases.
 
 
 </description>
 <parameters>
 <parameter name="info">
-<parameter_description> a #PangoOTInfo.
+<parameter_description> a `PangoOTInfo`
 </parameter_description>
 </parameter>
 <parameter name="table_type">
-<parameter_description> the table type to obtain information about.
+<parameter_description> the table type to obtain information about
 </parameter_description>
 </parameter>
 <parameter name="feature_tag">
-<parameter_description> the tag of the feature to find.
+<parameter_description> the tag of the feature to find
 </parameter_description>
 </parameter>
 <parameter name="script_index">
-<parameter_description> the index of the script.
+<parameter_description> the index of the script
 </parameter_description>
 </parameter>
 <parameter name="language_index">
 <parameter_description> the index of the language whose features are searched,
-or %PANGO_OT_DEFAULT_LANGUAGE to use the default language of the script.
+or %PANGO_OT_DEFAULT_LANGUAGE to use the default language of the script
 </parameter_description>
 </parameter>
 <parameter name="feature_index">
 <parameter_description> location to store the index of
-the feature, or %NULL.
+the feature
 </parameter_description>
 </parameter>
 </parameters>
-<return> %TRUE if the feature was found.
+<return> %TRUE if the feature was found
 </return>
 </function>
 
 <function name="pango_ot_info_find_language">
 <description>
 Finds the index of a language and its required feature index.
-If the language is not found, sets @language_index to
-PANGO_OT_DEFAULT_LANGUAGE and the required feature of the default language
-system is returned in required_feature_index.  For best compatibility with
-some fonts, also searches the language system tag 'dflt' before falling
-back to the default language system, but that is transparent to the user.
-The user can simply ignore the return value of this function to
-automatically fall back to the default language system.
+
+If the language is not found, sets @language_index to %PANGO_OT_DEFAULT_LANGUAGE
+and the required feature of the default language system is returned in
+required_feature_index. For best compatibility with some fonts, also
+searches the language system tag 'dflt' before falling back to the default
+language system, but that is transparent to the user. The user can simply
+ignore the return value of this function to automatically fall back to the
+default language system.
 
 
 </description>
 <parameters>
 <parameter name="info">
-<parameter_description> a #PangoOTInfo.
+<parameter_description> a `PangoOTInfo`
 </parameter_description>
 </parameter>
 <parameter name="table_type">
-<parameter_description> the table type to obtain information about.
+<parameter_description> the table type to obtain information about
 </parameter_description>
 </parameter>
 <parameter name="script_index">
-<parameter_description> the index of the script whose languages are searched.
+<parameter_description> the index of the script whose languages are searched
 </parameter_description>
 </parameter>
 <parameter name="language_tag">
-<parameter_description> the tag of the language to find.
+<parameter_description> the tag of the language to find
 </parameter_description>
 </parameter>
 <parameter name="language_index">
-<parameter_description> location to store the index of
-the language, or %NULL.
+<parameter_description> location to store the index of the language
 </parameter_description>
 </parameter>
 <parameter name="required_feature_index">
 <parameter_description> location to store the
-required feature index of the language, or %NULL.
+required feature index of the language
 </parameter_description>
 </parameter>
 </parameters>
-<return> %TRUE if the language was found.
+<return> %TRUE if the language was found
 </return>
 </function>
 
 <function name="pango_ot_info_find_script">
 <description>
-Finds the index of a script.  If not found, tries to find the 'DFLT'
-and then 'dflt' scripts and return the index of that in @script_index.
-If none of those is found either, %PANGO_OT_NO_SCRIPT is placed in
-@script_index.
+Finds the index of a script.
+
+If not found, tries to find the 'DFLT' and then 'dflt' scripts and
+return the index of that in @script_index. If none of those is found
+either, %PANGO_OT_NO_SCRIPT is placed in @script_index.
 
 All other functions taking an input script_index parameter know
 how to handle %PANGO_OT_NO_SCRIPT, so one can ignore the return
@@ -11659,42 +13134,41 @@ fallback to the 'DFLT'/'dflt' script.
 </description>
 <parameters>
 <parameter name="info">
-<parameter_description> a #PangoOTInfo.
+<parameter_description> a `PangoOTInfo`
 </parameter_description>
 </parameter>
 <parameter name="table_type">
-<parameter_description> the table type to obtain information about.
+<parameter_description> the table type to obtain information about
 </parameter_description>
 </parameter>
 <parameter name="script_tag">
-<parameter_description> the tag of the script to find.
+<parameter_description> the tag of the script to find
 </parameter_description>
 </parameter>
 <parameter name="script_index">
-<parameter_description> location to store the index of the
-script, or %NULL.
+<parameter_description> location to store the index of the script
 </parameter_description>
 </parameter>
 </parameters>
-<return> %TRUE if the script was found.
+<return> %TRUE if the script was found
 </return>
 </function>
 
 <function name="pango_ot_info_get">
 <description>
-Returns the #PangoOTInfo structure for the given FreeType font face.
+Returns the `PangoOTInfo` structure for the given FreeType font face.
 
 Since: 1.2
 
 </description>
 <parameters>
 <parameter name="face">
-<parameter_description> a &lt;type&gt;FT_Face&lt;/type&gt;.
+<parameter_description> a `FT_Face`
 </parameter_description>
 </parameter>
 </parameters>
-<return> the #PangoOTInfo for @face. This object
-will have the same lifetime as @face.
+<return> the `PangoOTInfo` for @face.
+This object will have the same lifetime as @face.
 
 </return>
 </function>
@@ -11707,30 +13181,30 @@ Obtains the list of features for the given language of the given script.
 </description>
 <parameters>
 <parameter name="info">
-<parameter_description> a #PangoOTInfo.
+<parameter_description> a `PangoOTInfo`
 </parameter_description>
 </parameter>
 <parameter name="table_type">
-<parameter_description> the table type to obtain information about.
+<parameter_description> the table type to obtain information about
 </parameter_description>
 </parameter>
 <parameter name="tag">
-<parameter_description> unused parameter.
+<parameter_description> unused parameter
 </parameter_description>
 </parameter>
 <parameter name="script_index">
-<parameter_description> the index of the script to obtain information about.
+<parameter_description> the index of the script to obtain information about
 </parameter_description>
 </parameter>
 <parameter name="language_index">
 <parameter_description> the index of the language to list features for, or
 %PANGO_OT_DEFAULT_LANGUAGE, to list features for the default
-language of the script.
+language of the script
 </parameter_description>
 </parameter>
 </parameters>
-<return> a newly-allocated zero-terminated array containing the tags of the
-available features.  Should be freed using g_free().
+<return> a newly-allocated zero-terminated
+array containing the tags of the available features
 </return>
 </function>
 
@@ -11742,24 +13216,24 @@ Obtains the list of available languages for a given script.
 </description>
 <parameters>
 <parameter name="info">
-<parameter_description> a #PangoOTInfo.
+<parameter_description> a `PangoOTInfo`
 </parameter_description>
 </parameter>
 <parameter name="table_type">
-<parameter_description> the table type to obtain information about.
+<parameter_description> the table type to obtain information about
 </parameter_description>
 </parameter>
 <parameter name="script_index">
-<parameter_description> the index of the script to list languages for.
+<parameter_description> the index of the script to list languages for
 </parameter_description>
 </parameter>
 <parameter name="language_tag">
-<parameter_description> unused parameter.
+<parameter_description> unused parameter
 </parameter_description>
 </parameter>
 </parameters>
-<return> a newly-allocated zero-terminated array containing the tags of the
-available languages.  Should be freed using g_free().
+<return> a newly-allocated zero-terminated
+array containing the tags of the available languages
 </return>
 </function>
 
@@ -11771,16 +13245,16 @@ Obtains the list of available scripts.
 </description>
 <parameters>
 <parameter name="info">
-<parameter_description> a #PangoOTInfo.
+<parameter_description> a `PangoOTInfo`
 </parameter_description>
 </parameter>
 <parameter name="table_type">
-<parameter_description> the table type to obtain information about.
+<parameter_description> the table type to obtain information about
 </parameter_description>
 </parameter>
 </parameters>
-<return> a newly-allocated zero-terminated array containing the tags of the
-available scripts.  Should be freed using g_free().
+<return> a newly-allocated zero-terminated
+array containing the tags of the available scripts
 </return>
 </function>
 
@@ -11791,20 +13265,20 @@ Adds a feature to the ruleset.
 </description>
 <parameters>
 <parameter name="ruleset">
-<parameter_description> a #PangoOTRuleset.
+<parameter_description> a `PangoOTRuleset`
 </parameter_description>
 </parameter>
 <parameter name="table_type">
-<parameter_description> the table type to add a feature to.
+<parameter_description> the table type to add a feature to
 </parameter_description>
 </parameter>
 <parameter name="feature_index">
-<parameter_description> the index of the feature to add.
+<parameter_description> the index of the feature to add
 </parameter_description>
 </parameter>
 <parameter name="property_bit">
-<parameter_description> the property bit to use for this feature. Used to identify
-the glyphs that this feature should be applied to, or
+<parameter_description> the property bit to use for this feature. Used to
+identify the glyphs that this feature should be applied to, or
 %PANGO_OT_ALL_GLYPHS if it should be applied to all glyphs.
 </parameter_description>
 </parameter>
@@ -11815,9 +13289,10 @@ the glyphs that this feature should be applied to, or
 <function name="pango_ot_ruleset_description_copy">
 <description>
 Creates a copy of @desc, which should be freed with
-pango_ot_ruleset_description_free(). Primarily used internally
-by pango_ot_ruleset_get_for_description() to cache rulesets for
-ruleset descriptions.
+[method PangoOT RulesetDescription free].
+
+Primarily used internally by [func@PangoOT.Ruleset.get_for_description]
+to cache rulesets for ruleset descriptions.
 
 Since: 1.18
 
@@ -11828,8 +13303,7 @@ Since: 1.18
 </parameter_description>
 </parameter>
 </parameters>
-<return> the newly allocated #PangoOTRulesetDescription, which
-should be freed with pango_ot_ruleset_description_free().
+<return> the newly allocated `PangoOTRulesetDescription`
 
 </return>
 </function>
@@ -11837,12 +13311,14 @@ should be freed with pango_ot_ruleset_description_free().
 <function name="pango_ot_ruleset_description_equal">
 <description>
 Compares two ruleset descriptions for equality.
+
 Two ruleset descriptions are considered equal if the rulesets
-they describe are provably identical.  This means that their
-script, language, and all feature sets should be equal.  For static feature
-sets, the array addresses are compared directly, while for other
-features, the list of features is compared one by one.
-(Two ruleset descriptions may result in identical rulesets
+they describe are provably identical. This means that their
+script, language, and all feature sets should be equal.
+
+For static feature sets, the array addresses are compared directly,
+while for other features, the list of features is compared one by
+one.(Two ruleset descriptions may result in identical rulesets
 being created, but still compare %FALSE.)
 
 Since: 1.18
@@ -11859,14 +13335,14 @@ Since: 1.18
 </parameter>
 </parameters>
 <return> %TRUE if two ruleset descriptions are identical,
-%FALSE otherwise.
+%FALSE otherwise
 
 </return>
 </function>
 
 <function name="pango_ot_ruleset_description_free">
 <description>
-Frees a ruleset description allocated by 
+Frees a ruleset description allocated by
 pango_ot_ruleset_description_copy().
 
 Since: 1.18
@@ -11874,7 +13350,7 @@ Since: 1.18
 </description>
 <parameters>
 <parameter name="desc">
-<parameter_description> an allocated #PangoOTRulesetDescription
+<parameter_description> an allocated `PangoOTRulesetDescription`
 </parameter_description>
 </parameter>
 </parameters>
@@ -11883,7 +13359,7 @@ Since: 1.18
 
 <function name="pango_ot_ruleset_description_hash">
 <description>
-Computes a hash of a #PangoOTRulesetDescription structure suitable
+Computes a hash of a `PangoOTRulesetDescription` structure suitable
 to be used, for example, as an argument to g_hash_table_new().
 
 Since: 1.18
@@ -11895,7 +13371,7 @@ Since: 1.18
 </parameter_description>
 </parameter>
 </parameters>
-<return> the hash value.
+<return> the hash value
 
 </return>
 </function>
@@ -11909,21 +13385,19 @@ Since: 1.18
 </description>
 <parameters>
 <parameter name="ruleset">
-<parameter_description> a #PangoOTRuleset.
+<parameter_description> a `PangoOTRuleset`
 </parameter_description>
 </parameter>
 <parameter name="n_gsub_features">
-<parameter_description> location to store number of
-GSUB features, or %NULL.
+<parameter_description> location to store number of GSUB features
 </parameter_description>
 </parameter>
 <parameter name="n_gpos_features">
-<parameter_description> location to store number of
-GPOS features, or %NULL.
+<parameter_description> location to store number of GPOS features
 </parameter_description>
 </parameter>
 </parameters>
-<return> Total number of features in the @ruleset.
+<return> Total number of features in the @ruleset
 
 </return>
 </function>
@@ -11931,8 +13405,10 @@ GPOS features, or %NULL.
 <function name="pango_ot_ruleset_get_for_description">
 <description>
 Returns a ruleset for the given OpenType info and ruleset
-description.  Rulesets are created on demand using
-pango_ot_ruleset_new_from_description().
+description.
+
+Rulesets are created on demand using
+[ctor@PangoOT.Ruleset.new_from_description].
 The returned ruleset should not be modified or destroyed.
 
 The static feature map members of @desc should be alive as
@@ -11943,15 +13419,15 @@ Since: 1.18
 </description>
 <parameters>
 <parameter name="info">
-<parameter_description> a #PangoOTInfo.
+<parameter_description> a `PangoOTInfo`
 </parameter_description>
 </parameter>
 <parameter name="desc">
-<parameter_description> a #PangoOTRulesetDescription.
+<parameter_description> a `PangoOTRulesetDescription`
 </parameter_description>
 </parameter>
 </parameters>
-<return> the #PangoOTRuleset for @desc. This object will have
+<return> the `PangoOTRuleset` for @desc. This object will have
 the same lifetime as @info.
 
 </return>
@@ -11960,132 +13436,124 @@ the same lifetime as @info.
 <function name="pango_ot_ruleset_maybe_add_feature">
 <description>
 This is a convenience function that first tries to find the feature
-using pango_ot_info_find_feature() and the ruleset script and language
-passed to pango_ot_ruleset_new_for(),
-and if the feature is found, adds it to the ruleset.
+using [method PangoOT Info.find_feature] and the ruleset script and
+language passed to [ctor@PangoOT.Ruleset.new_for] and if the feature
+is found, adds it to the ruleset.
 
-If @ruleset was not created using pango_ot_ruleset_new_for(), this function
-does nothing.
+If @ruleset was not created using [ctor@PangoOT.Ruleset.new_for],
+this function does nothing.
 
 Since: 1.18
 
 </description>
 <parameters>
 <parameter name="ruleset">
-<parameter_description> a #PangoOTRuleset.
+<parameter_description> a `PangoOTRuleset`
 </parameter_description>
 </parameter>
 <parameter name="table_type">
-<parameter_description> the table type to add a feature to.
+<parameter_description> the table type to add a feature to
 </parameter_description>
 </parameter>
 <parameter name="feature_tag">
-<parameter_description> the tag of the feature to add.
+<parameter_description> the tag of the feature to add
 </parameter_description>
 </parameter>
 <parameter name="property_bit">
-<parameter_description> the property bit to use for this feature. Used to identify
-the glyphs that this feature should be applied to, or
+<parameter_description> the property bit to use for this feature. Used to
+identify the glyphs that this feature should be applied to, or
 %PANGO_OT_ALL_GLYPHS if it should be applied to all glyphs.
 </parameter_description>
 </parameter>
 </parameters>
 <return> %TRUE if the feature was found and added to ruleset,
-%FALSE otherwise.
+%FALSE otherwise
 
 </return>
 </function>
 
 <function name="pango_ot_ruleset_maybe_add_features">
 <description>
-This is a convenience function that 
-for each feature in the feature map array @features
-converts the feature name to a #PangoOTTag feature tag using PANGO_OT_TAG_MAKE()
-and calls pango_ot_ruleset_maybe_add_feature() on it.
+This is a convenience function that for each feature in the feature map
+array @features converts the feature name to a `PangoOTTag` feature tag
+using PANGO_OT_TAG_MAKE() and calls [method@PangoOT.Ruleset.maybe_add_feature]
+on it.
 
 Since: 1.18
 
 </description>
 <parameters>
 <parameter name="ruleset">
-<parameter_description> a #PangoOTRuleset.
+<parameter_description> a `PangoOTRuleset`
 </parameter_description>
 </parameter>
 <parameter name="table_type">
-<parameter_description> the table type to add features to.
+<parameter_description> the table type to add features to
 </parameter_description>
 </parameter>
 <parameter name="features">
-<parameter_description> array of feature name and property bits to add.
+<parameter_description> array of feature name and property bits to add
 </parameter_description>
 </parameter>
 <parameter name="n_features">
-<parameter_description> number of feature records in @features array.
+<parameter_description> number of feature records in @features array
 </parameter_description>
 </parameter>
 </parameters>
 <return> The number of features in @features that were found
-and added to @ruleset.
+and added to @ruleset
 
 </return>
 </function>
 
 <function name="pango_ot_ruleset_new">
 <description>
-Creates a new #PangoOTRuleset for the given OpenType info.
+Creates a new `PangoOTRuleset` for the given OpenType info.
 
 
 </description>
 <parameters>
 <parameter name="info">
-<parameter_description> a #PangoOTInfo.
+<parameter_description> a `PangoOTInfo`
 </parameter_description>
 </parameter>
 </parameters>
-<return> the newly allocated #PangoOTRuleset, which
-should be freed with g_object_unref().
+<return> the newly allocated `PangoOTRuleset`
 </return>
 </function>
 
 <function name="pango_ot_ruleset_new_for">
 <description>
-Creates a new #PangoOTRuleset for the given OpenType info, script, and
+Creates a new `PangoOTRuleset` for the given OpenType info, script, and
 language.
 
 This function is part of a convenience scheme that highly simplifies
-using a #PangoOTRuleset to represent features for a specific pair of script
+using a `PangoOTRuleset` to represent features for a specific pair of script
 and language.  So one can use this function passing in the script and
 language of interest, and later try to add features to the ruleset by just
 specifying the feature name or tag, without having to deal with finding
 script, language, or feature indices manually.
 
-In excess to what pango_ot_ruleset_new() does, this function will:
-&lt;itemizedlist&gt;
-&lt;listitem&gt;
-Find the #PangoOTTag script and language tags associated with
-@script and @language using pango_ot_tag_from_script() and
-pango_ot_tag_from_language(),
-&lt;/listitem&gt;
-&lt;listitem&gt;
-For each of table types %PANGO_OT_TABLE_GSUB and %PANGO_OT_TABLE_GPOS,
+In addition to what [ctor PangoOT Ruleset new] does, this function will:
+
+* Find the `PangoOTTag` script and language tags associated with
+@script and @language using [func@PangoOT.tag_from_script] and
+[func@PangoOT.tag_from_language],
+
+* For each of table types %PANGO_OT_TABLE_GSUB and %PANGO_OT_TABLE_GPOS,
 find the script index of the script tag found and the language
 system index of the language tag found in that script system, using
-pango_ot_info_find_script() and pango_ot_info_find_language(),
-&lt;/listitem&gt;
-&lt;listitem&gt;
-For found language-systems, if they have required feature
-index, add that feature to the ruleset using
-pango_ot_ruleset_add_feature(),
-&lt;/listitem&gt;
-&lt;listitem&gt;
-Remember found script and language indices for both table types,
-and use them in future pango_ot_ruleset_maybe_add_feature() and
-pango_ot_ruleset_maybe_add_features().
-&lt;/listitem&gt;
-&lt;/itemizedlist&gt;
-
-Because of the way return values of pango_ot_info_find_script() and
-pango_ot_info_find_language() are ignored, this function automatically
+[method PangoOT Info.find_script] and [method PangoOT Info.find_language],
+
+* For found language-systems, if they have required feature index,
+add that feature to the ruleset using [method@PangoOT.Ruleset.add_feature],
+
+* Remember found script and language indices for both table types,
+and use them in future [method@PangoOT.Ruleset.maybe_add_feature] and
+[method@PangoOT.Ruleset.maybe_add_features].
+
+Because of the way return values of [method PangoOT Info.find_script] and
+[method PangoOT Info.find_language] are ignored, this function automatically
 finds and uses the 'DFLT' script and the default language-system.
 
 Since: 1.18
@@ -12093,32 +13561,31 @@ Since: 1.18
 </description>
 <parameters>
 <parameter name="info">
-<parameter_description> a #PangoOTInfo.
+<parameter_description> a `PangoOTInfo`
 </parameter_description>
 </parameter>
 <parameter name="script">
-<parameter_description> a #PangoScript.
+<parameter_description> a `PangoScript`
 </parameter_description>
 </parameter>
 <parameter name="language">
-<parameter_description> a #PangoLanguage.
+<parameter_description> a `PangoLanguage`
 </parameter_description>
 </parameter>
 </parameters>
-<return> the newly allocated #PangoOTRuleset, which
-should be freed with g_object_unref().
+<return> the newly allocated `PangoOTRuleset`
 
 </return>
 </function>
 
 <function name="pango_ot_ruleset_new_from_description">
 <description>
-Creates a new #PangoOTRuleset for the given OpenType infor and
+Creates a new `PangoOTRuleset` for the given OpenType info and
 matching the given ruleset description.
 
-This is a convenience function that calls pango_ot_ruleset_new_for() and
-adds the static GSUB/GPOS features to the resulting ruleset, followed by
-adding other features to both GSUB and GPOS.
+This is a convenience function that calls [ctor@PangoOT.Ruleset.new_for]
+and adds the static GSUB/GPOS features to the resulting ruleset,
+followed by adding other features to both GSUB and GPOS.
 
 The static feature map members of @desc should be alive as
 long as @info is.
@@ -12128,35 +13595,34 @@ Since: 1.18
 </description>
 <parameters>
 <parameter name="info">
-<parameter_description> a #PangoOTInfo.
+<parameter_description> a `PangoOTInfo`
 </parameter_description>
 </parameter>
 <parameter name="desc">
-<parameter_description> a #PangoOTRulesetDescription.
+<parameter_description> a `PangoOTRulesetDescription`
 </parameter_description>
 </parameter>
 </parameters>
-<return> the newly allocated #PangoOTRuleset, which
-should be freed with g_object_unref().
+<return> the newly allocated `PangoOTRuleset`
 
 </return>
 </function>
 
 <function name="pango_ot_ruleset_position">
 <description>
-Performs the OpenType GPOS positioning on @buffer using the features
-in @ruleset
+Performs the OpenType GPOS positioning on @buffer using
+the features in @ruleset.
 
 Since: 1.4
 
 </description>
 <parameters>
 <parameter name="ruleset">
-<parameter_description> a #PangoOTRuleset.
+<parameter_description> a `PangoOTRuleset`
 </parameter_description>
 </parameter>
 <parameter name="buffer">
-<parameter_description> a #PangoOTBuffer.
+<parameter_description> a `PangoOTBuffer`
 </parameter_description>
 </parameter>
 </parameters>
@@ -12165,19 +13631,19 @@ Since: 1.4
 
 <function name="pango_ot_ruleset_substitute">
 <description>
-Performs the OpenType GSUB substitution on @buffer using the features
-in @ruleset
+Performs the OpenType GSUB substitution on @buffer using
+the features in @ruleset.
 
 Since: 1.4
 
 </description>
 <parameters>
 <parameter name="ruleset">
-<parameter_description> a #PangoOTRuleset.
+<parameter_description> a `PangoOTRuleset`
 </parameter_description>
 </parameter>
 <parameter name="buffer">
-<parameter_description> a #PangoOTBuffer.
+<parameter_description> a `PangoOTBuffer`
 </parameter_description>
 </parameter>
 </parameters>
@@ -12193,11 +13659,11 @@ Since: 1.18
 </description>
 <parameters>
 <parameter name="language">
-<parameter_description> A #PangoLanguage, or %NULL
+<parameter_description> A `PangoLanguage`
 </parameter_description>
 </parameter>
 </parameters>
-<return> #PangoOTTag best matching @language or
+<return> `PangoOTTag` best matching @language or
 %PANGO_OT_TAG_DEFAULT_LANGUAGE if none found or if @language
 is %NULL.
 
@@ -12213,7 +13679,7 @@ The %PANGO_SCRIPT_COMMON, %PANGO_SCRIPT_INHERITED, and
 'DFLT' script tag that is also defined as
 %PANGO_OT_TAG_DEFAULT_SCRIPT.
 
-Note that multiple #PangoScript values may map to the same
+Note that multiple `PangoScript` values may map to the same
 OpenType script tag.  In particular, %PANGO_SCRIPT_HIRAGANA
 and %PANGO_SCRIPT_KATAKANA both map to the OT tag 'kana'.
 
@@ -12222,11 +13688,11 @@ Since: 1.18
 </description>
 <parameters>
 <parameter name="script">
-<parameter_description> A #PangoScript
+<parameter_description> A `PangoScript`
 </parameter_description>
 </parameter>
 </parameters>
-<return> #PangoOTTag corresponding to @script or
+<return> `PangoOTTag` corresponding to @script or
 %PANGO_OT_TAG_DEFAULT_SCRIPT if none found.
 
 </return>
@@ -12234,31 +13700,31 @@ Since: 1.18
 
 <function name="pango_ot_tag_to_language">
 <description>
-Finds a #PangoLanguage corresponding to @language_tag.
+Finds a `PangoLanguage` corresponding to @language_tag.
 
 Since: 1.18
 
 </description>
 <parameters>
 <parameter name="language_tag">
-<parameter_description> A #PangoOTTag OpenType language-system tag
+<parameter_description> A `PangoOTTag` OpenType language-system tag
 </parameter_description>
 </parameter>
 </parameters>
-<return> #PangoLanguage best matching @language_tag or
-#PangoLanguage corresponding to the string &quot;xx&quot; if none found.
+<return> `PangoLanguage` best matching @language_tag or
+`PangoLanguage` corresponding to the string &quot;xx&quot; if none found.
 
 </return>
 </function>
 
 <function name="pango_ot_tag_to_script">
 <description>
-Finds the #PangoScript corresponding to @script_tag.
+Finds the `PangoScript` corresponding to @script_tag.
 
 The 'DFLT' script tag is mapped to %PANGO_SCRIPT_COMMON.
 
 Note that an OpenType script tag may correspond to multiple
-#PangoScript values.  In such cases, the #PangoScript value
+`PangoScript` values.  In such cases, the `PangoScript` value
 with the smallest value is returned.
 In particular, %PANGO_SCRIPT_HIRAGANA
 and %PANGO_SCRIPT_KATAKANA both map to the OT tag 'kana'.
@@ -12270,11 +13736,11 @@ Since: 1.18
 </description>
 <parameters>
 <parameter name="script_tag">
-<parameter_description> A #PangoOTTag OpenType script tag
+<parameter_description> A `PangoOTTag` OpenType script tag
 </parameter_description>
 </parameter>
 </parameters>
-<return> #PangoScript corresponding to @script_tag or
+<return> `PangoScript` corresponding to @script_tag or
 %PANGO_SCRIPT_UNKNOWN if none found.
 
 </return>
@@ -12284,13 +13750,14 @@ Since: 1.18
 <description>
 Parses an enum type and stores the result in @value.
 
-If @str does not match the nick name of any of the possible values for the
-enum and is not an integer, %FALSE is returned, a warning is issued
-if @warn is %TRUE, and a
-string representing the list of possible values is stored in
-@possible_values.  The list is slash-separated, eg.
-&quot;none/start/middle/end&quot;.  If failed and @possible_values is not %NULL,
-returned string should be freed using g_free().
+If @str does not match the nick name of any of the possible values
+for the enum and is not an integer, %FALSE is returned, a warning
+is issued if @warn is %TRUE, and a string representing the list of
+possible values is stored in @possible_values. The list is
+slash-separated, eg. &quot;none/start/middle/end&quot;.
+
+If failed and @possible_values is not %NULL, returned string should
+be freed using g_free().
 
 Deprecated: 1.38
 
@@ -12299,36 +13766,38 @@ Since: 1.16
 </description>
 <parameters>
 <parameter name="type">
-<parameter_description> enum type to parse, eg. %PANGO_TYPE_ELLIPSIZE_MODE.
+<parameter_description> enum type to parse, eg. %PANGO_TYPE_ELLIPSIZE_MODE
 </parameter_description>
 </parameter>
 <parameter name="str">
-<parameter_description> string to parse.  May be %NULL.
+<parameter_description> string to parse
 </parameter_description>
 </parameter>
 <parameter name="value">
-<parameter_description> integer to store the result in, or %NULL.
+<parameter_description> integer to store the result in
 </parameter_description>
 </parameter>
 <parameter name="warn">
-<parameter_description> if %TRUE, issue a g_warning() on bad input.
+<parameter_description> if %TRUE, issue a g_warning() on bad input
 </parameter_description>
 </parameter>
 <parameter name="possible_values">
-<parameter_description> place to store list of possible values on failure, or %NULL.
+<parameter_description> place to store list of possible
+values on failure
 </parameter_description>
 </parameter>
 </parameters>
-<return> %TRUE if @str was successfully parsed.
+<return> %TRUE if @str was successfully parsed
 
 </return>
 </function>
 
 <function name="pango_parse_markup">
 <description>
-Parses marked-up text (see
-&lt;link linkend=&quot;PangoMarkupFormat&quot;&gt;markup format&lt;/link&gt;) to create
-a plain-text string and an attribute list.
+Parses marked-up text to create a plain-text string and an attribute list.
+
+See the [Pango Markup](pango_markup.html) docs for details about the
+supported markup.
 
 If @accel_marker is nonzero, the given character will mark the
 character following it as an accelerator. For example, @accel_marker
@@ -12338,7 +13807,7 @@ and the first character so marked will be returned in @accel_char.
 Two @accel_marker characters following each other produce a single
 literal @accel_marker character.
 
-To parse a stream of pango markup incrementally, use pango_markup_parser_new().
+To parse a stream of pango markup incrementally, use [func@markup_parser_new].
 
 If any error happens, none of the output arguments are touched except
 for @error.
@@ -12347,7 +13816,7 @@ for @error.
 </description>
 <parameters>
 <parameter name="markup_text">
-<parameter_description> markup to parse (see &lt;link linkend=&quot;PangoMarkupFormat&quot;&gt;markup 
format&lt;/link&gt;)
+<parameter_description> markup to parse (see the Pango Markup docs)
 </parameter_description>
 </parameter>
 <parameter name="length">
@@ -12359,19 +13828,19 @@ for @error.
 </parameter_description>
 </parameter>
 <parameter name="attr_list">
-<parameter_description> address of return location for a #PangoAttrList, or %NULL
+<parameter_description> address of return location for a `PangoAttrList`
 </parameter_description>
 </parameter>
 <parameter name="text">
-<parameter_description> address of return location for text with tags stripped, or %NULL
+<parameter_description> address of return location for text with tags stripped
 </parameter_description>
 </parameter>
 <parameter name="accel_char">
-<parameter_description> address of return location for accelerator char, or %NULL
+<parameter_description> address of return location for accelerator char
 </parameter_description>
 </parameter>
 <parameter name="error">
-<parameter_description> address of return location for errors, or %NULL
+<parameter_description> address of return location for errors
 </parameter_description>
 </parameter>
 </parameters>
@@ -12381,7 +13850,9 @@ for @error.
 
 <function name="pango_parse_stretch">
 <description>
-Parses a font stretch. The allowed values are
+Parses a font stretch.
+
+The allowed values are
 &quot;ultra_condensed&quot;, &quot;extra_condensed&quot;, &quot;condensed&quot;,
 &quot;semi_condensed&quot;, &quot;normal&quot;, &quot;semi_expanded&quot;, &quot;expanded&quot;,
 &quot;extra_expanded&quot; and &quot;ultra_expanded&quot;. Case variations are
@@ -12395,8 +13866,7 @@ ignored and the '_' characters may be omitted.
 </parameter_description>
 </parameter>
 <parameter name="stretch">
-<parameter_description> a #PangoStretch to store the
-result in.
+<parameter_description> a `PangoStretch` to store the result in.
 </parameter_description>
 </parameter>
 <parameter name="warn">
@@ -12410,8 +13880,10 @@ result in.
 
 <function name="pango_parse_style">
 <description>
-Parses a font style. The allowed values are &quot;normal&quot;,
-&quot;italic&quot; and &quot;oblique&quot;, case variations being
+Parses a font style.
+
+The allowed values are &quot;normal&quot;, &quot;italic&quot; and &quot;oblique&quot;, case
+variations being
 ignored.
 
 
@@ -12422,8 +13894,7 @@ ignored.
 </parameter_description>
 </parameter>
 <parameter name="style">
-<parameter_description> a #PangoStyle to store the result
-in.
+<parameter_description> a `PangoStyle` to store the result in.
 </parameter_description>
 </parameter>
 <parameter name="warn">
@@ -12437,9 +13908,10 @@ in.
 
 <function name="pango_parse_variant">
 <description>
-Parses a font variant. The allowed values are &quot;normal&quot;
-and &quot;smallcaps&quot; or &quot;small_caps&quot;, case variations being
-ignored.
+Parses a font variant.
+
+The allowed values are &quot;normal&quot; and &quot;smallcaps&quot; or &quot;small_caps&quot;,
+case variations being ignored.
 
 
 </description>
@@ -12449,8 +13921,7 @@ ignored.
 </parameter_description>
 </parameter>
 <parameter name="variant">
-<parameter_description> a #PangoVariant to store the
-result in.
+<parameter_description> a `PangoVariant` to store the result in.
 </parameter_description>
 </parameter>
 <parameter name="warn">
@@ -12464,7 +13935,9 @@ result in.
 
 <function name="pango_parse_weight">
 <description>
-Parses a font weight. The allowed values are &quot;heavy&quot;,
+Parses a font weight.
+
+The allowed values are &quot;heavy&quot;,
 &quot;ultrabold&quot;, &quot;bold&quot;, &quot;normal&quot;, &quot;light&quot;, &quot;ultraleight&quot;
 and integers. Case variations are ignored.
 
@@ -12476,8 +13949,7 @@ and integers. Case variations are ignored.
 </parameter_description>
 </parameter>
 <parameter name="weight">
-<parameter_description> a #PangoWeight to store the result
-in.
+<parameter_description> a `PangoWeight` to store the result in.
 </parameter_description>
 </parameter>
 <parameter name="warn">
@@ -12491,10 +13963,10 @@ in.
 
 <function name="pango_quantize_line_geometry">
 <description>
-Quantizes the thickness and position of a line, typically an
-underline or strikethrough, to whole device pixels, that is integer
-multiples of %PANGO_SCALE. The purpose of this function is to avoid
-such lines looking blurry.
+Quantizes the thickness and position of a line to whole device pixels.
+
+This is typically used for underline or strikethrough. The purpose of
+this function is to avoid such lines looking blurry.
 
 Care is taken to make sure @thickness is at least one pixel when this
 function returns, but returned @position may become zero as a result
@@ -12518,8 +13990,9 @@ Since: 1.12
 
 <function name="pango_read_line">
 <description>
-Reads an entire line from a file into a buffer. Lines may
-be delimited with '\n', '\r', '\n\r', or '\r\n'. The delimiter
+Reads an entire line from a file into a buffer.
+
+Lines may be delimited with '\n', '\r', '\n\r', or '\r\n'. The delimiter
 is not written into the buffer. Text after a '#' character is treated as
 a comment and skipped. '\' can be used to escape a # character.
 '\' proceeding a line delimiter combines adjacent lines. A '\' proceeding
@@ -12535,12 +14008,12 @@ Deprecated: 1.38
 </parameter_description>
 </parameter>
 <parameter name="str">
-<parameter_description> #GString buffer into which to write the result
+<parameter_description> `GString` buffer into which to write the result
 </parameter_description>
 </parameter>
 </parameters>
-<return> 0 if the stream was already at an %EOF character, otherwise
-the number of lines read (this is useful for maintaining
+<return> 0 if the stream was already at an %EOF character,
+otherwise the number of lines read (this is useful for maintaining
 a line number counter which doesn't combine lines with '\')
 
 </return>
@@ -12549,19 +14022,21 @@ a line number counter which doesn't combine lines with '\')
 <function name="pango_renderer_activate">
 <description>
 Does initial setup before rendering operations on @renderer.
-pango_renderer_deactivate() should be called when done drawing.
-Calls such as pango_renderer_draw_layout() automatically
-activate the layout before drawing on it. Calls to
-pango_renderer_activate() and pango_renderer_deactivate() can
-be nested and the renderer will only be initialized and
-deinitialized once.
+
+[method@Pango.Renderer.deactivate] should be called when done drawing.
+Calls such as [method@Pango.Renderer.draw_layout] automatically
+activate the layout before drawing on it.
+
+Calls to [method@Pango.Renderer.activate] and
+[method@Pango.Renderer.deactivate] can be nested and the
+renderer will only be initialized and deinitialized once.
 
 Since: 1.8
 
 </description>
 <parameters>
 <parameter name="renderer">
-<parameter_description> a #PangoRenderer
+<parameter_description> a `PangoRenderer`
 </parameter_description>
 </parameter>
 </parameters>
@@ -12570,15 +14045,16 @@ Since: 1.8
 
 <function name="pango_renderer_deactivate">
 <description>
-Cleans up after rendering operations on @renderer. See
-docs for pango_renderer_activate().
+Cleans up after rendering operations on @renderer.
+
+See docs for [method@Pango.Renderer.activate].
 
 Since: 1.8
 
 </description>
 <parameters>
 <parameter name="renderer">
-<parameter_description> a #PangoRenderer
+<parameter_description> a `PangoRenderer`
 </parameter_description>
 </parameter>
 </parameters>
@@ -12589,19 +14065,20 @@ Since: 1.8
 <description>
 Draw a squiggly line that approximately covers the given rectangle
 in the style of an underline used to indicate a spelling error.
-(The width of the underline is rounded to an integer number
+
+The width of the underline is rounded to an integer number
 of up/down segments and the resulting rectangle is centered
-in the original rectangle)
+in the original rectangle.
 
-This should be called while @renderer is already active.  Use
-pango_renderer_activate() to activate a renderer.
+This should be called while @renderer is already active.
+Use [method@Pango.Renderer.activate] to activate a renderer.
 
 Since: 1.8
 
 </description>
 <parameters>
 <parameter name="renderer">
-<parameter_description> a #PangoRenderer
+<parameter_description> a `PangoRenderer`
 </parameter_description>
 </parameter>
 <parameter name="x">
@@ -12633,11 +14110,11 @@ Since: 1.8
 </description>
 <parameters>
 <parameter name="renderer">
-<parameter_description> a #PangoRenderer
+<parameter_description> a `PangoRenderer`
 </parameter_description>
 </parameter>
 <parameter name="font">
-<parameter_description> a #PangoFont
+<parameter_description> a `PangoFont`
 </parameter_description>
 </parameter>
 <parameter name="glyph">
@@ -12658,42 +14135,49 @@ Since: 1.8
 
 <function name="pango_renderer_draw_glyph_item">
 <description>
-Draws the glyphs in @glyph_item with the specified #PangoRenderer,
+Draws the glyphs in @glyph_item with the specified `PangoRenderer`,
 embedding the text associated with the glyphs in the output if the
-output format supports it (PDF for example).
+output format supports it.
+
+This is useful for rendering text in PDF.
+
+Note that this method does not handle attributes in @glyph_item.
+If you want colors, shapes and lines handled automatically according
+to those attributes, you need to use pango_renderer_draw_layout_line()
+or pango_renderer_draw_layout().
 
 Note that @text is the start of the text for layout, which is then
-indexed by &lt;literal&gt;@glyph_item-&gt;item-&gt;offset&lt;/literal&gt;.
+indexed by `glyph_item-&gt;item-&gt;offset`.
 
-If @text is %NULL, this simply calls pango_renderer_draw_glyphs().
+If @text is %NULL, this simply calls [method@Pango.Renderer.draw_glyphs].
 
 The default implementation of this method simply falls back to
-pango_renderer_draw_glyphs().
+[method@Pango.Renderer.draw_glyphs].
 
 Since: 1.22
 
 </description>
 <parameters>
 <parameter name="renderer">
-<parameter_description> a #PangoRenderer
+<parameter_description> a `PangoRenderer`
 </parameter_description>
 </parameter>
 <parameter name="text">
-<parameter_description> the UTF-8 text that @glyph_item refers to, or %NULL
+<parameter_description> the UTF-8 text that @glyph_item refers to
 </parameter_description>
 </parameter>
 <parameter name="glyph_item">
-<parameter_description> a #PangoGlyphItem
+<parameter_description> a `PangoGlyphItem`
 </parameter_description>
 </parameter>
 <parameter name="x">
 <parameter_description> X position of left edge of baseline, in user space coordinates
-in Pango units.
+in Pango units
 </parameter_description>
 </parameter>
 <parameter name="y">
 <parameter_description> Y position of left edge of baseline, in user space coordinates
-in Pango units.
+in Pango units
 </parameter_description>
 </parameter>
 </parameters>
@@ -12702,22 +14186,22 @@ in Pango units.
 
 <function name="pango_renderer_draw_glyphs">
 <description>
-Draws the glyphs in @glyphs with the specified #PangoRenderer.
+Draws the glyphs in @glyphs with the specified `PangoRenderer`.
 
 Since: 1.8
 
 </description>
 <parameters>
 <parameter name="renderer">
-<parameter_description> a #PangoRenderer
+<parameter_description> a `PangoRenderer`
 </parameter_description>
 </parameter>
 <parameter name="font">
-<parameter_description> a #PangoFont
+<parameter_description> a `PangoFont`
 </parameter_description>
 </parameter>
 <parameter name="glyphs">
-<parameter_description> a #PangoGlyphString
+<parameter_description> a `PangoGlyphString`
 </parameter_description>
 </parameter>
 <parameter name="x">
@@ -12736,18 +14220,21 @@ in Pango units.
 
 <function name="pango_renderer_draw_layout">
 <description>
-Draws @layout with the specified #PangoRenderer.
+Draws @layout with the specified `PangoRenderer`.
+
+This is equivalent to drawing the lines of the layout, at their
+respective positions relative to @x, @y.
 
 Since: 1.8
 
 </description>
 <parameters>
 <parameter name="renderer">
-<parameter_description> a #PangoRenderer
+<parameter_description> a `PangoRenderer`
 </parameter_description>
 </parameter>
 <parameter name="layout">
-<parameter_description> a #PangoLayout
+<parameter_description> a `PangoLayout`
 </parameter_description>
 </parameter>
 <parameter name="x">
@@ -12766,18 +14253,22 @@ in Pango units.
 
 <function name="pango_renderer_draw_layout_line">
 <description>
-Draws @line with the specified #PangoRenderer.
+Draws @line with the specified `PangoRenderer`.
+
+This draws the glyph items that make up the line, as well as
+shapes, backgrounds and lines that are specified by the attributes
+of those items.
 
 Since: 1.8
 
 </description>
 <parameters>
 <parameter name="renderer">
-<parameter_description> a #PangoRenderer
+<parameter_description> a `PangoRenderer`
 </parameter_description>
 </parameter>
 <parameter name="line">
-<parameter_description> a #PangoLayoutLine
+<parameter_description> a `PangoLayoutLine`
 </parameter_description>
 </parameter>
 <parameter name="x">
@@ -12797,17 +14288,17 @@ in Pango units.
 <function name="pango_renderer_draw_rectangle">
 <description>
 Draws an axis-aligned rectangle in user space coordinates with the
-specified #PangoRenderer.
+specified `PangoRenderer`.
 
-This should be called while @renderer is already active.  Use
-pango_renderer_activate() to activate a renderer.
+This should be called while @renderer is already active.
+Use [method@Pango.Renderer.activate] to activate a renderer.
 
 Since: 1.8
 
 </description>
 <parameters>
 <parameter name="renderer">
-<parameter_description> a #PangoRenderer
+<parameter_description> a `PangoRenderer`
 </parameter_description>
 </parameter>
 <parameter name="part">
@@ -12815,19 +14306,21 @@ Since: 1.8
 </parameter_description>
 </parameter>
 <parameter name="x">
-<parameter_description> X position at which to draw rectangle, in user space coordinates in Pango units
+<parameter_description> X position at which to draw rectangle, in user space coordinates
+in Pango units
 </parameter_description>
 </parameter>
 <parameter name="y">
-<parameter_description> Y position at which to draw rectangle, in user space coordinates in Pango units
+<parameter_description> Y position at which to draw rectangle, in user space coordinates
+in Pango units
 </parameter_description>
 </parameter>
 <parameter name="width">
-<parameter_description> width of rectangle in Pango units in user space coordinates
+<parameter_description> width of rectangle in Pango units
 </parameter_description>
 </parameter>
 <parameter name="height">
-<parameter_description> height of rectangle in Pango units in user space coordinates
+<parameter_description> height of rectangle in Pango units
 </parameter_description>
 </parameter>
 </parameters>
@@ -12837,14 +14330,14 @@ Since: 1.8
 <function name="pango_renderer_draw_trapezoid">
 <description>
 Draws a trapezoid with the parallel sides aligned with the X axis
-using the given #PangoRenderer; coordinates are in device space.
+using the given `PangoRenderer`; coordinates are in device space.
 
 Since: 1.8
 
 </description>
 <parameters>
 <parameter name="renderer">
-<parameter_description> a #PangoRenderer
+<parameter_description> a `PangoRenderer`
 </parameter_description>
 </parameter>
 <parameter name="part">
@@ -12888,7 +14381,7 @@ Since: 1.38
 </description>
 <parameters>
 <parameter name="renderer">
-<parameter_description> a #PangoRenderer
+<parameter_description> a `PangoRenderer`
 </parameter_description>
 </parameter>
 <parameter name="part">
@@ -12912,7 +14405,7 @@ Since: 1.8
 </description>
 <parameters>
 <parameter name="renderer">
-<parameter_description> a #PangoRenderer
+<parameter_description> a `PangoRenderer`
 </parameter_description>
 </parameter>
 <parameter name="part">
@@ -12930,6 +14423,7 @@ inherited from the environment.
 <function name="pango_renderer_get_layout">
 <description>
 Gets the layout currently being rendered using @renderer.
+
 Calling this function only makes sense from inside a subclass's
 methods, like in its draw_shape vfunc, for example.
 
@@ -12941,7 +14435,7 @@ Since: 1.20
 </description>
 <parameters>
 <parameter name="renderer">
-<parameter_description> a #PangoRenderer
+<parameter_description> a `PangoRenderer`
 </parameter_description>
 </parameter>
 </parameters>
@@ -12954,6 +14448,7 @@ no layout is being rendered using @renderer at this time.
 <function name="pango_renderer_get_layout_line">
 <description>
 Gets the layout line currently being rendered using @renderer.
+
 Calling this function only makes sense from inside a subclass's
 methods, like in its draw_shape vfunc, for example.
 
@@ -12965,7 +14460,7 @@ Since: 1.20
 </description>
 <parameters>
 <parameter name="renderer">
-<parameter_description> a #PangoRenderer
+<parameter_description> a `PangoRenderer`
 </parameter_description>
 </parameter>
 </parameters>
@@ -12978,14 +14473,16 @@ if no layout line is being rendered using @renderer at this time.
 <function name="pango_renderer_get_matrix">
 <description>
 Gets the transformation matrix that will be applied when
-rendering. See pango_renderer_set_matrix().
+rendering.
+
+See [method@Pango.Renderer.set_matrix].
 
 Since: 1.8
 
 </description>
 <parameters>
 <parameter name="renderer">
-<parameter_description> a #PangoRenderer
+<parameter_description> a `PangoRenderer`
 </parameter_description>
 </parameter>
 </parameters>
@@ -12999,25 +14496,27 @@ matrix is owned by Pango and must not be modified or freed.
 <function name="pango_renderer_part_changed">
 <description>
 Informs Pango that the way that the rendering is done
-for @part has changed in a way that would prevent multiple
-pieces being joined together into one drawing call. For
-instance, if a subclass of #PangoRenderer was to add a stipple
+for @part has changed.
+
+This should be called if the rendering changes in a way that would
+prevent multiple pieces being joined together into one drawing call.
+For instance, if a subclass of `PangoRenderer` was to add a stipple
 option for drawing underlines, it needs to call
 
-&lt;informalexample&gt;&lt;programlisting&gt;
+```
 pango_renderer_part_changed (render, PANGO_RENDER_PART_UNDERLINE);
-&lt;/programlisting&gt;&lt;/informalexample&gt;
+```
 
 When the stipple changes or underlines with different stipples
 might be joined together. Pango automatically calls this for
-changes to colors. (See pango_renderer_set_color())
+changes to colors. (See [method@Pango.Renderer.set_color])
 
 Since: 1.8
 
 </description>
 <parameters>
 <parameter name="renderer">
-<parameter_description> a #PangoRenderer
+<parameter_description> a `PangoRenderer`
 </parameter_description>
 </parameter>
 <parameter name="part">
@@ -13030,18 +14529,18 @@ Since: 1.8
 
 <function name="pango_renderer_prepare_run">
 <description>
-Set up the state of the #PangoRenderer for rendering @run.
+Set up the state of the `PangoRenderer` for rendering @run.
 
 Since: 1.8
 
 </description>
 <parameters>
 <parameter name="renderer">
-<parameter_description> a #PangoRenderer
+<parameter_description> a `PangoRenderer`
 </parameter_description>
 </parameter>
 <parameter name="run">
-<parameter_description> a #PangoLayoutRun
+<parameter_description> a `PangoLayoutRun`
 </parameter_description>
 </parameter>
 </parameters>
@@ -13051,6 +14550,7 @@ Since: 1.8
 <function name="pango_renderer_set_alpha">
 <description>
 Sets the alpha for part of the rendering.
+
 Note that the alpha may only be used if a color is
 specified for @part as well.
 
@@ -13059,7 +14559,7 @@ Since: 1.38
 </description>
 <parameters>
 <parameter name="renderer">
-<parameter_description> a #PangoRenderer
+<parameter_description> a `PangoRenderer`
 </parameter_description>
 </parameter>
 <parameter name="part">
@@ -13077,14 +14577,15 @@ Since: 1.38
 <function name="pango_renderer_set_color">
 <description>
 Sets the color for part of the rendering.
-Also see pango_renderer_set_alpha().
+
+Also see [method@Pango.Renderer.set_alpha].
 
 Since: 1.8
 
 </description>
 <parameters>
 <parameter name="renderer">
-<parameter_description> a #PangoRenderer
+<parameter_description> a `PangoRenderer`
 </parameter_description>
 </parameter>
 <parameter name="part">
@@ -13108,11 +14609,11 @@ Since: 1.8
 </description>
 <parameters>
 <parameter name="renderer">
-<parameter_description> a #PangoRenderer
+<parameter_description> a `PangoRenderer`
 </parameter_description>
 </parameter>
 <parameter name="matrix">
-<parameter_description> a #PangoMatrix, or %NULL to unset any existing matrix.
+<parameter_description> a `PangoMatrix`, or %NULL to unset any existing matrix
 (No matrix set is the same as setting the identity matrix.)
 </parameter_description>
 </parameter>
@@ -13122,30 +14623,33 @@ Since: 1.8
 
 <function name="pango_reorder_items">
 <description>
-From a list of items in logical order and the associated
-directional levels, produce a list in visual order.
-The original list is unmodified.
+Reorder items from logical order to visual order.
+
+The visual order is determined from the associated directional
+levels of the items. The original list is unmodified.
+
+(Please open a bug if you use this function.
+It is not a particularly convenient interface, and the code
+is duplicated elsewhere in Pango for that reason.)
 
 
 </description>
 <parameters>
-<parameter name="logical_items">
-<parameter_description> a #GList of #PangoItem in logical order.
+<parameter name="items">
+<parameter_description> a `GList` of `PangoItem`
+in logical order.
 </parameter_description>
 </parameter>
 </parameters>
-<return> a #GList
-of #PangoItem structures in visual order.
-
-(Please open a bug if you use this function.
-It is not a particularly convenient interface, and the code
-is duplicated elsewhere in Pango for that reason.)
+<return> a `GList`
+of `PangoItem` structures in visual order.
 </return>
 </function>
 
 <function name="pango_scan_int">
 <description>
 Scans an integer.
+
 Leading white space is skipped.
 
 Deprecated: 1.38
@@ -13161,16 +14665,17 @@ Deprecated: 1.38
 </parameter_description>
 </parameter>
 </parameters>
-<return> %FALSE if a parse error occurred.
+<return> %FALSE if a parse error occurred
 
 </return>
 </function>
 
 <function name="pango_scan_string">
 <description>
-Scans a string into a #GString buffer. The string may either
-be a sequence of non-white-space characters, or a quoted
-string with '&quot;'. Instead a quoted string, '\&quot;' represents
+Scans a string into a `GString` buffer.
+
+The string may either be a sequence of non-white-space characters,
+or a quoted string with '&quot;'. Instead a quoted string, '\&quot;' represents
 a literal quote. Leading white space outside of quotes is skipped.
 
 Deprecated: 1.38
@@ -13182,20 +14687,21 @@ Deprecated: 1.38
 </parameter_description>
 </parameter>
 <parameter name="out">
-<parameter_description> a #GString into which to write the result
+<parameter_description> a `GString` into which to write the result
 </parameter_description>
 </parameter>
 </parameters>
-<return> %FALSE if a parse error occurred.
+<return> %FALSE if a parse error occurred
 
 </return>
 </function>
 
 <function name="pango_scan_word">
 <description>
-Scans a word into a #GString buffer. A word consists
-of [A-Za-z_] followed by zero or more [A-Za-z_0-9]
-Leading white space is skipped.
+Scans a word into a `GString` buffer.
+
+A word consists of [A-Za-z_] followed by zero or more
+[A-Za-z_0-9]. Leading white space is skipped.
 
 Deprecated: 1.38
 
@@ -13206,24 +14712,25 @@ Deprecated: 1.38
 </parameter_description>
 </parameter>
 <parameter name="out">
-<parameter_description> a #GString into which to write the result
+<parameter_description> a `GString` into which to write the result
 </parameter_description>
 </parameter>
 </parameters>
-<return> %FALSE if a parse error occurred.
+<return> %FALSE if a parse error occurred
 
 </return>
 </function>
 
 <function name="pango_script_for_unichar">
 <description>
-Looks up the script for a particular character (as defined by
-Unicode Standard Annex \#24). No check is made for @ch being a
-valid Unicode character; if you pass in invalid character, the
-result is undefined.
+Looks up the script for a particular character.
+
+The script of a character is defined by Unicode Standard Annex \#24.
+No check is made for @ch being a valid Unicode character; if you pass
+in invalid character, the result is undefined.
 
 Note that while the return type of this function is declared
-as PangoScript, as of Pango 1.18, this function simply returns
+as `PangoScript`, as of Pango 1.18, this function simply returns
 the return value of g_unichar_get_script(). Callers must be
 prepared to handle unknown values.
 
@@ -13237,41 +14744,40 @@ Deprecated: 1.44. Use g_unichar_get_script()
 </parameter_description>
 </parameter>
 </parameters>
-<return> the #PangoScript for the character.
+<return> the `PangoScript` for the character.
 
 </return>
 </function>
 
 <function name="pango_script_get_sample_language">
 <description>
-Given a script, finds a language tag that is reasonably
-representative of that script. This will usually be the
-most widely spoken or used language written in that script:
-for instance, the sample language for %PANGO_SCRIPT_CYRILLIC
-is &lt;literal&gt;ru&lt;/literal&gt; (Russian), the sample language
-for %PANGO_SCRIPT_ARABIC is &lt;literal&gt;ar&lt;/literal&gt;.
-
-For some
-scripts, no sample language will be returned because there
-is no language that is sufficiently representative. The best
-example of this is %PANGO_SCRIPT_HAN, where various different
+Finds a language tag that is reasonably representative of @script.
+
+The language will usually be the most widely spoken or used language
+written in that script: for instance, the sample language for
+%PANGO_SCRIPT_CYRILLIC is ru (Russian), the sample language for
+%PANGO_SCRIPT_ARABIC is ar.
+
+For some scripts, no sample language will be returned because
+there is no language that is sufficiently representative. The
+best example of this is %PANGO_SCRIPT_HAN, where various different
 variants of written Chinese, Japanese, and Korean all use
 significantly different sets of Han characters and forms
 of shared characters. No sample language can be provided
 for many historical scripts as well.
 
 As of 1.18, this function checks the environment variables
-PANGO_LANGUAGE and LANGUAGE (checked in that order) first.
+`PANGO_LANGUAGE` and `LANGUAGE` (checked in that order) first.
 If one of them is set, it is parsed as a list of language tags
-separated by colons or other separators.  This function
+separated by colons or other separators. This function
 will return the first language in the parsed list that Pango
-believes may use @script for writing.  This last predicate
-is tested using pango_language_includes_script().  This can
+believes may use @script for writing. This last predicate
+is tested using [method@Pango.Language.includes_script]. This can
 be used to control Pango's font selection for non-primary
-languages.  For example, a PANGO_LANGUAGE enviroment variable
-set to &quot;en:fa&quot; makes Pango choose fonts suitable for Persian (fa) 
+languages. For example, a `PANGO_LANGUAGE` enviroment variable
+set to &quot;en:fa&quot; makes Pango choose fonts suitable for Persian (fa)
 instead of Arabic (ar) when a segment of Arabic text is found
-in an otherwise non-Arabic text.  The same trick can be used to
+in an otherwise non-Arabic text. The same trick can be used to
 choose a default language for %PANGO_SCRIPT_HAN when setting
 context language is not feasible.
 
@@ -13280,26 +14786,26 @@ Since: 1.4
 </description>
 <parameters>
 <parameter name="script">
-<parameter_description> a #PangoScript
+<parameter_description> a `PangoScript`
 </parameter_description>
 </parameter>
 </parameters>
-<return> a #PangoLanguage that is representative
-of the script, or %NULL if no such language exists.
+<return> a `PangoLanguage` that is representative
+of the script
 
 </return>
 </function>
 
 <function name="pango_script_iter_free">
 <description>
-Frees a #PangoScriptIter created with pango_script_iter_new().
+Frees a `PangoScriptIter`.
 
 Since: 1.4
 
 </description>
 <parameters>
 <parameter name="iter">
-<parameter_description> a #PangoScriptIter
+<parameter_description> a `PangoScriptIter`
 </parameter_description>
 </parameter>
 </parameters>
@@ -13313,7 +14819,7 @@ The range is the set of locations p where *start &lt;= p &lt; *end.
 (That is, it doesn't include the character stored at *end)
 
 Note that while the type of the @script argument is declared
-as PangoScript, as of Pango 1.18, this function simply returns
+as `PangoScript`, as of Pango 1.18, this function simply returns
 GUnicodeScript values. Callers must be prepared to handle unknown
 values.
 
@@ -13322,19 +14828,19 @@ Since: 1.4
 </description>
 <parameters>
 <parameter name="iter">
-<parameter_description> a #PangoScriptIter
+<parameter_description> a `PangoScriptIter`
 </parameter_description>
 </parameter>
 <parameter name="start">
-<parameter_description> location to store start position of the range, or %NULL
+<parameter_description> location to store start position of the range
 </parameter_description>
 </parameter>
 <parameter name="end">
-<parameter_description> location to store end position of the range, or %NULL
+<parameter_description> location to store end position of the range
 </parameter_description>
 </parameter>
 <parameter name="script">
-<parameter_description> location to store script for range, or %NULL
+<parameter_description> location to store script for range
 </parameter_description>
 </parameter>
 </parameters>
@@ -13343,10 +14849,12 @@ Since: 1.4
 
 <function name="pango_script_iter_new">
 <description>
-Create a new #PangoScriptIter, used to break a string of
-Unicode text into runs by Unicode script. No copy is made of
-@text, so the caller needs to make sure it remains valid until
-the iterator is freed with pango_script_iter_free().
+Create a new `PangoScriptIter`, used to break a string of
+Unicode text into runs by Unicode script.
+
+No copy is made of @text, so the caller needs to make
+sure it remains valid until the iterator is freed with
+[method Pango ScriptIter free].
 
 Since: 1.4
 
@@ -13363,7 +14871,7 @@ Since: 1.4
 </parameters>
 <return> the new script iterator, initialized
 to point at the first range in the text, which should be
-freed with pango_script_iter_free(). If the string is
+freed with [method Pango ScriptIter free]. If the string is
 empty, it will point at an empty range.
 
 </return>
@@ -13371,55 +14879,58 @@ empty, it will point at an empty range.
 
 <function name="pango_script_iter_next">
 <description>
-Advances a #PangoScriptIter to the next range. If @iter
-is already at the end, it is left unchanged and %FALSE
-is returned.
+Advances a `PangoScriptIter` to the next range.
+
+If @iter is already at the end, it is left unchanged
+and %FALSE is returned.
 
 Since: 1.4
 
 </description>
 <parameters>
 <parameter name="iter">
-<parameter_description> a #PangoScriptIter
+<parameter_description> a `PangoScriptIter`
 </parameter_description>
 </parameter>
 </parameters>
-<return> %TRUE if @iter was successfully advanced.
+<return> %TRUE if @iter was successfully advanced
 
 </return>
 </function>
 
 <function name="pango_shape">
 <description>
-Given a segment of text and the corresponding #PangoAnalysis structure
-returned from pango_itemize(), convert the characters into glyphs. You
-may also pass in only a substring of the item from pango_itemize().
+Convert the characters in @text into glyphs.
+
+Given a segment of text and the corresponding `PangoAnalysis` structure
+returned from [func@Pango.itemize], convert the characters into glyphs. You
+may also pass in only a substring of the item from [func@Pango.itemize].
 
-It is recommended that you use pango_shape_full() instead, since
+It is recommended that you use [func@Pango.shape_full] instead, since
 that API allows for shaping interaction happening across text item
 boundaries.
 
 Note that the extra attributes in the @analyis that is returned from
-pango_itemize() have indices that are relative to the entire paragraph,
+[func@Pango.itemize] have indices that are relative to the entire paragraph,
 so you need to subtract the item offset from their indices before
-calling pango_shape().
+calling [func@Pango.shape].
 
 </description>
 <parameters>
 <parameter name="text">
-<parameter_description>      the text to process
+<parameter_description> the text to process
 </parameter_description>
 </parameter>
 <parameter name="length">
-<parameter_description>    the length (in bytes) of @text
+<parameter_description> the length (in bytes) of @text
 </parameter_description>
 </parameter>
 <parameter name="analysis">
-<parameter_description>  #PangoAnalysis structure from pango_itemize()
+<parameter_description> `PangoAnalysis` structure from [func@Pango.itemize]
 </parameter_description>
 </parameter>
 <parameter name="glyphs">
-<parameter_description>    glyph string in which to store results
+<parameter_description> glyph string in which to store results
 </parameter_description>
 </parameter>
 </parameters>
@@ -13428,36 +14939,38 @@ calling pango_shape().
 
 <function name="pango_shape_full">
 <description>
-Given a segment of text and the corresponding
-#PangoAnalysis structure returned from pango_itemize(),
-convert the characters into glyphs. You may also pass
-in only a substring of the item from pango_itemize().
+Convert the characters in @text into glyphs.
+
+Given a segment of text and the corresponding `PangoAnalysis` structure
+returned from [func@Pango.itemize], convert the characters into glyphs.
+You may also pass in only a substring of the item from [func@Pango.itemize].
 
-This is similar to pango_shape(), except it also can optionally take
+This is similar to [func@Pango.shape], except it also can optionally take
 the full paragraph text as input, which will then be used to perform
-certain cross-item shaping interactions.  If you have access to the broader
+certain cross-item shaping interactions. If you have access to the broader
 text of which @item_text is part of, provide the broader text as
-@paragraph_text.  If @paragraph_text is %NULL, item text is used instead.
+@paragraph_text. If @paragraph_text is %NULL, item text is used instead.
 
 Note that the extra attributes in the @analyis that is returned from
-pango_itemize() have indices that are relative to the entire paragraph,
+[func@Pango.itemize] have indices that are relative to the entire paragraph,
 so you do not pass the full paragraph text as @paragraph_text, you need
-to subtract the item offset from their indices before calling pango_shape_full().
+to subtract the item offset from their indices before calling
+[func@Pango.shape_full].
 
 Since: 1.32
 
 </description>
 <parameters>
 <parameter name="item_text">
-<parameter_description>        valid UTF-8 text to shape.
+<parameter_description> valid UTF-8 text to shape.
 </parameter_description>
 </parameter>
 <parameter name="item_length">
-<parameter_description>      the length (in bytes) of @item_text. -1 means nul-terminated text.
+<parameter_description> the length (in bytes) of @item_text. -1 means nul-terminated text.
 </parameter_description>
 </parameter>
 <parameter name="paragraph_text">
-<parameter_description> text of the paragraph (see details).  May be %NULL.
+<parameter_description> text of the paragraph (see details).
 </parameter_description>
 </parameter>
 <parameter name="paragraph_length">
@@ -13465,11 +14978,59 @@ Since: 1.32
 </parameter_description>
 </parameter>
 <parameter name="analysis">
-<parameter_description>  #PangoAnalysis structure from pango_itemize().
+<parameter_description> `PangoAnalysis` structure from [func@Pango.itemize].
+</parameter_description>
+</parameter>
+<parameter name="glyphs">
+<parameter_description> glyph string in which to store results.
+</parameter_description>
+</parameter>
+</parameters>
+<return></return>
+</function>
+
+<function name="pango_shape_item">
+<description>
+Convert the characters in @item into glyphs.
+
+This is similar to [func@Pango.shape_with_flags], except it takes a
+`PangoItem` instead of separate @item_text and @analysis arguments.
+It also takes @log_attrs, which may be used in implementing text
+transforms.
+
+Note that the extra attributes in the @analyis that is returned from
+[func@Pango.itemize] have indices that are relative to the entire paragraph,
+so you do not pass the full paragraph text as @paragraph_text, you need
+to subtract the item offset from their indices before calling
+[func@Pango.shape_with_flags].
+
+Since: 1.50
+
+</description>
+<parameters>
+<parameter name="item">
+<parameter_description> `PangoItem` to shape
+</parameter_description>
+</parameter>
+<parameter name="paragraph_text">
+<parameter_description> text of the paragraph (see details).
+</parameter_description>
+</parameter>
+<parameter name="paragraph_length">
+<parameter_description> the length (in bytes) of @paragraph_text.
+-1 means nul-terminated text.
+</parameter_description>
+</parameter>
+<parameter name="log_attrs">
+<parameter_description> array of `PangoLogAttr` for @item
 </parameter_description>
 </parameter>
 <parameter name="glyphs">
-<parameter_description>    glyph string in which to store results.
+<parameter_description> glyph string in which to store results
+</parameter_description>
+</parameter>
+<parameter name="flags">
+<parameter_description> flags influencing the shaping process
 </parameter_description>
 </parameter>
 </parameters>
@@ -13478,19 +15039,20 @@ Since: 1.32
 
 <function name="pango_shape_with_flags">
 <description>
-Given a segment of text and the corresponding
-#PangoAnalysis structure returned from pango_itemize(),
-convert the characters into glyphs. You may also pass
-in only a substring of the item from pango_itemize().
+Convert the characters in @text into glyphs.
+
+Given a segment of text and the corresponding `PangoAnalysis` structure
+returned from [func@Pango.itemize], convert the characters into glyphs.
+You may also pass in only a substring of the item from [func@Pango.itemize].
 
-This is similar to pango_shape_full(), except it also takes
-flags that can influence the shaping process.
+This is similar to [func@Pango.shape_full], except it also takes flags
+that can influence the shaping process.
 
 Note that the extra attributes in the @analyis that is returned from
-pango_itemize() have indices that are relative to the entire paragraph,
+[func@Pango.itemize] have indices that are relative to the entire paragraph,
 so you do not pass the full paragraph text as @paragraph_text, you need
 to subtract the item offset from their indices before calling
-pango_shape_with_flags().
+[func@Pango.shape_with_flags].
 
 Since: 1.44
 
@@ -13507,7 +15069,6 @@ Since: 1.44
 </parameter>
 <parameter name="paragraph_text">
 <parameter_description> text of the paragraph (see details).
-May be %NULL.
 </parameter_description>
 </parameter>
 <parameter name="paragraph_length">
@@ -13516,7 +15077,7 @@ May be %NULL.
 </parameter_description>
 </parameter>
 <parameter name="analysis">
-<parameter_description>  #PangoAnalysis structure from pango_itemize()
+<parameter_description>  `PangoAnalysis` structure from [func@Pango.itemize]
 </parameter_description>
 </parameter>
 <parameter name="glyphs">
@@ -13572,18 +15133,18 @@ strings to be freed with g_strfreev()
 
 <function name="pango_tab_array_copy">
 <description>
-Copies a #PangoTabArray
+Copies a `PangoTabArray`.
 
 
 </description>
 <parameters>
 <parameter name="src">
-<parameter_description> #PangoTabArray to copy
+<parameter_description> `PangoTabArray` to copy
 </parameter_description>
 </parameter>
 </parameters>
-<return> the newly allocated #PangoTabArray, which should
-be freed with pango_tab_array_free().
+<return> the newly allocated `PangoTabArray`, which should
+be freed with [method Pango TabArray free].
 </return>
 </function>
 
@@ -13591,11 +15152,55 @@ be freed with pango_tab_array_free().
 <description>
 Frees a tab array and associated resources.
 
+</description>
+<parameters>
+<parameter name="tab_array">
+<parameter_description> a `PangoTabArray`
+</parameter_description>
+</parameter>
+</parameters>
+<return></return>
+</function>
+
+<function name="pango_tab_array_from_string">
+<description>
+Deserializes a `PangoTabArray` from a string.
+
+This is the counterpart to [method@Pango.TabArray.to_string].
+See that functions for details about the format.
+
+Since: 1.50
+
+</description>
+<parameters>
+<parameter name="text">
+<parameter_description> a string
+</parameter_description>
+</parameter>
+</parameters>
+<return> a new `PangoTabArray`
+</return>
+</function>
+
+<function name="pango_tab_array_get_decimal_point">
+<description>
+Gets the decimal point to use.
+
+This is only relevant for %PANGO_TAB_DECIMAL.
+
+The default value of 0 means that Pango will use the
+decimal point according to the current locale.
+
+Since: 1.50
 
 </description>
 <parameters>
 <parameter name="tab_array">
-<parameter_description> a #PangoTabArray
+<parameter_description> a `PangoTabArray`
+</parameter_description>
+</parameter>
+<parameter name="tab_index">
+<parameter_description> the index of a tab stop
 </parameter_description>
 </parameter>
 </parameters>
@@ -13604,14 +15209,14 @@ Frees a tab array and associated resources.
 
 <function name="pango_tab_array_get_positions_in_pixels">
 <description>
-Returns %TRUE if the tab positions are in pixels, %FALSE if they are
-in Pango units.
+Returns %TRUE if the tab positions are in pixels,
+%FALSE if they are in Pango units.
 
 
 </description>
 <parameters>
 <parameter name="tab_array">
-<parameter_description> a #PangoTabArray
+<parameter_description> a `PangoTabArray`
 </parameter_description>
 </parameter>
 </parameters>
@@ -13627,7 +15232,7 @@ Gets the number of tab stops in @tab_array.
 </description>
 <parameters>
 <parameter name="tab_array">
-<parameter_description> a #PangoTabArray
+<parameter_description> a `PangoTabArray`
 </parameter_description>
 </parameter>
 </parameters>
@@ -13639,11 +15244,10 @@ Gets the number of tab stops in @tab_array.
 <description>
 Gets the alignment and position of a tab stop.
 
-
 </description>
 <parameters>
 <parameter name="tab_array">
-<parameter_description> a #PangoTabArray
+<parameter_description> a `PangoTabArray`
 </parameter_description>
 </parameter>
 <parameter name="tab_index">
@@ -13651,11 +15255,11 @@ Gets the alignment and position of a tab stop.
 </parameter_description>
 </parameter>
 <parameter name="alignment">
-<parameter_description> location to store alignment, or %NULL
+<parameter_description> location to store alignment
 </parameter_description>
 </parameter>
 <parameter name="location">
-<parameter_description> location to store tab position, or %NULL
+<parameter_description> location to store tab position
 </parameter_description>
 </parameter>
 </parameters>
@@ -13665,24 +15269,25 @@ Gets the alignment and position of a tab stop.
 <function name="pango_tab_array_get_tabs">
 <description>
 If non-%NULL, @alignments and @locations are filled with allocated
-arrays of length pango_tab_array_get_size(). You must free the
-returned array.
+arrays.
 
+The arrays are of length [method@Pango.TabArray.get_size].
+You must free the returned array.
 
 </description>
 <parameters>
 <parameter name="tab_array">
-<parameter_description> a #PangoTabArray
+<parameter_description> a `PangoTabArray`
 </parameter_description>
 </parameter>
 <parameter name="alignments">
 <parameter_description> location to store an array of tab
-stop alignments, or %NULL
+stop alignments
 </parameter_description>
 </parameter>
 <parameter name="locations">
 <parameter_description> location to store an array
-of tab positions, or %NULL
+of tab positions
 </parameter_description>
 </parameter>
 </parameters>
@@ -13691,9 +15296,10 @@ of tab positions, or %NULL
 
 <function name="pango_tab_array_new">
 <description>
-Creates an array of @initial_size tab stops. Tab stops are specified in
-pixel units if @positions_in_pixels is %TRUE, otherwise in Pango
-units. All stops are initially at position 0.
+Creates an array of @initial_size tab stops.
+
+Tab stops are specified in pixel units if @positions_in_pixels is %TRUE,
+otherwise in Pango units. All stops are initially at position 0.
 
 
 </description>
@@ -13707,17 +15313,17 @@ units. All stops are initially at position 0.
 </parameter_description>
 </parameter>
 </parameters>
-<return> the newly allocated #PangoTabArray, which should
-be freed with pango_tab_array_free().
+<return> the newly allocated `PangoTabArray`, which should
+be freed with [method Pango TabArray free].
 </return>
 </function>
 
 <function name="pango_tab_array_new_with_positions">
 <description>
-This is a convenience function that creates a #PangoTabArray
-and allows you to specify the alignment and position of each
-tab stop. You &lt;emphasis&gt;must&lt;/emphasis&gt; provide an alignment
-and position for @size tab stops.
+Creates a `PangoTabArray` and allows you to specify the alignment
+and position of each tab stop.
+
+You **must** provide an alignment and position for @size tab stops.
 
 
 </description>
@@ -13743,21 +15349,22 @@ and position for @size tab stops.
 </parameter_description>
 </parameter>
 </parameters>
-<return> the newly allocated #PangoTabArray, which should
-be freed with pango_tab_array_free().
+<return> the newly allocated `PangoTabArray`, which should
+be freed with [method Pango TabArray free].
 </return>
 </function>
 
 <function name="pango_tab_array_resize">
 <description>
-Resizes a tab array. You must subsequently initialize any tabs that
-were added as a result of growing the array.
+Resizes a tab array.
 
+You must subsequently initialize any tabs
+that were added as a result of growing the array.
 
 </description>
 <parameters>
 <parameter name="tab_array">
-<parameter_description> a #PangoTabArray
+<parameter_description> a `PangoTabArray`
 </parameter_description>
 </parameter>
 <parameter name="new_size">
@@ -13768,17 +15375,64 @@ were added as a result of growing the array.
 <return></return>
 </function>
 
+<function name="pango_tab_array_set_decimal_point">
+<description>
+Sets the decimal point to use.
+
+This is only relevant for %PANGO_TAB_DECIMAL.
+
+By default, Pango uses the decimal point according
+to the current locale.
+
+Since: 1.50
+
+</description>
+<parameters>
+<parameter name="tab_array">
+<parameter_description> a `PangoTabArray`
+</parameter_description>
+</parameter>
+<parameter name="tab_index">
+<parameter_description> the index of a tab stop
+</parameter_description>
+</parameter>
+<parameter name="decimal_point">
+<parameter_description> the decimal point to use
+</parameter_description>
+</parameter>
+</parameters>
+<return></return>
+</function>
+
+<function name="pango_tab_array_set_positions_in_pixels">
+<description>
+Sets whether positions in this array are specified in
+pixels.
+
+Since: 1.50
+
+</description>
+<parameters>
+<parameter name="tab_array">
+<parameter_description> a `PangoTabArray`
+</parameter_description>
+</parameter>
+<parameter name="positions_in_pixels">
+<parameter_description> whether positions are in pixels
+</parameter_description>
+</parameter>
+</parameters>
+<return></return>
+</function>
+
 <function name="pango_tab_array_set_tab">
 <description>
 Sets the alignment and location of a tab stop.
-@alignment must always be #PANGO_TAB_LEFT in the current
-implementation.
-
 
 </description>
 <parameters>
 <parameter name="tab_array">
-<parameter_description> a #PangoTabArray
+<parameter_description> a `PangoTabArray`
 </parameter_description>
 </parameter>
 <parameter name="tab_index">
@@ -13797,15 +15451,60 @@ implementation.
 <return></return>
 </function>
 
+<function name="pango_tab_array_sort">
+<description>
+Utility function to ensure that the tab stops are in increasing order.
+
+Since: 1.50
+
+</description>
+<parameters>
+<parameter name="tab_array">
+<parameter_description> a `PangoTabArray`
+</parameter_description>
+</parameter>
+</parameters>
+<return></return>
+</function>
+
+<function name="pango_tab_array_to_string">
+<description>
+Serializes a `PangoTabArray` to a string.
+
+No guarantees are made about the format of the string,
+it may change between Pango versions.
+
+The intended use of this function is testing and
+debugging. The format is not meant as a permanent
+storage format.
+
+Since: 1.50
+
+</description>
+<parameters>
+<parameter name="tab_array">
+<parameter_description> a `PangoTabArray`
+</parameter_description>
+</parameter>
+</parameters>
+<return> a newly allocated string
+</return>
+</function>
+
 <function name="pango_tailor_break">
 <description>
-Apply language-specific tailoring to the breaks in
-@log_attrs, which are assumed to have been produced
-by pango_default_break().
+Apply language-specific tailoring to the breaks in @attrs.
+
+The line breaks are assumed to have been produced
+by [func@Pango.default_break].
 
 If @offset is not -1, it is used to apply attributes
 from @analysis that are relevant to line breaking.
 
+Note that it is better to pass -1 for @offset and
+use [func@Pango.attr_break] to apply attributes to
+the whole paragraph.
+
 Since: 1.44
 
 </description>
@@ -13819,7 +15518,7 @@ Since: 1.44
 </parameter_description>
 </parameter>
 <parameter name="analysis">
-<parameter_description>  #PangoAnalysis structure from pango_itemize() for @text
+<parameter_description> `PangoAnalysis` for @text
 </parameter_description>
 </parameter>
 <parameter name="offset">
@@ -13827,13 +15526,13 @@ Since: 1.44
 paragraph, or -1 to ignore attributes from @analysis
 </parameter_description>
 </parameter>
-<parameter name="log_attrs">
-<parameter_description> array with one #PangoLogAttr
+<parameter name="attrs">
+<parameter_description> array with one `PangoLogAttr`
 per character in @text, plus one extra, to be filled in
 </parameter_description>
 </parameter>
-<parameter name="log_attrs_len">
-<parameter_description> length of @log_attrs array
+<parameter name="attrs_len">
+<parameter_description> length of @attrs array
 </parameter_description>
 </parameter>
 </parameters>
@@ -13860,14 +15559,15 @@ Deprecated: 1.38
 
 <function name="pango_unichar_direction">
 <description>
-Determines the inherent direction of a character; either
-%PANGO_DIRECTION_LTR, %PANGO_DIRECTION_RTL, or
-%PANGO_DIRECTION_NEUTRAL.
+Determines the inherent direction of a character.
+
+The inherent direction is either %PANGO_DIRECTION_LTR, %PANGO_DIRECTION_RTL,
+or %PANGO_DIRECTION_NEUTRAL.
 
 This function is useful to categorize characters into left-to-right
-letters, right-to-left letters, and everything else.  If full
-Unicode bidirectional type of a character is needed,
-pango_bidi_type_for_unichar() can be used instead.
+letters, right-to-left letters, and everything else. If full Unicode
+bidirectional type of a character is needed,
+[func@Pango.BidiType.for_unichar] can be used instead.
 
 
 </description>
@@ -13883,8 +15583,10 @@ pango_bidi_type_for_unichar() can be used instead.
 
 <function name="pango_units_from_double">
 <description>
-Converts a floating-point number to Pango units: multiplies
-it by %PANGO_SCALE and rounds to nearest integer.
+Converts a floating-point number to Pango units.
+
+The conversion is done by multiplying @d by %PANGO_SCALE and
+rounding the result to nearest integer.
 
 Since: 1.16
 
@@ -13902,8 +15604,9 @@ Since: 1.16
 
 <function name="pango_units_to_double">
 <description>
-Converts a number in Pango units to floating-point: divides
-it by %PANGO_SCALE.
+Converts a number in Pango units to floating-point.
+
+The conversion is done by dividing @i by %PANGO_SCALE.
 
 Since: 1.16
 
@@ -13921,20 +15624,18 @@ Since: 1.16
 
 <function name="pango_version">
 <description>
-This is similar to the macro %PANGO_VERSION except that
-it returns the encoded version of Pango available at run-time,
-as opposed to the version available at compile-time.
+Returns the encoded version of Pango available at run-time.
 
-A version number can be encoded into an integer using
-PANGO_VERSION_ENCODE().
+This is similar to the macro %PANGO_VERSION except that the macro
+returns the encoded version available at compile-time. A version
+number can be encoded into an integer using PANGO_VERSION_ENCODE().
 
 Since: 1.16
 
 </description>
 <parameters>
 </parameters>
-<return> The encoded version of Pango library
-available at run time.
+<return> The encoded version of Pango library available at run time.
 
 </return>
 </function>
@@ -13942,11 +15643,13 @@ available at run time.
 <function name="pango_version_check">
 <description>
 Checks that the Pango library in use is compatible with the
-given version. Generally you would pass in the constants
-%PANGO_VERSION_MAJOR, %PANGO_VERSION_MINOR, %PANGO_VERSION_MICRO
-as the three arguments to this function; that produces
-a check that the library in use at run-time is compatible with
-the version of Pango the application or module was compiled against.
+given version.
+
+Generally you would pass in the constants %PANGO_VERSION_MAJOR,
+%PANGO_VERSION_MINOR, %PANGO_VERSION_MICRO as the three arguments
+to this function; that produces a check that the library in use at
+run-time is compatible with the version of Pango the application or
+module was compiled against.
 
 Compatibility is defined by two things: first the version
 of the running library is newer than the version
@@ -13962,15 +15665,15 @@ Since: 1.16
 </description>
 <parameters>
 <parameter name="required_major">
-<parameter_description> the required major version.
+<parameter_description> the required major version
 </parameter_description>
 </parameter>
 <parameter name="required_minor">
-<parameter_description> the required minor version.
+<parameter_description> the required minor version
 </parameter_description>
 </parameter>
 <parameter name="required_micro">
-<parameter_description> the required major version.
+<parameter_description> the required major version
 </parameter_description>
 </parameter>
 </parameters>
@@ -13984,32 +15687,34 @@ be modified or freed.
 
 <function name="pango_version_string">
 <description>
-This is similar to the macro %PANGO_VERSION_STRING except that
-it returns the version of Pango available at run-time, as opposed to
-the version available at compile-time.
+Returns the version of Pango available at run-time.
+
+This is similar to the macro %PANGO_VERSION_STRING except that the
+macro returns the version available at compile-time.
 
 Since: 1.16
 
 </description>
 <parameters>
 </parameters>
-<return> A string containing the version of Pango library
-available at run time.
-The returned string is owned by Pango and should not be modified
-or freed.
+<return> A string containing the version of Pango library available
+at run time. The returned string is owned by Pango and should not
+be modified or freed.
 
 </return>
 </function>
 
 <function name="pango_win32_font_cache_free">
 <description>
-Frees a #PangoWin32FontCache and all associated memory. All fonts loaded
-through this font cache will be freed along with the cache.
+Frees a `PangoWin32FontCache` and all associated memory.
+
+All fonts loaded through this font cache will be freed
+along with the cache.
 
 </description>
 <parameters>
 <parameter name="cache">
-<parameter_description> a #PangoWin32FontCache
+<parameter_description> a `PangoWin32FontCache`
 </parameter_description>
 </parameter>
 </parameters>
@@ -14026,7 +15731,7 @@ stored
 </description>
 <parameters>
 <parameter name="cache">
-<parameter_description> a #PangoWin32FontCache
+<parameter_description> a `PangoWin32FontCache`
 </parameter_description>
 </parameter>
 <parameter name="logfont">
@@ -14036,7 +15741,7 @@ stored
 </parameters>
 <return> The font structure, or %NULL if the font
 could not be loaded. In order to free this structure, you must call
-pango_win32_font_cache_unload().
+[method@Pango.Win32FontCache.unload].
 </return>
 </function>
 
@@ -14051,7 +15756,7 @@ Since: 1.16
 </description>
 <parameters>
 <parameter name="cache">
-<parameter_description> a #PangoWin32FontCache
+<parameter_description> a `PangoWin32FontCache`
 </parameter_description>
 </parameter>
 <parameter name="logfont">
@@ -14061,7 +15766,7 @@ Since: 1.16
 </parameters>
 <return> The font structure, or %NULL if the font
 could not be loaded. In order to free this structure, you must call
-pango_win32_font_cache_unload().
+[method@Pango.Win32FontCache.unload].
 
 </return>
 </function>
@@ -14081,12 +15786,13 @@ pango_win32_font_cache_free().
 
 <function name="pango_win32_font_cache_unload">
 <description>
-Frees a font structure previously loaded with pango_win32_font_cache_load().
+Frees a font structure previously loaded with
+[method Pango Win32FontCache load].
 
 </description>
 <parameters>
 <parameter name="cache">
-<parameter_description> a #PangoWin32FontCache
+<parameter_description> a `PangoWin32FontCache`
 </parameter_description>
 </parameter>
 <parameter name="hfont">
@@ -14099,10 +15805,10 @@ Frees a font structure previously loaded with pango_win32_font_cache_load().
 
 <function name="pango_win32_font_description_from_logfont">
 <description>
-Creates a #PangoFontDescription that matches the specified LOGFONTA.
+Creates a `PangoFontDescription` that matches the specified LOGFONTA.
 
 The face name, italicness and weight fields in the LOGFONTA are used
-to set up the resulting #PangoFontDescription. If the face name in
+to set up the resulting `PangoFontDescription`. If the face name in
 the LOGFONTA contains non-ASCII characters the font is temporarily
 loaded (using CreateFontIndirect()) and an ASCII (usually English)
 name for it is looked up from the font name tables in the font
@@ -14118,18 +15824,18 @@ Since: 1.12
 </parameter_description>
 </parameter>
 </parameters>
-<return> the newly allocated #PangoFontDescription, which
-should be freed using pango_font_description_free()
+<return> the newly allocated `PangoFontDescription`, which
+should be freed using [method Pango FontDescription free]
 
 </return>
 </function>
 
 <function name="pango_win32_font_description_from_logfontw">
 <description>
-Creates a #PangoFontDescription that matches the specified LOGFONTW.
+Creates a `PangoFontDescription` that matches the specified LOGFONTW.
 
 The face name, italicness and weight fields in the LOGFONTW are used
-to set up the resulting #PangoFontDescription. If the face name in
+to set up the resulting `PangoFontDescription`. If the face name in
 the LOGFONTW contains non-ASCII characters the font is temporarily
 loaded (using CreateFontIndirect()) and an ASCII (usually English)
 name for it is looked up from the font name tables in the font
@@ -14145,20 +15851,20 @@ Since: 1.16
 </parameter_description>
 </parameter>
 </parameters>
-<return> the newly allocated #PangoFontDescription, which
-should be freed using pango_font_description_free()
+<return> the newly allocated `PangoFontDescription`, which
+should be freed using [method Pango FontDescription free]
 
 </return>
 </function>
 
 <function name="pango_win32_font_done_font">
 <description>
-Releases any resources allocated by pango_win32_font_done_font()
+Releases any resources allocated by [method@Pango.Win32Font.select_font].
 
 </description>
 <parameters>
 <parameter name="font">
-<parameter_description> a #PangoFont from the win32 backend
+<parameter_description> a `PangoFont` from the win32 backend
 </parameter_description>
 </parameter>
 </parameters>
@@ -14174,11 +15880,11 @@ covered.
 </description>
 <parameters>
 <parameter name="font">
-<parameter_description> a #PangoFont.
+<parameter_description> a `PangoFont`
 </parameter_description>
 </parameter>
 <parameter name="wc">
-<parameter_description> a Unicode character.
+<parameter_description> a Unicode character
 </parameter_description>
 </parameter>
 </parameters>
@@ -14189,14 +15895,14 @@ covered.
 <function name="pango_win32_font_get_metrics_factor">
 <description>
 Returns the scale factor from logical units in the coordinate
-space used by pango_win32_font_select_font() to Pango units
-in user space.
+space used by [method@Pango.Win32Font.select_font] to Pango
+units in user space.
 
 
 </description>
 <parameters>
 <parameter name="font">
-<parameter_description> a #PangoFont from the win32 backend
+<parameter_description> a `PangoFont` from the win32 backend
 </parameter_description>
 </parameter>
 </parameters>
@@ -14219,7 +15925,7 @@ to come across fonts with odd names.
 </description>
 <parameters>
 <parameter name="font">
-<parameter_description> a #PangoFont which must be from the Win32 backend
+<parameter_description> a `PangoFont` which must be from the Win32 backend
 </parameter_description>
 </parameter>
 </parameters>
@@ -14237,7 +15943,7 @@ Since: 1.16
 </description>
 <parameters>
 <parameter name="font">
-<parameter_description> a #PangoFont which must be from the Win32 backend
+<parameter_description> a `PangoFont` which must be from the Win32 backend
 </parameter_description>
 </parameter>
 </parameters>
@@ -14249,15 +15955,17 @@ freed with g_free().
 
 <function name="pango_win32_font_map_for_display">
 <description>
-Returns a &lt;type&gt;PangoWin32FontMap&lt;/type&gt;. Font maps are cached and should
-not be freed. If the font map is no longer needed, it can
-be released with pango_win32_shutdown_display().
+Returns a `PangoWin32FontMap`.
+
+Font maps are cached and should not be freed. If
+the font map is no longer needed, it can be released
+with [func@Pango.win32_shutdown_display].
 
 
 </description>
 <parameters>
 </parameters>
-<return> a #PangoFontMap.
+<return> a `PangoFontMap`
 </return>
 </function>
 
@@ -14269,11 +15977,11 @@ Obtains the font cache associated with the given font map.
 </description>
 <parameters>
 <parameter name="font_map">
-<parameter_description> a &lt;type&gt;PangoWin32FontMap&lt;/type&gt;.
+<parameter_description> a `PangoWin32FontMap`
 </parameter_description>
 </parameter>
 </parameters>
-<return> the #PangoWin32FontCache of @font_map.
+<return> the `PangoWin32FontCache` of @font_map.
 </return>
 </function>
 
@@ -14281,11 +15989,12 @@ Obtains the font cache associated with the given font map.
 <description>
 Selects the font into the specified DC and changes the mapping mode
 and world transformation of the DC appropriately for the font.
+
 You may want to surround the use of this function with calls
-to SaveDC() and RestoreDC(). Call pango_win32_font_done_font() when
+to SaveDC() and RestoreDC(). Call [method@Pango.Win32Font.done_font[ when
 you are done using the DC to release allocated resources.
 
-See pango_win32_font_get_metrics_factor() for information about
+See [method@Pango.Win32Font.get_metrics_factor] for information about
 converting from the coordinate space used by this function
 into Pango units.
 
@@ -14293,7 +16002,7 @@ into Pango units.
 </description>
 <parameters>
 <parameter name="font">
-<parameter_description> a #PangoFont from the Win32 backend
+<parameter_description> a `PangoFont` from the Win32 backend
 </parameter_description>
 </parameter>
 <parameter name="hdc">
@@ -14307,15 +16016,15 @@ into Pango units.
 
 <function name="pango_win32_get_context">
 <description>
-Retrieves a #PangoContext appropriate for rendering with Windows fonts.
+Retrieves a `PangoContext` appropriate for rendering with Windows fonts.
 
-Deprecated: 1.22: Use pango_win32_font_map_for_display() followed by
-pango_font_map_create_context() instead.
+Deprecated: 1.22: Use [func@Pango.Win32FontMap.for_display] followed by
+[method@Pango.FontMap.create_context] instead.
 
 </description>
 <parameters>
 </parameters>
-<return> the new #PangoContext
+<return> the new `PangoContext`
 
 </return>
 </function>
@@ -14357,11 +16066,11 @@ Use PANGO_GET_UNKNOWN_GLYPH() instead.
 </description>
 <parameters>
 <parameter name="font">
-<parameter_description> a #PangoFont
+<parameter_description> a `PangoFont`
 </parameter_description>
 </parameter>
 <parameter name="wc">
-<parameter_description> the Unicode character for which a glyph is needed.
+<parameter_description> the Unicode character for which a glyph is needed
 </parameter_description>
 </parameter>
 </parameters>
@@ -14371,7 +16080,7 @@ Use PANGO_GET_UNKNOWN_GLYPH() instead.
 
 <function name="pango_win32_render">
 <description>
-Render a #PangoGlyphString onto a Windows DC
+Render a `PangoGlyphString` onto a Windows DC
 
 </description>
 <parameters>
@@ -14401,24 +16110,24 @@ Render a #PangoGlyphString onto a Windows DC
 
 <function name="pango_win32_render_layout">
 <description>
-Render a #PangoLayoutLine onto an X drawable
+Render a `PangoLayoutLine` onto an HDC.
 
 </description>
 <parameters>
 <parameter name="hdc">
-<parameter_description>       HDC to use for drawing
+<parameter_description> HDC to use for drawing
 </parameter_description>
 </parameter>
 <parameter name="layout">
-<parameter_description>    a #PangoLayout
+<parameter_description> a `PangoLayout`
 </parameter_description>
 </parameter>
 <parameter name="x">
-<parameter_description>         the X position of the left of the layout (in pixels)
+<parameter_description> the X position of the left of the layout (in pixels)
 </parameter_description>
 </parameter>
 <parameter name="y">
-<parameter_description>         the Y position of the top of the layout (in pixels)
+<parameter_description> the Y position of the top of the layout (in pixels)
 </parameter_description>
 </parameter>
 </parameters>
@@ -14427,26 +16136,27 @@ Render a #PangoLayoutLine onto an X drawable
 
 <function name="pango_win32_render_layout_line">
 <description>
-Render a #PangoLayoutLine onto a device context. For underlining to
-work property the text alignment of the DC should have TA_BASELINE
-and TA_LEFT.
+Render a `PangoLayoutLine` onto a device context.
+
+For underlining to work property the text alignment
+of the DC should have TA_BASELINE and TA_LEFT.
 
 </description>
 <parameters>
 <parameter name="hdc">
-<parameter_description>       DC to use for drawing
+<parameter_description> DC to use for drawing
 </parameter_description>
 </parameter>
 <parameter name="line">
-<parameter_description>      a #PangoLayoutLine
+<parameter_description> a `PangoLayoutLine`
 </parameter_description>
 </parameter>
 <parameter name="x">
-<parameter_description>         the x position of start of string (in pixels)
+<parameter_description> the x position of start of string (in pixels)
 </parameter_description>
 </parameter>
 <parameter name="y">
-<parameter_description>         the y position of baseline (in pixels)
+<parameter_description> the y position of baseline (in pixels)
 </parameter_description>
 </parameter>
 </parameters>
@@ -14455,39 +16165,40 @@ and TA_LEFT.
 
 <function name="pango_win32_render_transformed">
 <description>
-Renders a #PangoGlyphString onto a windows DC, possibly
+Renders a `PangoGlyphString` onto a windows DC, possibly
 transforming the layed-out coordinates through a transformation
-matrix. Note that the transformation matrix for @font is not
+matrix.
+
+Note that the transformation matrix for @font is not
 changed, so to produce correct rendering results, the @font
-must have been loaded using a #PangoContext with an identical
+must have been loaded using a `PangoContext` with an identical
 transformation matrix to that passed in to this function.
 
 </description>
 <parameters>
 <parameter name="hdc">
-<parameter_description>     a windows device context
+<parameter_description> a windows device context
 </parameter_description>
 </parameter>
 <parameter name="matrix">
-<parameter_description> a #PangoMatrix, or %NULL to use an identity
-transformation
+<parameter_description> a `PangoMatrix`
 </parameter_description>
 </parameter>
 <parameter name="font">
-<parameter_description>    the font in which to draw the string
+<parameter_description> the font in which to draw the string
 </parameter_description>
 </parameter>
 <parameter name="glyphs">
-<parameter_description>  the glyph string to draw
+<parameter_description> the glyph string to draw
 </parameter_description>
 </parameter>
 <parameter name="x">
-<parameter_description>       the x position of the start of the string (in Pango
+<parameter_description> the x position of the start of the string (in Pango
 units in user space coordinates)
 </parameter_description>
 </parameter>
 <parameter name="y">
-<parameter_description>       the y position of the baseline (in Pango units
+<parameter_description> the y position of the baseline (in Pango units
 in user space coordinates)
 </parameter_description>
 </parameter>
@@ -14513,7 +16224,7 @@ Returns the X display of the `XftFont` of a font.
 </description>
 <parameters>
 <parameter name="font">
-<parameter_description> a #PangoFont.
+<parameter_description> a `PangoFont`
 </parameter_description>
 </parameter>
 </parameters>
@@ -14529,20 +16240,21 @@ Returns the `XftFont` of a font.
 </description>
 <parameters>
 <parameter name="font">
-<parameter_description> a #PangoFont.
+<parameter_description> a `PangoFont`
 </parameter_description>
 </parameter>
 </parameters>
-<return> the `XftFont` associated to @font,
-or %NULL if @font is %NULL.
+<return> the `XftFont` associated to @font
 </return>
 </function>
 
 <function name="pango_xft_font_get_glyph">
 <description>
 Gets the glyph index for a given Unicode character
-for @font. If you only want to determine
-whether the font has the glyph, use pango_xft_font_has_char().
+for @font.
+
+If you only want to determine whether the font has
+the glyph, use pango_xft_font_has_char().
 
 Use pango_fc_font_get_glyph() instead.
 
@@ -14551,7 +16263,7 @@ Since: 1.2
 </description>
 <parameters>
 <parameter name="font">
-<parameter_description> a #PangoFont for the Xft backend
+<parameter_description> a `PangoFont` for the Xft backend
 </parameter_description>
 </parameter>
 <parameter name="wc">
@@ -14576,7 +16288,7 @@ Use PANGO_GET_UNKNOWN_GLYPH() instead.
 </description>
 <parameters>
 <parameter name="font">
-<parameter_description> a #PangoFont.
+<parameter_description> a `PangoFont`
 </parameter_description>
 </parameter>
 <parameter name="wc">
@@ -14599,7 +16311,7 @@ Since: 1.2
 </description>
 <parameters>
 <parameter name="font">
-<parameter_description> a #PangoFont for the Xft backend
+<parameter_description> a `PangoFont` for the Xft backend
 </parameter_description>
 </parameter>
 <parameter name="wc">
@@ -14625,7 +16337,7 @@ Since: 1.2
 </description>
 <parameters>
 <parameter name="font">
-<parameter_description> a #PangoFont.
+<parameter_description> a `PangoFont`
 </parameter_description>
 </parameter>
 </parameters>
@@ -14646,7 +16358,7 @@ Since: 1.2
 </description>
 <parameters>
 <parameter name="font">
-<parameter_description> a #PangoFont.
+<parameter_description> a `PangoFont`
 </parameter_description>
 </parameter>
 </parameters>
@@ -14655,7 +16367,7 @@ Since: 1.2
 
 <function name="pango_xft_get_context">
 <description>
-Retrieves a #PangoContext appropriate for rendering with
+Retrieves a `PangoContext` appropriate for rendering with
 Xft fonts on the given screen of the given display.
 
 Deprecated: 1.22: Use pango_xft_get_font_map() followed by
@@ -14672,14 +16384,14 @@ pango_font_map_create_context() instead.
 </parameter_description>
 </parameter>
 </parameters>
-<return> the new #PangoContext.
+<return> the new `PangoContext`.
 
 </return>
 </function>
 
 <function name="pango_xft_get_font_map">
 <description>
-Returns the #PangoXftFontMap for the given display and screen.
+Returns the `PangoXftFontMap` for the given display and screen.
 The fontmap is owned by Pango and will be valid until
 the display is closed.
 
@@ -14696,23 +16408,23 @@ Since: 1.2
 </parameter_description>
 </parameter>
 </parameters>
-<return> a #PangoFontMap object, owned by Pango.
+<return> a `PangoFontMap` object, owned by Pango.
 
 </return>
 </function>
 
 <function name="pango_xft_picture_render">
 <description>
-Renders a #PangoGlyphString onto an Xrender &lt;type&gt;Picture&lt;/type&gt; object.
+Renders a `PangoGlyphString` onto an Xrender Picture object.
 
 </description>
 <parameters>
 <parameter name="display">
-<parameter_description>      an X display
+<parameter_description> an X display
 </parameter_description>
 </parameter>
 <parameter name="src_picture">
-<parameter_description>  the source picture to draw the string with
+<parameter_description> the source picture to draw the string with
 </parameter_description>
 </parameter>
 <parameter name="dest_picture">
@@ -14720,19 +16432,19 @@ Renders a #PangoGlyphString onto an Xrender &lt;type&gt;Picture&lt;/type&gt; obj
 </parameter_description>
 </parameter>
 <parameter name="font">
-<parameter_description>         the font in which to draw the string
+<parameter_description> the font in which to draw the string
 </parameter_description>
 </parameter>
 <parameter name="glyphs">
-<parameter_description>       the glyph string to draw
+<parameter_description> the glyph string to draw
 </parameter_description>
 </parameter>
 <parameter name="x">
-<parameter_description>            the x position of start of string (in pixels)
+<parameter_description> the x position of start of string (in pixels)
 </parameter_description>
 </parameter>
 <parameter name="y">
-<parameter_description>            the y position of baseline (in pixels)
+<parameter_description> the y position of baseline (in pixels)
 </parameter_description>
 </parameter>
 </parameters>
@@ -14741,32 +16453,32 @@ Renders a #PangoGlyphString onto an Xrender &lt;type&gt;Picture&lt;/type&gt; obj
 
 <function name="pango_xft_render">
 <description>
-Renders a #PangoGlyphString onto an &lt;type&gt;XftDraw&lt;/type&gt; object wrapping an X drawable.
+Renders a `PangoGlyphString` onto an XftDraw object wrapping an X drawable.
 
 </description>
 <parameters>
 <parameter name="draw">
-<parameter_description>    the &lt;type&gt;XftDraw&lt;/type&gt; object.
+<parameter_description> the XftDraw object.
 </parameter_description>
 </parameter>
 <parameter name="color">
-<parameter_description>   the color in which to draw the string
+<parameter_description> the color in which to draw the string
 </parameter_description>
 </parameter>
 <parameter name="font">
-<parameter_description>    the font in which to draw the string
+<parameter_description> the font in which to draw the string
 </parameter_description>
 </parameter>
 <parameter name="glyphs">
-<parameter_description>  the glyph string to draw
+<parameter_description> the glyph string to draw
 </parameter_description>
 </parameter>
 <parameter name="x">
-<parameter_description>       the x position of start of string (in pixels)
+<parameter_description> the x position of start of string (in pixels)
 </parameter_description>
 </parameter>
 <parameter name="y">
-<parameter_description>       the y position of baseline (in pixels)
+<parameter_description> the y position of baseline (in pixels)
 </parameter_description>
 </parameter>
 </parameters>
@@ -14775,31 +16487,31 @@ Renders a #PangoGlyphString onto an &lt;type&gt;XftDraw&lt;/type&gt; object wrap
 
 <function name="pango_xft_render_layout">
 <description>
-Render a #PangoLayout onto a #XftDraw
+Render a `PangoLayout` onto a XftDraw
 
 Since: 1.8
 
 </description>
 <parameters>
 <parameter name="draw">
-<parameter_description>      an #XftDraw
+<parameter_description> an XftDraw
 </parameter_description>
 </parameter>
 <parameter name="color">
-<parameter_description>     the foreground color in which to draw the layout
+<parameter_description> the foreground color in which to draw the layout
 (may be overridden by color attributes)
 </parameter_description>
 </parameter>
 <parameter name="layout">
-<parameter_description>    a #PangoLayout
+<parameter_description> a `PangoLayout`
 </parameter_description>
 </parameter>
 <parameter name="x">
-<parameter_description>         the X position of the left of the layout (in Pango units)
+<parameter_description> the X position of the left of the layout (in Pango units)
 </parameter_description>
 </parameter>
 <parameter name="y">
-<parameter_description>         the Y position of the top of the layout (in Pango units)
+<parameter_description> the Y position of the top of the layout (in Pango units)
 </parameter_description>
 </parameter>
 </parameters>
@@ -14808,31 +16520,31 @@ Since: 1.8
 
 <function name="pango_xft_render_layout_line">
 <description>
-Render a #PangoLayoutLine onto a #XftDraw
+Render a `PangoLayoutLine` onto a XftDraw
 
 Since: 1.8
 
 </description>
 <parameters>
 <parameter name="draw">
-<parameter_description>      an #XftDraw
+<parameter_description> an XftDraw
 </parameter_description>
 </parameter>
 <parameter name="color">
-<parameter_description>     the foreground color in which to draw the layout line
+<parameter_description> the foreground color in which to draw the layout line
 (may be overridden by color attributes)
 </parameter_description>
 </parameter>
 <parameter name="line">
-<parameter_description>      a #PangoLayoutLine
+<parameter_description> a `PangoLayoutLine`
 </parameter_description>
 </parameter>
 <parameter name="x">
-<parameter_description>         the x position of start of string (in Pango units)
+<parameter_description> the x position of start of string (in Pango units)
 </parameter_description>
 </parameter>
 <parameter name="y">
-<parameter_description>         the y position of baseline (in Pango units)
+<parameter_description> the y position of baseline (in Pango units)
 </parameter_description>
 </parameter>
 </parameters>
@@ -14841,11 +16553,13 @@ Since: 1.8
 
 <function name="pango_xft_render_transformed">
 <description>
-Renders a #PangoGlyphString onto a #XftDraw, possibly
+Renders a `PangoGlyphString` onto a XftDraw, possibly
 transforming the layed-out coordinates through a transformation
-matrix. Note that the transformation matrix for @font is not
+matrix.
+
+Note that the transformation matrix for @font is not
 changed, so to produce correct rendering results, the @font
-must have been loaded using a #PangoContext with an identical
+must have been loaded using a `PangoContext` with an identical
 transformation matrix to that passed in to this function.
 
 Since: 1.8
@@ -14853,33 +16567,32 @@ Since: 1.8
 </description>
 <parameters>
 <parameter name="draw">
-<parameter_description>    an #XftDraw
+<parameter_description> an XftDraw
 </parameter_description>
 </parameter>
 <parameter name="color">
-<parameter_description>   the color in which to draw the glyphs
+<parameter_description> the color in which to draw the glyphs
 </parameter_description>
 </parameter>
 <parameter name="font">
-<parameter_description>    the font in which to draw the string
+<parameter_description> the font in which to draw the string
 </parameter_description>
 </parameter>
 <parameter name="matrix">
-<parameter_description> a #PangoMatrix, or %NULL to use an identity
-transformation
+<parameter_description> a `PangoMatrix`
 </parameter_description>
 </parameter>
 <parameter name="glyphs">
-<parameter_description>  the glyph string to draw
+<parameter_description> the glyph string to draw
 </parameter_description>
 </parameter>
 <parameter name="x">
-<parameter_description>       the x position of the start of the string (in Pango
+<parameter_description> the x position of the start of the string (in Pango
 units in user space coordinates)
 </parameter_description>
 </parameter>
 <parameter name="y">
-<parameter_description>       the y position of the baseline (in Pango units
+<parameter_description> the y position of the baseline (in Pango units
 in user space coordinates)
 </parameter_description>
 </parameter>
@@ -14889,8 +16602,10 @@ in user space coordinates)
 
 <function name="pango_xft_renderer_new">
 <description>
-Create a new #PangoXftRenderer to allow rendering Pango objects
-with the Xft library. You must call pango_xft_renderer_set_draw() before
+Create a new `PangoXftRenderer` to allow rendering Pango objects
+with the Xft library.
+
+You must call pango_xft_renderer_set_draw() before
 using the renderer.
 
 Since: 1.8
@@ -14902,26 +16617,25 @@ Since: 1.8
 </parameter_description>
 </parameter>
 <parameter name="screen">
-<parameter_description>   the index of the screen for @display to which rendering will be done
+<parameter_description> the index of the screen for @display to which rendering will be done
 </parameter_description>
 </parameter>
 </parameters>
-<return> the newly created #PangoXftRenderer, which should
-be freed with g_object_unref().
+<return> the newly created `PangoXftRenderer`
 
 </return>
 </function>
 
 <function name="pango_xft_renderer_set_default_color">
 <description>
-Sets the default foreground color for a #XftRenderer.
+Sets the default foreground color for a XftRenderer.
 
 Since: 1.8
 
 </description>
 <parameters>
 <parameter name="xftrenderer">
-<parameter_description> a #XftRenderer
+<parameter_description> a XftRenderer
 </parameter_description>
 </parameter>
 <parameter name="default_color">
@@ -14934,7 +16648,7 @@ Since: 1.8
 
 <function name="pango_xft_renderer_set_draw">
 <description>
-Sets the #XftDraw object that the renderer is drawing to.
+Sets the XftDraw object that the renderer is drawing to.
 The renderer must not be currently active.
 
 Since: 1.8
@@ -14942,11 +16656,11 @@ Since: 1.8
 </description>
 <parameters>
 <parameter name="xftrenderer">
-<parameter_description> a #PangoXftRenderer
+<parameter_description> a `PangoXftRenderer`
 </parameter_description>
 </parameter>
 <parameter name="draw">
-<parameter_description> a #XftDraw
+<parameter_description> a XftDraw
 </parameter_description>
 </parameter>
 </parameters>
@@ -15079,7 +16793,7 @@ Deprecated: 1.38
 </description>
 <parameters>
 <parameter name="module">
-<parameter_description> a #GTypeModule structure used to associate any
+<parameter_description> a `GTypeModule` structure used to associate any
 GObject types created in this module with the module.
 </parameter_description>
 </parameter>
diff --git a/pango/src/pango_docs_override.xml b/pango/src/pango_docs_override.xml
index f29bd93..2b0e006 100644
--- a/pango/src/pango_docs_override.xml
+++ b/pango/src/pango_docs_override.xml
@@ -10,6 +10,7 @@
 <substitute_enumerator_name from_prefix="PANGO_ATTR_" to_prefix="Pango::AttrType::" />
 <substitute_enumerator_name from_prefix="PANGO_TAB_" to_prefix="Pango::TabAlign::" />
 <substitute_enumerator_name from_prefix="PANGO_COVERAGE_" to_prefix="Pango::Coverage::Level::" />
+<substitute_enumerator_name from_prefix="PANGO_WRAP_" to_prefix="Pango::WrapMode::" />
 <!-- These are preprocessor defines. Don't substitute. -->
 <substitute_enumerator_name from="G_MAXINT" to="G_MAXINT" />
 <!-- This is the default substitution. Included here to avoid warnings from DocsParser.pm. -->
diff --git a/pango/src/pango_enums.defs b/pango/src/pango_enums.defs
index d41c496..4a5cd58 100644
--- a/pango/src/pango_enums.defs
+++ b/pango/src/pango_enums.defs
@@ -4,36 +4,43 @@
 ;; typedef enum
 ;; {
 ;;   PANGO_ATTR_INVALID,           /* 0 is an invalid attribute type */
-;;   PANGO_ATTR_LANGUAGE,              /* PangoAttrLanguage */
-;;   PANGO_ATTR_FAMILY,                /* PangoAttrString */
-;;   PANGO_ATTR_STYLE,         /* PangoAttrInt */
-;;   PANGO_ATTR_WEIGHT,                /* PangoAttrInt */
-;;   PANGO_ATTR_VARIANT,               /* PangoAttrInt */
-;;   PANGO_ATTR_STRETCH,               /* PangoAttrInt */
-;;   PANGO_ATTR_SIZE,          /* PangoAttrSize */
-;;   PANGO_ATTR_FONT_DESC,             /* PangoAttrFontDesc */
-;;   PANGO_ATTR_FOREGROUND,    /* PangoAttrColor */
-;;   PANGO_ATTR_BACKGROUND,    /* PangoAttrColor */
-;;   PANGO_ATTR_UNDERLINE,             /* PangoAttrInt */
-;;   PANGO_ATTR_STRIKETHROUGH, /* PangoAttrInt */
-;;   PANGO_ATTR_RISE,          /* PangoAttrInt */
-;;   PANGO_ATTR_SHAPE,         /* PangoAttrShape */
+;;   PANGO_ATTR_LANGUAGE,          /* PangoAttrLanguage */
+;;   PANGO_ATTR_FAMILY,            /* PangoAttrString */
+;;   PANGO_ATTR_STYLE,             /* PangoAttrInt */
+;;   PANGO_ATTR_WEIGHT,            /* PangoAttrInt */
+;;   PANGO_ATTR_VARIANT,           /* PangoAttrInt */
+;;   PANGO_ATTR_STRETCH,           /* PangoAttrInt */
+;;   PANGO_ATTR_SIZE,              /* PangoAttrSize */
+;;   PANGO_ATTR_FONT_DESC,         /* PangoAttrFontDesc */
+;;   PANGO_ATTR_FOREGROUND,        /* PangoAttrColor */
+;;   PANGO_ATTR_BACKGROUND,        /* PangoAttrColor */
+;;   PANGO_ATTR_UNDERLINE,         /* PangoAttrInt */
+;;   PANGO_ATTR_STRIKETHROUGH,     /* PangoAttrInt */
+;;   PANGO_ATTR_RISE,              /* PangoAttrInt */
+;;   PANGO_ATTR_SHAPE,             /* PangoAttrShape */
 ;;   PANGO_ATTR_SCALE,             /* PangoAttrFloat */
 ;;   PANGO_ATTR_FALLBACK,          /* PangoAttrInt */
 ;;   PANGO_ATTR_LETTER_SPACING,    /* PangoAttrInt */
-;;   PANGO_ATTR_UNDERLINE_COLOR,       /* PangoAttrColor */
+;;   PANGO_ATTR_UNDERLINE_COLOR,   /* PangoAttrColor */
 ;;   PANGO_ATTR_STRIKETHROUGH_COLOR,/* PangoAttrColor */
-;;   PANGO_ATTR_ABSOLUTE_SIZE, /* PangoAttrSize */
-;;   PANGO_ATTR_GRAVITY,               /* PangoAttrInt */
-;;   PANGO_ATTR_GRAVITY_HINT,  /* PangoAttrInt */
-;;   PANGO_ATTR_FONT_FEATURES, /* PangoAttrString */
-;;   PANGO_ATTR_FOREGROUND_ALPHA,      /* PangoAttrInt */
-;;   PANGO_ATTR_BACKGROUND_ALPHA,      /* PangoAttrInt */
-;;   PANGO_ATTR_ALLOW_BREAKS,  /* PangoAttrInt */
-;;   PANGO_ATTR_SHOW,          /* PangoAttrInt */
-;;   PANGO_ATTR_INSERT_HYPHENS,        /* PangoAttrInt */
-;;   PANGO_ATTR_OVERLINE,              /* PangoAttrInt */
-;;   PANGO_ATTR_OVERLINE_COLOR,        /* PangoAttrColor */
+;;   PANGO_ATTR_ABSOLUTE_SIZE,     /* PangoAttrSize */
+;;   PANGO_ATTR_GRAVITY,           /* PangoAttrInt */
+;;   PANGO_ATTR_GRAVITY_HINT,      /* PangoAttrInt */
+;;   PANGO_ATTR_FONT_FEATURES,     /* PangoAttrFontFeatures */
+;;   PANGO_ATTR_FOREGROUND_ALPHA,  /* PangoAttrInt */
+;;   PANGO_ATTR_BACKGROUND_ALPHA,  /* PangoAttrInt */
+;;   PANGO_ATTR_ALLOW_BREAKS,      /* PangoAttrInt */
+;;   PANGO_ATTR_SHOW,              /* PangoAttrInt */
+;;   PANGO_ATTR_INSERT_HYPHENS,    /* PangoAttrInt */
+;;   PANGO_ATTR_OVERLINE,          /* PangoAttrInt */
+;;   PANGO_ATTR_OVERLINE_COLOR,    /* PangoAttrColor */
+;;   PANGO_ATTR_LINE_HEIGHT,       /* PangoAttrFloat */
+;;   PANGO_ATTR_ABSOLUTE_LINE_HEIGHT, /* PangoAttrInt */
+;;   PANGO_ATTR_TEXT_TRANSFORM,    /* PangoAttrInt */
+;;   PANGO_ATTR_WORD,              /* PangoAttrInt */
+;;   PANGO_ATTR_SENTENCE,          /* PangoAttrInt */
+;;   PANGO_ATTR_BASELINE_SHIFT,    /* PangoAttrSize */
+;;   PANGO_ATTR_FONT_SCALE,        /* PangoAttrInt */
 ;; } PangoAttrType;
 
 (define-enum-extended AttrType
@@ -71,6 +78,13 @@
     '("insert-hyphens" "PANGO_ATTR_INSERT_HYPHENS" "28")
     '("overline" "PANGO_ATTR_OVERLINE" "29")
     '("overline-color" "PANGO_ATTR_OVERLINE_COLOR" "30")
+    '("line-height" "PANGO_ATTR_LINE_HEIGHT" "31")
+    '("absolute-line-height" "PANGO_ATTR_ABSOLUTE_LINE_HEIGHT" "32")
+    '("text-transform" "PANGO_ATTR_TEXT_TRANSFORM" "33")
+    '("word" "PANGO_ATTR_WORD" "34")
+    '("sentence" "PANGO_ATTR_SENTENCE" "35")
+    '("baseline-shift" "PANGO_ATTR_BASELINE_SHIFT" "36")
+    '("font-scale" "PANGO_ATTR_FONT_SCALE" "37")
   )
 )
 
@@ -135,6 +149,61 @@
   )
 )
 
+;; Original typedef:
+;; typedef enum {
+;;   PANGO_TEXT_TRANSFORM_NONE,
+;;   PANGO_TEXT_TRANSFORM_LOWERCASE,
+;;   PANGO_TEXT_TRANSFORM_UPPERCASE,
+;;   PANGO_TEXT_TRANSFORM_CAPITALIZE,
+;; } PangoTextTransform;
+
+(define-enum-extended TextTransform
+  (in-module "Pango")
+  (c-name "PangoTextTransform")
+  (values
+    '("none" "PANGO_TEXT_TRANSFORM_NONE" "0")
+    '("lowercase" "PANGO_TEXT_TRANSFORM_LOWERCASE" "1")
+    '("uppercase" "PANGO_TEXT_TRANSFORM_UPPERCASE" "2")
+    '("capitalize" "PANGO_TEXT_TRANSFORM_CAPITALIZE" "3")
+  )
+)
+
+;; Original typedef:
+;; typedef enum {
+;;   PANGO_BASELINE_SHIFT_NONE,
+;;   PANGO_BASELINE_SHIFT_SUPERSCRIPT,
+;;   PANGO_BASELINE_SHIFT_SUBSCRIPT,
+;; } PangoBaselineShift;
+
+(define-enum-extended BaselineShift
+  (in-module "Pango")
+  (c-name "PangoBaselineShift")
+  (values
+    '("none" "PANGO_BASELINE_SHIFT_NONE" "0")
+    '("superscript" "PANGO_BASELINE_SHIFT_SUPERSCRIPT" "1")
+    '("subscript" "PANGO_BASELINE_SHIFT_SUBSCRIPT" "2")
+  )
+)
+
+;; Original typedef:
+;; typedef enum {
+;;   PANGO_FONT_SCALE_NONE,
+;;   PANGO_FONT_SCALE_SUPERSCRIPT,
+;;   PANGO_FONT_SCALE_SUBSCRIPT,
+;;   PANGO_FONT_SCALE_SMALL_CAPS,
+;; } PangoFontScale;
+
+(define-enum-extended FontScale
+  (in-module "Pango")
+  (c-name "PangoFontScale")
+  (values
+    '("none" "PANGO_FONT_SCALE_NONE" "0")
+    '("superscript" "PANGO_FONT_SCALE_SUPERSCRIPT" "1")
+    '("subscript" "PANGO_FONT_SCALE_SUBSCRIPT" "2")
+    '("small-caps" "PANGO_FONT_SCALE_SMALL_CAPS" "3")
+  )
+)
+
 ;; From pango-bidi-type.h
 
 ;; Original typedef:
@@ -162,7 +231,13 @@
 ;;   PANGO_BIDI_TYPE_B,
 ;;   PANGO_BIDI_TYPE_S,
 ;;   PANGO_BIDI_TYPE_WS,
-;;   PANGO_BIDI_TYPE_ON
+;;   PANGO_BIDI_TYPE_ON,
+;; 
+;;   /* Explicit formatting */
+;;   PANGO_BIDI_TYPE_LRI,
+;;   PANGO_BIDI_TYPE_RLI,
+;;   PANGO_BIDI_TYPE_FSI,
+;;   PANGO_BIDI_TYPE_PDI
 ;; } PangoBidiType;
 
 (define-enum-extended BidiType
@@ -188,6 +263,10 @@
     '("s" "PANGO_BIDI_TYPE_S" "16")
     '("ws" "PANGO_BIDI_TYPE_WS" "17")
     '("on" "PANGO_BIDI_TYPE_ON" "18")
+    '("lri" "PANGO_BIDI_TYPE_LRI" "19")
+    '("rli" "PANGO_BIDI_TYPE_RLI" "20")
+    '("fsi" "PANGO_BIDI_TYPE_FSI" "21")
+    '("pdi" "PANGO_BIDI_TYPE_PDI" "22")
   )
 )
 
@@ -261,7 +340,12 @@
 ;; Original typedef:
 ;; typedef enum {
 ;;   PANGO_VARIANT_NORMAL,
-;;   PANGO_VARIANT_SMALL_CAPS
+;;   PANGO_VARIANT_SMALL_CAPS,
+;;   PANGO_VARIANT_ALL_SMALL_CAPS,
+;;   PANGO_VARIANT_PETITE_CAPS,
+;;   PANGO_VARIANT_ALL_PETITE_CAPS,
+;;   PANGO_VARIANT_UNICASE,
+;;   PANGO_VARIANT_TITLE_CAPS
 ;; } PangoVariant;
 
 (define-enum-extended Variant
@@ -270,6 +354,11 @@
   (values
     '("normal" "PANGO_VARIANT_NORMAL" "0")
     '("small-caps" "PANGO_VARIANT_SMALL_CAPS" "1")
+    '("all-small-caps" "PANGO_VARIANT_ALL_SMALL_CAPS" "2")
+    '("petite-caps" "PANGO_VARIANT_PETITE_CAPS" "3")
+    '("all-petite-caps" "PANGO_VARIANT_ALL_PETITE_CAPS" "4")
+    '("unicase" "PANGO_VARIANT_UNICASE" "5")
+    '("title-caps" "PANGO_VARIANT_TITLE_CAPS" "6")
   )
 )
 
@@ -476,6 +565,55 @@
   )
 )
 
+;; Original typedef:
+;; typedef enum {
+;;   PANGO_LAYOUT_SERIALIZE_DEFAULT = 0,
+;;   PANGO_LAYOUT_SERIALIZE_CONTEXT = 1 << 0,
+;;   PANGO_LAYOUT_SERIALIZE_OUTPUT = 1 << 1,
+;; } PangoLayoutSerializeFlags;
+
+(define-flags-extended LayoutSerializeFlags
+  (in-module "Pango")
+  (c-name "PangoLayoutSerializeFlags")
+  (values
+    '("default" "PANGO_LAYOUT_SERIALIZE_DEFAULT" "0x0")
+    '("context" "PANGO_LAYOUT_SERIALIZE_CONTEXT" "1 << 0")
+    '("output" "PANGO_LAYOUT_SERIALIZE_OUTPUT" "1 << 1")
+  )
+)
+
+;; Original typedef:
+;; typedef enum {
+;;   PANGO_LAYOUT_DESERIALIZE_INVALID,
+;;   PANGO_LAYOUT_DESERIALIZE_INVALID_VALUE,
+;;   PANGO_LAYOUT_DESERIALIZE_MISSING_VALUE,
+;; } PangoLayoutDeserializeError;
+
+(define-enum-extended LayoutDeserializeError
+  (in-module "Pango")
+  (c-name "PangoLayoutDeserializeError")
+  (values
+    '("invalid" "PANGO_LAYOUT_DESERIALIZE_INVALID" "0")
+    '("invalid-value" "PANGO_LAYOUT_DESERIALIZE_INVALID_VALUE" "1")
+    '("missing-value" "PANGO_LAYOUT_DESERIALIZE_MISSING_VALUE" "2")
+  )
+)
+
+;; Original typedef:
+;; typedef enum {
+;;   PANGO_LAYOUT_DESERIALIZE_DEFAULT = 0,
+;;   PANGO_LAYOUT_DESERIALIZE_CONTEXT = 1 << 0,
+;; } PangoLayoutDeserializeFlags;
+
+(define-flags-extended LayoutDeserializeFlags
+  (in-module "Pango")
+  (c-name "PangoLayoutDeserializeFlags")
+  (values
+    '("default" "PANGO_LAYOUT_DESERIALIZE_DEFAULT" "0x0")
+    '("context" "PANGO_LAYOUT_DESERIALIZE_CONTEXT" "1 << 0")
+  )
+)
+
 ;; From pango-ot.h
 
 ;; Original typedef:
@@ -788,15 +926,10 @@
 ;; Original typedef:
 ;; typedef enum
 ;; {
-;;   PANGO_TAB_LEFT
-;; 
-;;   /* These are not supported now, but may be in the
-;;    * future.
-;;    *
-;;    *  PANGO_TAB_RIGHT,
-;;    *  PANGO_TAB_CENTER,
-;;    *  PANGO_TAB_NUMERIC
-;;    */
+;;   PANGO_TAB_LEFT,
+;;   PANGO_TAB_RIGHT,
+;;   PANGO_TAB_CENTER,
+;;   PANGO_TAB_DECIMAL
 ;; } PangoTabAlign;
 
 (define-enum-extended TabAlign
@@ -804,6 +937,9 @@
   (c-name "PangoTabAlign")
   (values
     '("left" "PANGO_TAB_LEFT" "0")
+    '("right" "PANGO_TAB_RIGHT" "1")
+    '("center" "PANGO_TAB_CENTER" "2")
+    '("decimal" "PANGO_TAB_DECIMAL" "3")
   )
 )
 
diff --git a/pango/src/pango_methods.defs b/pango/src/pango_methods.defs
index ddc23dc..f4a5c47 100644
--- a/pango/src/pango_methods.defs
+++ b/pango/src/pango_methods.defs
@@ -115,6 +115,13 @@
     '("insert-hyphens" "PANGO_ATTR_INSERT_HYPHENS")
     '("overline" "PANGO_ATTR_OVERLINE")
     '("overline-color" "PANGO_ATTR_OVERLINE_COLOR")
+    '("line-height" "PANGO_ATTR_LINE_HEIGHT")
+    '("absolute-line-height" "PANGO_ATTR_ABSOLUTE_LINE_HEIGHT")
+    '("text-transform" "PANGO_ATTR_TEXT_TRANSFORM")
+    '("word" "PANGO_ATTR_WORD")
+    '("sentence" "PANGO_ATTR_SENTENCE")
+    '("baseline-shift" "PANGO_ATTR_BASELINE_SHIFT")
+    '("font-scale" "PANGO_ATTR_FONT_SCALE")
   )
 )
 
@@ -156,6 +163,41 @@
   )
 )
 
+(define-enum TextTransform
+  (in-module "Pango")
+  (c-name "PangoTextTransform")
+  (gtype-id "PANGO_TYPE_TEXT_TRANSFORM")
+  (values
+    '("none" "PANGO_TEXT_TRANSFORM_NONE")
+    '("lowercase" "PANGO_TEXT_TRANSFORM_LOWERCASE")
+    '("uppercase" "PANGO_TEXT_TRANSFORM_UPPERCASE")
+    '("capitalize" "PANGO_TEXT_TRANSFORM_CAPITALIZE")
+  )
+)
+
+(define-enum BaselineShift
+  (in-module "Pango")
+  (c-name "PangoBaselineShift")
+  (gtype-id "PANGO_TYPE_BASELINE_SHIFT")
+  (values
+    '("none" "PANGO_BASELINE_SHIFT_NONE")
+    '("superscript" "PANGO_BASELINE_SHIFT_SUPERSCRIPT")
+    '("subscript" "PANGO_BASELINE_SHIFT_SUBSCRIPT")
+  )
+)
+
+(define-enum FontScale
+  (in-module "Pango")
+  (c-name "PangoFontScale")
+  (gtype-id "PANGO_TYPE_FONT_SCALE")
+  (values
+    '("none" "PANGO_FONT_SCALE_NONE")
+    '("superscript" "PANGO_FONT_SCALE_SUPERSCRIPT")
+    '("subscript" "PANGO_FONT_SCALE_SUBSCRIPT")
+    '("small-caps" "PANGO_FONT_SCALE_SMALL_CAPS")
+  )
+)
+
 (define-enum BidiType
   (in-module "Pango")
   (c-name "PangoBidiType")
@@ -180,6 +222,10 @@
     '("s" "PANGO_BIDI_TYPE_S")
     '("ws" "PANGO_BIDI_TYPE_WS")
     '("on" "PANGO_BIDI_TYPE_ON")
+    '("lri" "PANGO_BIDI_TYPE_LRI")
+    '("rli" "PANGO_BIDI_TYPE_RLI")
+    '("fsi" "PANGO_BIDI_TYPE_FSI")
+    '("pdi" "PANGO_BIDI_TYPE_PDI")
   )
 )
 
@@ -228,6 +274,11 @@
   (values
     '("normal" "PANGO_VARIANT_NORMAL")
     '("small-caps" "PANGO_VARIANT_SMALL_CAPS")
+    '("all-small-caps" "PANGO_VARIANT_ALL_SMALL_CAPS")
+    '("petite-caps" "PANGO_VARIANT_PETITE_CAPS")
+    '("all-petite-caps" "PANGO_VARIANT_ALL_PETITE_CAPS")
+    '("unicase" "PANGO_VARIANT_UNICASE")
+    '("title-caps" "PANGO_VARIANT_TITLE_CAPS")
   )
 )
 
@@ -352,6 +403,38 @@
   )
 )
 
+(define-flags LayoutSerializeFlags
+  (in-module "Pango")
+  (c-name "PangoLayoutSerializeFlags")
+  (gtype-id "PANGO_TYPE_LAYOUT_SERIALIZE_FLAGS")
+  (values
+    '("default" "PANGO_LAYOUT_SERIALIZE_DEFAULT")
+    '("context" "PANGO_LAYOUT_SERIALIZE_CONTEXT")
+    '("output" "PANGO_LAYOUT_SERIALIZE_OUTPUT")
+  )
+)
+
+(define-enum LayoutDeserializeError
+  (in-module "Pango")
+  (c-name "PangoLayoutDeserializeError")
+  (gtype-id "PANGO_TYPE_LAYOUT_DESERIALIZE_ERROR")
+  (values
+    '("invalid" "PANGO_LAYOUT_DESERIALIZE_INVALID")
+    '("invalid-value" "PANGO_LAYOUT_DESERIALIZE_INVALID_VALUE")
+    '("missing-value" "PANGO_LAYOUT_DESERIALIZE_MISSING_VALUE")
+  )
+)
+
+(define-flags LayoutDeserializeFlags
+  (in-module "Pango")
+  (c-name "PangoLayoutDeserializeFlags")
+  (gtype-id "PANGO_TYPE_LAYOUT_DESERIALIZE_FLAGS")
+  (values
+    '("default" "PANGO_LAYOUT_DESERIALIZE_DEFAULT")
+    '("context" "PANGO_LAYOUT_DESERIALIZE_CONTEXT")
+  )
+)
+
 (define-enum OTTableType
   (in-module "Pango")
   (c-name "PangoOTTableType")
@@ -507,64 +590,25 @@
   (gtype-id "PANGO_TYPE_TAB_ALIGN")
   (values
     '("left" "PANGO_TAB_LEFT")
+    '("right" "PANGO_TAB_RIGHT")
+    '("center" "PANGO_TAB_CENTER")
+    '("decimal" "PANGO_TAB_DECIMAL")
   )
 )
 
 
 ;; From pango-attributes.h
 
-(define-function pango_color_get_type
-  (c-name "pango_color_get_type")
-  (return-type "GType")
-)
-
 (define-function pango_attribute_get_type
   (c-name "pango_attribute_get_type")
   (return-type "GType")
 )
 
-(define-method copy
-  (of-object "PangoColor")
-  (c-name "pango_color_copy")
-  (return-type "PangoColor*")
-)
-
-(define-method free
-  (of-object "PangoColor")
-  (c-name "pango_color_free")
-  (return-type "none")
-)
-
-(define-method parse
-  (of-object "PangoColor")
-  (c-name "pango_color_parse")
-  (return-type "gboolean")
-  (parameters
-    '("const-char*" "spec")
-  )
-)
-
-(define-method parse_with_alpha
-  (of-object "PangoColor")
-  (c-name "pango_color_parse_with_alpha")
-  (return-type "gboolean")
-  (parameters
-    '("guint16*" "alpha")
-    '("const-char*" "spec")
-  )
-)
-
-(define-method to_string
-  (of-object "PangoColor")
-  (c-name "pango_color_to_string")
-  (return-type "gchar*")
-)
-
 (define-function pango_attr_type_register
   (c-name "pango_attr_type_register")
   (return-type "PangoAttrType")
   (parameters
-    '("const-gchar*" "name")
+    '("const-char*" "name")
   )
 )
 
@@ -755,6 +799,24 @@
   )
 )
 
+(define-function pango_attr_baseline_shift_new
+  (c-name "pango_attr_baseline_shift_new")
+  (is-constructor-of "PangoAttrBaselineShift")
+  (return-type "PangoAttribute*")
+  (parameters
+    '("int" "shift")
+  )
+)
+
+(define-function pango_attr_font_scale_new
+  (c-name "pango_attr_font_scale_new")
+  (is-constructor-of "PangoAttrFontScale")
+  (return-type "PangoAttribute*")
+  (parameters
+    '("PangoFontScale" "scale")
+  )
+)
+
 (define-function pango_attr_scale_new
   (c-name "pango_attr_scale_new")
   (is-constructor-of "PangoAttrScale")
@@ -827,7 +889,7 @@
   (is-constructor-of "PangoAttrFontFeatures")
   (return-type "PangoAttribute*")
   (parameters
-    '("const-gchar*" "features")
+    '("const-char*" "features")
   )
 )
 
@@ -858,6 +920,18 @@
   )
 )
 
+(define-function pango_attr_word_new
+  (c-name "pango_attr_word_new")
+  (is-constructor-of "PangoAttrWord")
+  (return-type "PangoAttribute*")
+)
+
+(define-function pango_attr_sentence_new
+  (c-name "pango_attr_sentence_new")
+  (is-constructor-of "PangoAttrSentence")
+  (return-type "PangoAttribute*")
+)
+
 (define-function pango_attr_insert_hyphens_new
   (c-name "pango_attr_insert_hyphens_new")
   (is-constructor-of "PangoAttrInsertHyphens")
@@ -896,6 +970,86 @@
   )
 )
 
+(define-function pango_attr_line_height_new
+  (c-name "pango_attr_line_height_new")
+  (is-constructor-of "PangoAttrLineHeight")
+  (return-type "PangoAttribute*")
+  (parameters
+    '("double" "factor")
+  )
+)
+
+(define-function pango_attr_line_height_new_absolute
+  (c-name "pango_attr_line_height_new_absolute")
+  (return-type "PangoAttribute*")
+  (parameters
+    '("int" "height")
+  )
+)
+
+(define-function pango_attr_text_transform_new
+  (c-name "pango_attr_text_transform_new")
+  (is-constructor-of "PangoAttrTextTransform")
+  (return-type "PangoAttribute*")
+  (parameters
+    '("PangoTextTransform" "transform")
+  )
+)
+
+(define-method as_string
+  (of-object "PangoAttribute")
+  (c-name "pango_attribute_as_string")
+  (return-type "PangoAttrString*")
+)
+
+(define-method as_language
+  (of-object "PangoAttribute")
+  (c-name "pango_attribute_as_language")
+  (return-type "PangoAttrLanguage*")
+)
+
+(define-method as_int
+  (of-object "PangoAttribute")
+  (c-name "pango_attribute_as_int")
+  (return-type "PangoAttrInt*")
+)
+
+(define-method as_size
+  (of-object "PangoAttribute")
+  (c-name "pango_attribute_as_size")
+  (return-type "PangoAttrSize*")
+)
+
+(define-method as_float
+  (of-object "PangoAttribute")
+  (c-name "pango_attribute_as_float")
+  (return-type "PangoAttrFloat*")
+)
+
+(define-method as_color
+  (of-object "PangoAttribute")
+  (c-name "pango_attribute_as_color")
+  (return-type "PangoAttrColor*")
+)
+
+(define-method as_font_desc
+  (of-object "PangoAttribute")
+  (c-name "pango_attribute_as_font_desc")
+  (return-type "PangoAttrFontDesc*")
+)
+
+(define-method as_shape
+  (of-object "PangoAttribute")
+  (c-name "pango_attribute_as_shape")
+  (return-type "PangoAttrShape*")
+)
+
+(define-method as_font_features
+  (of-object "PangoAttribute")
+  (c-name "pango_attribute_as_font_features")
+  (return-type "PangoAttrFontFeatures*")
+)
+
 (define-function pango_attr_list_get_type
   (c-name "pango_attr_list_get_type")
   (return-type "GType")
@@ -958,8 +1112,8 @@
   (return-type "none")
   (parameters
     '("PangoAttrList*" "other")
-    '("gint" "pos")
-    '("gint" "len")
+    '("int" "pos")
+    '("int" "len")
   )
 )
 
@@ -999,6 +1153,20 @@
   )
 )
 
+(define-method to_string
+  (of-object "PangoAttrList")
+  (c-name "pango_attr_list_to_string")
+  (return-type "char*")
+)
+
+(define-function pango_attr_list_from_string
+  (c-name "pango_attr_list_from_string")
+  (return-type "PangoAttrList*")
+  (parameters
+    '("const-char*" "text")
+  )
+)
+
 (define-function pango_attr_iterator_get_type
   (c-name "pango_attr_iterator_get_type")
   (return-type "GType")
@@ -1015,8 +1183,8 @@
   (c-name "pango_attr_iterator_range")
   (return-type "none")
   (parameters
-    '("gint*" "start")
-    '("gint*" "end")
+    '("int*" "start")
+    '("int*" "end")
   )
 )
 
@@ -1064,41 +1232,6 @@
   (return-type "GSList*")
 )
 
-(define-function pango_parse_markup
-  (c-name "pango_parse_markup")
-  (return-type "gboolean")
-  (parameters
-    '("const-char*" "markup_text")
-    '("int" "length")
-    '("gunichar" "accel_marker")
-    '("PangoAttrList**" "attr_list")
-    '("char**" "text")
-    '("gunichar*" "accel_char")
-    '("GError**" "error")
-  )
-)
-
-(define-function pango_markup_parser_new
-  (c-name "pango_markup_parser_new")
-  (is-constructor-of "PangoMarkupParser")
-  (return-type "GMarkupParseContext*")
-  (parameters
-    '("gunichar" "accel_marker")
-  )
-)
-
-(define-function pango_markup_parser_finish
-  (c-name "pango_markup_parser_finish")
-  (return-type "gboolean")
-  (parameters
-    '("GMarkupParseContext*" "context")
-    '("PangoAttrList**" "attr_list")
-    '("char**" "text")
-    '("gunichar*" "accel_char")
-    '("GError**" "error")
-  )
-)
-
 
 
 ;; From pango-bidi-type.h
@@ -1145,7 +1278,7 @@
   (c-name "pango_break")
   (return-type "none")
   (parameters
-    '("const-gchar*" "text")
+    '("const-char*" "text")
     '("int" "length")
     '("PangoAnalysis*" "analysis")
     '("PangoLogAttr*" "attrs")
@@ -1153,17 +1286,6 @@
   )
 )
 
-(define-function pango_find_paragraph_boundary
-  (c-name "pango_find_paragraph_boundary")
-  (return-type "none")
-  (parameters
-    '("const-gchar*" "text")
-    '("gint" "length")
-    '("gint*" "paragraph_delimiter_index")
-    '("gint*" "next_paragraph_start")
-  )
-)
-
 (define-function pango_get_log_attrs
   (c-name "pango_get_log_attrs")
   (return-type "none")
@@ -1172,7 +1294,7 @@
     '("int" "length")
     '("int" "level")
     '("PangoLanguage*" "language")
-    '("PangoLogAttr*" "log_attrs")
+    '("PangoLogAttr*" "attrs")
     '("int" "attrs_len")
   )
 )
@@ -1181,7 +1303,7 @@
   (c-name "pango_default_break")
   (return-type "none")
   (parameters
-    '("const-gchar*" "text")
+    '("const-char*" "text")
     '("int" "length")
     '("PangoAnalysis*" "analysis")
     '("PangoLogAttr*" "attrs")
@@ -1197,8 +1319,21 @@
     '("int" "length")
     '("PangoAnalysis*" "analysis")
     '("int" "offset")
-    '("PangoLogAttr*" "log_attrs")
-    '("int" "log_attrs_len")
+    '("PangoLogAttr*" "attrs")
+    '("int" "attrs_len")
+  )
+)
+
+(define-function pango_attr_break
+  (c-name "pango_attr_break")
+  (return-type "none")
+  (parameters
+    '("const-char*" "text")
+    '("int" "length")
+    '("PangoAttrList*" "attr_list")
+    '("int" "offset")
+    '("PangoLogAttr*" "attrs")
+    '("int" "attrs_len")
   )
 )
 
@@ -1484,6 +1619,52 @@
 
 
 
+;; From pango-color.h
+
+(define-function pango_color_get_type
+  (c-name "pango_color_get_type")
+  (return-type "GType")
+)
+
+(define-method copy
+  (of-object "PangoColor")
+  (c-name "pango_color_copy")
+  (return-type "PangoColor*")
+)
+
+(define-method free
+  (of-object "PangoColor")
+  (c-name "pango_color_free")
+  (return-type "none")
+)
+
+(define-method parse
+  (of-object "PangoColor")
+  (c-name "pango_color_parse")
+  (return-type "gboolean")
+  (parameters
+    '("const-char*" "spec")
+  )
+)
+
+(define-method parse_with_alpha
+  (of-object "PangoColor")
+  (c-name "pango_color_parse_with_alpha")
+  (return-type "gboolean")
+  (parameters
+    '("guint16*" "alpha")
+    '("const-char*" "spec")
+  )
+)
+
+(define-method to_string
+  (of-object "PangoColor")
+  (c-name "pango_color_to_string")
+  (return-type "char*")
+)
+
+
+
 ;; From pango-color-table.h
 
 
@@ -1678,33 +1859,6 @@
   (return-type "gboolean")
 )
 
-(define-function pango_itemize
-  (c-name "pango_itemize")
-  (return-type "GList*")
-  (parameters
-    '("PangoContext*" "context")
-    '("const-char*" "text")
-    '("int" "start_index")
-    '("int" "length")
-    '("PangoAttrList*" "attrs")
-    '("PangoAttrIterator*" "cached_iter")
-  )
-)
-
-(define-function pango_itemize_with_base_dir
-  (c-name "pango_itemize_with_base_dir")
-  (return-type "GList*")
-  (parameters
-    '("PangoContext*" "context")
-    '("PangoDirection" "base_dir")
-    '("const-char*" "text")
-    '("int" "start_index")
-    '("int" "length")
-    '("PangoAttrList*" "attrs")
-    '("PangoAttrIterator*" "cached_iter")
-  )
-)
-
 
 
 ;; From pangocoretext.h
@@ -2578,6 +2732,28 @@
   (return-type "hb_font_t*")
 )
 
+(define-method get_languages
+  (of-object "PangoFont")
+  (c-name "pango_font_get_languages")
+  (return-type "PangoLanguage**")
+)
+
+(define-method serialize
+  (of-object "PangoFont")
+  (c-name "pango_font_serialize")
+  (return-type "GBytes*")
+)
+
+(define-function pango_font_deserialize
+  (c-name "pango_font_deserialize")
+  (return-type "PangoFont*")
+  (parameters
+    '("PangoContext*" "context")
+    '("GBytes*" "bytes")
+    '("GError**" "error")
+  )
+)
+
 
 
 ;; From pango-fontmap.h
@@ -2883,6 +3059,11 @@
 
 ;; From pango-glyph.h
 
+(define-function pango_glyph_string_get_type
+  (c-name "pango_glyph_string_get_type")
+  (return-type "GType")
+)
+
 (define-function pango_glyph_string_new
   (c-name "pango_glyph_string_new")
   (is-constructor-of "PangoGlyphString")
@@ -2894,15 +3075,10 @@
   (c-name "pango_glyph_string_set_size")
   (return-type "none")
   (parameters
-    '("gint" "new_len")
+    '("int" "new_len")
   )
 )
 
-(define-function pango_glyph_string_get_type
-  (c-name "pango_glyph_string_get_type")
-  (return-type "GType")
-)
-
 (define-method copy
   (of-object "PangoGlyphString")
   (c-name "pango_glyph_string_copy")
@@ -2962,7 +3138,7 @@
   (c-name "pango_glyph_string_index_to_x")
   (return-type "none")
   (parameters
-    '("char*" "text")
+    '("const-char*" "text")
     '("int" "length")
     '("PangoAnalysis*" "analysis")
     '("int" "index_")
@@ -2976,7 +3152,7 @@
   (c-name "pango_glyph_string_x_to_index")
   (return-type "none")
   (parameters
-    '("char*" "text")
+    '("const-char*" "text")
     '("int" "length")
     '("PangoAnalysis*" "analysis")
     '("int" "x_pos")
@@ -2985,6 +3161,21 @@
   )
 )
 
+(define-method index_to_x_full
+  (of-object "PangoGlyphString")
+  (c-name "pango_glyph_string_index_to_x_full")
+  (return-type "none")
+  (parameters
+    '("const-char*" "text")
+    '("int" "length")
+    '("PangoAnalysis*" "analysis")
+    '("PangoLogAttr*" "attrs")
+    '("int" "index_")
+    '("gboolean" "trailing")
+    '("int*" "x_pos")
+  )
+)
+
 (define-function pango_shape
   (c-name "pango_shape")
   (return-type "none")
@@ -3023,11 +3214,16 @@
   )
 )
 
-(define-function pango_reorder_items
-  (c-name "pango_reorder_items")
-  (return-type "GList*")
+(define-function pango_shape_item
+  (c-name "pango_shape_item")
+  (return-type "none")
   (parameters
-    '("GList*" "logical_items")
+    '("PangoItem*" "item")
+    '("const-char*" "paragraph_text")
+    '("int" "paragraph_length")
+    '("PangoLogAttr*" "log_attrs")
+    '("PangoGlyphString*" "glyphs")
+    '("PangoShapeFlags" "flags")
   )
 )
 
@@ -3189,6 +3385,14 @@
 
 ;; From pango-impl-utils.h
 
+(define-function pango_is_default_ignorable
+  (c-name "pango_is_default_ignorable")
+  (return-type "gboolean")
+  (parameters
+    '("gunichar" "ch")
+  )
+)
+
 
 
 ;; From pango-item.h
@@ -3235,6 +3439,41 @@
   )
 )
 
+(define-function pango_reorder_items
+  (c-name "pango_reorder_items")
+  (return-type "GList*")
+  (parameters
+    '("GList*" "items")
+  )
+)
+
+(define-function pango_itemize
+  (c-name "pango_itemize")
+  (return-type "GList*")
+  (parameters
+    '("PangoContext*" "context")
+    '("const-char*" "text")
+    '("int" "start_index")
+    '("int" "length")
+    '("PangoAttrList*" "attrs")
+    '("PangoAttrIterator*" "cached_iter")
+  )
+)
+
+(define-function pango_itemize_with_base_dir
+  (c-name "pango_itemize_with_base_dir")
+  (return-type "GList*")
+  (parameters
+    '("PangoContext*" "context")
+    '("PangoDirection" "base_dir")
+    '("const-char*" "text")
+    '("int" "start_index")
+    '("int" "length")
+    '("PangoAttrList*" "attrs")
+    '("PangoAttrIterator*" "cached_iter")
+  )
+)
+
 
 
 ;; From pango-language.h
@@ -3244,6 +3483,16 @@
   (return-type "GType")
 )
 
+(define-function pango_language_get_default
+  (c-name "pango_language_get_default")
+  (return-type "PangoLanguage*")
+)
+
+(define-function pango_language_get_preferred
+  (c-name "pango_language_get_preferred")
+  (return-type "PangoLanguage**")
+)
+
 (define-function pango_language_from_string
   (c-name "pango_language_from_string")
   (return-type "PangoLanguage*")
@@ -3264,16 +3513,6 @@
   (return-type "const-char*")
 )
 
-(define-function pango_language_get_default
-  (c-name "pango_language_get_default")
-  (return-type "PangoLanguage*")
-)
-
-(define-function pango_language_get_preferred
-  (c-name "pango_language_get_preferred")
-  (return-type "PangoLanguage**")
-)
-
 (define-method matches
   (of-object "PangoLanguage")
   (c-name "pango_language_matches")
@@ -3520,6 +3759,21 @@
   (return-type "gboolean")
 )
 
+(define-method set_justify_last_line
+  (of-object "PangoLayout")
+  (c-name "pango_layout_set_justify_last_line")
+  (return-type "none")
+  (parameters
+    '("gboolean" "justify")
+  )
+)
+
+(define-method get_justify_last_line
+  (of-object "PangoLayout")
+  (c-name "pango_layout_get_justify_last_line")
+  (return-type "gboolean")
+)
+
 (define-method set_auto_dir
   (of-object "PangoLayout")
   (c-name "pango_layout_set_auto_dir")
@@ -3680,6 +3934,17 @@
   )
 )
 
+(define-method get_caret_pos
+  (of-object "PangoLayout")
+  (c-name "pango_layout_get_caret_pos")
+  (return-type "none")
+  (parameters
+    '("int" "index_")
+    '("PangoRectangle*" "strong_pos")
+    '("PangoRectangle*" "weak_pos")
+  )
+)
+
 (define-method move_cursor_visually
   (of-object "PangoLayout")
   (c-name "pango_layout_move_cursor_visually")
@@ -3788,6 +4053,42 @@
   (return-type "GSList*")
 )
 
+(define-method serialize
+  (of-object "PangoLayout")
+  (c-name "pango_layout_serialize")
+  (return-type "GBytes*")
+  (parameters
+    '("PangoLayoutSerializeFlags" "flags")
+  )
+)
+
+(define-method write_to_file
+  (of-object "PangoLayout")
+  (c-name "pango_layout_write_to_file")
+  (return-type "gboolean")
+  (parameters
+    '("PangoLayoutSerializeFlags" "flags")
+    '("const-char*" "filename")
+    '("GError**" "error")
+  )
+)
+
+(define-function pango_layout_deserialize_error_quark
+  (c-name "pango_layout_deserialize_error_quark")
+  (return-type "GQuark")
+)
+
+(define-function pango_layout_deserialize
+  (c-name "pango_layout_deserialize")
+  (return-type "PangoLayout*")
+  (parameters
+    '("PangoContext*" "context")
+    '("GBytes*" "bytes")
+    '("PangoLayoutDeserializeFlags" "flags")
+    '("GError**" "error")
+  )
+)
+
 (define-function pango_layout_line_get_type
   (c-name "pango_layout_line_get_type")
   (return-type "GType")
@@ -3805,6 +4106,30 @@
   (return-type "none")
 )
 
+(define-method get_start_index
+  (of-object "PangoLayoutLine")
+  (c-name "pango_layout_line_get_start_index")
+  (return-type "int")
+)
+
+(define-method get_length
+  (of-object "PangoLayoutLine")
+  (c-name "pango_layout_line_get_length")
+  (return-type "int")
+)
+
+(define-method is_paragraph_start
+  (of-object "PangoLayoutLine")
+  (c-name "pango_layout_line_is_paragraph_start")
+  (return-type "gboolean")
+)
+
+(define-method get_resolved_direction
+  (of-object "PangoLayoutLine")
+  (c-name "pango_layout_line_get_resolved_direction")
+  (return-type "PangoDirection")
+)
+
 (define-method x_to_index
   (of-object "PangoLayoutLine")
   (c-name "pango_layout_line_x_to_index")
@@ -4022,6 +4347,51 @@
   (return-type "int")
 )
 
+(define-method get_run_baseline
+  (of-object "PangoLayoutIter")
+  (c-name "pango_layout_iter_get_run_baseline")
+  (return-type "int")
+)
+
+
+
+;; From pango-markup.h
+
+(define-function pango_markup_parser_new
+  (c-name "pango_markup_parser_new")
+  (is-constructor-of "PangoMarkupParser")
+  (return-type "GMarkupParseContext*")
+  (parameters
+    '("gunichar" "accel_marker")
+  )
+)
+
+(define-function pango_markup_parser_finish
+  (c-name "pango_markup_parser_finish")
+  (return-type "gboolean")
+  (parameters
+    '("GMarkupParseContext*" "context")
+    '("PangoAttrList**" "attr_list")
+    '("char**" "text")
+    '("gunichar*" "accel_char")
+    '("GError**" "error")
+  )
+)
+
+(define-function pango_parse_markup
+  (c-name "pango_parse_markup")
+  (return-type "gboolean")
+  (parameters
+    '("const-char*" "markup_text")
+    '("int" "length")
+    '("gunichar" "accel_marker")
+    '("PangoAttrList**" "attr_list")
+    '("char**" "text")
+    '("gunichar*" "accel_char")
+    '("GError**" "error")
+  )
+)
+
 
 
 ;; From pango-matrix.h
@@ -4849,6 +5219,54 @@
   (return-type "gboolean")
 )
 
+(define-method set_positions_in_pixels
+  (of-object "PangoTabArray")
+  (c-name "pango_tab_array_set_positions_in_pixels")
+  (return-type "none")
+  (parameters
+    '("gboolean" "positions_in_pixels")
+  )
+)
+
+(define-method to_string
+  (of-object "PangoTabArray")
+  (c-name "pango_tab_array_to_string")
+  (return-type "char*")
+)
+
+(define-function pango_tab_array_from_string
+  (c-name "pango_tab_array_from_string")
+  (return-type "PangoTabArray*")
+  (parameters
+    '("const-char*" "text")
+  )
+)
+
+(define-method set_decimal_point
+  (of-object "PangoTabArray")
+  (c-name "pango_tab_array_set_decimal_point")
+  (return-type "none")
+  (parameters
+    '("int" "tab_index")
+    '("gunichar" "decimal_point")
+  )
+)
+
+(define-method get_decimal_point
+  (of-object "PangoTabArray")
+  (c-name "pango_tab_array_get_decimal_point")
+  (return-type "gunichar")
+  (parameters
+    '("int" "tab_index")
+  )
+)
+
+(define-method sort
+  (of-object "PangoTabArray")
+  (c-name "pango_tab_array_sort")
+  (return-type "none")
+)
+
 
 
 ;; From pango-types.h
@@ -5021,6 +5439,17 @@
   )
 )
 
+(define-function pango_find_paragraph_boundary
+  (c-name "pango_find_paragraph_boundary")
+  (return-type "none")
+  (parameters
+    '("const-char*" "text")
+    '("int" "length")
+    '("int*" "paragraph_delimiter_index")
+    '("int*" "next_paragraph_start")
+  )
+)
+
 (define-function pango_version
   (c-name "pango_version")
   (return-type "int")
@@ -5490,6 +5919,21 @@
   (return-type "GType")
 )
 
+(define-function pango_text_transform_get_type
+  (c-name "pango_text_transform_get_type")
+  (return-type "GType")
+)
+
+(define-function pango_baseline_shift_get_type
+  (c-name "pango_baseline_shift_get_type")
+  (return-type "GType")
+)
+
+(define-function pango_font_scale_get_type
+  (c-name "pango_font_scale_get_type")
+  (return-type "GType")
+)
+
 (define-function pango_bidi_type_get_type
   (c-name "pango_bidi_type_get_type")
   (return-type "GType")
@@ -5560,6 +6004,21 @@
   (return-type "GType")
 )
 
+(define-function pango_layout_serialize_flags_get_type
+  (c-name "pango_layout_serialize_flags_get_type")
+  (return-type "GType")
+)
+
+(define-function pango_layout_deserialize_error_get_type
+  (c-name "pango_layout_deserialize_error_get_type")
+  (return-type "GType")
+)
+
+(define-function pango_layout_deserialize_flags_get_type
+  (c-name "pango_layout_deserialize_flags_get_type")
+  (return-type "GType")
+)
+
 (define-function pango_render_part_get_type
   (c-name "pango_render_part_get_type")
   (return-type "GType")


[Date Prev][Date Next]   [Thread Prev][Thread Next]   [Thread Index] [Date Index] [Author Index]