This commit is contained in:
Steven R. Loomis 2025-04-03 16:05:02 -07:00 committed by GitHub
commit 4c49d1190d
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
10 changed files with 138 additions and 22 deletions

View file

@ -721,6 +721,8 @@ INSTALL_DATA
INSTALL_SCRIPT
INSTALL_PROGRAM
CPP
OTHER_ICUUC_LIBS
OTHER_ICUUC_CFLAGS
ICULEHB_LIBS
ICULEHB_CFLAGS
PKG_CONFIG_LIBDIR
@ -771,7 +773,6 @@ infodir
docdir
oldincludedir
includedir
runstatedir
localstatedir
sharedstatedir
sysconfdir
@ -838,6 +839,8 @@ PKG_CONFIG_PATH
PKG_CONFIG_LIBDIR
ICULEHB_CFLAGS
ICULEHB_LIBS
OTHER_ICUUC_CFLAGS
OTHER_ICUUC_LIBS
CPP'
@ -877,7 +880,6 @@ datadir='${datarootdir}'
sysconfdir='${prefix}/etc'
sharedstatedir='${prefix}/com'
localstatedir='${prefix}/var'
runstatedir='${localstatedir}/run'
includedir='${prefix}/include'
oldincludedir='/usr/include'
docdir='${datarootdir}/doc/${PACKAGE_TARNAME}'
@ -1128,15 +1130,6 @@ do
| -silent | --silent | --silen | --sile | --sil)
silent=yes ;;
-runstatedir | --runstatedir | --runstatedi | --runstated \
| --runstate | --runstat | --runsta | --runst | --runs \
| --run | --ru | --r)
ac_prev=runstatedir ;;
-runstatedir=* | --runstatedir=* | --runstatedi=* | --runstated=* \
| --runstate=* | --runstat=* | --runsta=* | --runst=* | --runs=* \
| --run=* | --ru=* | --r=*)
runstatedir=$ac_optarg ;;
-sbindir | --sbindir | --sbindi | --sbind | --sbin | --sbi | --sb)
ac_prev=sbindir ;;
-sbindir=* | --sbindir=* | --sbindi=* | --sbind=* | --sbin=* \
@ -1274,7 +1267,7 @@ fi
for ac_var in exec_prefix prefix bindir sbindir libexecdir datarootdir \
datadir sysconfdir sharedstatedir localstatedir includedir \
oldincludedir docdir infodir htmldir dvidir pdfdir psdir \
libdir localedir mandir runstatedir
libdir localedir mandir
do
eval ac_val=\$$ac_var
# Remove trailing slashes.
@ -1427,7 +1420,6 @@ Fine tuning of the installation directories:
--sysconfdir=DIR read-only single-machine data [PREFIX/etc]
--sharedstatedir=DIR modifiable architecture-independent data [PREFIX/com]
--localstatedir=DIR modifiable single-machine data [PREFIX/var]
--runstatedir=DIR modifiable per-process data [LOCALSTATEDIR/run]
--libdir=DIR object code libraries [EPREFIX/lib]
--includedir=DIR C header files [PREFIX/include]
--oldincludedir=DIR C header files for non-gcc [/usr/include]
@ -1522,6 +1514,10 @@ Some influential environment variables:
C compiler flags for ICULEHB, overriding pkg-config
ICULEHB_LIBS
linker flags for ICULEHB, overriding pkg-config
OTHER_ICUUC_CFLAGS
C compiler flags for OTHER_ICUUC, overriding pkg-config
OTHER_ICUUC_LIBS
linker flags for OTHER_ICUUC, overriding pkg-config
CPP C preprocessor
Use these variables to override the choices made by 'configure' or to help
@ -4685,6 +4681,78 @@ else
printf "%s\n" "yes" >&6; }
have_icu_le_hb=true
fi
# is there another ICUUC installed? For layoutex.
pkg_failed=no
{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for OTHER_ICUUC" >&5
$as_echo_n "checking for OTHER_ICUUC... " >&6; }
if test -n "$OTHER_ICUUC_CFLAGS"; then
pkg_cv_OTHER_ICUUC_CFLAGS="$OTHER_ICUUC_CFLAGS"
elif test -n "$PKG_CONFIG"; then
if test -n "$PKG_CONFIG" && \
{ { $as_echo "$as_me:${as_lineno-$LINENO}: \$PKG_CONFIG --exists --print-errors \"icu-uc\""; } >&5
($PKG_CONFIG --exists --print-errors "icu-uc") 2>&5
ac_status=$?
$as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5
test $ac_status = 0; }; then
pkg_cv_OTHER_ICUUC_CFLAGS=`$PKG_CONFIG --cflags "icu-uc" 2>/dev/null`
test "x$?" != "x0" && pkg_failed=yes
else
pkg_failed=yes
fi
else
pkg_failed=untried
fi
if test -n "$OTHER_ICUUC_LIBS"; then
pkg_cv_OTHER_ICUUC_LIBS="$OTHER_ICUUC_LIBS"
elif test -n "$PKG_CONFIG"; then
if test -n "$PKG_CONFIG" && \
{ { $as_echo "$as_me:${as_lineno-$LINENO}: \$PKG_CONFIG --exists --print-errors \"icu-uc\""; } >&5
($PKG_CONFIG --exists --print-errors "icu-uc") 2>&5
ac_status=$?
$as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5
test $ac_status = 0; }; then
pkg_cv_OTHER_ICUUC_LIBS=`$PKG_CONFIG --libs "icu-uc" 2>/dev/null`
test "x$?" != "x0" && pkg_failed=yes
else
pkg_failed=yes
fi
else
pkg_failed=untried
fi
if test $pkg_failed = yes; then
{ $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5
$as_echo "no" >&6; }
if $PKG_CONFIG --atleast-pkgconfig-version 0.20; then
_pkg_short_errors_supported=yes
else
_pkg_short_errors_supported=no
fi
if test $_pkg_short_errors_supported = yes; then
OTHER_ICUUC_PKG_ERRORS=`$PKG_CONFIG --short-errors --print-errors --cflags --libs "icu-uc" 2>&1`
else
OTHER_ICUUC_PKG_ERRORS=`$PKG_CONFIG --print-errors --cflags --libs "icu-uc" 2>&1`
fi
# Put the nasty error message in config.log where it belongs
echo "$OTHER_ICUUC_PKG_ERRORS" >&5
:
elif test $pkg_failed = untried; then
{ $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5
$as_echo "no" >&6; }
:
else
OTHER_ICUUC_CFLAGS=$pkg_cv_OTHER_ICUUC_CFLAGS
OTHER_ICUUC_LIBS=$pkg_cv_OTHER_ICUUC_LIBS
{ $as_echo "$as_me:${as_lineno-$LINENO}: result: yes" >&5
$as_echo "yes" >&6; }
have_other_icu_uc=true
fi
# Ensure that if CXXFLAGS/CFLAGS were not set when calling configure, set it correctly based on (enable/disable) debug or release option
# The release mode use is the default one for autoconf

