[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[freetype2] master 4a85db7e3: [type1/MM] Tighten headers.
From: |
Werner Lemberg |
Subject: |
[freetype2] master 4a85db7e3: [type1/MM] Tighten headers. |
Date: |
Sat, 11 May 2024 22:22:08 -0400 (EDT) |
branch: master
commit 4a85db7e3181f23126af6c4473b245e48f6b1902
Author: Alexei Podtelezhnikov <apodtele@gmail.com>
Commit: Alexei Podtelezhnikov <apodtele@gmail.com>
[type1/MM] Tighten headers.
* include/freetype/internal/t1types.h: Host PS_DesignMap and PS_Blend.
* include/freetype/ftmm.h: Host and document TT_MAX_MM_XXX.
* include/freetype/t1tables.h: Remove them from here.
---
include/freetype/ftmm.h | 27 +++++++++++++++--
include/freetype/internal/t1types.h | 50 +++++++++++++++++++++++++++++++-
include/freetype/t1tables.h | 58 -------------------------------------
3 files changed, 73 insertions(+), 62 deletions(-)
diff --git a/include/freetype/ftmm.h b/include/freetype/ftmm.h
index a6e3e34fb..a85d0be43 100644
--- a/include/freetype/ftmm.h
+++ b/include/freetype/ftmm.h
@@ -20,9 +20,6 @@
#define FTMM_H_
-#include <freetype/t1tables.h>
-
-
FT_BEGIN_HEADER
@@ -53,6 +50,30 @@ FT_BEGIN_HEADER
*/
+ /**************************************************************************
+ *
+ * @enum:
+ * T1_MAX_MM_XXX
+ *
+ * @description:
+ * Multiple Masters limits as defined in their specifications.
+ *
+ * @values:
+ * T1_MAX_MM_AXIS ::
+ * The maximum number of Multiple Masters axes.
+ *
+ * T1_MAX_MM_DESIGNS ::
+ * The maximum number of Multiple Masters designs.
+ *
+ * T1_MAX_MM_MAP_POINTS ::
+ * The maximum number of elements in a design map.
+ *
+ */
+#define T1_MAX_MM_AXIS 4
+#define T1_MAX_MM_DESIGNS 16
+#define T1_MAX_MM_MAP_POINTS 20
+
+
/**************************************************************************
*
* @struct:
diff --git a/include/freetype/internal/t1types.h
b/include/freetype/internal/t1types.h
index be63e4dcf..1821ae5cc 100644
--- a/include/freetype/internal/t1types.h
+++ b/include/freetype/internal/t1types.h
@@ -21,7 +21,7 @@
#define T1TYPES_H_
-#include <freetype/t1tables.h>
+#include <freetype/ftmm.h>
#include <freetype/internal/pshints.h>
#include <freetype/internal/ftserv.h>
#include <freetype/internal/fthash.h>
@@ -137,6 +137,54 @@ FT_BEGIN_HEADER
} CID_SubrsRec, *CID_Subrs;
+ /* this structure is used to store the BlendDesignMap entry for an axis */
+ typedef struct PS_DesignMap_
+ {
+ FT_Byte num_points;
+ FT_Long* design_points;
+ FT_Fixed* blend_points;
+
+ } PS_DesignMapRec, *PS_DesignMap;
+
+ /* backward compatible definition */
+ typedef PS_DesignMapRec T1_DesignMap;
+
+
+ typedef struct PS_BlendRec_
+ {
+ FT_UInt num_designs;
+ FT_UInt num_axis;
+
+ FT_String* axis_names[T1_MAX_MM_AXIS];
+ FT_Fixed* design_pos[T1_MAX_MM_DESIGNS];
+ PS_DesignMapRec design_map[T1_MAX_MM_AXIS];
+
+ FT_Fixed* weight_vector;
+ FT_Fixed* default_weight_vector;
+
+ PS_FontInfo font_infos[T1_MAX_MM_DESIGNS + 1];
+ PS_Private privates [T1_MAX_MM_DESIGNS + 1];
+
+ FT_ULong blend_bitflags;
+
+ FT_BBox* bboxes [T1_MAX_MM_DESIGNS + 1];
+
+ /* since 2.3.0 */
+
+ /* undocumented, optional: the default design instance; */
+ /* corresponds to default_weight_vector -- */
+ /* num_default_design_vector == 0 means it is not present */
+ /* in the font and associated metrics files */
+ FT_UInt default_design_vector[T1_MAX_MM_DESIGNS];
+ FT_UInt num_default_design_vector;
+
+ } PS_BlendRec, *PS_Blend;
+
+
+ /* backward compatible definition */
+ typedef PS_BlendRec T1_Blend;
+
+
/*************************************************************************/
/*************************************************************************/
/*************************************************************************/
diff --git a/include/freetype/t1tables.h b/include/freetype/t1tables.h
index 8a1b10593..fbd558aa3 100644
--- a/include/freetype/t1tables.h
+++ b/include/freetype/t1tables.h
@@ -269,64 +269,6 @@ FT_BEGIN_HEADER
/* */
- /* maximum number of Multiple Masters designs, as defined in the spec */
-#define T1_MAX_MM_DESIGNS 16
-
- /* maximum number of Multiple Masters axes, as defined in the spec */
-#define T1_MAX_MM_AXIS 4
-
- /* maximum number of elements in a design map */
-#define T1_MAX_MM_MAP_POINTS 20
-
-
- /* this structure is used to store the BlendDesignMap entry for an axis */
- typedef struct PS_DesignMap_
- {
- FT_Byte num_points;
- FT_Long* design_points;
- FT_Fixed* blend_points;
-
- } PS_DesignMapRec, *PS_DesignMap;
-
- /* backward compatible definition */
- typedef PS_DesignMapRec T1_DesignMap;
-
-
- typedef struct PS_BlendRec_
- {
- FT_UInt num_designs;
- FT_UInt num_axis;
-
- FT_String* axis_names[T1_MAX_MM_AXIS];
- FT_Fixed* design_pos[T1_MAX_MM_DESIGNS];
- PS_DesignMapRec design_map[T1_MAX_MM_AXIS];
-
- FT_Fixed* weight_vector;
- FT_Fixed* default_weight_vector;
-
- PS_FontInfo font_infos[T1_MAX_MM_DESIGNS + 1];
- PS_Private privates [T1_MAX_MM_DESIGNS + 1];
-
- FT_ULong blend_bitflags;
-
- FT_BBox* bboxes [T1_MAX_MM_DESIGNS + 1];
-
- /* since 2.3.0 */
-
- /* undocumented, optional: the default design instance; */
- /* corresponds to default_weight_vector -- */
- /* num_default_design_vector == 0 means it is not present */
- /* in the font and associated metrics files */
- FT_UInt default_design_vector[T1_MAX_MM_DESIGNS];
- FT_UInt num_default_design_vector;
-
- } PS_BlendRec, *PS_Blend;
-
-
- /* backward compatible definition */
- typedef PS_BlendRec T1_Blend;
-
-
/**************************************************************************
*
* @struct:
[Prev in Thread] |
Current Thread |
[Next in Thread] |
- [freetype2] master 4a85db7e3: [type1/MM] Tighten headers.,
Werner Lemberg <=