[util] Add option to set font function implementation to use
Supports ft and ot right now. hb-view currently not rendering with ot. Will fix after some clean up.
This commit is contained in:
parent
2306ad46dc
commit
8650def735
|
@ -28,10 +28,24 @@
|
||||||
|
|
||||||
#ifdef HAVE_FREETYPE
|
#ifdef HAVE_FREETYPE
|
||||||
#include <hb-ft.h>
|
#include <hb-ft.h>
|
||||||
#else
|
#endif
|
||||||
|
#ifdef HAVE_OT
|
||||||
#include <hb-ot-font.h>
|
#include <hb-ot-font.h>
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
struct supported_font_funcs_t {
|
||||||
|
char name[4];
|
||||||
|
void (*func) (hb_font_t *);
|
||||||
|
} supported_font_funcs[] =
|
||||||
|
{
|
||||||
|
#ifdef HAVE_FREETYPE
|
||||||
|
{"ft", hb_ft_font_set_funcs},
|
||||||
|
#endif
|
||||||
|
#ifdef HAVE_OT
|
||||||
|
{"ot", hb_ot_font_set_funcs},
|
||||||
|
#endif
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
void
|
void
|
||||||
fail (hb_bool_t suggest_help, const char *format, ...)
|
fail (hb_bool_t suggest_help, const char *format, ...)
|
||||||
|
@ -269,7 +283,7 @@ shape_options_t::add_options (option_parser_t *parser)
|
||||||
G_OPTION_ARG_CALLBACK, (gpointer) &list_shapers, "List available shapers and quit", NULL},
|
G_OPTION_ARG_CALLBACK, (gpointer) &list_shapers, "List available shapers and quit", NULL},
|
||||||
{"shaper", 0, G_OPTION_FLAG_HIDDEN,
|
{"shaper", 0, G_OPTION_FLAG_HIDDEN,
|
||||||
G_OPTION_ARG_CALLBACK, (gpointer) &parse_shapers, "Hidden duplicate of --shapers", NULL},
|
G_OPTION_ARG_CALLBACK, (gpointer) &parse_shapers, "Hidden duplicate of --shapers", NULL},
|
||||||
{"shapers", 0, 0, G_OPTION_ARG_CALLBACK, (gpointer) &parse_shapers, "Comma-separated list of shapers to try","list"},
|
{"shapers", 0, 0, G_OPTION_ARG_CALLBACK, (gpointer) &parse_shapers, "Set comma-separated list of shapers to try","list"},
|
||||||
{"direction", 0, 0, G_OPTION_ARG_STRING, &this->direction, "Set text direction (default: auto)", "ltr/rtl/ttb/btt"},
|
{"direction", 0, 0, G_OPTION_ARG_STRING, &this->direction, "Set text direction (default: auto)", "ltr/rtl/ttb/btt"},
|
||||||
{"language", 0, 0, G_OPTION_ARG_STRING, &this->language, "Set text language (default: $LANG)", "langstr"},
|
{"language", 0, 0, G_OPTION_ARG_STRING, &this->language, "Set text language (default: $LANG)", "langstr"},
|
||||||
{"script", 0, 0, G_OPTION_ARG_STRING, &this->script, "Set text script (default: auto)", "ISO-15924 tag"},
|
{"script", 0, 0, G_OPTION_ARG_STRING, &this->script, "Set text script (default: auto)", "ISO-15924 tag"},
|
||||||
|
@ -336,10 +350,28 @@ shape_options_t::add_options (option_parser_t *parser)
|
||||||
void
|
void
|
||||||
font_options_t::add_options (option_parser_t *parser)
|
font_options_t::add_options (option_parser_t *parser)
|
||||||
{
|
{
|
||||||
|
char *text = NULL;
|
||||||
|
|
||||||
|
{
|
||||||
|
ASSERT_STATIC (ARRAY_LENGTH_CONST (supported_font_funcs) > 0);
|
||||||
|
GString *s = g_string_new (NULL);
|
||||||
|
g_string_printf (s, "Set font functions implementation to use (default: %s)\n\n Supported font function implementations are: %s",
|
||||||
|
supported_font_funcs[0].name,
|
||||||
|
supported_font_funcs[0].name);
|
||||||
|
for (unsigned int i = 1; i < ARRAY_LENGTH (supported_font_funcs); i++)
|
||||||
|
{
|
||||||
|
g_string_append_c (s, '/');
|
||||||
|
g_string_append (s, supported_font_funcs[i].name);
|
||||||
|
}
|
||||||
|
text = g_string_free (s, FALSE);
|
||||||
|
parser->free_later (text);
|
||||||
|
}
|
||||||
|
|
||||||
GOptionEntry entries[] =
|
GOptionEntry entries[] =
|
||||||
{
|
{
|
||||||
{"font-file", 0, 0, G_OPTION_ARG_STRING, &this->font_file, "Font file-name", "filename"},
|
{"font-file", 0, 0, G_OPTION_ARG_STRING, &this->font_file, "Set font file-name", "filename"},
|
||||||
{"face-index", 0, 0, G_OPTION_ARG_INT, &this->face_index, "Face index (default: 0)", "index"},
|
{"face-index", 0, 0, G_OPTION_ARG_INT, &this->face_index, "Set face index (default: 0)", "index"},
|
||||||
|
{"font-funcs", 0, 0, G_OPTION_ARG_STRING, &this->font_funcs, text, "format"},
|
||||||
{NULL}
|
{NULL}
|
||||||
};
|
};
|
||||||
parser->add_group (entries,
|
parser->add_group (entries,
|
||||||
|
@ -484,11 +516,37 @@ font_options_t::get_font (void) const
|
||||||
hb_font_set_scale (font, upem, upem);
|
hb_font_set_scale (font, upem, upem);
|
||||||
hb_face_destroy (face);
|
hb_face_destroy (face);
|
||||||
|
|
||||||
#ifdef HAVE_FREETYPE
|
void (*set_font_funcs) (hb_font_t *) = NULL;
|
||||||
hb_ft_font_set_funcs (font);
|
if (!font_funcs)
|
||||||
#else
|
{
|
||||||
hb_ot_font_set_funcs (font);
|
set_font_funcs = supported_font_funcs[0].func;
|
||||||
#endif
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
for (unsigned int i = 0; i < ARRAY_LENGTH (supported_font_funcs); i++)
|
||||||
|
if (0 == strcasecmp (font_funcs, supported_font_funcs[i].name))
|
||||||
|
{
|
||||||
|
set_font_funcs = supported_font_funcs[i].func;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
if (!set_font_funcs)
|
||||||
|
{
|
||||||
|
GString *s = g_string_new (NULL);
|
||||||
|
for (unsigned int i = 0; i < ARRAY_LENGTH (supported_font_funcs); i++)
|
||||||
|
{
|
||||||
|
if (i)
|
||||||
|
g_string_append_c (s, '/');
|
||||||
|
g_string_append (s, supported_font_funcs[i].name);
|
||||||
|
}
|
||||||
|
char *p = g_string_free (s, FALSE);
|
||||||
|
fail (false, "Unknown font function implementation `%s'; supported values are: %s; default is %s",
|
||||||
|
font_funcs,
|
||||||
|
p,
|
||||||
|
supported_font_funcs[0].name);
|
||||||
|
//free (p);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
set_font_funcs (font);
|
||||||
|
|
||||||
return font;
|
return font;
|
||||||
}
|
}
|
||||||
|
|
|
@ -58,12 +58,31 @@
|
||||||
# define g_mapped_file_unref g_mapped_file_free
|
# define g_mapped_file_unref g_mapped_file_free
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
/* A few macros copied from hb-private.hh. */
|
||||||
|
|
||||||
|
#if __GNUC__ >= 4
|
||||||
|
#define HB_UNUSED __attribute__((unused))
|
||||||
|
#else
|
||||||
|
#define HB_UNUSED
|
||||||
|
#endif
|
||||||
|
|
||||||
#undef MIN
|
#undef MIN
|
||||||
template <typename Type> static inline Type MIN (const Type &a, const Type &b) { return a < b ? a : b; }
|
template <typename Type> static inline Type MIN (const Type &a, const Type &b) { return a < b ? a : b; }
|
||||||
|
|
||||||
#undef MAX
|
#undef MAX
|
||||||
template <typename Type> static inline Type MAX (const Type &a, const Type &b) { return a > b ? a : b; }
|
template <typename Type> static inline Type MAX (const Type &a, const Type &b) { return a > b ? a : b; }
|
||||||
|
|
||||||
|
#undef ARRAY_LENGTH
|
||||||
|
template <typename Type, unsigned int n>
|
||||||
|
static inline unsigned int ARRAY_LENGTH (const Type (&)[n]) { return n; }
|
||||||
|
/* A const version, but does not detect erratically being called on pointers. */
|
||||||
|
#define ARRAY_LENGTH_CONST(__array) ((signed int) (sizeof (__array) / sizeof (__array[0])))
|
||||||
|
|
||||||
|
#define _ASSERT_STATIC1(_line, _cond) HB_UNUSED 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))
|
||||||
|
|
||||||
|
|
||||||
void fail (hb_bool_t suggest_help, const char *format, ...) G_GNUC_NORETURN G_GNUC_PRINTF (2, 3);
|
void fail (hb_bool_t suggest_help, const char *format, ...) G_GNUC_NORETURN G_GNUC_PRINTF (2, 3);
|
||||||
|
|
||||||
|
@ -257,6 +276,7 @@ struct font_options_t : option_group_t
|
||||||
font_options_t (option_parser_t *parser) {
|
font_options_t (option_parser_t *parser) {
|
||||||
font_file = NULL;
|
font_file = NULL;
|
||||||
face_index = 0;
|
face_index = 0;
|
||||||
|
font_funcs = NULL;
|
||||||
|
|
||||||
font = NULL;
|
font = NULL;
|
||||||
|
|
||||||
|
@ -272,6 +292,7 @@ struct font_options_t : option_group_t
|
||||||
|
|
||||||
const char *font_file;
|
const char *font_file;
|
||||||
int face_index;
|
int face_index;
|
||||||
|
const char *font_funcs;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
mutable hb_font_t *font;
|
mutable hb_font_t *font;
|
||||||
|
|
Loading…
Reference in New Issue