View file

@ -143,6 +143,8 @@ AC_MSG_NOTICE([versions of the compilers used:])
# pkg-config is needed for harfbuzz support
PKG_PROG_PKG_CONFIG([0.20])
PKG_CHECK_MODULES(ICULEHB, icu-le-hb, have_icu_le_hb=true, :)
# is there another ICUUC installed? For layoutex.
PKG_CHECK_MODULES(OTHER_ICUUC, icu-uc, have_other_icu_uc=true, :)
# Ensure that if CXXFLAGS/CFLAGS were not set when calling configure, set it correctly based on (enable/disable) debug or release option
# The release mode use is the default one for autoconf
@ -638,7 +640,7 @@ sparc-*-solaris*)
ia64-*-hpux*)
# There has been some issues with building ICU data on HPUX ia64 aCC
# when using the assemble code setting below. For now, build without
# assemble code for this platform. This will increase the build time.
# assemble code for this platform. This will increase the build time.
# GENCCODE_ASSEMBLY="-a aCC-ia64"
;;
esac

View file

@ -50,13 +50,13 @@ SO_TARGET_VERSION_MAJOR = @LIB_VERSION_MAJOR@
# The ICU data external name is usually icudata; the entry point name is
# the version-dependent name (for no particular reason except it was easier
# to change the build this way). When building in common mode, the data
# name is the versioned platform-dependent one.
# name is the versioned platform-dependent one.
ICUDATA_DIR = @pkgicudatadir@/$(PACKAGE)$(ICULIBSUFFIX)/$(VERSION)
ICUDATA_BASENAME_VERSION = $(ICUPREFIX)dt@LIB_VERSION_MAJOR@
# the entry point is almost like the basename, but has the lib suffix.
ICUDATA_ENTRY_POINT = $(ICUPREFIX)dt@ICULIBSUFFIXCNAME@@LIB_VERSION_MAJOR@
# the entry point is almost like the basename, but has the lib suffix.
ICUDATA_ENTRY_POINT = $(ICUPREFIX)dt@ICULIBSUFFIXCNAME@@LIB_VERSION_MAJOR@
ICUDATA_CHAR = @ICUDATA_CHAR@
ICUDATA_PLATFORM_NAME = $(ICUDATA_BASENAME_VERSION)$(ICUDATA_CHAR)
PKGDATA_LIBSTATICNAME = -L $(STATIC_PREFIX)$(ICUPREFIX)$(DATA_STUBNAME)$(ICULIBSUFFIX)
@ -210,7 +210,7 @@ LIBICU = $(LIBPREFIX)$(ICUPREFIX)
ifneq ($(ENABLE_SHARED),YES)
STATIC_PREFIX_WHEN_USED = s
else
STATIC_PREFIX_WHEN_USED =
STATIC_PREFIX_WHEN_USED =
endif
# Static library prefix and file extension
@ -268,6 +268,18 @@ ICULEHB_TRUE=#
ICULEHB_FALSE=
endif
OTHER_ICUUC_CFLAGS=@OTHER_ICUUC_CFLAGS@
OTHER_ICUUC_LIBS=@OTHER_ICUUC_LIBS@
ifneq ($(OTHER_ICUUC_CFLAGS),)
HAVE_OTHER_ICUUC=yes
OTHERICUUC_TRUE=
OTHERICUUC_FALSE=#
else
HAVE_OTHER_ICUUC=no
OTHERICUUC_TRUE=#
OTHERICUUC_FALSE=
endif
# Just the libs.
ICULIBS_DT = -l$(STATIC_PREFIX_WHEN_USED)$(ICUPREFIX)$(DATA_STUBNAME)$(ICULIBSUFFIX)$(SO_TARGET_VERSION_SUFFIX)
ICULIBS_UC = -l$(STATIC_PREFIX_WHEN_USED)$(ICUPREFIX)$(COMMON_STUBNAME)$(ICULIBSUFFIX)$(SO_TARGET_VERSION_SUFFIX)

