ref: 0c83ba6d61e686ca55c3cc763d48a38cb4d7ca67
parent: d01e28f41f8810c8ea422b854f8722659589fa99
author: Werner Lemberg <[email protected]>
date: Mon Dec 10 07:11:54 EST 2018
Minor documentation updates and fixes.
--- a/docs/CHANGES
+++ b/docs/CHANGES
@@ -53,7 +53,15 @@
- `FT_Outline_New_Internal' and `FT_Outline_Done_Internal' have
been removed. These two functions were public by oversight only
- and were never documented either.
+ and were never documented.
+
+ - A new function `FT_Error_String' returns descriptions of error
+ codes if configuration macro FT_CONFIG_OPTION_ERROR_STRINGS is
+ defined.
+
+ - `FT_Set_MM_WeightVector' and `FT_Get_MM_WeightVector' are new
+ functions limited to Adobe MultiMaster fonts to directly set and
+ get the weight vector.
======================================================================
--- a/docs/DOCGUIDE
+++ b/docs/DOCGUIDE
@@ -1,5 +1,6 @@
Introduction
------------
+
Documentation is an extremely important part of any project, and it
helps a lot if it uses consistent syntax and layout.
@@ -12,8 +13,10 @@
Documentation comments follow a specific structure and format as
described below.
+
Documentation Structure
-----------------------
+
The documentation is divided into multiple chapters, which contain
sections relevant to it. The chapter details and sections contained
in them are listed in `include/freetype/ftchapters.h`. Any unlisted
@@ -22,8 +25,10 @@
Sections may contain sub-sections which consist of properties,
enumerations, and other data types.
+
Comment Blocks
--------------
+
Documentation blocks follow a specific format:
/***************************** (should end on column 77)
@@ -38,8 +43,10 @@
block being handled by 'docwriter' (for example, change `/****/` to
`/*#**/`).
+
Markup Tags
-----------
+
Markup tags are used to indicate what comes next. The syntax for a
tag is:
@@ -47,8 +54,10 @@
An `@`, followed by the tag, and then `:`.
+
Reserved Tags
-------------
+
There are some keywords that have a special meaning to docwriter.
As a convention, all keywords are written in lowercase.
@@ -63,13 +72,17 @@
* `values`: A list of 'values' for the tag. These values are used for
cross-referencing.
+
Other Tags
----------
+
Except the ones given above, any other tags will be added as a part of
a subsection. All tags are lowercase by convention.
+
Public Header Definitions
-------------------------
+
The public headers for FreeType have their names defined in
`include/freetype/config/ftheader.h`. Any new public header file must
be defined in this file, in the following format:
@@ -81,14 +94,18 @@
This macro is combined with the file location of a sub-section and
printed with the object.
+
Note on code blocks captured after comments
-------------------------------------------
+
All non-documentation lines after a documentation comment block are
captured to be displayed as the code for the sub-section. To stop
collection, a line with `/* */` should be added.
+
General Formatting Conventions
------------------------------
+
* Use two spaces after a full stop ending a sentence.
* Use appropriate uppercasing in titles. Refer
@@ -97,8 +114,10 @@
for more information.
* Do not add trailing parentheses when citing a C function.
+
Markdown Usage
--------------
+
All tags, except the ones that define the name and title for a block
support markdown in them. Docwriter uses a markdown parser that
follows rules given in John Gruber's markdown guide:
@@ -108,8 +127,10 @@
with a few exceptions and extensions, detailed below. This may also
be referred to as the **FreeType Flavored Markdown**.
+
Headers
-------
+
Markdown headers should not be used directly, because these are added
based on section titles, sub-section names, and tags. However, if a
header needs to be added, note the following correspondence to HTML tags:
@@ -120,8 +141,10 @@
* Any header added will be visible in the Table of Contents (TOC) of
the page.
+
Emphasis
--------
+
* Use `_underscores_` for italics.
* Use `**double asterisks**` for bold.
@@ -138,8 +161,10 @@
absolutely required outside of an inline code block or code sequence,
escape it with a backslash (like `\*` or `\_`).
+
Lists
-----
+
Unordered lists can be created with asterisks:
* Unordered list items can use asterisks.
@@ -168,8 +193,10 @@
https://daringfireball.net/projects/markdown/syntax#list
+
Cross-references
----------------
+
Other sub-sections can be linked with the `@` symbol:
@description:
@@ -180,14 +207,18 @@
If a field in the `values` table of another sub-section is linked, the
link leads to its parent sub-section.
+
Links and Images
----------------
+
All URLs are converted to links in the HTML documentation.
Markdown syntax for links and images are fully supported.
+
Inline Code
-----------
+
To indicate a span of code, wrap it with backtick quotes (`` ` ``):
Use the `printf()` function.
@@ -195,8 +226,10 @@
Cross-references, markdown, and html styling do not work in inline code
sequences.
+
Code and Syntax Highlighting
----------------------------
+
Blocks of code are fenced by lines with three back-ticks `` ``` ``
followed by the language name, if any (used for syntax highlighting),
as demonstrated in the following example.
@@ -216,9 +249,11 @@
Like inline code, markdown and html styling is *not* supported inside
code blocks.
+
Tables
------
-Tables are used to list values, input, and other fields. The FreeType
+
+Tables are used to list values, input, and other fields. The FreeType
Flavored Markdown adopts a simple approach to tables with two columns,
or field definition tables.
@@ -235,8 +270,10 @@
See @FT_Open_Face for a detailed description of this
parameter.
+
Non-breaking Space
------------------
+
A tilde can be used to create a non-breaking space. The example
The encoding value~0 is reserved.
@@ -244,6 +281,7 @@
is converted to
The encoding value 0 is reserved.
+
----------------------------------------------------------------------
--- a/include/freetype/tttables.h
+++ b/include/freetype/tttables.h
@@ -79,8 +79,8 @@
* @description:
* A structure to model a TrueType font header table. All fields follow
* the OpenType specification. The 64-bit timestamps are stored in
- * two-member arrays `Created` and `Modified`, first upper then lower
- * 32 bits.
+ * two-element arrays `Created` and `Modified`, first the upper then
+ * the lower 32~bits.
*/
typedef struct TT_Header_
{