harfbuzz/src/hb-private.h

106 lines
2.9 KiB
C
Raw Normal View History

2008-01-23 22:14:38 +01:00
/*
2009-05-25 09:22:19 +02:00
* Copyright (C) 2007,2008,2009 Red Hat, Inc.
2008-01-23 22:14:38 +01:00
*
* This is part of HarfBuzz, an OpenType Layout engine library.
*
* Permission is hereby granted, without written agreement and without
* license or royalty fees, to use, copy, modify, and distribute this
* software and its documentation for any purpose, provided that the
* above copyright notice and the following two paragraphs appear in
* all copies of this software.
*
* IN NO EVENT SHALL THE COPYRIGHT HOLDER BE LIABLE TO ANY PARTY FOR
* DIRECT, INDIRECT, SPECIAL, INCIDENTAL, OR CONSEQUENTIAL DAMAGES
* ARISING OUT OF THE USE OF THIS SOFTWARE AND ITS DOCUMENTATION, EVEN
* IF THE COPYRIGHT HOLDER HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH
* DAMAGE.
*
* THE COPYRIGHT HOLDER SPECIFICALLY DISCLAIMS ANY WARRANTIES, INCLUDING,
* BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND
* FITNESS FOR A PARTICULAR PURPOSE. THE SOFTWARE PROVIDED HEREUNDER IS
* ON AN "AS IS" BASIS, AND THE COPYRIGHT HOLDER HAS NO OBLIGATION TO
* PROVIDE MAINTENANCE, SUPPORT, UPDATES, ENHANCEMENTS, OR MODIFICATIONS.
*
* Red Hat Author(s): Behdad Esfahbod
*/
2008-01-23 11:00:30 +01:00
#ifndef HB_PRIVATE_H
#define HB_PRIVATE_H
2006-12-28 12:42:37 +01:00
2009-07-28 21:43:34 +02:00
#include "hb-common.h"
2009-05-21 18:46:29 +02:00
#include <glib.h>
/* Macros to convert to/from BigEndian */
#define hb_be_uint8_t
#define hb_be_int8_t
#define hb_be_uint16_t GUINT16_TO_BE
#define hb_be_int16_t GINT16_TO_BE
#define hb_be_uint32_t GUINT32_TO_BE
#define hb_be_int32_t GINT32_TO_BE
#define hb_be_uint64_t GUINT64_TO_BE
#define hb_be_int64_t GINT64_TO_BE
2009-05-21 18:46:29 +02:00
#define HB_LIKELY G_LIKELY
#define HB_UNLIKELY G_UNLIKELY
2008-01-24 00:02:28 +01:00
#define HB_UNUSED(arg) ((arg) = (arg))
2009-05-21 18:46:29 +02:00
#define HB_GNUC_UNUSED G_GNUC_UNUSED
#include <stdlib.h>
#include <stdio.h> /* XXX */
2009-07-30 21:33:57 +02:00
#include <string.h>
#include <assert.h>
2009-05-21 18:46:29 +02:00
/* Basics */
#undef MIN
#define MIN(a,b) ((a) < (b) ? (a) : (b))
2008-01-24 00:02:28 +01:00
2009-05-21 18:46:29 +02:00
#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
2006-12-28 12:42:37 +01:00
2008-01-23 06:20:48 +01:00
#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_STATIC(_cond) _ASSERT_STATIC0 (__LINE__, (_cond))
#define ASSERT_SIZE(_type, _size) ASSERT_STATIC (sizeof (_type) == (_size))
2009-05-21 18:46:29 +02:00
/* 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
}
2008-01-23 11:00:30 +01:00
#endif /* HB_PRIVATE_H */