View file

@ -56,16 +56,29 @@ CXXFLAGS += $(LIBCXXFLAGS)
ifeq ($(USING_ICULEHB),no)
# cppflags: load .. so that #include <layout/...> works
ICULE_CFLAGS=-I$(srcdir)/..
error("ICULEHB is required, see build instructions")
else
ICULE_CFLAGS=$(ICULEHB_CFLAGS)
endif
CPPFLAGS += -I$(srcdir) -I$(srcdir)/unicode -I$(top_srcdir)/common $(ICULE_CFLAGS) $(LIBCPPFLAGS)
CPPFLAGS += -I$(srcdir)
ifeq ($(HAVE_OTHER_ICUUC),yes)
# use other installed ICU
CPPFLAGS += $(OTHER_ICUUC_CFLAGS) -ULE_USE_CMEMORY
LIBS += $(OTHER_ICUUC_LIBS)
DEFS += -DHAVE_OTHER_ICUUC
# Do not set U_LAYOUTEX_IMPLEMENTATION
else
# attempt to use 'this' ICU
CPPFLAGS += -I$(srcdir)/unicode -I$(top_srcdir)/common $(ICULE_CFLAGS)
DEFS += -DU_LAYOUTEX_IMPLEMENTATION
LIBS += $(LIBICUUC) $(DEFAULT_LIBS)
endif
CPPFLAGS += $(LIBCPPFLAGS) $(ICULE_CFLAGS)
LDFLAGS += $(LDFLAGSICULX)
LIBS = $(LIBICUUC) $(LIBICULE) $(DEFAULT_LIBS)
LIBS += $(ICULEHB_LIBS)
SOURCES = $(shell cat $(srcdir)/sources.txt)
OBJECTS = $(SOURCES:.cpp=.o)

View file

@ -30,6 +30,14 @@
U_NAMESPACE_BEGIN
#ifndef FALSE
#define FALSE false
#endif
#ifndef TRUE
#define TRUE true
#endif
#define ARRAY_SIZE(array) (sizeof array / sizeof array[0])
/* Leave this copyright notice here! It needs to go somewhere in this library. */

View file

@ -16,6 +16,15 @@
U_NAMESPACE_BEGIN
#ifndef FALSE
#define FALSE false
#endif
#ifndef TRUE
#define TRUE true
#endif
const char RunArray::fgClassID = 0;
RunArray::RunArray(le_int32 initialCapacity)

View file

@ -0,0 +1 @@
../common/cmemory.h

View file

@ -0,0 +1 @@
../common/cstring.h

View file

@ -0,0 +1 @@
../common/uassert.h

View file

@ -0,0 +1 @@
../common/usc_impl.h