From 7b3f4cf0121c2e16b1de710c4b3f15d214fec072 Mon Sep 17 00:00:00 2001 From: Tim Ruehsen Date: Mon, 23 Jun 2014 12:50:02 +0200 Subject: [PATCH 01/10] fixed psl_str_to_utf8lower prototype --- include/libpsl.h | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/include/libpsl.h b/include/libpsl.h index b7fe952..4ead03d 100644 --- a/include/libpsl.h +++ b/include/libpsl.h @@ -87,7 +87,7 @@ const char * const char * psl_registrable_domain(const psl_ctx_t *psl, const char *domain); /* convert a string into lowercase UTF-8 */ -int +psl_error_t psl_str_to_utf8lower(const char *str, const char *encoding, const char *locale, char **lower); /* does not include exceptions */ int From c9fd29a97774e6b159b53b3b217fbe1b01e15836 Mon Sep 17 00:00:00 2001 From: Tim Ruehsen Date: Mon, 23 Jun 2014 12:56:13 +0200 Subject: [PATCH 02/10] small doc format change --- src/psl.c | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/src/psl.c b/src/psl.c index 2875c35..46eaa47 100644 --- a/src/psl.c +++ b/src/psl.c @@ -849,7 +849,8 @@ int psl_is_cookie_domain_acceptable(const psl_ctx_t *psl, const char *hostname, * This helper function converts a string to lowercase UTF-8 representation. * Lowercase UTF-8 is needed as input to the domain checking functions. * - * @lower is %NULL on error. + * @lower is set to %NULL on error. + * * The return value 'lower' must be freed after usage. * * Returns: psl_error_t value. From c9f8ad42fe7355904662665a38b2082e2b05ef37 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Tim=20R=C3=BChsen?= Date: Fri, 27 Jun 2014 09:54:32 +0200 Subject: [PATCH 03/10] fixed authors name to UTF-8 --- COPYING | 2 +- LICENSE | 2 +- NEWS | 2 +- 3 files changed, 3 insertions(+), 3 deletions(-) diff --git a/COPYING b/COPYING index b6a1570..90c5c79 100644 --- a/COPYING +++ b/COPYING @@ -1,4 +1,4 @@ -Copyright (C) 2014 Tim Ruehsen +Copyright (C) 2014 Tim Rühsen Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), diff --git a/LICENSE b/LICENSE index b6a1570..90c5c79 100644 --- a/LICENSE +++ b/LICENSE @@ -1,4 +1,4 @@ -Copyright (C) 2014 Tim Ruehsen +Copyright (C) 2014 Tim Rühsen Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), diff --git a/NEWS b/NEWS index df6d258..8d0159c 100644 --- a/NEWS +++ b/NEWS @@ -1,4 +1,4 @@ -Copyright (C) 2014 Tim Ruehsen +Copyright (C) 2014 Tim Rühsen 23.06.2014 Release V0.4.0 * depend on libicu for punycode, utf-8 and lowercase conversions From fc8f72098b78f46fd8644817d84e62fe2fa4d8c9 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Tim=20R=C3=BChsen?= Date: Fri, 27 Jun 2014 09:55:47 +0200 Subject: [PATCH 04/10] removed ChangeLog (see NEWS for summarized changes) --- ChangeLog | 17 ----------------- 1 file changed, 17 deletions(-) delete mode 100644 ChangeLog diff --git a/ChangeLog b/ChangeLog deleted file mode 100644 index 714fcb1..0000000 --- a/ChangeLog +++ /dev/null @@ -1,17 +0,0 @@ -2014-03-20 gettextize - - * m4/gettext.m4: New file, from gettext-0.18.3. - * m4/iconv.m4: New file, from gettext-0.18.3. - * m4/lib-ld.m4: New file, from gettext-0.18.3. - * m4/lib-link.m4: New file, from gettext-0.18.3. - * m4/lib-prefix.m4: New file, from gettext-0.18.3. - * m4/nls.m4: New file, from gettext-0.18.3. - * m4/po.m4: New file, from gettext-0.18.3. - * m4/progtest.m4: New file, from gettext-0.18.3. - * Makefile.am (SUBDIRS): Add po. - (ACLOCAL_AMFLAGS): Add -I m4. - (EXTRA_DIST): New variable. - * configure.ac (AC_CONFIG_FILES): Add po/Makefile.in. - -2014-02-20 Tim Ruehsen - * inital setup From 74f715bd9cc86702aa3bda5e0827500fabd83e10 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Tim=20R=C3=BChsen?= Date: Fri, 27 Jun 2014 17:13:30 +0200 Subject: [PATCH 05/10] started with libidn2 integration --- configure.ac | 47 ++++++++++++++++++++++++++++++++++++----------- src/Makefile.am | 11 +++++++++-- src/psl2c.c | 24 ++++++++++++------------ tests/Makefile.am | 13 ++++++------- 4 files changed, 63 insertions(+), 32 deletions(-) diff --git a/configure.ac b/configure.ac index f89b1e1..2260f3a 100644 --- a/configure.ac +++ b/configure.ac @@ -1,7 +1,7 @@ AC_INIT([libpsl], [0.4.0], [tim.ruehsen@gmx.de], [libpsl], [http://github.com/rockdaboot/libpsl]) AC_PREREQ([2.59]) -AM_INIT_AUTOMAKE([1.10 -Wall no-define]) +AM_INIT_AUTOMAKE([1.10 -Wall no-define foreign]) # Generate two configuration headers; one for building the library itself with # an autogenerated template, and a second one that will be installed alongside @@ -93,25 +93,50 @@ AC_ARG_WITH(libicu, # Check for enable/disable builtin PSL data AC_ARG_ENABLE(builtin, - AS_HELP_STRING([--disable-builtin], [do not compile PSL data into library]), [ - enable_builtin=no + --enable-builtin[=IDNA library] + Specify the IDNA library used for built-in data generation: + libicu [[default]]: IDNA2008 UTS#46 library + libidn2: IDNA2008 library also needs libunistring + --disable-builtin Do not generate built-in data ], [ - enable_builtin=yes + if test "$enableval" = "libicu" -o "$enableval" = "yes"; then + if test "$HAVE_LIBICU" != "yes"; then + AC_MSG_ERROR(You requested libicu but it is not installed.) + fi + enable_builtin=libicu + AC_DEFINE([BUILTIN_GENERATOR_LIBICU], [1], [generate PSL data using libicu]) + elif test "$enableval" = "libidn2"; then + if test "$HAVE_LIBIDN2" != "yes"; then + AC_MSG_ERROR(You requested libidn2 but it is not installed.) + fi + enable_builtin=libidn2 + AC_DEFINE([BUILTIN_GENERATOR_LIBIDN2], [1], [generate PSL data using libidn2]) + elif test "$enableval" = "no"; then + enable_builtin=no + else + AC_MSG_ERROR(Unknown value $enableval) + fi + ], [ + # this is the default if neither --enable-builtin nor --disable-built were specified + enable_builtin=libicu + if test "$HAVE_LIBIDN2" != "yes"; then + AC_MSG_ERROR(You requested libidn2 but it is not installed.) + fi + AC_DEFINE([BUILTIN_GENERATOR_LIBICU], [1], [generate PSL data using libicu]) AC_DEFINE([WITH_BUILTIN], [1], [compile PSL data into library]) - AS_IF([test $HAVE_LIBICU != yes], - [ - # Check for idn2 fallback to generate punycode - AC_CHECK_PROG(HAVE_IDN2, idn2, yes, AC_MSG_ERROR(Cannot find required tool 'idn2' as fallback.)) - ]) ]) -AM_CONDITIONAL([WITH_BUILTIN], [test $enable_builtin = yes]) + +AM_CONDITIONAL([BUILTIN_GENERATOR_LIBICU], test "x$enable_builtin" = "xlibicu") +AM_CONDITIONAL([BUILTIN_GENERATOR_LIBIDN2], test "x$enable_builtin" = "xlibidn2") +AM_CONDITIONAL([WITH_BUILTIN], test $enable_builtin = yes) # Check for valgrind ac_enable_valgrind=no AC_ARG_ENABLE(valgrind-tests, AS_HELP_STRING([--enable-valgrind-tests], [enable using Valgrind for tests]), - [ac_enable_valgrind=$enableval], [ac_enable_valgrind=no]) + [ac_enable_valgrind=$enableval], + [ac_enable_valgrind=no]) if test "${ac_enable_valgrind}" = "yes" ; then AC_CHECK_PROG(HAVE_VALGRIND, valgrind, yes, no) diff --git a/src/Makefile.am b/src/Makefile.am index 0fe1ec7..36da6d4 100644 --- a/src/Makefile.am +++ b/src/Makefile.am @@ -13,8 +13,15 @@ libpsl_la_LDFLAGS = -version-info $(LIBPSL_SO_VERSION) noinst_PROGRAMS = psl2c psl2c_SOURCES = psl2c.c -psl2c_CPPFLAGS = -I$(top_srcdir)/include -D _GNU_SOURCE $(LIBICU_CFLAGS) -psl2c_LDADD = $(LIBICU_LIBS) +psl2c_CPPFLAGS = -I$(top_srcdir)/include -D _GNU_SOURCE +if BUILTIN_GENERATOR_LIBICU + psl2c_CPPFLAGS += $(LIBICU_CFLAGS) + psl2c_LDADD = $(LIBICU_LIBS) +endif +if BUILTIN_GENERATOR_LIBIDN2 + psl2c_CPPFLAGS += $(LIBIDN2_CFLAGS) + psl2c_LDADD = $(LIBIDN2_LIBS) +endif # Build rule for suffix.c # PSL_FILE can be set by ./configure --with-psl-file=[PATH] diff --git a/src/psl2c.c b/src/psl2c.c index daeec83..0909c7e 100644 --- a/src/psl2c.c +++ b/src/psl2c.c @@ -39,7 +39,7 @@ #include #include -#ifdef WITH_BUILTIN +#if defined(BUILTIN_GENERATOR_LIBICU) || defined(BUILTIN_GENERATOR_LIBIDN2) #include @@ -52,7 +52,7 @@ static void _print_psl_entries(FILE *fpout, const _psl_vector_t *v, const char * { int it; -#ifdef WITH_LIBICU +#ifdef BUILTIN_GENERATOR_LIBICU do { UVersionInfo version_info; char version[U_MAX_VERSION_STRING_LENGTH]; @@ -61,9 +61,11 @@ static void _print_psl_entries(FILE *fpout, const _psl_vector_t *v, const char * u_versionToString(version_info, version); fprintf(fpout, "/* automatically generated by psl2c (punycode generated with libicu/%s) */\n", version); } while (0); +#elif BUILTIN_GENERATOR_LIBIDN2 + fprintf(fpout, "/* automatically generated by psl2c (punycode generated with libidn2/%s) */\n", idn2_check_version(NULL)); #else fprintf(fpout, "/* automatically generated by psl2c (without punycode support) */\n"); -#endif /* WITH_LIBICU */ +#endif fprintf(fpout, "static _psl_entry_t %s[] = {\n", varname); @@ -77,7 +79,7 @@ static void _print_psl_entries(FILE *fpout, const _psl_vector_t *v, const char * fprintf(fpout, "};\n"); } -#ifndef WITH_LIBICU +#if !defined(WITH_LIBICU) && !defined(WITH_IDN2) static int _str_needs_encoding(const char *s) { while (*s > 0) s++; @@ -117,14 +119,14 @@ static void _add_punycode_if_needed(_psl_vector_t *v) _vector_sort(v); } -#endif /* ! WITH_LIBICU */ +#endif /* !defined(WITH_LIBICU) && !defined(WITH_IDN2) */ -#endif /* WITH_BUILTIN */ +#endif /* defined(BUILTIN_GENERATOR_LIBICU) || defined(BUILTIN_GENERATOR_LIBIDN2) */ int main(int argc, const char **argv) { FILE *fpout; -#ifdef WITH_BUILTIN +#if defined(BUILTIN_GENERATOR_LIBICU) || defined(BUILTIN_GENERATOR_LIBIDN2) psl_ctx_t *psl; #endif int ret = 0; @@ -136,7 +138,7 @@ int main(int argc, const char **argv) return 1; } -#ifdef WITH_BUILTIN +#if defined(BUILTIN_GENERATOR_LIBICU) || defined(BUILTIN_GENERATOR_LIBIDN2) if (!(psl = psl_load_file(argv[1]))) return 2; @@ -146,9 +148,8 @@ int main(int argc, const char **argv) size_t cmdsize = 16 + strlen(argv[1]); char *cmd = alloca(cmdsize), checksum[64] = ""; -#ifndef WITH_LIBICU - /* If libicu is not configured, we still need to have punycode in our built-in data. */ - /* Else the test suite fails. */ +#if !defined(WITH_LIBICU) && !defined(WITH_IDN2) + /* library is compiled without ability to generate punycode, so let's generate punycode at least for the builtin data */ _add_punycode_if_needed(psl->suffixes); _add_punycode_if_needed(psl->suffix_exceptions); #endif @@ -193,7 +194,6 @@ int main(int argc, const char **argv) fprintf(stderr, "Failed to write open '%s'\n", argv[2]); ret = 3; } - #endif /* WITH_BUILTIN */ return ret; diff --git a/tests/Makefile.am b/tests/Makefile.am index 9234320..e3324f9 100644 --- a/tests/Makefile.am +++ b/tests/Makefile.am @@ -2,18 +2,17 @@ DEFS = @DEFS@ -DDATADIR=\"$(top_srcdir)/data\" -DSRCDIR=\"$(srcdir)\" -DPSL_FILE AM_CPPFLAGS = -I$(top_srcdir)/include LDADD = ../src/libpsl.la -if WITH_BUILTIN - -PSL_TESTS = test-is-public test-is-public-builtin test-is-public-all test-registrable-domain \ - test-is-cookie-domain-acceptable - -else - # ./configure'd with '--disable-builtin' # Do not call test-is-public-builtin here: it does not make sense. # Do not call test-registrable-domain here: it would fail due to missing punycode entries in PSL file. PSL_TESTS = test-is-public test-is-public-all test-is-cookie-domain-acceptable +if BUILTIN_GENERATOR_LIBICU + PSL_TESTS += test-is-public-builtin test-registrable-domain +endif + +if BUILTIN_GENERATOR_LIBIDN2 + PSL_TESTS += test-is-public-builtin test-registrable-domain endif check_PROGRAMS = $(PSL_TESTS) From 373bcb912cbf2b0d6d5ad66275bd7e6f3d5c3051 Mon Sep 17 00:00:00 2001 From: Tim Ruehsen Date: Sun, 29 Jun 2014 22:56:33 +0200 Subject: [PATCH 06/10] more work on support for libidn, libidn2, libicu --- .travis.yml | 3 +- configure.ac | 113 +++++++++++++++++++++++++++++++--------------- src/Makefile.am | 18 ++++++-- src/psl.c | 104 +++++++++++++++++++++++++++++++++++++++--- src/psl2c.c | 24 ++++++---- tests/Makefile.am | 4 ++ tools/Makefile.am | 10 ++++ 7 files changed, 219 insertions(+), 57 deletions(-) diff --git a/.travis.yml b/.travis.yml index 6976291..6b268be 100644 --- a/.travis.yml +++ b/.travis.yml @@ -12,6 +12,5 @@ script: - ./configure --enable-gtk-doc && make -j4 && make check -j4 - make distcheck before_install: - - apt-cache search libicu | grep icu - sudo apt-get -qq update - - sudo apt-get -q install autoconf automake autopoint libtool gtk-doc-tools gettext idn2 libidn2-0 libidn2-0-dev libicu48 libicu-dev + - sudo apt-get -q install autoconf automake autopoint libtool gtk-doc-tools gettext libidn libidn-dev libidn2-0 libidn2-0-dev libicu48 libicu-dev diff --git a/configure.ac b/configure.ac index 2260f3a..01c2840 100644 --- a/configure.ac +++ b/configure.ac @@ -66,29 +66,34 @@ AS_IF([ test "$enable_man" != no ], [ AC_SUBST([LIBPSL_SO_VERSION], [2:0:2]) AC_SUBST([LIBPSL_VERSION], $VERSION) -# Check for libicu -HAVE_LIBICU=no -AC_ARG_WITH(libicu, - AC_HELP_STRING([--without-libicu], [build libpsl without IDNA/Punycode support]), - [], +# Check for enable/disable builtin PSL data +AC_ARG_ENABLE(runtime, [ - # using pkg-config won't work on older systems like Ubuntu 12.04 LTS Server Edition 64bit - OLDLIBS=$LIBS - LIBS="-licuuc $LIBS" - AC_MSG_CHECKING([for ICU unicode library]) - AC_LINK_IFELSE( - [AC_LANG_PROGRAM( - [[#include ]], - [[u_strToUTF8(NULL, 0, NULL, NULL, 0, NULL);]])], - [HAVE_LIBICU=yes; AC_MSG_RESULT([yes]) AC_DEFINE([WITH_LIBICU], [1], [generate PSL data with IDNA2008 UTS#46 punycode])], - [LIBS=$OLDLIBS; AC_MSG_ERROR([no working ICU unicode library was found])]) - -# AC_SEARCH_LIBS(uidna_close, icuuc, -# [HAVE_LIBICU=yes; AC_DEFINE([WITH_LIBICU], [1], [generate PSL data with IDNA2008 UTS#46 punycode])], -# [AC_MSG_ERROR(*** libicu was not found. Aborting.)], -# -licudata ) -# PKG_CHECK_MODULES(LIBICU, [icu-uc], -# [HAVE_LIBICU=yes; AC_DEFINE([WITH_LIBICU], [1], [generate PSL data with IDNA2008 UTS#46 punycode])]) + --enable-runtime[=IDNA library] + Specify the IDNA library used for libpsl run-time conversions: + libicu [[default]]: IDNA2008 UTS#46 library + libidn2: IDNA2008 library (also needs libunistring) + libidn: IDNA2003 library + --disable-runtime Do not link runtime IDNA functionality + ], [ + if test "$enableval" = "libicu" -o "$enableval" = "yes"; then + enable_runtime=libicu + AC_DEFINE([WITH_LIBICU], [1], [generate PSL data using libicu]) + elif test "$enableval" = "libidn2"; then + enable_runtime=libidn2 + AC_DEFINE([WITH_LIBIDN2], [1], [generate PSL data using libidn2]) + elif test "$enableval" = "libidn"; then + enable_runtime=libidn + AC_DEFINE([WITH_LIBIDN], [1], [generate PSL data using libidn]) + elif test "$enableval" = "no"; then + enable_runtime=no + else + AC_MSG_ERROR([Unknown value $enableval for --enable-runtime]) + fi + ], [ + # this is the default if neither --enable-runtime nor --disable-runtime were specified + enable_runtime=libicu + AC_DEFINE([WITH_LIBICU], [1], [generate PSL data using libicu]) ]) # Check for enable/disable builtin PSL data @@ -97,38 +102,73 @@ AC_ARG_ENABLE(builtin, --enable-builtin[=IDNA library] Specify the IDNA library used for built-in data generation: libicu [[default]]: IDNA2008 UTS#46 library - libidn2: IDNA2008 library also needs libunistring + libidn2: IDNA2008 library (also needs libunistring) + libidn: IDNA2003 library --disable-builtin Do not generate built-in data ], [ if test "$enableval" = "libicu" -o "$enableval" = "yes"; then - if test "$HAVE_LIBICU" != "yes"; then - AC_MSG_ERROR(You requested libicu but it is not installed.) - fi enable_builtin=libicu AC_DEFINE([BUILTIN_GENERATOR_LIBICU], [1], [generate PSL data using libicu]) elif test "$enableval" = "libidn2"; then - if test "$HAVE_LIBIDN2" != "yes"; then - AC_MSG_ERROR(You requested libidn2 but it is not installed.) - fi enable_builtin=libidn2 AC_DEFINE([BUILTIN_GENERATOR_LIBIDN2], [1], [generate PSL data using libidn2]) + elif test "$enableval" = "libidn"; then + enable_builtin=libidn + AC_DEFINE([BUILTIN_GENERATOR_LIBIDN], [1], [generate PSL data using libidn]) elif test "$enableval" = "no"; then enable_builtin=no else AC_MSG_ERROR(Unknown value $enableval) fi ], [ - # this is the default if neither --enable-builtin nor --disable-built were specified + # this is the default if neither --enable-builtin nor --disable-builtin were specified enable_builtin=libicu - if test "$HAVE_LIBIDN2" != "yes"; then - AC_MSG_ERROR(You requested libidn2 but it is not installed.) - fi AC_DEFINE([BUILTIN_GENERATOR_LIBICU], [1], [generate PSL data using libicu]) - AC_DEFINE([WITH_BUILTIN], [1], [compile PSL data into library]) ]) +if test "$enable_runtime" = "libicu" -o "$enable_builtin" = "libicu"; then + # Check for libicu + # using pkg-config won't work on older systems like Ubuntu 12.04 LTS Server Edition 64bit + # using AC_SEARCH_LIBS also don't work since functions have the library version appended + OLDLIBS=$LIBS + LIBS="-licuuc $LIBS" + AC_MSG_CHECKING([for ICU unicode library]) + AC_LINK_IFELSE( + [AC_LANG_PROGRAM( + [[#include ]], + [[u_strToUTF8(NULL, 0, NULL, NULL, 0, NULL);]])], + [HAVE_LIBICU=yes; AC_MSG_RESULT([yes])], + [AC_MSG_RESULT([no]); AC_MSG_ERROR(You requested libicu but it is not installed.)]) + LIBS=$OLDLIBS +fi + +if test "$enable_runtime" = "libidn2" -o "$enable_builtin" = "libidn2"; then + # Check for libidn2 + OLDLIBS=$LIBS + AC_SEARCH_LIBS(idn2_lookup_u8, idn2, HAVE_LIBIDN2=yes, AC_MSG_ERROR(You requested libidn2 but it is not installed.)) + LIBS=$OLDLIBS +fi + +if test "$enable_runtime" = "libidn" -o "$enable_builtin" = "libidn"; then + # Check for libidn + OLDLIBS=$LIBS + AC_SEARCH_LIBS(idna_to_ascii_8z, idn, HAVE_LIBIDN=yes, AC_MSG_ERROR(You requested libidn but it is not installed.)) + LIBS=$OLDLIBS +fi + +if test "x$HAVE_LIBIDN2" = "xyes" -o "x$HAVE_LIBIDN" = "xyes"; then + # Check for libunistring, we need it for psl_str_to_utf8lower() + OLDLIBS=$LIBS + AC_SEARCH_LIBS(u8_tolower, unistring, HAVE_UNISTRING=yes, AC_MSG_ERROR(You requested libidn2 but libunistring is not installed.)) + LIBS=$OLDLIBS +fi + +AM_CONDITIONAL([WITH_LIBICU], test "x$enable_runtime" = "xlibicu") +AM_CONDITIONAL([WITH_LIBIDN2], test "x$enable_runtime" = "xlibidn2") +AM_CONDITIONAL([WITH_LIBIDN], test "x$enable_runtime" = "xlibidn") AM_CONDITIONAL([BUILTIN_GENERATOR_LIBICU], test "x$enable_builtin" = "xlibicu") AM_CONDITIONAL([BUILTIN_GENERATOR_LIBIDN2], test "x$enable_builtin" = "xlibidn2") +AM_CONDITIONAL([BUILTIN_GENERATOR_LIBIDN], test "x$enable_builtin" = "xlibidn") AM_CONDITIONAL([WITH_BUILTIN], test $enable_builtin = yes) # Check for valgrind @@ -187,8 +227,9 @@ AC_MSG_NOTICE([Summary of build options: Compiler: ${CC} CFlags: ${CFLAGS} ${CPPFLAGS} LDFlags: ${LDFLAGS} - ICU: ${HAVE_LIBICU} - Builtin PSL: ${enable_builtin} + Libs: ${LIBS} + Runtime: ${enable_runtime} + Builtin: ${enable_builtin} PSL File: ${PSL_FILE} PSL Test File: ${PSL_TESTFILE} Tests: ${TESTS_INFO} diff --git a/src/Makefile.am b/src/Makefile.am index 36da6d4..eef692b 100644 --- a/src/Makefile.am +++ b/src/Makefile.am @@ -10,17 +10,27 @@ libpsl_la_SOURCES = psl.c libpsl_la_CPPFLAGS = -I$(top_srcdir)/include # include ABI version information libpsl_la_LDFLAGS = -version-info $(LIBPSL_SO_VERSION) +if WITH_LIBICU + libpsl_la_LDFLAGS += -licuuc +endif +if WITH_LIBIDN2 + libpsl_la_LDFLAGS += -lidn2 +endif +if WITH_LIBIDN + libpsl_la_LDFLAGS += -lunistring -lidn +endif noinst_PROGRAMS = psl2c psl2c_SOURCES = psl2c.c psl2c_CPPFLAGS = -I$(top_srcdir)/include -D _GNU_SOURCE if BUILTIN_GENERATOR_LIBICU - psl2c_CPPFLAGS += $(LIBICU_CFLAGS) - psl2c_LDADD = $(LIBICU_LIBS) + psl2c_LDADD = -licuuc endif if BUILTIN_GENERATOR_LIBIDN2 - psl2c_CPPFLAGS += $(LIBIDN2_CFLAGS) - psl2c_LDADD = $(LIBIDN2_LIBS) + psl2c_LDADD = -lidn2 +endif +if BUILTIN_GENERATOR_LIBIDN + psl2c_LDADD = -lidn endif # Build rule for suffix.c diff --git a/src/psl.c b/src/psl.c index 46eaa47..3b263c8 100644 --- a/src/psl.c +++ b/src/psl.c @@ -37,6 +37,20 @@ # include #endif +/* if this file is included by psl2c, redefine to use requested library for builtin data */ +#ifdef _LIBPSL_INCLUDED_BY_PSL2C +# undef WITH_LIBICU +# undef WITH_LIBIDN2 +# undef WITH_LIBIDN +# ifdef BUILTIN_GENERATOR_LIBICU +# define WITH_LIBICU +# elif defined(BUILTIN_GENERATOR_LIBIDN2) +# define WITH_LIBIDN2 +# elif defined(BUILTIN_GENERATOR_LIBIDN) +# define WITH_LIBIDN +# endif +#endif + #if ENABLE_NLS != 0 # include # define _(STRING) gettext(STRING) @@ -56,6 +70,13 @@ # include # include # include +#elif defined(WITH_LIBIDN2) +# include +# include +# include +#elif defined(WITH_LIBIDN) +# include +# include #endif #include @@ -457,7 +478,7 @@ static int _str_is_ascii(const char *s) return !*s; } -#ifdef WITH_LIBICU +#if defined(WITH_LIBICU) static void _add_punycode_if_needed(UIDNA *idna, _psl_vector_t *v, _psl_entry_t *e) { if (_str_is_ascii(e->label_buf)) @@ -465,7 +486,6 @@ static void _add_punycode_if_needed(UIDNA *idna, _psl_vector_t *v, _psl_entry_t /* IDNA2008 UTS#46 punycode conversion */ if (idna) { - _psl_entry_t suffix, *suffixp; char lookupname[128] = ""; UErrorCode status = 0; UIDNAInfo info = UIDNA_INFO_INITIALIZER; @@ -479,6 +499,8 @@ static void _add_punycode_if_needed(UIDNA *idna, _psl_vector_t *v, _psl_entry_t u_strToUTF8(lookupname, sizeof(lookupname), NULL, utf16_dst, dst_length, &status); if (U_SUCCESS(status)) { if (strcmp(e->label_buf, lookupname)) { + _psl_entry_t suffix, *suffixp; + /* fprintf(stderr, "libicu '%s' -> '%s'\n", e->label_buf, lookupname); */ _suffix_init(&suffix, lookupname, strlen(lookupname)); suffix.wildcard = e->wildcard; @@ -493,6 +515,66 @@ static void _add_punycode_if_needed(UIDNA *idna, _psl_vector_t *v, _psl_entry_t fprintf(stderr, "Failed to convert UTF-8 to UTF-16 (status %d)\n", status); */ } } +#elif defined(WITH_LIBIDN2) +static void _add_punycode_if_needed(_psl_vector_t *v, _psl_entry_t *e) +{ + char *lookupname = NULL; + int rc; + uint8_t *lower, resbuf[256]; + size_t len = sizeof(resbuf) - 1; /* leave space for additional \0 byte */ + + if (_str_is_ascii(e->label_buf)) + return; + + /* we need a conversion to lowercase */ + lower = u8_tolower((uint8_t *)src, u8_strlen((uint8_t *)src), 0, UNINORM_NFKC, resbuf, &len); + if (!lower) { + printf("u8_tolower(%s) failed (%d)\n", src, errno); + return src; + } + + /* u8_tolower() does not terminate the result string */ + if (lower == resbuf) { + lower[len]=0; + } else { + uint8_t *tmp = lower; + lower = (uint8_t *)strndup((char *)lower, len); + xfree(tmp); + } + + if ((rc = idn2_lookup_u8(lower, (uint8_t **)&asc, 0)) == IDN2_OK) { + debug_printf("idn2 '%s' -> '%s'\n", src, asc); + src = asc; + } else + error_printf(_("toASCII(%s) failed (%d): %s\n"), lower, rc, idn2_strerror(rc)); + + if (lower != resbuf) + xfree(lower); +} +#elif defined(WITH_LIBIDN) +static void _add_punycode_if_needed(_psl_vector_t *v, _psl_entry_t *e) +{ + char *lookupname = NULL; + int rc; + + if (_str_is_ascii(e->label_buf)) + return; + + /* idna_to_ascii_8z() automatically converts UTF-8 to lowercase */ + + if ((rc = idna_to_ascii_8z(e->label_buf, &lookupname, IDNA_USE_STD3_ASCII_RULES)) == IDNA_SUCCESS) { + if (strcmp(e->label_buf, lookupname)) { + _psl_entry_t suffix, *suffixp; + + /* fprintf(stderr, "libidn '%s' -> '%s'\n", e->label_buf, lookupname); */ + _suffix_init(&suffix, lookupname, strlen(lookupname)); + suffix.wildcard = e->wildcard; + suffixp = _vector_get(v, _vector_add(v, &suffix)); + suffixp->label = suffixp->label_buf; /* set label to changed address */ + } /* else ignore */ + } /* else + fprintf(_(stderr, "toASCII failed (%d): %s\n"), rc, idna_strerror(rc)); */ +} #endif /** @@ -582,6 +664,8 @@ psl_ctx_t *psl_load_fp(FILE *fp) suffixp->label = suffixp->label_buf; /* set label to changed address */ #ifdef WITH_LIBICU _add_punycode_if_needed(idna, psl->suffix_exceptions, suffixp); +#elif defined(WITH_LIBIDN2) || defined(WITH_LIBIDN) + _add_punycode_if_needed(psl->suffix_exceptions, suffixp); #endif } } else { @@ -591,6 +675,8 @@ psl_ctx_t *psl_load_fp(FILE *fp) suffixp->label = suffixp->label_buf; /* set label to changed address */ #ifdef WITH_LIBICU _add_punycode_if_needed(idna, psl->suffixes, suffixp); +#elif defined(WITH_LIBIDN2) || defined(WITH_LIBIDN) + _add_punycode_if_needed(psl->suffix_exceptions, suffixp); #endif } } @@ -645,7 +731,7 @@ void psl_free(psl_ctx_t *psl) */ const psl_ctx_t *psl_builtin(void) { -#ifdef WITH_BUILTIN +#if defined(BUILTIN_GENERATOR_LIBICU) || defined(BUILTIN_GENERATOR_LIBIDN2) || defined(BUILTIN_GENERATOR_LIBIDN) return &_builtin_psl; #else return NULL; @@ -773,13 +859,15 @@ const char *psl_builtin_filename(void) **/ const char *psl_get_version (void) { - return PACKAGE_VERSION #ifdef WITH_LIBICU - " (+libicu/" U_ICU_VERSION ")" + return PACKAGE_VERSION " (+libicu/" U_ICU_VERSION ")"; +#elif defined(WITH_LIBIDN2) + return PACKAGE_VERSION " (+libidn2/" IDN2_VERSION ")"; +#elif defined(WITH_LIBIDN) + return PACKAGE_VERSION " (+libidn/" STRINGPREP_VERSION ")"; #else - " (limited IDNA support)" + return PACKAGE_VERSION " (limited IDNA support)"; #endif - ; } /** @@ -932,6 +1020,8 @@ psl_error_t psl_str_to_utf8lower(const char *str, const char *encoding, const ch /* fprintf(stderr, "Failed to open converter for '%s' (status %d)\n", encoding, status); */ } } while (0); +#elif defined(WITH_LIBIDN2) +#elif defined(WITH_LIBIDN) #endif return ret; diff --git a/src/psl2c.c b/src/psl2c.c index 0909c7e..0f2e066 100644 --- a/src/psl2c.c +++ b/src/psl2c.c @@ -39,7 +39,11 @@ #include #include -#if defined(BUILTIN_GENERATOR_LIBICU) || defined(BUILTIN_GENERATOR_LIBIDN2) +#if defined(BUILTIN_GENERATOR_LIBICU) || defined(BUILTIN_GENERATOR_LIBIDN2) || defined(BUILTIN_GENERATOR_LIBIDN) +# define _GENERATE_BUILTIN_DATA +#endif + +#ifdef _GENERATE_BUILTIN_DATA #include @@ -61,8 +65,10 @@ static void _print_psl_entries(FILE *fpout, const _psl_vector_t *v, const char * u_versionToString(version_info, version); fprintf(fpout, "/* automatically generated by psl2c (punycode generated with libicu/%s) */\n", version); } while (0); -#elif BUILTIN_GENERATOR_LIBIDN2 +#elif defined(BUILTIN_GENERATOR_LIBIDN2) fprintf(fpout, "/* automatically generated by psl2c (punycode generated with libidn2/%s) */\n", idn2_check_version(NULL)); +#elif defined(BUILTIN_GENERATOR_LIBIDN) + fprintf(fpout, "/* automatically generated by psl2c (punycode generated with libidn/%s) */\n", stringprep_check_version(NULL)); #else fprintf(fpout, "/* automatically generated by psl2c (without punycode support) */\n"); #endif @@ -79,6 +85,7 @@ static void _print_psl_entries(FILE *fpout, const _psl_vector_t *v, const char * fprintf(fpout, "};\n"); } +#if 0 #if !defined(WITH_LIBICU) && !defined(WITH_IDN2) static int _str_needs_encoding(const char *s) { @@ -120,13 +127,14 @@ static void _add_punycode_if_needed(_psl_vector_t *v) _vector_sort(v); } #endif /* !defined(WITH_LIBICU) && !defined(WITH_IDN2) */ +#endif -#endif /* defined(BUILTIN_GENERATOR_LIBICU) || defined(BUILTIN_GENERATOR_LIBIDN2) */ +#endif /* _GENERATE_BUILTIN_DATA */ int main(int argc, const char **argv) { FILE *fpout; -#if defined(BUILTIN_GENERATOR_LIBICU) || defined(BUILTIN_GENERATOR_LIBIDN2) +#ifdef _GENERATE_BUILTIN_DATA psl_ctx_t *psl; #endif int ret = 0; @@ -138,7 +146,7 @@ int main(int argc, const char **argv) return 1; } -#if defined(BUILTIN_GENERATOR_LIBICU) || defined(BUILTIN_GENERATOR_LIBIDN2) +#ifdef _GENERATE_BUILTIN_DATA if (!(psl = psl_load_file(argv[1]))) return 2; @@ -148,8 +156,8 @@ int main(int argc, const char **argv) size_t cmdsize = 16 + strlen(argv[1]); char *cmd = alloca(cmdsize), checksum[64] = ""; -#if !defined(WITH_LIBICU) && !defined(WITH_IDN2) - /* library is compiled without ability to generate punycode, so let's generate punycode at least for the builtin data */ +#if 0 + /* include library code did not generate punycode, so let's do it for the builtin data */ _add_punycode_if_needed(psl->suffixes); _add_punycode_if_needed(psl->suffix_exceptions); #endif @@ -194,7 +202,7 @@ int main(int argc, const char **argv) fprintf(stderr, "Failed to write open '%s'\n", argv[2]); ret = 3; } -#endif /* WITH_BUILTIN */ +#endif /* GENERATE_BUILTIN_DATA */ return ret; } diff --git a/tests/Makefile.am b/tests/Makefile.am index e3324f9..2bc8f82 100644 --- a/tests/Makefile.am +++ b/tests/Makefile.am @@ -15,6 +15,10 @@ if BUILTIN_GENERATOR_LIBIDN2 PSL_TESTS += test-is-public-builtin test-registrable-domain endif +if BUILTIN_GENERATOR_LIBIDN + PSL_TESTS += test-is-public-builtin test-registrable-domain +endif + check_PROGRAMS = $(PSL_TESTS) TESTS_ENVIRONMENT = TESTS_VALGRIND="@VALGRIND_ENVIRONMENT@" diff --git a/tools/Makefile.am b/tools/Makefile.am index d2b973e..73cf0a6 100644 --- a/tools/Makefile.am +++ b/tools/Makefile.am @@ -2,3 +2,13 @@ bin_PROGRAMS = psl AM_CPPFLAGS = -I$(top_srcdir)/include LDADD = ../src/libpsl.la + +#if WITH_LIBICU +# LDADD += $(LIBICU_LIBS) +#endif +#if WITH_LIBIDN2 +# LDADD += -lidn2 +#endif +#if WITH_LIBIDN +# LDADD += -lidn +#endif From bb12832c308af394d5b7420d33340e78b946ff02 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Tim=20R=C3=BChsen?= Date: Mon, 30 Jun 2014 10:35:33 +0200 Subject: [PATCH 07/10] added all combinations of runtime and builtin options --- .travis.yml | 19 ++++++++++++++++--- tools/Makefile.am | 2 +- tools/psl.c | 5 ++++- 3 files changed, 21 insertions(+), 5 deletions(-) diff --git a/.travis.yml b/.travis.yml index 6b268be..59fa4b3 100644 --- a/.travis.yml +++ b/.travis.yml @@ -6,9 +6,22 @@ compiler: script: - ./autogen.sh - ./configure && make -j4 && make check -j4 - - ./configure --without-libicu && make clean && make -j4 && make check -j4 - - ./configure --disable-builtin && make clean && make -j4 && make check -j4 - - ./configure --disable-builtin --without-libicu && make clean && make -j4 && make check -j4 + - ./configure --enable-runtime=libicu --enable-builtin=libicu && make clean && make -j4 && make check -j4 + - ./configure --enable-runtime=libicu --enable-builtin=libidn2 && make clean && make -j4 && make check -j4 + - ./configure --enable-runtime=libicu --enable-builtin=libidn && make clean && make -j4 && make check -j4 + - ./configure --enable-runtime=libicu --disable-builtin && make clean && make -j4 && make check -j4 + - ./configure --enable-runtime=libidn2 --enable-builtin=libicu && make clean && make -j4 && make check -j4 + - ./configure --enable-runtime=libidn2 --enable-builtin=libidn2 && make clean && make -j4 && make check -j4 + - ./configure --enable-runtime=libidn2 --enable-builtin=libidn && make clean && make -j4 && make check -j4 + - ./configure --enable-runtime=libidn2 --disable-builtin && make clean && make -j4 && make check -j4 + - ./configure --enable-runtime=libidn --enable-builtin=libicu && make clean && make -j4 && make check -j4 + - ./configure --enable-runtime=libidn --enable-builtin=libidn2 && make clean && make -j4 && make check -j4 + - ./configure --enable-runtime=libidn --enable-builtin=libidn && make clean && make -j4 && make check -j4 + - ./configure --enable-runtime=libidn --disable-builtin && make clean && make -j4 && make check -j4 + - ./configure --disable-runtime --enable-builtin=libicu && make clean && make -j4 && make check -j4 + - ./configure --disable-runtime --enable-builtin=libidn2 && make clean && make -j4 && make check -j4 + - ./configure --disable-runtime --enable-builtin=libidn && make clean && make -j4 && make check -j4 + - ./configure --disable-runtime --disable-builtin && make clean && make -j4 && make check -j4 - ./configure --enable-gtk-doc && make -j4 && make check -j4 - make distcheck before_install: diff --git a/tools/Makefile.am b/tools/Makefile.am index 73cf0a6..f758ccd 100644 --- a/tools/Makefile.am +++ b/tools/Makefile.am @@ -4,7 +4,7 @@ AM_CPPFLAGS = -I$(top_srcdir)/include LDADD = ../src/libpsl.la #if WITH_LIBICU -# LDADD += $(LIBICU_LIBS) +# LDADD += -licuuc #endif #if WITH_LIBIDN2 # LDADD += -lidn2 diff --git a/tools/psl.c b/tools/psl.c index 976ada6..82618b5 100644 --- a/tools/psl.c +++ b/tools/psl.c @@ -37,10 +37,12 @@ #include #include +/* #ifdef WITH_LIBICU # include # include #endif +*/ #include @@ -217,11 +219,12 @@ int main(int argc, const char *const *argv) printf("builtin compile time: %ld (%s)\n", psl_builtin_compile_time(), time2str(psl_builtin_compile_time())); printf("builtin file time: %ld (%s)\n", psl_builtin_file_time(), time2str(psl_builtin_file_time())); printf("builtin SHA1 file hash: %s\n", psl_builtin_sha1sum()); - +/* #ifdef WITH_LIBICU printf("uloc_getDefault=%s\n", uloc_getDefault()); printf("ucnv_getDefaultName=%s\n", ucnv_getDefaultName()); #endif +*/ } else printf("No builtin PSL data available\n"); } From 5c5ee3aad7dc739c4f26c6b43fe331de0c1112e8 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Tim=20R=C3=BChsen?= Date: Mon, 30 Jun 2014 13:21:16 +0200 Subject: [PATCH 08/10] added code for all of runtime and builtin options --- .travis.yml | 2 +- src/Makefile.am | 8 ++-- src/psl.c | 106 +++++++++++++++++++++++++++++++++++++++++------- tools/psl.c | 13 ------ 4 files changed, 97 insertions(+), 32 deletions(-) diff --git a/.travis.yml b/.travis.yml index 59fa4b3..489ad18 100644 --- a/.travis.yml +++ b/.travis.yml @@ -26,4 +26,4 @@ script: - make distcheck before_install: - sudo apt-get -qq update - - sudo apt-get -q install autoconf automake autopoint libtool gtk-doc-tools gettext libidn libidn-dev libidn2-0 libidn2-0-dev libicu48 libicu-dev + - sudo apt-get -q install autoconf automake autopoint libtool gtk-doc-tools gettext libidn libidn-dev libidn2-0 libidn2-0-dev libicu48 libicu-dev libunistring0 libunistring-dev diff --git a/src/Makefile.am b/src/Makefile.am index eef692b..f600134 100644 --- a/src/Makefile.am +++ b/src/Makefile.am @@ -14,10 +14,10 @@ if WITH_LIBICU libpsl_la_LDFLAGS += -licuuc endif if WITH_LIBIDN2 - libpsl_la_LDFLAGS += -lidn2 + libpsl_la_LDFLAGS += -lidn2 -lunistring endif if WITH_LIBIDN - libpsl_la_LDFLAGS += -lunistring -lidn + libpsl_la_LDFLAGS += -lidn -lunistring endif noinst_PROGRAMS = psl2c @@ -27,10 +27,10 @@ if BUILTIN_GENERATOR_LIBICU psl2c_LDADD = -licuuc endif if BUILTIN_GENERATOR_LIBIDN2 - psl2c_LDADD = -lidn2 + psl2c_LDADD = -lidn2 -lunistring endif if BUILTIN_GENERATOR_LIBIDN - psl2c_LDADD = -lidn + psl2c_LDADD = -lidn -lunistring endif # Build rule for suffix.c diff --git a/src/psl.c b/src/psl.c index 3b263c8..9798e61 100644 --- a/src/psl.c +++ b/src/psl.c @@ -64,6 +64,8 @@ #include #include #include +#include +#include #ifdef WITH_LIBICU # include @@ -71,12 +73,16 @@ # include # include #elif defined(WITH_LIBIDN2) +# include # include # include # include #elif defined(WITH_LIBIDN) +# include # include # include +# include +# include #endif #include @@ -527,10 +533,10 @@ static void _add_punycode_if_needed(_psl_vector_t *v, _psl_entry_t *e) return; /* we need a conversion to lowercase */ - lower = u8_tolower((uint8_t *)src, u8_strlen((uint8_t *)src), 0, UNINORM_NFKC, resbuf, &len); + lower = u8_tolower((uint8_t *)e->label_buf, u8_strlen((uint8_t *)e->label_buf), 0, UNINORM_NFKC, resbuf, &len); if (!lower) { - printf("u8_tolower(%s) failed (%d)\n", src, errno); - return src; + /* fprintf(stderr, "u8_tolower(%s) failed (%d)\n", e->label_buf, errno); */ + return; } /* u8_tolower() does not terminate the result string */ @@ -539,17 +545,24 @@ static void _add_punycode_if_needed(_psl_vector_t *v, _psl_entry_t *e) } else { uint8_t *tmp = lower; lower = (uint8_t *)strndup((char *)lower, len); - xfree(tmp); + free(tmp); } - if ((rc = idn2_lookup_u8(lower, (uint8_t **)&asc, 0)) == IDN2_OK) { - debug_printf("idn2 '%s' -> '%s'\n", src, asc); - src = asc; - } else - error_printf(_("toASCII(%s) failed (%d): %s\n"), lower, rc, idn2_strerror(rc)); + if ((rc = idn2_lookup_u8(lower, (uint8_t **)&lookupname, 0)) == IDN2_OK) { + if (strcmp(e->label_buf, lookupname)) { + _psl_entry_t suffix, *suffixp; + + /* fprintf(stderr, "libidn '%s' -> '%s'\n", e->label_buf, lookupname); */ + _suffix_init(&suffix, lookupname, strlen(lookupname)); + suffix.wildcard = e->wildcard; + suffixp = _vector_get(v, _vector_add(v, &suffix)); + suffixp->label = suffixp->label_buf; /* set label to changed address */ + } /* else ignore */ + } /* else + fprintf(stderr, "toASCII(%s) failed (%d): %s\n", lower, rc, idn2_strerror(rc)); */ if (lower != resbuf) - xfree(lower); + free(lower); } #elif defined(WITH_LIBIDN) static void _add_punycode_if_needed(_psl_vector_t *v, _psl_entry_t *e) @@ -676,7 +689,7 @@ psl_ctx_t *psl_load_fp(FILE *fp) #ifdef WITH_LIBICU _add_punycode_if_needed(idna, psl->suffixes, suffixp); #elif defined(WITH_LIBIDN2) || defined(WITH_LIBIDN) - _add_punycode_if_needed(psl->suffix_exceptions, suffixp); + _add_punycode_if_needed(psl->suffixes, suffixp); #endif } } @@ -866,7 +879,7 @@ const char *psl_get_version (void) #elif defined(WITH_LIBIDN) return PACKAGE_VERSION " (+libidn/" STRINGPREP_VERSION ")"; #else - return PACKAGE_VERSION " (limited IDNA support)"; + return PACKAGE_VERSION " (no IDNA support)"; #endif } @@ -1020,8 +1033,73 @@ psl_error_t psl_str_to_utf8lower(const char *str, const char *encoding, const ch /* fprintf(stderr, "Failed to open converter for '%s' (status %d)\n", encoding, status); */ } } while (0); -#elif defined(WITH_LIBIDN2) -#elif defined(WITH_LIBIDN) +#elif defined(WITH_LIBIDN2) || defined(WITH_LIBIDN) + do { + /* find out local charset encoding */ + if (!encoding) { + encoding = nl_langinfo(CODESET); + + if (!encoding || !*encoding) + encoding = "ASCII"; + } + + /* convert to UTF-8 */ + if (strcasecmp(encoding, "utf-8")) { + iconv_t cd = iconv_open("utf-8", encoding); + + if (cd != (iconv_t)-1) { + char *tmp = (char *)str; /* iconv won't change where str points to, but changes tmp itself */ + size_t tmp_len = strlen(str); + size_t dst_len = tmp_len * 6, dst_len_tmp = dst_len; + char *dst = malloc(dst_len + 1), *dst_tmp = dst; + + if (iconv(cd, &tmp, &tmp_len, &dst_tmp, &dst_len_tmp) != (size_t)-1) { + uint8_t *resbuf = malloc(dst_len * 2 + 1); + size_t len = dst_len * 2; /* leave space for additional \0 byte */ + + if ((dst = (char *)u8_tolower((uint8_t *)dst, dst_len - dst_len_tmp, 0, UNINORM_NFKC, resbuf, &len))) { + /* u8_tolower() does not terminate the result string */ + if (lower) + *lower = strndup((char *)dst, len); + } else { + ret = PSL_ERR_TO_LOWER; + /* fprintf(stderr, "Failed to convert UTF-8 to lowercase (errno %d)\n", errno); */ + } + + if (lower) + *lower = strndup(dst, dst_len - dst_len_tmp); + ret = PSL_SUCCESS; + } else { + ret = PSL_ERR_TO_UTF8; + /* fprintf(stderr, "Failed to convert '%s' string into '%s' (%d)\n", src_encoding, dst_encoding, errno); */ + } + + free(dst); + iconv_close(cd); + } else { + ret = PSL_ERR_TO_UTF8; + /* fprintf(stderr, "Failed to prepare encoding '%s' into '%s' (%d)\n", src_encoding, dst_encoding, errno); */ + } + } else + ret = PSL_SUCCESS; + + /* convert to lowercase */ + if (ret == PSL_SUCCESS) { + uint8_t *dst, resbuf[256]; + size_t len = sizeof(resbuf) - 1; /* leave space for additional \0 byte */ + + /* we need a conversion to lowercase */ + if ((dst = u8_tolower((uint8_t *)str, u8_strlen((uint8_t *)str), 0, UNINORM_NFKC, resbuf, &len))) { + /* u8_tolower() does not terminate the result string */ + if (lower) + *lower = strndup((char *)dst, len); + } else { + ret = PSL_ERR_TO_LOWER; + /* fprintf(stderr, "Failed to convert UTF-8 to lowercase (errno %d)\n", errno); */ + } + } + + } while (0); #endif return ret; diff --git a/tools/psl.c b/tools/psl.c index 82618b5..e1969c2 100644 --- a/tools/psl.c +++ b/tools/psl.c @@ -37,13 +37,6 @@ #include #include -/* -#ifdef WITH_LIBICU -# include -# include -#endif -*/ - #include static void usage(int err, FILE* f) @@ -219,12 +212,6 @@ int main(int argc, const char *const *argv) printf("builtin compile time: %ld (%s)\n", psl_builtin_compile_time(), time2str(psl_builtin_compile_time())); printf("builtin file time: %ld (%s)\n", psl_builtin_file_time(), time2str(psl_builtin_file_time())); printf("builtin SHA1 file hash: %s\n", psl_builtin_sha1sum()); -/* -#ifdef WITH_LIBICU - printf("uloc_getDefault=%s\n", uloc_getDefault()); - printf("ucnv_getDefaultName=%s\n", ucnv_getDefaultName()); -#endif -*/ } else printf("No builtin PSL data available\n"); } From 4304a861c5be5df72e2ab6b273689a23cee8dd06 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Tim=20R=C3=BChsen?= Date: Mon, 30 Jun 2014 14:49:22 +0200 Subject: [PATCH 09/10] fixed libidn package names in .travis.yml --- .travis.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.travis.yml b/.travis.yml index 489ad18..d72425b 100644 --- a/.travis.yml +++ b/.travis.yml @@ -26,4 +26,4 @@ script: - make distcheck before_install: - sudo apt-get -qq update - - sudo apt-get -q install autoconf automake autopoint libtool gtk-doc-tools gettext libidn libidn-dev libidn2-0 libidn2-0-dev libicu48 libicu-dev libunistring0 libunistring-dev + - sudo apt-get -q install autoconf automake autopoint libtool gtk-doc-tools gettext libidn11 libidn11-dev libidn2-0 libidn2-0-dev libicu48 libicu-dev libunistring0 libunistring-dev From c3a2b9a1375ae3e5323f6e9d2f7b470e4a068352 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Tim=20R=C3=BChsen?= Date: Tue, 1 Jul 2014 13:05:32 +0200 Subject: [PATCH 10/10] added unistring hint to configure --help --- configure.ac | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/configure.ac b/configure.ac index 01c2840..4db2642 100644 --- a/configure.ac +++ b/configure.ac @@ -69,11 +69,11 @@ AC_SUBST([LIBPSL_VERSION], $VERSION) # Check for enable/disable builtin PSL data AC_ARG_ENABLE(runtime, [ - --enable-runtime[=IDNA library] + --enable-runtime[[=IDNA library]] Specify the IDNA library used for libpsl run-time conversions: libicu [[default]]: IDNA2008 UTS#46 library libidn2: IDNA2008 library (also needs libunistring) - libidn: IDNA2003 library + libidn: IDNA2003 library (also needs libunistring) --disable-runtime Do not link runtime IDNA functionality ], [ if test "$enableval" = "libicu" -o "$enableval" = "yes"; then @@ -99,12 +99,12 @@ AC_ARG_ENABLE(runtime, # Check for enable/disable builtin PSL data AC_ARG_ENABLE(builtin, [ - --enable-builtin[=IDNA library] + --enable-builtin[[=IDNA library]] Specify the IDNA library used for built-in data generation: libicu [[default]]: IDNA2008 UTS#46 library libidn2: IDNA2008 library (also needs libunistring) - libidn: IDNA2003 library - --disable-builtin Do not generate built-in data + libidn: IDNA2003 library (also needs libunistring) + --disable-builtin Do not generate built-in PSL data ], [ if test "$enableval" = "libicu" -o "$enableval" = "yes"; then enable_builtin=libicu