[pshinter] Use macros for (unsigned) flags, not enumerations.

* src/pshinter/pshalgo.h (PSH_Hint_Flags): Replace with macros.
Updated.
* src/pshinter/pshrec.h (PS_Hint_Flags): Replace with macros.
This commit is contained in:
Werner Lemberg 2015-02-22 15:57:47 +01:00
parent 25c2f8820f
commit 41c2ed8143
3 changed files with 31 additions and 32 deletions

View File

@ -1,3 +1,11 @@
2015-02-22 Werner Lemberg <wl@gnu.org>
[pshinter] Use macros for (unsigned) flags, not enumerations.
* src/pshinter/pshalgo.h (PSH_Hint_Flags): Replace with macros.
Updated.
* src/pshinter/pshrec.h (PS_Hint_Flags): Replace with macros.
2015-02-22 Werner Lemberg <wl@gnu.org> 2015-02-22 Werner Lemberg <wl@gnu.org>
* src/pshinter/pshrec.c: Simplify. * src/pshinter/pshrec.c: Simplify.

View File

@ -30,15 +30,12 @@ FT_BEGIN_HEADER
/* handle to Hint structure */ /* handle to Hint structure */
typedef struct PSH_HintRec_* PSH_Hint; typedef struct PSH_HintRec_* PSH_Hint;
/* hint bit-flags */
typedef enum PSH_Hint_Flags_
{
PSH_HINT_GHOST = PS_HINT_FLAG_GHOST,
PSH_HINT_BOTTOM = PS_HINT_FLAG_BOTTOM,
PSH_HINT_ACTIVE = 4,
PSH_HINT_FITTED = 8
} PSH_Hint_Flags; /* hint bit-flags */
#define PSH_HINT_GHOST PS_HINT_FLAG_GHOST
#define PSH_HINT_BOTTOM PS_HINT_FLAG_BOTTOM
#define PSH_HINT_ACTIVE 4U
#define PSH_HINT_FITTED 8U
#define psh_hint_is_active( x ) ( ( (x)->flags & PSH_HINT_ACTIVE ) != 0 ) #define psh_hint_is_active( x ) ( ( (x)->flags & PSH_HINT_ACTIVE ) != 0 )
@ -49,6 +46,7 @@ FT_BEGIN_HEADER
#define psh_hint_deactivate( x ) (x)->flags &= ~PSH_HINT_ACTIVE #define psh_hint_deactivate( x ) (x)->flags &= ~PSH_HINT_ACTIVE
#define psh_hint_set_fitted( x ) (x)->flags |= PSH_HINT_FITTED #define psh_hint_set_fitted( x ) (x)->flags |= PSH_HINT_FITTED
/* hint structure */ /* hint structure */
typedef struct PSH_HintRec_ typedef struct PSH_HintRec_
{ {
@ -112,14 +110,12 @@ FT_BEGIN_HEADER
#define PSH_DIR_IS_VERTICAL( d ) PSH_DIR_COMPARE( d, PSH_DIR_VERTICAL ) #define PSH_DIR_IS_VERTICAL( d ) PSH_DIR_COMPARE( d, PSH_DIR_VERTICAL )
/* the following bit-flags are computed once by the glyph */ /* the following bit-flags are computed once by the glyph */
/* analyzer, for both dimensions */ /* analyzer, for both dimensions */
enum #define PSH_POINT_OFF 1U /* point is off the curve */
{ #define PSH_POINT_SMOOTH 2U /* point is smooth */
PSH_POINT_OFF = 1, /* point is off the curve */ #define PSH_POINT_INFLEX 4U /* point is inflection */
PSH_POINT_SMOOTH = 2, /* point is smooth */
PSH_POINT_INFLEX = 4 /* point is inflection */
};
#define psh_point_is_smooth( p ) ( (p)->flags & PSH_POINT_SMOOTH ) #define psh_point_is_smooth( p ) ( (p)->flags & PSH_POINT_SMOOTH )
#define psh_point_is_off( p ) ( (p)->flags & PSH_POINT_OFF ) #define psh_point_is_off( p ) ( (p)->flags & PSH_POINT_OFF )
@ -129,17 +125,16 @@ FT_BEGIN_HEADER
#define psh_point_set_off( p ) (p)->flags |= PSH_POINT_OFF #define psh_point_set_off( p ) (p)->flags |= PSH_POINT_OFF
#define psh_point_set_inflex( p ) (p)->flags |= PSH_POINT_INFLEX #define psh_point_set_inflex( p ) (p)->flags |= PSH_POINT_INFLEX
/* the following bit-flags are re-computed for each dimension */ /* the following bit-flags are re-computed for each dimension */
enum #define PSH_POINT_STRONG 16U /* point is strong */
{ #define PSH_POINT_FITTED 32U /* point is already fitted */
PSH_POINT_STRONG = 16, /* point is strong */ #define PSH_POINT_EXTREMUM 64U /* point is local extremum */
PSH_POINT_FITTED = 32, /* point is already fitted */ #define PSH_POINT_POSITIVE 128U /* extremum has positive contour flow */
PSH_POINT_EXTREMUM = 64, /* point is local extremum */ #define PSH_POINT_NEGATIVE 256U /* extremum has negative contour flow */
PSH_POINT_POSITIVE = 128, /* extremum has positive contour flow */ #define PSH_POINT_EDGE_MIN 512U /* point is aligned to left/bottom stem edge */
PSH_POINT_NEGATIVE = 256, /* extremum has negative contour flow */ #define PSH_POINT_EDGE_MAX 1024U /* point is aligned to top/right stem edge */
PSH_POINT_EDGE_MIN = 512, /* point is aligned to left/bottom stem edge */
PSH_POINT_EDGE_MAX = 1024 /* point is aligned to top/right stem edge */
};
#define psh_point_is_strong( p ) ( (p)->flags2 & PSH_POINT_STRONG ) #define psh_point_is_strong( p ) ( (p)->flags2 & PSH_POINT_STRONG )
#define psh_point_is_fitted( p ) ( (p)->flags2 & PSH_POINT_FITTED ) #define psh_point_is_fitted( p ) ( (p)->flags2 & PSH_POINT_FITTED )

View File

@ -61,12 +61,8 @@ FT_BEGIN_HEADER
/* hint flags */ /* hint flags */
typedef enum PS_Hint_Flags_ #define PS_HINT_FLAG_GHOST 1U
{ #define PS_HINT_FLAG_BOTTOM 2U
PS_HINT_FLAG_GHOST = 1,
PS_HINT_FLAG_BOTTOM = 2
} PS_Hint_Flags;
/* hint descriptor */ /* hint descriptor */