build: Build the DirectWrite sources if requested

This adds to the autotools build system so that the (experimental)
DirectWrite support for HarfBuzz is built (and dist'ed).
This commit is contained in:
Chun-wei Fan 2016-02-03 18:31:23 +08:00
parent d7b6636e5e
commit c679285455
3 changed files with 35 additions and 0 deletions

View File

@ -356,6 +356,30 @@ AM_CONDITIONAL(HAVE_UNISCRIBE, $have_uniscribe)
dnl =========================================================================== dnl ===========================================================================
AC_ARG_WITH(directwrite,
[AS_HELP_STRING([--with-directwrite=@<:@yes/no/auto@:>@],
[Use the DirectWrite library (experimental) @<:@default=no@:>@])],,
[with_directwrite=no])
have_directwrite=false
AC_LANG_PUSH([C++])
if test "x$with_directwrite" = "xyes" -o "x$with_directwrite" = "xauto"; then
AC_CHECK_HEADERS(dwrite.h, have_directwrite=true)
fi
AC_LANG_POP([C++])
if test "x$with_directwrite" = "xyes" -a "x$have_directwrite" != "xtrue"; then
AC_MSG_ERROR([directwrite support requested but not found])
fi
if $have_directwrite; then
DIRECTWRITE_CXXFLAGS=
DIRECTWRITE_LIBS="-ldwrite"
AC_SUBST(DIRECTWRITE_CXXFLAGS)
AC_SUBST(DIRECTWRITE_LIBS)
AC_DEFINE(HAVE_DIRECTWRITE, 1, [Have DirectWrite library])
fi
AM_CONDITIONAL(HAVE_DIRECTWRITE, $have_directwrite)
dnl ===========================================================================
AC_ARG_WITH(coretext, AC_ARG_WITH(coretext,
[AS_HELP_STRING([--with-coretext=@<:@yes/no/auto@:>@], [AS_HELP_STRING([--with-coretext=@<:@yes/no/auto@:>@],
[Use CoreText @<:@default=no@:>@])],, [Use CoreText @<:@default=no@:>@])],,
@ -472,6 +496,7 @@ Additional shapers (the more the better):
Platform shapers (not normally needed): Platform shapers (not normally needed):
CoreText: ${have_coretext} CoreText: ${have_coretext}
Uniscribe: ${have_uniscribe} Uniscribe: ${have_uniscribe}
DirectWrite: ${have_directwrite}
Other features: Other features:
Documentation: ${have_gtk_doc} Documentation: ${have_gtk_doc}

View File

@ -78,6 +78,13 @@ HBSOURCES += $(HB_UNISCRIBE_sources)
HBHEADERS += $(HB_UNISCRIBE_headers) HBHEADERS += $(HB_UNISCRIBE_headers)
endif endif
if HAVE_DIRECTWRITE
HBCFLAGS += $(DIRECTWRITE_CXXFLAGS)
HBNONPCLIBS += $(DIRECTWRITE_LIBS)
HBSOURCES += $(HB_DIRECTWRITE_sources)
HBHEADERS += $(HB_DIRECTWRITE_headers)
endif
if HAVE_CORETEXT if HAVE_CORETEXT
HBCFLAGS += $(CORETEXT_CFLAGS) HBCFLAGS += $(CORETEXT_CFLAGS)
HBNONPCLIBS += $(CORETEXT_LIBS) HBNONPCLIBS += $(CORETEXT_LIBS)

View File

@ -130,6 +130,9 @@ HB_GRAPHITE2_headers = hb-graphite2.h
HB_CORETEXT_sources = hb-coretext.cc HB_CORETEXT_sources = hb-coretext.cc
HB_CORETEXT_headers = hb-coretext.h HB_CORETEXT_headers = hb-coretext.h
HB_DIRECTWRITE_sources = hb-directwrite.cc
HB_DIRECTWRITE_headers = hb-directwrite.h
HB_UNISCRIBE_sources = hb-uniscribe.cc HB_UNISCRIBE_sources = hb-uniscribe.cc
HB_UNISCRIBE_headers = hb-uniscribe.h HB_UNISCRIBE_headers = hb-uniscribe.h