[HB] Ouch. Add files.
This commit is contained in:
parent
fe550f4dd8
commit
c7d457aa3a
@ -30,11 +30,11 @@
|
|||||||
#include <stdint.h>
|
#include <stdint.h>
|
||||||
|
|
||||||
# ifdef __cplusplus
|
# ifdef __cplusplus
|
||||||
# define HB_BEGIN_DECLS() extern "C" { extern int hb_dummy_prototype (int)
|
# define HB_BEGIN_DECLS() extern "C" { extern int _hb_dummy_prototype1 (int)
|
||||||
# define HB_END_DECLS() } extern "C" int hb_dummy_prototype (int)
|
# define HB_END_DECLS() } extern "C" int _hb_dummy_prototype2 (int)
|
||||||
# else /* !__cplusplus */
|
# else /* !__cplusplus */
|
||||||
# define HB_BEGIN_DECLS() extern int hb_dummy_prototype (int)
|
# define HB_BEGIN_DECLS() extern int _hb_dummy_prototype1 (int)
|
||||||
# define HB_END_DECLS() extern int hb_dummy_prototype (int)
|
# define HB_END_DECLS() extern int _hb_dummy_prototype2 (int)
|
||||||
# endif /* !__cplusplus */
|
# endif /* !__cplusplus */
|
||||||
|
|
||||||
typedef int hb_bool_t;
|
typedef int hb_bool_t;
|
||||||
@ -47,8 +47,7 @@ typedef uint32_t hb_tag_t;
|
|||||||
((const char *) s)[3]))
|
((const char *) s)[3]))
|
||||||
|
|
||||||
typedef uint32_t hb_codepoint_t;
|
typedef uint32_t hb_codepoint_t;
|
||||||
|
typedef int32_t hb_position_t;
|
||||||
/* XXX */
|
typedef int32_t hb_16dot16_t;
|
||||||
typedef struct HB_BufferRec_ hb_buffer_t;
|
|
||||||
|
|
||||||
#endif /* HB_COMMON_H */
|
#endif /* HB_COMMON_H */
|
||||||
|
@ -27,6 +27,8 @@
|
|||||||
#ifndef HB_PRIVATE_H
|
#ifndef HB_PRIVATE_H
|
||||||
#define HB_PRIVATE_H
|
#define HB_PRIVATE_H
|
||||||
|
|
||||||
|
#include <hb-common.h>
|
||||||
|
|
||||||
#include <glib.h>
|
#include <glib.h>
|
||||||
|
|
||||||
/* Macros to convert to/from BigEndian */
|
/* Macros to convert to/from BigEndian */
|
||||||
@ -39,12 +41,36 @@
|
|||||||
#define hb_be_uint64_t GUINT64_TO_BE
|
#define hb_be_uint64_t GUINT64_TO_BE
|
||||||
#define hb_be_int64_t GINT64_TO_BE
|
#define hb_be_int64_t GINT64_TO_BE
|
||||||
|
|
||||||
#define HB_LIKELY G_LIKEYLY
|
#define HB_LIKELY G_LIKELY
|
||||||
#define HB_UNLIKELY G_UNLIKELY
|
#define HB_UNLIKELY G_UNLIKELY
|
||||||
#define HB_UNUSED(arg) ((arg) = (arg))
|
#define HB_UNUSED(arg) ((arg) = (arg))
|
||||||
|
#define HB_GNUC_UNUSED G_GNUC_UNUSED
|
||||||
|
|
||||||
|
|
||||||
#include <assert.h>
|
#include <stdlib.h>
|
||||||
|
#include <stdio.h> /* XXX */
|
||||||
|
|
||||||
|
/* Basics */
|
||||||
|
|
||||||
|
#undef MIN
|
||||||
|
#define MIN(a,b) ((a) < (b) ? (a) : (b))
|
||||||
|
|
||||||
|
#ifndef HB_INTERNAL
|
||||||
|
# define HB_INTERNAL
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifndef NULL
|
||||||
|
# define NULL ((void *)0)
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifndef FALSE
|
||||||
|
# define FALSE 0
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifndef TRUE
|
||||||
|
# define TRUE 1
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
#define _ASSERT_STATIC1(_line, _cond) typedef int _static_assert_on_line_##_line##_failed[(_cond)?1:-1]
|
#define _ASSERT_STATIC1(_line, _cond) typedef int _static_assert_on_line_##_line##_failed[(_cond)?1:-1]
|
||||||
#define _ASSERT_STATIC0(_line, _cond) _ASSERT_STATIC1 (_line, (_cond))
|
#define _ASSERT_STATIC0(_line, _cond) _ASSERT_STATIC1 (_line, (_cond))
|
||||||
@ -52,11 +78,55 @@
|
|||||||
|
|
||||||
#define ASSERT_SIZE(_type, _size) ASSERT_STATIC (sizeof (_type) == (_size))
|
#define ASSERT_SIZE(_type, _size) ASSERT_STATIC (sizeof (_type) == (_size))
|
||||||
|
|
||||||
|
|
||||||
|
/* Return the number of 1 bits in mask.
|
||||||
|
*
|
||||||
|
* GCC 3.4 supports a "population count" builtin, which on many targets is
|
||||||
|
* implemented with a single instruction. There is a fallback definition
|
||||||
|
* in libgcc in case a target does not have one, which should be just as
|
||||||
|
* good as the open-coded solution below, (which is "HACKMEM 169").
|
||||||
|
*/
|
||||||
|
static inline unsigned int
|
||||||
|
_hb_popcount32 (uint32_t mask)
|
||||||
|
{
|
||||||
|
#if __GNUC__ > 3 || (__GNUC__ == 3 && __GNUC_MINOR__ >= 4)
|
||||||
|
return __builtin_popcount (mask);
|
||||||
|
#else
|
||||||
|
register int y;
|
||||||
|
|
||||||
|
y = (mask >> 1) &033333333333;
|
||||||
|
y = mask - y - ((y >>1) & 033333333333);
|
||||||
|
return (((y + (y >> 3)) & 030707070707) % 077);
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* buffer
|
* buffer
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/* XXX */
|
/* XXX */
|
||||||
#define HB_BUFFER_GLYPH_PROPERTIES_UNKNOWN 0xFFFF
|
#define HB_BUFFER_GLYPH_PROPERTIES_UNKNOWN 0xFFFF
|
||||||
|
#define HB_OT_GPOS_NO_LAST ((unsigned int) -1)
|
||||||
|
|
||||||
|
/* XXX */
|
||||||
|
typedef enum {
|
||||||
|
/* no error */
|
||||||
|
HB_Err_Ok = 0x0000,
|
||||||
|
HB_Err_Not_Covered = 0xFFFF,
|
||||||
|
|
||||||
|
/* _hb_err() is called whenever returning the following errors,
|
||||||
|
* and in a couple places for HB_Err_Not_Covered too. */
|
||||||
|
|
||||||
|
/* programmer error */
|
||||||
|
HB_Err_Invalid_Argument = 0x1A66,
|
||||||
|
|
||||||
|
/* font error */
|
||||||
|
HB_Err_Invalid_SubTable_Format = 0x157F,
|
||||||
|
HB_Err_Invalid_SubTable = 0x1570,
|
||||||
|
HB_Err_Read_Error = 0x6EAD,
|
||||||
|
|
||||||
|
/* system error */
|
||||||
|
HB_Err_Out_Of_Memory = 0xDEAD
|
||||||
|
} HB_Error;
|
||||||
|
|
||||||
#endif /* HB_PRIVATE_H */
|
#endif /* HB_PRIVATE_H */
|
||||||
|
Loading…
Reference in New Issue
Block a user