From: DongHun Kwak Date: Wed, 13 Sep 2017 07:06:47 +0000 (+0900) Subject: Imported Upstream version 2.2.4 X-Git-Tag: upstream/2.2.4^0 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=91321ac4f69e0f63d5215b1c8dba5022a6f3f1a9;p=platform%2Fupstream%2Fexpat.git Imported Upstream version 2.2.4 Change-Id: I7586c345c8d87644334e2099468648209135cc6c Signed-off-by: DongHun Kwak --- diff --git a/CMake.README b/CMake.README index 6ac3eb4..281eb52 100644 --- a/CMake.README +++ b/CMake.README @@ -3,25 +3,25 @@ The cmake based buildsystem for expat works on Windows (cygwin, mingw, Visual Studio) and should work on all other platform cmake supports. -Assuming ~/expat-2.2.3 is the source directory of expat, add a subdirectory +Assuming ~/expat-2.2.4 is the source directory of expat, add a subdirectory build and change into that directory: -~/expat-2.2.3$ mkdir build && cd build -~/expat-2.2.3/build$ +~/expat-2.2.4$ mkdir build && cd build +~/expat-2.2.4/build$ From that directory, call cmake first, then call make, make test and make install in the usual way: -~/expat-2.2.3/build$ cmake .. +~/expat-2.2.4/build$ cmake .. -- The C compiler identification is GNU -- The CXX compiler identification is GNU .... -- Configuring done -- Generating done --- Build files have been written to: /home/patrick/expat-2.2.3/build +-- Build files have been written to: /home/patrick/expat-2.2.4/build If you want to specify the install location for your files, append -DCMAKE_INSTALL_PREFIX=/your/install/path to the cmake call. -~/expat-2.2.3/build$ make && make test && make install +~/expat-2.2.4/build$ make && make test && make install Scanning dependencies of target expat [ 5%] Building C object CMakeFiles/expat.dir/lib/xmlparse.c.o [ 11%] Building C object CMakeFiles/expat.dir/lib/xmlrole.c.o diff --git a/CMakeLists.txt b/CMakeLists.txt index 9ba93f4..1026938 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -6,21 +6,53 @@ project(expat) cmake_minimum_required(VERSION 2.6) set(PACKAGE_BUGREPORT "expat-bugs@libexpat.org") set(PACKAGE_NAME "expat") -set(PACKAGE_VERSION "2.2.3") +set(PACKAGE_VERSION "2.2.4") set(PACKAGE_STRING "${PACKAGE_NAME} ${PACKAGE_VERSION}") set(PACKAGE_TARNAME "${PACKAGE_NAME}") -option(BUILD_tools "build the xmlwf tool for expat library" ON) +if(WINCE) + set(BUILD_tools_default OFF) +else() + set(BUILD_tools_default ON) +endif() +if(MSVC OR NOT BUILD_tools_default) + set(BUILD_doc_default OFF) +else() + find_program(DOCBOOK_TO_MAN NAMES docbook2x-man) + if(DOCBOOK_TO_MAN) + set(BUILD_doc_default ON) + else() + set(BUILD_doc_default OFF) + endif() +endif() + +option(BUILD_tools "build the xmlwf tool for expat library" ${BUILD_tools_default}) option(BUILD_examples "build the examples for expat library" ON) option(BUILD_tests "build the tests for expat library" ON) option(BUILD_shared "build a shared expat library" ON) -option(BUILD_doc "build man page for xmlwf" ON) +option(BUILD_doc "build man page for xmlwf" ${BUILD_doc_default}) +option(USE_libbsd "utilize libbsd (for arc4random_buf)" OFF) option(INSTALL "install expat files in cmake install target" ON) +if(USE_libbsd) + find_library(LIB_BSD NAMES bsd) + if(NOT LIB_BSD) + message(FATAL_ERROR "USE_libbsd option is enabled, but libbsd was not found") + else() + set(HAVE_LIBBSD TRUE) + endif() +endif() + # configuration options set(XML_CONTEXT_BYTES 1024 CACHE STRING "Define to specify how much context to retain around the current parse point") option(XML_DTD "Define to make parameter entity parsing functionality available" ON) option(XML_NS "Define to make XML Namespaces functionality available" ON) +if(NOT WIN32) + option(XML_DEV_URANDOM "Define to include code reading entropy from `/dev/urandom'." ON) + if(XML_DEV_URANDOM) + add_definitions(-DXML_DEV_URANDOM) + endif() +endif() if(XML_DTD) set(XML_DTD 1) @@ -39,11 +71,12 @@ endif(BUILD_tests) include(${CMAKE_CURRENT_LIST_DIR}/ConfigureChecks.cmake) -set(EXTRA_LINK_AND_COMPILE_FLAGS "-fno-strict-aliasing") -set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} ${EXTRA_LINK_AND_COMPILE_FLAGS}") -set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} ${EXTRA_LINK_AND_COMPILE_FLAGS}") -set(CMAKE_EXE_LINKER_FLAGS "${CMAKE_EXE_LINKER_FLAGS} ${EXTRA_LINK_AND_COMPILE_FLAGS}") -set(CMAKE_SHARED_LINKER_FLAGS "${CMAKE_SHARED_LINKER_FLAGS} ${EXTRA_LINK_AND_COMPILE_FLAGS}") +set(EXTRA_COMPILE_FLAGS) +if(FLAG_NO_STRICT_ALIASING) + set(EXTRA_COMPILE_FLAGS "${EXTRA_COMPILE_FLAGS} -fno-strict-aliasing") +endif() +set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} ${EXTRA_COMPILE_FLAGS}") +set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} ${EXTRA_COMPILE_FLAGS}") include_directories(${CMAKE_CURRENT_BINARY_DIR} ${CMAKE_CURRENT_SOURCE_DIR}/lib) if(MSVC) @@ -75,9 +108,12 @@ else(BUILD_shared) endif(BUILD_shared) add_library(expat ${_SHARED} ${expat_SRCS}) +if(USE_libbsd) + target_link_libraries(expat ${LIB_BSD}) +endif() set(LIBCURRENT 7) # sync -set(LIBREVISION 5) # with +set(LIBREVISION 6) # with set(LIBAGE 6) # configure.ac! math(EXPR LIBCURRENT_MINUS_AGE "${LIBCURRENT} - ${LIBAGE}") @@ -106,7 +142,7 @@ configure_file(expat.pc.in ${CMAKE_CURRENT_BINARY_DIR}/expat.pc) expat_install(FILES lib/expat.h lib/expat_external.h DESTINATION include) expat_install(FILES ${CMAKE_CURRENT_BINARY_DIR}/expat.pc DESTINATION lib/pkgconfig) -if(BUILD_tools AND NOT WINCE) +if(BUILD_tools) set(xmlwf_SRCS xmlwf/xmlwf.c xmlwf/xmlfile.c @@ -118,17 +154,17 @@ if(BUILD_tools AND NOT WINCE) set_property(TARGET xmlwf PROPERTY RUNTIME_OUTPUT_DIRECTORY xmlwf) target_link_libraries(xmlwf expat) expat_install(TARGETS xmlwf DESTINATION bin) - if(BUILD_doc AND NOT MSVC) + if(BUILD_doc) if(CMAKE_GENERATOR STREQUAL "Unix Makefiles") set(make_command "$(MAKE)") else() set(make_command "make") endif() - add_custom_command(TARGET expat PRE_BUILD COMMAND "${make_command}" -C "${PROJECT_SOURCE_DIR}/doc" xmlwf.1) + add_custom_command(TARGET expat PRE_BUILD COMMAND "${make_command}" -f "${PROJECT_SOURCE_DIR}/doc/doc.mk" -C "${PROJECT_SOURCE_DIR}/doc" xmlwf.1 "DOCBOOK_TO_MAN=${DOCBOOK_TO_MAN}") expat_install(FILES "${PROJECT_SOURCE_DIR}/doc/xmlwf.1" DESTINATION share/man/man1) endif() -endif(BUILD_tools AND NOT WINCE) +endif() if(BUILD_examples) add_executable(elements examples/elements.c) diff --git a/Changes b/Changes index 147f482..9b62893 100644 --- a/Changes +++ b/Changes @@ -2,6 +2,34 @@ NOTE: We are looking for help with a few things: https://github.com/libexpat/libexpat/labels/help%20wanted If you can help, please get in touch. Thanks! +Release 2.2.4 Sat Auguest 19 2017 + Bug fixes: + #115 Fix copying of partial characters for UTF-8 input + + Other changes: + #109 Fix "make check" for non-x86 architectures that default + to unsigned type char (-128..127 rather than 0..255) + #109 coverage.sh: Cover -funsigned-char + Autotools: Introduce --without-xmlwf argument + #65 Autotools: Replace handwritten Makefile with GNU Automake + #43 CMake: Auto-detect high quality entropy extractors, add new + option USE_libbsd=ON to use arc4random_buf of libbsd + #74 CMake: Add -fno-strict-aliasing only where supported + #114 CMake: Always honor manually set BUILD_* options + #114 CMake: Compile man page if docbook2x-man is available, only + #117 Include file tests/xmltest.log.expected in source tarball + (required for "make run-xmltest") + #117 Include (existing) Visual Studio 2013 files in source tarball + Improve test suite error output + #111 Fix some typos in documentation + Version info bumped from 7:5:6 to 7:6:6 + + Special thanks to: + Jakub Wilk + Joe Orton + Lin Tian + Rolf Eike Beer + Release 2.2.3 Wed August 2 2017 Security fixes: #82 CVE-2017-11742 -- Windows: Fix DLL hijacking vulnerability @@ -73,7 +101,7 @@ Release 2.2.2 Wed July 12 2017 #68 Fix "./buildconf.sh && ./configure" for some versions of Dash for /bin/sh #72 CMake: Ease use of Expat in context of a parent project - with multipe CMakeLists.txt files + with multiple CMakeLists.txt files #72 CMake: Resolve mistaken executable permissions #76 Address compile warning with -DNDEBUG (not recommended!) #77 Address compile warning about macro redefinition @@ -289,7 +317,7 @@ Release 2.1.0 Sat March 24 2012 #2855609: Dangling positionPtr after error. #2990652: CMake support. #3010819: UNEXPECTED_STATE with a trailing "%" in entity value. - #3206497: Unitialized memory returned from XML_Parse. + #3206497: Uninitialized memory returned from XML_Parse. #3287849: make check fails on mingw-w64. - Patches: #1749198: pkg-config support. diff --git a/ConfigureChecks.cmake b/ConfigureChecks.cmake index 2771a74..d97b397 100644 --- a/ConfigureChecks.cmake +++ b/ConfigureChecks.cmake @@ -1,3 +1,5 @@ +include(CheckCCompilerFlag) +include(CheckCSourceCompiles) include(CheckIncludeFile) include(CheckIncludeFiles) include(CheckFunctionExists) @@ -20,6 +22,16 @@ check_function_exists("getpagesize" HAVE_GETPAGESIZE) check_function_exists("bcopy" HAVE_BCOPY) check_symbol_exists("memmove" "string.h" HAVE_MEMMOVE) check_function_exists("mmap" HAVE_MMAP) +check_function_exists("getrandom" HAVE_GETRANDOM) + +if(USE_libbsd) + set(CMAKE_REQUIRED_LIBRARIES "${LIB_BSD}") +endif() +check_function_exists("arc4random_buf" HAVE_ARC4RANDOM_BUF) +if(NOT HAVE_ARC4RANDOM_BUF) + check_function_exists("arc4random" HAVE_ARC4RANDOM) +endif() +set(CMAKE_REQUIRED_LIBRARIES) #/* Define to 1 if you have the ANSI C header files. */ check_include_files("stdlib.h;stdarg.h;string.h;float.h" STDC_HEADERS) @@ -40,5 +52,17 @@ else(HAVE_SYS_TYPES_H) set(SIZE_T "unsigned") endif(HAVE_SYS_TYPES_H) +check_c_source_compiles(" + #include /* for NULL */ + #include /* for syscall */ + #include /* for SYS_getrandom */ + int main() { + syscall(SYS_getrandom, NULL, 0, 0); + return 0; + }" + HAVE_SYSCALL_GETRANDOM) + configure_file(expat_config.h.cmake "${CMAKE_CURRENT_BINARY_DIR}/expat_config.h") add_definitions(-DHAVE_EXPAT_CONFIG_H) + +check_c_compiler_flag("-fno-strict-aliasing" FLAG_NO_STRICT_ALIASING) diff --git a/MANIFEST b/MANIFEST deleted file mode 100644 index f602b4b..0000000 --- a/MANIFEST +++ /dev/null @@ -1,90 +0,0 @@ -AUTHORS -doc/expat.png -doc/reference.html -doc/style.css -doc/valid-xhtml10.png -doc/xmlwf.1 -doc/xmlwf.xml -CMakeLists.txt -CMake.README -COPYING -Changes -ConfigureChecks.cmake -MANIFEST -Makefile.in -README.md -configure -configure.ac -expat_config.h.in -expat_config.h.cmake -expat.pc.in -aclocal.m4 -run.sh.in -conftools/PrintPath -conftools/ac_c_bigendian_cross.m4 -conftools/expat.m4 -conftools/get-version.sh -conftools/mkinstalldirs -conftools/config.guess -conftools/config.sub -conftools/install-sh -conftools/ltmain.sh -m4/libtool.m4 -m4/ltversion.m4 -m4/ltoptions.m4 -m4/ltsugar.m4 -m4/lt~obsolete.m4 -examples/elements.c -examples/outline.c -lib/ascii.h -lib/asciitab.h -lib/expat.h -lib/expat_external.h -lib/iasciitab.h -lib/internal.h -lib/latin1tab.h -lib/libexpat.def -lib/libexpatw.def -lib/loadlibrary.c -lib/nametab.h -lib/siphash.h -lib/utf8tab.h -lib/winconfig.h -lib/xmlparse.c -lib/xmlrole.c -lib/xmlrole.h -lib/xmltok.c -lib/xmltok.h -lib/xmltok_impl.c -lib/xmltok_impl.h -lib/xmltok_ns.c -tests/benchmark/README.txt -tests/benchmark/benchmark.c -tests/README.txt -tests/chardata.c -tests/chardata.h -tests/memcheck.c -tests/memcheck.h -tests/minicheck.c -tests/minicheck.h -tests/runtests.c -tests/runtestspp.cpp -tests/xmltest.sh -win32/MANIFEST.txt -win32/README.txt -win32/expat.iss -xmlwf/codepage.c -xmlwf/codepage.h -xmlwf/ct.c -xmlwf/filemap.h -xmlwf/readfilemap.c -xmlwf/unixfilemap.c -xmlwf/win32filemap.c -xmlwf/xmlfile.c -xmlwf/xmlfile.h -xmlwf/xmlmime.c -xmlwf/xmlmime.h -xmlwf/xmltchar.h -xmlwf/xmlurl.h -xmlwf/xmlwf.c -xmlwf/xmlwin32url.cxx diff --git a/Makefile.am b/Makefile.am new file mode 100644 index 0000000..5b1c055 --- /dev/null +++ b/Makefile.am @@ -0,0 +1,153 @@ +# +# __ __ _ +# ___\ \/ /_ __ __ _| |_ +# / _ \\ /| '_ \ / _` | __| +# | __// \| |_) | (_| | |_ +# \___/_/\_\ .__/ \__,_|\__| +# |_| XML parser +# +# Copyright (c) 2017 Expat development team +# Licensed under the MIT license: +# +# Permission is hereby granted, free of charge, to any person obtaining +# a copy of this software and associated documentation files (the +# "Software"), to deal in the Software without restriction, including +# without limitation the rights to use, copy, modify, merge, publish, +# distribute, sublicense, and/or sell copies of the Software, and to permit +# persons to whom the Software is furnished to do so, subject to the +# following conditions: +# +# The above copyright notice and this permission notice shall be included +# in all copies or substantial portions of the Software. +# +# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, +# EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF +# MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN +# NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, +# DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR +# OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE +# USE OR OTHER DEALINGS IN THE SOFTWARE. + +AUTOMAKE_OPTIONS = \ + dist-bzip2 \ + foreign \ + no-dist-gzip \ + subdir-objects + +ACLOCAL_AMFLAGS = -I m4 +LIBTOOLFLAGS = --verbose + +SUBDIRS = lib examples tests # lib goes first to build first +if WITH_XMLWF +SUBDIRS += xmlwf doc +endif + +pkgconfig_DATA = expat.pc +pkgconfigdir = $(libdir)/pkgconfig + + +_EXTRA_DIST_CMAKE = \ + CMakeLists.txt \ + CMake.README \ + ConfigureChecks.cmake \ + expat_config.h.cmake + +_EXTRA_DIST_WINDOWS = \ + examples/elements.vcxproj \ + examples/elements.vcxproj.filters \ + examples/outline.vcxproj \ + examples/outline.vcxproj.filters \ + \ + lib/expat_static.vcxproj \ + lib/expat_static.vcxproj.filters \ + lib/expat.vcxproj \ + lib/expat.vcxproj.filters \ + lib/expatw_static.vcxproj \ + lib/expatw_static.vcxproj.filters \ + lib/expatw.vcxproj \ + lib/expatw.vcxproj.filters \ + \ + tests/benchmark/benchmark.sln \ + tests/benchmark/benchmark.vcxproj \ + \ + tests/runtests.sln \ + tests/runtests.vcxproj \ + tests/runtests.vcxproj.filters \ + \ + win32/expat.iss \ + win32/MANIFEST.txt \ + win32/README.txt \ + \ + xmlwf/xmlwf.vcxproj \ + xmlwf/xmlwf.vcxproj.filters \ + \ + expat.sln + +EXTRA_DIST = \ + $(_EXTRA_DIST_CMAKE) \ + $(_EXTRA_DIST_WINDOWS) \ + \ + conftools/expat.m4 \ + conftools/get-version.sh \ + conftools/PrintPath \ + \ + Changes \ + README.md \ + test-driver-wrapper.sh + + +.PHONY: buildlib +buildlib: + @echo 'ERROR: Running "make buildlib LIBRARY=libexpatw.la"' >&2 + @echo 'ERROR: is no longer supported. INSTEAD please:' >&2 + @echo 'ERROR:' >&2 + @echo 'ERROR: * Mass-patch Makefile.am, e.g.' >&2 + @echo 'ERROR: # find -name Makefile.am -exec sed \' >&2 + @echo 'ERROR: -e "s,libexpat\.la,libexpatw\.la," \' >&2 + @echo 'ERROR: -e "s,libexpat_la,libexpatw_la," \' >&2 + @echo 'ERROR: -i {} +' >&2 + @echo 'ERROR:' >&2 + @echo 'ERROR: * Run automake to re-generate Makefile.in files' >&2 + @echo 'ERROR:' >&2 + @echo 'ERROR: * Use "./configure --without-xmlwf" and/or' >&2 + @echo 'ERROR: "make -C lib all install" to bypass compilation' >&2 + @echo 'ERROR: of xmlwf (e.g. with -DXML_UNICODE)' >&2 + @echo 'ERROR:' >&2 + @false + + +.PHONY: run-benchmark +run-benchmark: + $(MAKE) -C tests/benchmark + tests/benchmark/benchmark@EXEEXT@ -n $(top_srcdir)/../testdata/largefiles/recset.xml 65535 3 + +tests/xmlts.zip: + if test "$(XMLTS_ZIP)" = ""; then \ + wget --output-document=tests/xmlts.zip \ + https://www.w3.org/XML/Test/xmlts20080827.zip; \ + else \ + cp $(XMLTS_ZIP) tests/xmlts.zip; \ + fi + +tests/xmlconf: tests/xmlts.zip + cd tests && unzip -q xmlts.zip + +.PHONY: run-xmltest +run-xmltest: tests/xmlconf +if WITH_XMLWF + $(MAKE) -C xmlwf + tests/xmltest.sh "$(PWD)/run.sh $(PWD)/xmlwf/xmlwf@EXEEXT@" 2>&1 | tee tests/xmltest.log + dos2unix tests/xmltest.log + diff -u tests/xmltest.log.expected tests/xmltest.log +else + @echo 'ERROR: xmlwf is needed for "make run-xmltest".' >&2 + @echo 'ERROR: Please re-configure without --without-xmlwf.' >&2 + @false +endif + +.PHONY: qa +qa: + ./qa.sh address + ./qa.sh memory + ./qa.sh undefined + ./qa.sh coverage diff --git a/Makefile.in b/Makefile.in index 3e98d24..1bd1c04 100644 --- a/Makefile.in +++ b/Makefile.in @@ -1,185 +1,996 @@ -################################################################ -# Process this file with top-level configure script to produce Makefile +# Makefile.in generated by automake 1.15.1 from Makefile.am. +# @configure_input@ + +# Copyright (C) 1994-2017 Free Software Foundation, Inc. + +# This Makefile.in is free software; the Free Software Foundation +# gives unlimited permission to copy and/or distribute it, +# with or without modifications, as long as this notice is preserved. + +# This program is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY, to the extent permitted by law; without +# even the implied warranty of MERCHANTABILITY or FITNESS FOR A +# PARTICULAR PURPOSE. + +@SET_MAKE@ + # -# Copyright 2000 Clark Cooper +# __ __ _ +# ___\ \/ /_ __ __ _| |_ +# / _ \\ /| '_ \ / _` | __| +# | __// \| |_) | (_| | |_ +# \___/_/\_\ .__/ \__,_|\__| +# |_| XML parser # -# This file is part of EXPAT. +# Copyright (c) 2017 Expat development team +# Licensed under the MIT license: # -# EXPAT is free software; you can redistribute it and/or modify it -# under the terms of the License (based on the MIT/X license) contained -# in the file COPYING that comes with this distribution. +# Permission is hereby granted, free of charge, to any person obtaining +# a copy of this software and associated documentation files (the +# "Software"), to deal in the Software without restriction, including +# without limitation the rights to use, copy, modify, merge, publish, +# distribute, sublicense, and/or sell copies of the Software, and to permit +# persons to whom the Software is furnished to do so, subject to the +# following conditions: # -# EXPAT IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, -# EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF -# MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. -# IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY -# CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, -# TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE -# SOFTWARE OR THE USE OR OTHER DEALINGS IN EXPAT. +# The above copyright notice and this permission notice shall be included +# in all copies or substantial portions of the Software. # +# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, +# EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF +# MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN +# NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, +# DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR +# OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE +# USE OR OTHER DEALINGS IN THE SOFTWARE. +VPATH = @srcdir@ +am__is_gnu_make = { \ + if test -z '$(MAKELEVEL)'; then \ + false; \ + elif test -n '$(MAKE_HOST)'; then \ + true; \ + elif test -n '$(MAKE_VERSION)' && test -n '$(CURDIR)'; then \ + true; \ + else \ + false; \ + fi; \ +} +am__make_running_with_option = \ + case $${target_option-} in \ + ?) ;; \ + *) echo "am__make_running_with_option: internal error: invalid" \ + "target option '$${target_option-}' specified" >&2; \ + exit 1;; \ + esac; \ + has_opt=no; \ + sane_makeflags=$$MAKEFLAGS; \ + if $(am__is_gnu_make); then \ + sane_makeflags=$$MFLAGS; \ + else \ + case $$MAKEFLAGS in \ + *\\[\ \ ]*) \ + bs=\\; \ + sane_makeflags=`printf '%s\n' "$$MAKEFLAGS" \ + | sed "s/$$bs$$bs[$$bs $$bs ]*//g"`;; \ + esac; \ + fi; \ + skip_next=no; \ + strip_trailopt () \ + { \ + flg=`printf '%s\n' "$$flg" | sed "s/$$1.*$$//"`; \ + }; \ + for flg in $$sane_makeflags; do \ + test $$skip_next = yes && { skip_next=no; continue; }; \ + case $$flg in \ + *=*|--*) continue;; \ + -*I) strip_trailopt 'I'; skip_next=yes;; \ + -*I?*) strip_trailopt 'I';; \ + -*O) strip_trailopt 'O'; skip_next=yes;; \ + -*O?*) strip_trailopt 'O';; \ + -*l) strip_trailopt 'l'; skip_next=yes;; \ + -*l?*) strip_trailopt 'l';; \ + -[dEDm]) skip_next=yes;; \ + -[JT]) skip_next=yes;; \ + esac; \ + case $$flg in \ + *$$target_option*) has_opt=yes; break;; \ + esac; \ + done; \ + test $$has_opt = yes +am__make_dryrun = (target_option=n; $(am__make_running_with_option)) +am__make_keepgoing = (target_option=k; $(am__make_running_with_option)) +pkgdatadir = $(datadir)/@PACKAGE@ +pkgincludedir = $(includedir)/@PACKAGE@ +pkglibdir = $(libdir)/@PACKAGE@ +pkglibexecdir = $(libexecdir)/@PACKAGE@ +am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd +install_sh_DATA = $(install_sh) -c -m 644 +install_sh_PROGRAM = $(install_sh) -c +install_sh_SCRIPT = $(install_sh) -c +INSTALL_HEADER = $(INSTALL_DATA) +transform = $(program_transform_name) +NORMAL_INSTALL = : +PRE_INSTALL = : +POST_INSTALL = : +NORMAL_UNINSTALL = : +PRE_UNINSTALL = : +POST_UNINSTALL = : +build_triplet = @build@ +host_triplet = @host@ +@WITH_XMLWF_TRUE@am__append_1 = xmlwf doc +subdir = . +ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 +am__aclocal_m4_deps = $(top_srcdir)/m4/libtool.m4 \ + $(top_srcdir)/m4/ltoptions.m4 $(top_srcdir)/m4/ltsugar.m4 \ + $(top_srcdir)/m4/ltversion.m4 $(top_srcdir)/m4/lt~obsolete.m4 \ + $(top_srcdir)/conftools/ac_c_bigendian_cross.m4 \ + $(top_srcdir)/configure.ac +am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \ + $(ACLOCAL_M4) +DIST_COMMON = $(srcdir)/Makefile.am $(top_srcdir)/configure \ + $(am__configure_deps) $(am__DIST_COMMON) +am__CONFIG_DISTCLEAN_FILES = config.status config.cache config.log \ + configure.lineno config.status.lineno +mkinstalldirs = $(install_sh) -d +CONFIG_HEADER = expat_config.h +CONFIG_CLEAN_FILES = expat.pc run.sh +CONFIG_CLEAN_VPATH_FILES = +AM_V_P = $(am__v_P_@AM_V@) +am__v_P_ = $(am__v_P_@AM_DEFAULT_V@) +am__v_P_0 = false +am__v_P_1 = : +AM_V_GEN = $(am__v_GEN_@AM_V@) +am__v_GEN_ = $(am__v_GEN_@AM_DEFAULT_V@) +am__v_GEN_0 = @echo " GEN " $@; +am__v_GEN_1 = +AM_V_at = $(am__v_at_@AM_V@) +am__v_at_ = $(am__v_at_@AM_DEFAULT_V@) +am__v_at_0 = @ +am__v_at_1 = +SOURCES = +DIST_SOURCES = +RECURSIVE_TARGETS = all-recursive check-recursive cscopelist-recursive \ + ctags-recursive dvi-recursive html-recursive info-recursive \ + install-data-recursive install-dvi-recursive \ + install-exec-recursive install-html-recursive \ + install-info-recursive install-pdf-recursive \ + install-ps-recursive install-recursive installcheck-recursive \ + installdirs-recursive pdf-recursive ps-recursive \ + tags-recursive uninstall-recursive +am__can_run_installinfo = \ + case $$AM_UPDATE_INFO_DIR in \ + n|no|NO) false;; \ + *) (install-info --version) >/dev/null 2>&1;; \ + esac +am__vpath_adj_setup = srcdirstrip=`echo "$(srcdir)" | sed 's|.|.|g'`; +am__vpath_adj = case $$p in \ + $(srcdir)/*) f=`echo "$$p" | sed "s|^$$srcdirstrip/||"`;; \ + *) f=$$p;; \ + esac; +am__strip_dir = f=`echo $$p | sed -e 's|^.*/||'`; +am__install_max = 40 +am__nobase_strip_setup = \ + srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*|]/\\\\&/g'` +am__nobase_strip = \ + for p in $$list; do echo "$$p"; done | sed -e "s|$$srcdirstrip/||" +am__nobase_list = $(am__nobase_strip_setup); \ + for p in $$list; do echo "$$p $$p"; done | \ + sed "s| $$srcdirstrip/| |;"' / .*\//!s/ .*/ ./; s,\( .*\)/[^/]*$$,\1,' | \ + $(AWK) 'BEGIN { files["."] = "" } { files[$$2] = files[$$2] " " $$1; \ + if (++n[$$2] == $(am__install_max)) \ + { print $$2, files[$$2]; n[$$2] = 0; files[$$2] = "" } } \ + END { for (dir in files) print dir, files[dir] }' +am__base_list = \ + sed '$$!N;$$!N;$$!N;$$!N;$$!N;$$!N;$$!N;s/\n/ /g' | \ + sed '$$!N;$$!N;$$!N;$$!N;s/\n/ /g' +am__uninstall_files_from_dir = { \ + test -z "$$files" \ + || { test ! -d "$$dir" && test ! -f "$$dir" && test ! -r "$$dir"; } \ + || { echo " ( cd '$$dir' && rm -f" $$files ")"; \ + $(am__cd) "$$dir" && rm -f $$files; }; \ + } +am__installdirs = "$(DESTDIR)$(pkgconfigdir)" +DATA = $(pkgconfig_DATA) +RECURSIVE_CLEAN_TARGETS = mostlyclean-recursive clean-recursive \ + distclean-recursive maintainer-clean-recursive +am__recursive_targets = \ + $(RECURSIVE_TARGETS) \ + $(RECURSIVE_CLEAN_TARGETS) \ + $(am__extra_recursive_targets) +AM_RECURSIVE_TARGETS = $(am__recursive_targets:-recursive=) TAGS CTAGS \ + cscope distdir dist dist-all distcheck +am__tagged_files = $(HEADERS) $(SOURCES) $(TAGS_FILES) \ + $(LISP)expat_config.h.in +# Read a list of newline-separated strings from the standard input, +# and print each of them once, without duplicates. Input order is +# *not* preserved. +am__uniquify_input = $(AWK) '\ + BEGIN { nonempty = 0; } \ + { items[$$0] = 1; nonempty = 1; } \ + END { if (nonempty) { for (i in items) print i; }; } \ +' +# Make sure the list of sources is unique. This is necessary because, +# e.g., the same source file might be shared among _SOURCES variables +# for different programs/libraries. +am__define_uniq_tagged_files = \ + list='$(am__tagged_files)'; \ + unique=`for i in $$list; do \ + if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ + done | $(am__uniquify_input)` +ETAGS = etags +CTAGS = ctags +CSCOPE = cscope +DIST_SUBDIRS = lib examples tests xmlwf doc +am__DIST_COMMON = $(srcdir)/Makefile.in $(srcdir)/expat.pc.in \ + $(srcdir)/expat_config.h.in $(srcdir)/run.sh.in \ + $(top_srcdir)/conftools/compile \ + $(top_srcdir)/conftools/config.guess \ + $(top_srcdir)/conftools/config.sub \ + $(top_srcdir)/conftools/install-sh \ + $(top_srcdir)/conftools/ltmain.sh \ + $(top_srcdir)/conftools/missing AUTHORS COPYING \ + conftools/compile conftools/config.guess conftools/config.sub \ + conftools/install-sh conftools/ltmain.sh conftools/missing +DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST) +distdir = $(PACKAGE)-$(VERSION) +top_distdir = $(distdir) +am__remove_distdir = \ + if test -d "$(distdir)"; then \ + find "$(distdir)" -type d ! -perm -200 -exec chmod u+w {} ';' \ + && rm -rf "$(distdir)" \ + || { sleep 5 && rm -rf "$(distdir)"; }; \ + else :; fi +am__post_remove_distdir = $(am__remove_distdir) +am__relativize = \ + dir0=`pwd`; \ + sed_first='s,^\([^/]*\)/.*$$,\1,'; \ + sed_rest='s,^[^/]*/*,,'; \ + sed_last='s,^.*/\([^/]*\)$$,\1,'; \ + sed_butlast='s,/*[^/]*$$,,'; \ + while test -n "$$dir1"; do \ + first=`echo "$$dir1" | sed -e "$$sed_first"`; \ + if test "$$first" != "."; then \ + if test "$$first" = ".."; then \ + dir2=`echo "$$dir0" | sed -e "$$sed_last"`/"$$dir2"; \ + dir0=`echo "$$dir0" | sed -e "$$sed_butlast"`; \ + else \ + first2=`echo "$$dir2" | sed -e "$$sed_first"`; \ + if test "$$first2" = "$$first"; then \ + dir2=`echo "$$dir2" | sed -e "$$sed_rest"`; \ + else \ + dir2="../$$dir2"; \ + fi; \ + dir0="$$dir0"/"$$first"; \ + fi; \ + fi; \ + dir1=`echo "$$dir1" | sed -e "$$sed_rest"`; \ + done; \ + reldir="$$dir2" +GZIP_ENV = --best +DIST_ARCHIVES = $(distdir).tar.bz2 +DIST_TARGETS = dist-bzip2 +distuninstallcheck_listfiles = find . -type f -print +am__distuninstallcheck_listfiles = $(distuninstallcheck_listfiles) \ + | sed 's|^\./|$(prefix)/|' | grep -v '$(infodir)/dir$$' +distcleancheck_listfiles = find . -type f -print +ACLOCAL = @ACLOCAL@ +AMTAR = @AMTAR@ +AM_DEFAULT_VERBOSITY = @AM_DEFAULT_VERBOSITY@ +AR = @AR@ +AS = @AS@ +AUTOCONF = @AUTOCONF@ +AUTOHEADER = @AUTOHEADER@ +AUTOMAKE = @AUTOMAKE@ +AWK = @AWK@ +CC = @CC@ +CCDEPMODE = @CCDEPMODE@ +CFLAGS = @CFLAGS@ +CPP = @CPP@ +CPPFLAGS = @CPPFLAGS@ +CXX = @CXX@ +CXXCPP = @CXXCPP@ +CXXDEPMODE = @CXXDEPMODE@ +CXXFLAGS = @CXXFLAGS@ +CYGPATH_W = @CYGPATH_W@ +DEFS = @DEFS@ +DEPDIR = @DEPDIR@ +DLLTOOL = @DLLTOOL@ +DSYMUTIL = @DSYMUTIL@ +DUMPBIN = @DUMPBIN@ +ECHO_C = @ECHO_C@ +ECHO_N = @ECHO_N@ +ECHO_T = @ECHO_T@ +EGREP = @EGREP@ +EXEEXT = @EXEEXT@ +FGREP = @FGREP@ +FILEMAP = @FILEMAP@ +GREP = @GREP@ +INSTALL = @INSTALL@ +INSTALL_DATA = @INSTALL_DATA@ +INSTALL_PROGRAM = @INSTALL_PROGRAM@ +INSTALL_SCRIPT = @INSTALL_SCRIPT@ +INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ +LD = @LD@ +LDFLAGS = @LDFLAGS@ +LIBAGE = @LIBAGE@ +LIBCURRENT = @LIBCURRENT@ +LIBOBJS = @LIBOBJS@ +LIBREVISION = @LIBREVISION@ +LIBS = @LIBS@ +LIBTOOL = @LIBTOOL@ +LIPO = @LIPO@ +LN_S = @LN_S@ +LTLIBOBJS = @LTLIBOBJS@ +LT_SYS_LIBRARY_PATH = @LT_SYS_LIBRARY_PATH@ +MAKEINFO = @MAKEINFO@ +MANIFEST_TOOL = @MANIFEST_TOOL@ +MKDIR_P = @MKDIR_P@ +NM = @NM@ +NMEDIT = @NMEDIT@ +OBJDUMP = @OBJDUMP@ +OBJEXT = @OBJEXT@ +OTOOL = @OTOOL@ +OTOOL64 = @OTOOL64@ +PACKAGE = @PACKAGE@ +PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@ +PACKAGE_NAME = @PACKAGE_NAME@ +PACKAGE_STRING = @PACKAGE_STRING@ +PACKAGE_TARNAME = @PACKAGE_TARNAME@ +PACKAGE_URL = @PACKAGE_URL@ +PACKAGE_VERSION = @PACKAGE_VERSION@ +PATH_SEPARATOR = @PATH_SEPARATOR@ +RANLIB = @RANLIB@ +SED = @SED@ +SET_MAKE = @SET_MAKE@ SHELL = @SHELL@ - +STRIP = @STRIP@ +VERSION = @VERSION@ +abs_builddir = @abs_builddir@ +abs_srcdir = @abs_srcdir@ +abs_top_builddir = @abs_top_builddir@ +abs_top_srcdir = @abs_top_srcdir@ +ac_ct_AR = @ac_ct_AR@ +ac_ct_CC = @ac_ct_CC@ +ac_ct_CXX = @ac_ct_CXX@ +ac_ct_DUMPBIN = @ac_ct_DUMPBIN@ +am__include = @am__include@ +am__leading_dot = @am__leading_dot@ +am__quote = @am__quote@ +am__tar = @am__tar@ +am__untar = @am__untar@ +bindir = @bindir@ +build = @build@ +build_alias = @build_alias@ +build_cpu = @build_cpu@ +build_os = @build_os@ +build_vendor = @build_vendor@ +builddir = @builddir@ +datadir = @datadir@ +datarootdir = @datarootdir@ +docdir = @docdir@ +dvidir = @dvidir@ +exec_prefix = @exec_prefix@ +host = @host@ +host_alias = @host_alias@ +host_cpu = @host_cpu@ +host_os = @host_os@ +host_vendor = @host_vendor@ +htmldir = @htmldir@ +includedir = @includedir@ +infodir = @infodir@ +install_sh = @install_sh@ +libdir = @libdir@ +libexecdir = @libexecdir@ +localedir = @localedir@ +localstatedir = @localstatedir@ +mandir = @mandir@ +mkdir_p = @mkdir_p@ +oldincludedir = @oldincludedir@ +pdfdir = @pdfdir@ +prefix = @prefix@ +program_transform_name = @program_transform_name@ +psdir = @psdir@ +sbindir = @sbindir@ +sharedstatedir = @sharedstatedir@ srcdir = @srcdir@ +sysconfdir = @sysconfdir@ +target_alias = @target_alias@ +top_build_prefix = @top_build_prefix@ +top_builddir = @top_builddir@ top_srcdir = @top_srcdir@ -VPATH = @srcdir@ - -prefix = @prefix@ -exec_prefix = @exec_prefix@ +AUTOMAKE_OPTIONS = \ + dist-bzip2 \ + foreign \ + no-dist-gzip \ + subdir-objects -bindir = @bindir@ -libdir = @libdir@ -includedir = @includedir@ -man1dir = @mandir@/man1 +ACLOCAL_AMFLAGS = -I m4 +LIBTOOLFLAGS = --verbose +SUBDIRS = lib examples tests $(am__append_1) +pkgconfig_DATA = expat.pc pkgconfigdir = $(libdir)/pkgconfig +_EXTRA_DIST_CMAKE = \ + CMakeLists.txt \ + CMake.README \ + ConfigureChecks.cmake \ + expat_config.h.cmake -top_builddir = . +_EXTRA_DIST_WINDOWS = \ + examples/elements.vcxproj \ + examples/elements.vcxproj.filters \ + examples/outline.vcxproj \ + examples/outline.vcxproj.filters \ + \ + lib/expat_static.vcxproj \ + lib/expat_static.vcxproj.filters \ + lib/expat.vcxproj \ + lib/expat.vcxproj.filters \ + lib/expatw_static.vcxproj \ + lib/expatw_static.vcxproj.filters \ + lib/expatw.vcxproj \ + lib/expatw.vcxproj.filters \ + \ + tests/benchmark/benchmark.sln \ + tests/benchmark/benchmark.vcxproj \ + \ + tests/runtests.sln \ + tests/runtests.vcxproj \ + tests/runtests.vcxproj.filters \ + \ + win32/expat.iss \ + win32/MANIFEST.txt \ + win32/README.txt \ + \ + xmlwf/xmlwf.vcxproj \ + xmlwf/xmlwf.vcxproj.filters \ + \ + expat.sln +EXTRA_DIST = \ + $(_EXTRA_DIST_CMAKE) \ + $(_EXTRA_DIST_WINDOWS) \ + \ + conftools/expat.m4 \ + conftools/get-version.sh \ + conftools/PrintPath \ + \ + Changes \ + README.md \ + test-driver-wrapper.sh -INSTALL = @INSTALL@ -INSTALL_PROGRAM = @INSTALL_PROGRAM@ -INSTALL_DATA = @INSTALL_DATA@ -mkinstalldirs = $(SHELL) $(top_srcdir)/conftools/mkinstalldirs +all: expat_config.h + $(MAKE) $(AM_MAKEFLAGS) all-recursive -MANFILE = $(srcdir)/doc/xmlwf.1 -APIHEADER = $(srcdir)/lib/expat.h $(srcdir)/lib/expat_external.h expat_config.h -LIBRARY = libexpat.la +.SUFFIXES: +am--refresh: Makefile + @: +$(srcdir)/Makefile.in: $(srcdir)/Makefile.am $(am__configure_deps) + @for dep in $?; do \ + case '$(am__configure_deps)' in \ + *$$dep*) \ + echo ' cd $(srcdir) && $(AUTOMAKE) --foreign'; \ + $(am__cd) $(srcdir) && $(AUTOMAKE) --foreign \ + && exit 0; \ + exit 1;; \ + esac; \ + done; \ + echo ' cd $(top_srcdir) && $(AUTOMAKE) --foreign Makefile'; \ + $(am__cd) $(top_srcdir) && \ + $(AUTOMAKE) --foreign Makefile +Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status + @case '$?' in \ + *config.status*) \ + echo ' $(SHELL) ./config.status'; \ + $(SHELL) ./config.status;; \ + *) \ + echo ' cd $(top_builddir) && $(SHELL) ./config.status $@ $(am__depfiles_maybe)'; \ + cd $(top_builddir) && $(SHELL) ./config.status $@ $(am__depfiles_maybe);; \ + esac; -DESTDIR = $(INSTALL_ROOT) +$(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES) + $(SHELL) ./config.status --recheck -default: buildlib xmlwf/xmlwf@EXEEXT@ +$(top_srcdir)/configure: $(am__configure_deps) + $(am__cd) $(srcdir) && $(AUTOCONF) +$(ACLOCAL_M4): $(am__aclocal_m4_deps) + $(am__cd) $(srcdir) && $(ACLOCAL) $(ACLOCAL_AMFLAGS) +$(am__aclocal_m4_deps): -buildlib: $(LIBRARY) expat.pc +expat_config.h: stamp-h1 + @test -f $@ || rm -f stamp-h1 + @test -f $@ || $(MAKE) $(AM_MAKEFLAGS) stamp-h1 -all: $(LIBRARY) expat.pc xmlwf/xmlwf@EXEEXT@ examples/elements examples/outline $(MANFILE) +stamp-h1: $(srcdir)/expat_config.h.in $(top_builddir)/config.status + @rm -f stamp-h1 + cd $(top_builddir) && $(SHELL) ./config.status expat_config.h +$(srcdir)/expat_config.h.in: $(am__configure_deps) + ($(am__cd) $(top_srcdir) && $(AUTOHEADER)) + rm -f stamp-h1 + touch $@ -clean: - cd lib && rm -f $(LIBRARY) *.@OBJEXT@ *.lo && rm -rf .libs _libs - cd xmlwf && rm -f xmlwf *.@OBJEXT@ *.lo && rm -rf .libs _libs - cd examples && rm -f elements outline *.@OBJEXT@ *.lo && rm -rf .libs _libs - cd tests && rm -rf .libs runtests@EXEEXT@ runtests.@OBJEXT@ runtestspp@EXEEXT@ runtestspp.@OBJEXT@ - cd tests && rm -f chardata.@OBJEXT@ memcheck.@OBJEXT@ minicheck.@OBJEXT@ - rm -rf .libs libexpat.la - rm -f examples/core tests/core xmlwf/core +distclean-hdr: + -rm -f expat_config.h stamp-h1 +expat.pc: $(top_builddir)/config.status $(srcdir)/expat.pc.in + cd $(top_builddir) && $(SHELL) ./config.status $@ +run.sh: $(top_builddir)/config.status $(srcdir)/run.sh.in + cd $(top_builddir) && $(SHELL) ./config.status $@ + +mostlyclean-libtool: + -rm -f *.lo -clobber: clean +clean-libtool: + -rm -rf .libs _libs -distclean: clean - rm -f expat_config.h config.status config.log config.cache libtool - rm -f Makefile expat.pc +distclean-libtool: + -rm -f libtool config.lt +install-pkgconfigDATA: $(pkgconfig_DATA) + @$(NORMAL_INSTALL) + @list='$(pkgconfig_DATA)'; test -n "$(pkgconfigdir)" || list=; \ + if test -n "$$list"; then \ + echo " $(MKDIR_P) '$(DESTDIR)$(pkgconfigdir)'"; \ + $(MKDIR_P) "$(DESTDIR)$(pkgconfigdir)" || exit 1; \ + fi; \ + for p in $$list; do \ + if test -f "$$p"; then d=; else d="$(srcdir)/"; fi; \ + echo "$$d$$p"; \ + done | $(am__base_list) | \ + while read files; do \ + echo " $(INSTALL_DATA) $$files '$(DESTDIR)$(pkgconfigdir)'"; \ + $(INSTALL_DATA) $$files "$(DESTDIR)$(pkgconfigdir)" || exit $$?; \ + done -extraclean: distclean - rm -f expat_config.h.in configure - rm -f aclocal.m4 m4/* - rm -f conftools/ltmain.sh conftools/install-sh conftools/config.guess conftools/config.sub +uninstall-pkgconfigDATA: + @$(NORMAL_UNINSTALL) + @list='$(pkgconfig_DATA)'; test -n "$(pkgconfigdir)" || list=; \ + files=`for p in $$list; do echo $$p; done | sed -e 's|^.*/||'`; \ + dir='$(DESTDIR)$(pkgconfigdir)'; $(am__uninstall_files_from_dir) + +# This directory's subdirectories are mostly independent; you can cd +# into them and run 'make' without going through this Makefile. +# To change the values of 'make' variables: instead of editing Makefiles, +# (1) if the variable is set in 'config.status', edit 'config.status' +# (which will cause the Makefiles to be regenerated when you run 'make'); +# (2) otherwise, pass the desired values on the 'make' command line. +$(am__recursive_targets): + @fail=; \ + if $(am__make_keepgoing); then \ + failcom='fail=yes'; \ + else \ + failcom='exit 1'; \ + fi; \ + dot_seen=no; \ + target=`echo $@ | sed s/-recursive//`; \ + case "$@" in \ + distclean-* | maintainer-clean-*) list='$(DIST_SUBDIRS)' ;; \ + *) list='$(SUBDIRS)' ;; \ + esac; \ + for subdir in $$list; do \ + echo "Making $$target in $$subdir"; \ + if test "$$subdir" = "."; then \ + dot_seen=yes; \ + local_target="$$target-am"; \ + else \ + local_target="$$target"; \ + fi; \ + ($(am__cd) $$subdir && $(MAKE) $(AM_MAKEFLAGS) $$local_target) \ + || eval $$failcom; \ + done; \ + if test "$$dot_seen" = "no"; then \ + $(MAKE) $(AM_MAKEFLAGS) "$$target-am" || exit 1; \ + fi; test -z "$$fail" -check: tests/runtests@EXEEXT@ tests/runtestspp@EXEEXT@ - ./run.sh tests/runtests@EXEEXT@ - ./run.sh tests/runtestspp@EXEEXT@ +ID: $(am__tagged_files) + $(am__define_uniq_tagged_files); mkid -fID $$unique +tags: tags-recursive +TAGS: tags -$(MANFILE): - $(MAKE) -C doc xmlwf.1 +tags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files) + set x; \ + here=`pwd`; \ + if ($(ETAGS) --etags-include --version) >/dev/null 2>&1; then \ + include_option=--etags-include; \ + empty_fix=.; \ + else \ + include_option=--include; \ + empty_fix=; \ + fi; \ + list='$(SUBDIRS)'; for subdir in $$list; do \ + if test "$$subdir" = .; then :; else \ + test ! -f $$subdir/TAGS || \ + set "$$@" "$$include_option=$$here/$$subdir/TAGS"; \ + fi; \ + done; \ + $(am__define_uniq_tagged_files); \ + shift; \ + if test -z "$(ETAGS_ARGS)$$*$$unique"; then :; else \ + test -n "$$unique" || unique=$$empty_fix; \ + if test $$# -gt 0; then \ + $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ + "$$@" $$unique; \ + else \ + $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ + $$unique; \ + fi; \ + fi +ctags: ctags-recursive -install: xmlwf/xmlwf@EXEEXT@ installlib $(MANFILE) - $(mkinstalldirs) $(DESTDIR)$(bindir) $(DESTDIR)$(man1dir) - $(LIBTOOL) --mode=install $(INSTALL_PROGRAM) xmlwf/xmlwf@EXEEXT@ $(DESTDIR)$(bindir)/xmlwf - $(INSTALL_DATA) $(MANFILE) $(DESTDIR)$(man1dir) +CTAGS: ctags +ctags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files) + $(am__define_uniq_tagged_files); \ + test -z "$(CTAGS_ARGS)$$unique" \ + || $(CTAGS) $(CTAGSFLAGS) $(AM_CTAGSFLAGS) $(CTAGS_ARGS) \ + $$unique -installlib: $(LIBRARY) $(APIHEADER) expat.pc - $(mkinstalldirs) $(DESTDIR)$(libdir) $(DESTDIR)$(includedir) $(DESTDIR)$(pkgconfigdir) - $(LIBTOOL) --mode=install $(INSTALL) $(LIBRARY) $(DESTDIR)$(libdir)/$(LIBRARY) - for FN in $(APIHEADER) ; do $(INSTALL_DATA) $$FN $(DESTDIR)$(includedir) ; done - $(INSTALL_DATA) expat.pc $(DESTDIR)$(pkgconfigdir)/expat.pc +GTAGS: + here=`$(am__cd) $(top_builddir) && pwd` \ + && $(am__cd) $(top_srcdir) \ + && gtags -i $(GTAGS_ARGS) "$$here" +cscope: cscope.files + test ! -s cscope.files \ + || $(CSCOPE) -b -q $(AM_CSCOPEFLAGS) $(CSCOPEFLAGS) -i cscope.files $(CSCOPE_ARGS) +clean-cscope: + -rm -f cscope.files +cscope.files: clean-cscope cscopelist +cscopelist: cscopelist-recursive -uninstall: uninstalllib - $(LIBTOOL) --mode=uninstall rm -f $(DESTDIR)$(bindir)/xmlwf@EXEEXT@ - rm -f $(DESTDIR)$(man1dir)/xmlwf.1 +cscopelist-am: $(am__tagged_files) + list='$(am__tagged_files)'; \ + case "$(srcdir)" in \ + [\\/]* | ?:[\\/]*) sdir="$(srcdir)" ;; \ + *) sdir=$(subdir)/$(srcdir) ;; \ + esac; \ + for i in $$list; do \ + if test -f "$$i"; then \ + echo "$(subdir)/$$i"; \ + else \ + echo "$$sdir/$$i"; \ + fi; \ + done >> $(top_builddir)/cscope.files -uninstalllib: - $(LIBTOOL) --mode=uninstall rm -f $(DESTDIR)$(libdir)/$(LIBRARY) - rm -f $(DESTDIR)$(includedir)/expat.h - rm -f $(DESTDIR)$(includedir)/expat_external.h - rm -f $(DESTDIR)$(pkgconfigdir)/expat.pc +distclean-tags: + -rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH tags + -rm -f cscope.out cscope.in.out cscope.po.out cscope.files -# for VPATH builds (invoked by configure) -mkdir-init: - @for d in lib xmlwf examples tests ; do \ - (mkdir $$d 2> /dev/null || test 1) ; \ +distdir: $(DISTFILES) + $(am__remove_distdir) + test -d "$(distdir)" || mkdir "$(distdir)" + @srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ + topsrcdirstrip=`echo "$(top_srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ + list='$(DISTFILES)'; \ + dist_files=`for file in $$list; do echo $$file; done | \ + sed -e "s|^$$srcdirstrip/||;t" \ + -e "s|^$$topsrcdirstrip/|$(top_builddir)/|;t"`; \ + case $$dist_files in \ + */*) $(MKDIR_P) `echo "$$dist_files" | \ + sed '/\//!d;s|^|$(distdir)/|;s,/[^/]*$$,,' | \ + sort -u` ;; \ + esac; \ + for file in $$dist_files; do \ + if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \ + if test -d $$d/$$file; then \ + dir=`echo "/$$file" | sed -e 's,/[^/]*$$,,'`; \ + if test -d "$(distdir)/$$file"; then \ + find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ + fi; \ + if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \ + cp -fpR $(srcdir)/$$file "$(distdir)$$dir" || exit 1; \ + find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ + fi; \ + cp -fpR $$d/$$file "$(distdir)$$dir" || exit 1; \ + else \ + test -f "$(distdir)/$$file" \ + || cp -p $$d/$$file "$(distdir)/$$file" \ + || exit 1; \ + fi; \ + done + @list='$(DIST_SUBDIRS)'; for subdir in $$list; do \ + if test "$$subdir" = .; then :; else \ + $(am__make_dryrun) \ + || test -d "$(distdir)/$$subdir" \ + || $(MKDIR_P) "$(distdir)/$$subdir" \ + || exit 1; \ + dir1=$$subdir; dir2="$(distdir)/$$subdir"; \ + $(am__relativize); \ + new_distdir=$$reldir; \ + dir1=$$subdir; dir2="$(top_distdir)"; \ + $(am__relativize); \ + new_top_distdir=$$reldir; \ + echo " (cd $$subdir && $(MAKE) $(AM_MAKEFLAGS) top_distdir="$$new_top_distdir" distdir="$$new_distdir" \\"; \ + echo " am__remove_distdir=: am__skip_length_check=: am__skip_mode_fix=: distdir)"; \ + ($(am__cd) $$subdir && \ + $(MAKE) $(AM_MAKEFLAGS) \ + top_distdir="$$new_top_distdir" \ + distdir="$$new_distdir" \ + am__remove_distdir=: \ + am__skip_length_check=: \ + am__skip_mode_fix=: \ + distdir) \ + || exit 1; \ + fi; \ done + -test -n "$(am__skip_mode_fix)" \ + || find "$(distdir)" -type d ! -perm -755 \ + -exec chmod u+rwx,go+rx {} \; -o \ + ! -type d ! -perm -444 -links 1 -exec chmod a+r {} \; -o \ + ! -type d ! -perm -400 -exec chmod a+r {} \; -o \ + ! -type d ! -perm -444 -exec $(install_sh) -c -m a+r {} {} \; \ + || chmod -R a+r "$(distdir)" +dist-gzip: distdir + tardir=$(distdir) && $(am__tar) | eval GZIP= gzip $(GZIP_ENV) -c >$(distdir).tar.gz + $(am__post_remove_distdir) +dist-bzip2: distdir + tardir=$(distdir) && $(am__tar) | BZIP2=$${BZIP2--9} bzip2 -c >$(distdir).tar.bz2 + $(am__post_remove_distdir) -CC = @CC@ -CXX = @CXX@ -LIBTOOL = @LIBTOOL@ +dist-lzip: distdir + tardir=$(distdir) && $(am__tar) | lzip -c $${LZIP_OPT--9} >$(distdir).tar.lz + $(am__post_remove_distdir) -INCLUDES = -I$(srcdir)/lib -I. -LDFLAGS = @LDFLAGS@ -CPPFLAGS = @CPPFLAGS@ -DHAVE_EXPAT_CONFIG_H -CFLAGS = @CFLAGS@ -CXXFLAGS = @CXXFLAGS@ -VSNFLAG = -version-info @LIBCURRENT@:@LIBREVISION@:@LIBAGE@ +dist-xz: distdir + tardir=$(distdir) && $(am__tar) | XZ_OPT=$${XZ_OPT--e} xz -c >$(distdir).tar.xz + $(am__post_remove_distdir) -### autoconf this? -LTFLAGS = --verbose +dist-tarZ: distdir + @echo WARNING: "Support for distribution archives compressed with" \ + "legacy program 'compress' is deprecated." >&2 + @echo WARNING: "It will be removed altogether in Automake 2.0" >&2 + tardir=$(distdir) && $(am__tar) | compress -c >$(distdir).tar.Z + $(am__post_remove_distdir) -COMPILE = $(CC) $(INCLUDES) $(CFLAGS) $(DEFS) $(CPPFLAGS) -CXXCOMPILE = $(CXX) $(INCLUDES) $(CXXFLAGS) $(DEFS) $(CPPFLAGS) -LTCOMPILE = $(LIBTOOL) $(LTFLAGS) --mode=compile $(COMPILE) -LINK_LIB = $(LIBTOOL) $(LTFLAGS) --mode=link $(COMPILE) -no-undefined $(VSNFLAG) -rpath $(libdir) $(LDFLAGS) @LIBS@ -o $@ -LINK_EXE = $(LIBTOOL) $(LTFLAGS) --mode=link $(COMPILE) $(LDFLAGS) -o $@ -LINK_CXX_EXE = $(LIBTOOL) $(LTFLAGS) --mode=link $(CXXCOMPILE) $(LDFLAGS) -o $@ +dist-shar: distdir + @echo WARNING: "Support for shar distribution archives is" \ + "deprecated." >&2 + @echo WARNING: "It will be removed altogether in Automake 2.0" >&2 + shar $(distdir) | eval GZIP= gzip $(GZIP_ENV) -c >$(distdir).shar.gz + $(am__post_remove_distdir) -LIB_OBJS = lib/loadlibrary.lo lib/xmlparse.lo lib/xmltok.lo lib/xmlrole.lo -$(LIBRARY): $(LIB_OBJS) - $(LINK_LIB) $(LIB_OBJS) +dist-zip: distdir + -rm -f $(distdir).zip + zip -rq $(distdir).zip $(distdir) + $(am__post_remove_distdir) -expat.pc: $(top_builddir)/config.status - cd $(top_builddir) && $(SHELL) ./config.status $@ +dist dist-all: + $(MAKE) $(AM_MAKEFLAGS) $(DIST_TARGETS) am__post_remove_distdir='@:' + $(am__post_remove_distdir) + +# This target untars the dist file and tries a VPATH configuration. Then +# it guarantees that the distribution is self-contained by making another +# tarfile. +distcheck: dist + case '$(DIST_ARCHIVES)' in \ + *.tar.gz*) \ + eval GZIP= gzip $(GZIP_ENV) -dc $(distdir).tar.gz | $(am__untar) ;;\ + *.tar.bz2*) \ + bzip2 -dc $(distdir).tar.bz2 | $(am__untar) ;;\ + *.tar.lz*) \ + lzip -dc $(distdir).tar.lz | $(am__untar) ;;\ + *.tar.xz*) \ + xz -dc $(distdir).tar.xz | $(am__untar) ;;\ + *.tar.Z*) \ + uncompress -c $(distdir).tar.Z | $(am__untar) ;;\ + *.shar.gz*) \ + eval GZIP= gzip $(GZIP_ENV) -dc $(distdir).shar.gz | unshar ;;\ + *.zip*) \ + unzip $(distdir).zip ;;\ + esac + chmod -R a-w $(distdir) + chmod u+w $(distdir) + mkdir $(distdir)/_build $(distdir)/_build/sub $(distdir)/_inst + chmod a-w $(distdir) + test -d $(distdir)/_build || exit 0; \ + dc_install_base=`$(am__cd) $(distdir)/_inst && pwd | sed -e 's,^[^:\\/]:[\\/],/,'` \ + && dc_destdir="$${TMPDIR-/tmp}/am-dc-$$$$/" \ + && am__cwd=`pwd` \ + && $(am__cd) $(distdir)/_build/sub \ + && ../../configure \ + $(AM_DISTCHECK_CONFIGURE_FLAGS) \ + $(DISTCHECK_CONFIGURE_FLAGS) \ + --srcdir=../.. --prefix="$$dc_install_base" \ + && $(MAKE) $(AM_MAKEFLAGS) \ + && $(MAKE) $(AM_MAKEFLAGS) dvi \ + && $(MAKE) $(AM_MAKEFLAGS) check \ + && $(MAKE) $(AM_MAKEFLAGS) install \ + && $(MAKE) $(AM_MAKEFLAGS) installcheck \ + && $(MAKE) $(AM_MAKEFLAGS) uninstall \ + && $(MAKE) $(AM_MAKEFLAGS) distuninstallcheck_dir="$$dc_install_base" \ + distuninstallcheck \ + && chmod -R a-w "$$dc_install_base" \ + && ({ \ + (cd ../.. && umask 077 && mkdir "$$dc_destdir") \ + && $(MAKE) $(AM_MAKEFLAGS) DESTDIR="$$dc_destdir" install \ + && $(MAKE) $(AM_MAKEFLAGS) DESTDIR="$$dc_destdir" uninstall \ + && $(MAKE) $(AM_MAKEFLAGS) DESTDIR="$$dc_destdir" \ + distuninstallcheck_dir="$$dc_destdir" distuninstallcheck; \ + } || { rm -rf "$$dc_destdir"; exit 1; }) \ + && rm -rf "$$dc_destdir" \ + && $(MAKE) $(AM_MAKEFLAGS) dist \ + && rm -rf $(DIST_ARCHIVES) \ + && $(MAKE) $(AM_MAKEFLAGS) distcleancheck \ + && cd "$$am__cwd" \ + || exit 1 + $(am__post_remove_distdir) + @(echo "$(distdir) archives ready for distribution: "; \ + list='$(DIST_ARCHIVES)'; for i in $$list; do echo $$i; done) | \ + sed -e 1h -e 1s/./=/g -e 1p -e 1x -e '$$p' -e '$$x' +distuninstallcheck: + @test -n '$(distuninstallcheck_dir)' || { \ + echo 'ERROR: trying to run $@ with an empty' \ + '$$(distuninstallcheck_dir)' >&2; \ + exit 1; \ + }; \ + $(am__cd) '$(distuninstallcheck_dir)' || { \ + echo 'ERROR: cannot chdir into $(distuninstallcheck_dir)' >&2; \ + exit 1; \ + }; \ + test `$(am__distuninstallcheck_listfiles) | wc -l` -eq 0 \ + || { echo "ERROR: files left after uninstall:" ; \ + if test -n "$(DESTDIR)"; then \ + echo " (check DESTDIR support)"; \ + fi ; \ + $(distuninstallcheck_listfiles) ; \ + exit 1; } >&2 +distcleancheck: distclean + @if test '$(srcdir)' = . ; then \ + echo "ERROR: distcleancheck can only run from a VPATH build" ; \ + exit 1 ; \ + fi + @test `$(distcleancheck_listfiles) | wc -l` -eq 0 \ + || { echo "ERROR: files left in build directory after distclean:" ; \ + $(distcleancheck_listfiles) ; \ + exit 1; } >&2 +check-am: all-am +check: check-recursive +all-am: Makefile $(DATA) expat_config.h +installdirs: installdirs-recursive +installdirs-am: + for dir in "$(DESTDIR)$(pkgconfigdir)"; do \ + test -z "$$dir" || $(MKDIR_P) "$$dir"; \ + done +install: install-recursive +install-exec: install-exec-recursive +install-data: install-data-recursive +uninstall: uninstall-recursive + +install-am: all-am + @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am + +installcheck: installcheck-recursive +install-strip: + if test -z '$(STRIP)'; then \ + $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ + install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ + install; \ + else \ + $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ + install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ + "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'" install; \ + fi +mostlyclean-generic: + +clean-generic: + +distclean-generic: + -test -z "$(CONFIG_CLEAN_FILES)" || rm -f $(CONFIG_CLEAN_FILES) + -test . = "$(srcdir)" || test -z "$(CONFIG_CLEAN_VPATH_FILES)" || rm -f $(CONFIG_CLEAN_VPATH_FILES) + +maintainer-clean-generic: + @echo "This command is intended for maintainers to use" + @echo "it deletes files that may require special tools to rebuild." +clean: clean-recursive + +clean-am: clean-generic clean-libtool mostlyclean-am + +distclean: distclean-recursive + -rm -f $(am__CONFIG_DISTCLEAN_FILES) + -rm -f Makefile +distclean-am: clean-am distclean-generic distclean-hdr \ + distclean-libtool distclean-tags + +dvi: dvi-recursive + +dvi-am: + +html: html-recursive + +html-am: -lib/xmlparse.lo: lib/xmlparse.c lib/expat.h lib/siphash.h lib/xmlrole.h lib/xmltok.h \ - $(top_builddir)/expat_config.h lib/expat_external.h lib/internal.h +info: info-recursive -lib/loadlibrary.lo: lib/loadlibrary.c +info-am: -lib/xmlrole.lo: lib/xmlrole.c lib/ascii.h lib/xmlrole.h \ - $(top_builddir)/expat_config.h lib/expat_external.h lib/internal.h +install-data-am: install-pkgconfigDATA -lib/xmltok.lo: lib/xmltok.c lib/xmltok_impl.c lib/xmltok_ns.c \ - lib/ascii.h lib/asciitab.h lib/iasciitab.h lib/latin1tab.h \ - lib/nametab.h lib/utf8tab.h lib/xmltok.h lib/xmltok_impl.h \ - $(top_builddir)/expat_config.h lib/expat_external.h lib/internal.h +install-dvi: install-dvi-recursive +install-dvi-am: -XMLWF_OBJS = xmlwf/xmlwf.@OBJEXT@ xmlwf/xmlfile.@OBJEXT@ xmlwf/codepage.@OBJEXT@ xmlwf/@FILEMAP@.@OBJEXT@ -xmlwf/xmlwf.@OBJEXT@: xmlwf/xmlwf.c -xmlwf/xmlfile.@OBJEXT@: xmlwf/xmlfile.c -xmlwf/codepage.@OBJEXT@: xmlwf/codepage.c -xmlwf/@FILEMAP@.@OBJEXT@: xmlwf/@FILEMAP@.c xmlwf/filemap.h -xmlwf/xmlwf@EXEEXT@: $(XMLWF_OBJS) $(LIBRARY) - $(LINK_EXE) $(XMLWF_OBJS) $(LIBRARY) +install-exec-am: -examples/elements.@OBJEXT@: examples/elements.c -examples/elements: examples/elements.@OBJEXT@ $(LIBRARY) - $(LINK_EXE) examples/elements.@OBJEXT@ $(LIBRARY) +install-html: install-html-recursive -examples/outline.@OBJEXT@: examples/outline.c -examples/outline: examples/outline.@OBJEXT@ $(LIBRARY) - $(LINK_EXE) examples/outline.@OBJEXT@ $(LIBRARY) +install-html-am: -tests/chardata.@OBJEXT@: tests/chardata.c tests/chardata.h -tests/minicheck.@OBJEXT@: tests/minicheck.c tests/minicheck.h -tests/memcheck.@OBJEXT@: tests/memcheck.c tests/memcheck.h -tests/runtests.@OBJEXT@: tests/runtests.c tests/chardata.h tests/memcheck.h lib/siphash.h -tests/runtests@EXEEXT@: tests/runtests.@OBJEXT@ tests/chardata.@OBJEXT@ tests/minicheck.@OBJEXT@ tests/memcheck.@OBJEXT@ $(LIBRARY) - $(LINK_EXE) tests/runtests.@OBJEXT@ tests/chardata.@OBJEXT@ tests/minicheck.@OBJEXT@ tests/memcheck.@OBJEXT@ $(LIBRARY) -tests/runtestspp.@OBJEXT@: tests/runtestspp.cpp tests/runtests.c tests/chardata.h tests/memcheck.h -tests/runtestspp@EXEEXT@: tests/runtestspp.@OBJEXT@ tests/chardata.@OBJEXT@ tests/minicheck.@OBJEXT@ tests/memcheck.@OBJEXT@ $(LIBRARY) - $(LINK_CXX_EXE) tests/runtestspp.@OBJEXT@ tests/chardata.@OBJEXT@ tests/minicheck.@OBJEXT@ tests/memcheck.@OBJEXT@ $(LIBRARY) +install-info: install-info-recursive -tests/benchmark/benchmark.@OBJEXT@: tests/benchmark/benchmark.c -tests/benchmark/benchmark: tests/benchmark/benchmark.@OBJEXT@ $(LIBRARY) - $(LINK_EXE) tests/benchmark/benchmark.@OBJEXT@ $(LIBRARY) +install-info-am: -run-benchmark: tests/benchmark/benchmark +install-man: + +install-pdf: install-pdf-recursive + +install-pdf-am: + +install-ps: install-ps-recursive + +install-ps-am: + +installcheck-am: + +maintainer-clean: maintainer-clean-recursive + -rm -f $(am__CONFIG_DISTCLEAN_FILES) + -rm -rf $(top_srcdir)/autom4te.cache + -rm -f Makefile +maintainer-clean-am: distclean-am maintainer-clean-generic + +mostlyclean: mostlyclean-recursive + +mostlyclean-am: mostlyclean-generic mostlyclean-libtool + +pdf: pdf-recursive + +pdf-am: + +ps: ps-recursive + +ps-am: + +uninstall-am: uninstall-pkgconfigDATA + +.MAKE: $(am__recursive_targets) all install-am install-strip + +.PHONY: $(am__recursive_targets) CTAGS GTAGS TAGS all all-am \ + am--refresh check check-am clean clean-cscope clean-generic \ + clean-libtool cscope cscopelist-am ctags ctags-am dist \ + dist-all dist-bzip2 dist-gzip dist-lzip dist-shar dist-tarZ \ + dist-xz dist-zip distcheck distclean distclean-generic \ + distclean-hdr distclean-libtool distclean-tags distcleancheck \ + distdir distuninstallcheck dvi dvi-am html html-am info \ + info-am install install-am install-data install-data-am \ + install-dvi install-dvi-am install-exec install-exec-am \ + install-html install-html-am install-info install-info-am \ + install-man install-pdf install-pdf-am install-pkgconfigDATA \ + install-ps install-ps-am install-strip installcheck \ + installcheck-am installdirs installdirs-am maintainer-clean \ + maintainer-clean-generic mostlyclean mostlyclean-generic \ + mostlyclean-libtool pdf pdf-am ps ps-am tags tags-am uninstall \ + uninstall-am uninstall-pkgconfigDATA + +.PRECIOUS: Makefile + + +.PHONY: buildlib +buildlib: + @echo 'ERROR: Running "make buildlib LIBRARY=libexpatw.la"' >&2 + @echo 'ERROR: is no longer supported. INSTEAD please:' >&2 + @echo 'ERROR:' >&2 + @echo 'ERROR: * Mass-patch Makefile.am, e.g.' >&2 + @echo 'ERROR: # find -name Makefile.am -exec sed \' >&2 + @echo 'ERROR: -e "s,libexpat\.la,libexpatw\.la," \' >&2 + @echo 'ERROR: -e "s,libexpat_la,libexpatw_la," \' >&2 + @echo 'ERROR: -i {} +' >&2 + @echo 'ERROR:' >&2 + @echo 'ERROR: * Run automake to re-generate Makefile.in files' >&2 + @echo 'ERROR:' >&2 + @echo 'ERROR: * Use "./configure --without-xmlwf" and/or' >&2 + @echo 'ERROR: "make -C lib all install" to bypass compilation' >&2 + @echo 'ERROR: of xmlwf (e.g. with -DXML_UNICODE)' >&2 + @echo 'ERROR:' >&2 + @false + +.PHONY: run-benchmark +run-benchmark: + $(MAKE) -C tests/benchmark tests/benchmark/benchmark@EXEEXT@ -n $(top_srcdir)/../testdata/largefiles/recset.xml 65535 3 tests/xmlts.zip: @@ -193,10 +1004,15 @@ tests/xmlts.zip: tests/xmlconf: tests/xmlts.zip cd tests && unzip -q xmlts.zip -run-xmltest: xmlwf/xmlwf@EXEEXT@ tests/xmlconf - tests/xmltest.sh "$(PWD)/run.sh $(PWD)/xmlwf/xmlwf@EXEEXT@" 2>&1 | tee tests/xmltest.log - dos2unix tests/xmltest.log - diff -u tests/xmltest.log.expected tests/xmltest.log +.PHONY: run-xmltest +run-xmltest: tests/xmlconf +@WITH_XMLWF_TRUE@ $(MAKE) -C xmlwf +@WITH_XMLWF_TRUE@ tests/xmltest.sh "$(PWD)/run.sh $(PWD)/xmlwf/xmlwf@EXEEXT@" 2>&1 | tee tests/xmltest.log +@WITH_XMLWF_TRUE@ dos2unix tests/xmltest.log +@WITH_XMLWF_TRUE@ diff -u tests/xmltest.log.expected tests/xmltest.log +@WITH_XMLWF_FALSE@ @echo 'ERROR: xmlwf is needed for "make run-xmltest".' >&2 +@WITH_XMLWF_FALSE@ @echo 'ERROR: Please re-configure without --without-xmlwf.' >&2 +@WITH_XMLWF_FALSE@ @false .PHONY: qa qa: @@ -205,16 +1021,6 @@ qa: ./qa.sh undefined ./qa.sh coverage -.SUFFIXES: .c .cpp .lo .@OBJEXT@ - -.cpp.@OBJEXT@: - $(CXXCOMPILE) -o $@ -c $< -.c.@OBJEXT@: - $(COMPILE) -o $@ -c $< -.c.lo: - $(LTCOMPILE) -o $@ -c $< - -.PHONY: buildlib all \ - clean distclean extraclean maintainer-clean \ - dist distdir \ - install uninstall +# Tell versions [3.59,3.63) of GNU make to not export all variables. +# Otherwise a system limit (for SysV at least) may be exceeded. +.NOEXPORT: diff --git a/README.md b/README.md index 0a1777e..7bb5512 100644 --- a/README.md +++ b/README.md @@ -1,4 +1,4 @@ -# Expat, Release 2.2.3 +# Expat, Release 2.2.4 This is Expat, a C library for parsing XML, started by [James Clark](https://en.wikipedia.org/wiki/James_Clark_(programmer)) in 1997. @@ -72,47 +72,43 @@ the directories into which things will be installed. If you are interested in building Expat to provide document information in UTF-16 encoding rather than the default UTF-8, follow -these instructions (after having run `make distclean`): +these instructions (after having run `make distclean`). +Please note that we configure with `--without-xmlwf` as xmlwf does not +support this mode of compilation (yet): + +1. Mass-patch `Makefile.am` files to use `libexpatw.la` for a library name: +
+ `find -name Makefile.am -exec sed + -e 's,libexpat\.la,libexpatw\.la,' + -e 's,libexpat_la,libexpatw_la,' + -i {} +` + +1. Run `automake` to re-write `Makefile.in` files:
+ `automake` 1. For UTF-16 output as unsigned short (and version/error strings as char), run:
- `./configure CPPFLAGS=-DXML_UNICODE`
+ `./configure CPPFLAGS=-DXML_UNICODE --without-xmlwf`
For UTF-16 output as `wchar_t` (incl. version/error strings), run:
- `./configure CFLAGS="-g -O2 -fshort-wchar" CPPFLAGS=-DXML_UNICODE_WCHAR_T` + `./configure CFLAGS="-g -O2 -fshort-wchar" CPPFLAGS=-DXML_UNICODE_WCHAR_T + --without-xmlwf`
Note: The latter requires libc compiled with `-fshort-wchar`, as well. -1. Edit `Makefile`, changing:
- `LIBRARY = libexpat.la`
- to:
- `LIBRARY = libexpatw.la`
- (Note the additional "w" in the library name.) - -1. Run `make buildlib` (which builds the library only). - Or, to save step 2, run `make buildlib LIBRARY=libexpatw.la`. +1. Run `make` (which excludes xmlwf). -1. Run `make installlib` (which installs the library only). - Or, if step 2 was omitted, run `make installlib LIBRARY=libexpatw.la`. +1. Run `make install` (again, excludes xmlwf). -Using `DESTDIR` or `INSTALL_ROOT` is enabled, with `INSTALL_ROOT` being the -default value for `DESTDIR`, and the rest of the make file using only -`DESTDIR`. It works as follows: +Using `DESTDIR` is supported. It works as follows: ```console make install DESTDIR=/path/to/image ``` -overrides the in-makefile set `DESTDIR`, while both - -```console -INSTALL_ROOT=/path/to/image make install -make install INSTALL_ROOT=/path/to/image -``` +overrides the in-makefile set `DESTDIR`, because variable-setting priority is -use `DESTDIR=$(INSTALL_ROOT)`, even if `DESTDIR` eventually is defined in the -environment, because variable-setting priority is 1. commandline -2. in-makefile -3. environment +1. in-makefile +1. environment Note: This only applies to the Expat library itself, building UTF-16 versions of xmlwf and the tests is currently not supported. diff --git a/aclocal.m4 b/aclocal.m4 index 210610f..3610979 100644 --- a/aclocal.m4 +++ b/aclocal.m4 @@ -12,6 +12,1144 @@ # PARTICULAR PURPOSE. m4_ifndef([AC_CONFIG_MACRO_DIRS], [m4_defun([_AM_CONFIG_MACRO_DIRS], [])m4_defun([AC_CONFIG_MACRO_DIRS], [_AM_CONFIG_MACRO_DIRS($@)])]) +m4_ifndef([AC_AUTOCONF_VERSION], + [m4_copy([m4_PACKAGE_VERSION], [AC_AUTOCONF_VERSION])])dnl +m4_if(m4_defn([AC_AUTOCONF_VERSION]), [2.69],, +[m4_warning([this file was generated for autoconf 2.69. +You have another version of autoconf. It may work, but is not guaranteed to. +If you have problems, you may need to regenerate the build system entirely. +To do so, use the procedure documented by the package, typically 'autoreconf'.])]) + +# Copyright (C) 2002-2017 Free Software Foundation, Inc. +# +# This file is free software; the Free Software Foundation +# gives unlimited permission to copy and/or distribute it, +# with or without modifications, as long as this notice is preserved. + +# AM_AUTOMAKE_VERSION(VERSION) +# ---------------------------- +# Automake X.Y traces this macro to ensure aclocal.m4 has been +# generated from the m4 files accompanying Automake X.Y. +# (This private macro should not be called outside this file.) +AC_DEFUN([AM_AUTOMAKE_VERSION], +[am__api_version='1.15' +dnl Some users find AM_AUTOMAKE_VERSION and mistake it for a way to +dnl require some minimum version. Point them to the right macro. +m4_if([$1], [1.15.1], [], + [AC_FATAL([Do not call $0, use AM_INIT_AUTOMAKE([$1]).])])dnl +]) + +# _AM_AUTOCONF_VERSION(VERSION) +# ----------------------------- +# aclocal traces this macro to find the Autoconf version. +# This is a private macro too. Using m4_define simplifies +# the logic in aclocal, which can simply ignore this definition. +m4_define([_AM_AUTOCONF_VERSION], []) + +# AM_SET_CURRENT_AUTOMAKE_VERSION +# ------------------------------- +# Call AM_AUTOMAKE_VERSION and AM_AUTOMAKE_VERSION so they can be traced. +# This function is AC_REQUIREd by AM_INIT_AUTOMAKE. +AC_DEFUN([AM_SET_CURRENT_AUTOMAKE_VERSION], +[AM_AUTOMAKE_VERSION([1.15.1])dnl +m4_ifndef([AC_AUTOCONF_VERSION], + [m4_copy([m4_PACKAGE_VERSION], [AC_AUTOCONF_VERSION])])dnl +_AM_AUTOCONF_VERSION(m4_defn([AC_AUTOCONF_VERSION]))]) + +# AM_AUX_DIR_EXPAND -*- Autoconf -*- + +# Copyright (C) 2001-2017 Free Software Foundation, Inc. +# +# This file is free software; the Free Software Foundation +# gives unlimited permission to copy and/or distribute it, +# with or without modifications, as long as this notice is preserved. + +# For projects using AC_CONFIG_AUX_DIR([foo]), Autoconf sets +# $ac_aux_dir to '$srcdir/foo'. In other projects, it is set to +# '$srcdir', '$srcdir/..', or '$srcdir/../..'. +# +# Of course, Automake must honor this variable whenever it calls a +# tool from the auxiliary directory. The problem is that $srcdir (and +# therefore $ac_aux_dir as well) can be either absolute or relative, +# depending on how configure is run. This is pretty annoying, since +# it makes $ac_aux_dir quite unusable in subdirectories: in the top +# source directory, any form will work fine, but in subdirectories a +# relative path needs to be adjusted first. +# +# $ac_aux_dir/missing +# fails when called from a subdirectory if $ac_aux_dir is relative +# $top_srcdir/$ac_aux_dir/missing +# fails if $ac_aux_dir is absolute, +# fails when called from a subdirectory in a VPATH build with +# a relative $ac_aux_dir +# +# The reason of the latter failure is that $top_srcdir and $ac_aux_dir +# are both prefixed by $srcdir. In an in-source build this is usually +# harmless because $srcdir is '.', but things will broke when you +# start a VPATH build or use an absolute $srcdir. +# +# So we could use something similar to $top_srcdir/$ac_aux_dir/missing, +# iff we strip the leading $srcdir from $ac_aux_dir. That would be: +# am_aux_dir='\$(top_srcdir)/'`expr "$ac_aux_dir" : "$srcdir//*\(.*\)"` +# and then we would define $MISSING as +# MISSING="\${SHELL} $am_aux_dir/missing" +# This will work as long as MISSING is not called from configure, because +# unfortunately $(top_srcdir) has no meaning in configure. +# However there are other variables, like CC, which are often used in +# configure, and could therefore not use this "fixed" $ac_aux_dir. +# +# Another solution, used here, is to always expand $ac_aux_dir to an +# absolute PATH. The drawback is that using absolute paths prevent a +# configured tree to be moved without reconfiguration. + +AC_DEFUN([AM_AUX_DIR_EXPAND], +[AC_REQUIRE([AC_CONFIG_AUX_DIR_DEFAULT])dnl +# Expand $ac_aux_dir to an absolute path. +am_aux_dir=`cd "$ac_aux_dir" && pwd` +]) + +# AM_CONDITIONAL -*- Autoconf -*- + +# Copyright (C) 1997-2017 Free Software Foundation, Inc. +# +# This file is free software; the Free Software Foundation +# gives unlimited permission to copy and/or distribute it, +# with or without modifications, as long as this notice is preserved. + +# AM_CONDITIONAL(NAME, SHELL-CONDITION) +# ------------------------------------- +# Define a conditional. +AC_DEFUN([AM_CONDITIONAL], +[AC_PREREQ([2.52])dnl + m4_if([$1], [TRUE], [AC_FATAL([$0: invalid condition: $1])], + [$1], [FALSE], [AC_FATAL([$0: invalid condition: $1])])dnl +AC_SUBST([$1_TRUE])dnl +AC_SUBST([$1_FALSE])dnl +_AM_SUBST_NOTMAKE([$1_TRUE])dnl +_AM_SUBST_NOTMAKE([$1_FALSE])dnl +m4_define([_AM_COND_VALUE_$1], [$2])dnl +if $2; then + $1_TRUE= + $1_FALSE='#' +else + $1_TRUE='#' + $1_FALSE= +fi +AC_CONFIG_COMMANDS_PRE( +[if test -z "${$1_TRUE}" && test -z "${$1_FALSE}"; then + AC_MSG_ERROR([[conditional "$1" was never defined. +Usually this means the macro was only invoked conditionally.]]) +fi])]) + +# Copyright (C) 1999-2017 Free Software Foundation, Inc. +# +# This file is free software; the Free Software Foundation +# gives unlimited permission to copy and/or distribute it, +# with or without modifications, as long as this notice is preserved. + + +# There are a few dirty hacks below to avoid letting 'AC_PROG_CC' be +# written in clear, in which case automake, when reading aclocal.m4, +# will think it sees a *use*, and therefore will trigger all it's +# C support machinery. Also note that it means that autoscan, seeing +# CC etc. in the Makefile, will ask for an AC_PROG_CC use... + + +# _AM_DEPENDENCIES(NAME) +# ---------------------- +# See how the compiler implements dependency checking. +# NAME is "CC", "CXX", "OBJC", "OBJCXX", "UPC", or "GJC". +# We try a few techniques and use that to set a single cache variable. +# +# We don't AC_REQUIRE the corresponding AC_PROG_CC since the latter was +# modified to invoke _AM_DEPENDENCIES(CC); we would have a circular +# dependency, and given that the user is not expected to run this macro, +# just rely on AC_PROG_CC. +AC_DEFUN([_AM_DEPENDENCIES], +[AC_REQUIRE([AM_SET_DEPDIR])dnl +AC_REQUIRE([AM_OUTPUT_DEPENDENCY_COMMANDS])dnl +AC_REQUIRE([AM_MAKE_INCLUDE])dnl +AC_REQUIRE([AM_DEP_TRACK])dnl + +m4_if([$1], [CC], [depcc="$CC" am_compiler_list=], + [$1], [CXX], [depcc="$CXX" am_compiler_list=], + [$1], [OBJC], [depcc="$OBJC" am_compiler_list='gcc3 gcc'], + [$1], [OBJCXX], [depcc="$OBJCXX" am_compiler_list='gcc3 gcc'], + [$1], [UPC], [depcc="$UPC" am_compiler_list=], + [$1], [GCJ], [depcc="$GCJ" am_compiler_list='gcc3 gcc'], + [depcc="$$1" am_compiler_list=]) + +AC_CACHE_CHECK([dependency style of $depcc], + [am_cv_$1_dependencies_compiler_type], +[if test -z "$AMDEP_TRUE" && test -f "$am_depcomp"; then + # We make a subdir and do the tests there. Otherwise we can end up + # making bogus files that we don't know about and never remove. For + # instance it was reported that on HP-UX the gcc test will end up + # making a dummy file named 'D' -- because '-MD' means "put the output + # in D". + rm -rf conftest.dir + mkdir conftest.dir + # Copy depcomp to subdir because otherwise we won't find it if we're + # using a relative directory. + cp "$am_depcomp" conftest.dir + cd conftest.dir + # We will build objects and dependencies in a subdirectory because + # it helps to detect inapplicable dependency modes. For instance + # both Tru64's cc and ICC support -MD to output dependencies as a + # side effect of compilation, but ICC will put the dependencies in + # the current directory while Tru64 will put them in the object + # directory. + mkdir sub + + am_cv_$1_dependencies_compiler_type=none + if test "$am_compiler_list" = ""; then + am_compiler_list=`sed -n ['s/^#*\([a-zA-Z0-9]*\))$/\1/p'] < ./depcomp` + fi + am__universal=false + m4_case([$1], [CC], + [case " $depcc " in #( + *\ -arch\ *\ -arch\ *) am__universal=true ;; + esac], + [CXX], + [case " $depcc " in #( + *\ -arch\ *\ -arch\ *) am__universal=true ;; + esac]) + + for depmode in $am_compiler_list; do + # Setup a source with many dependencies, because some compilers + # like to wrap large dependency lists on column 80 (with \), and + # we should not choose a depcomp mode which is confused by this. + # + # We need to recreate these files for each test, as the compiler may + # overwrite some of them when testing with obscure command lines. + # This happens at least with the AIX C compiler. + : > sub/conftest.c + for i in 1 2 3 4 5 6; do + echo '#include "conftst'$i'.h"' >> sub/conftest.c + # Using ": > sub/conftst$i.h" creates only sub/conftst1.h with + # Solaris 10 /bin/sh. + echo '/* dummy */' > sub/conftst$i.h + done + echo "${am__include} ${am__quote}sub/conftest.Po${am__quote}" > confmf + + # We check with '-c' and '-o' for the sake of the "dashmstdout" + # mode. It turns out that the SunPro C++ compiler does not properly + # handle '-M -o', and we need to detect this. Also, some Intel + # versions had trouble with output in subdirs. + am__obj=sub/conftest.${OBJEXT-o} + am__minus_obj="-o $am__obj" + case $depmode in + gcc) + # This depmode causes a compiler race in universal mode. + test "$am__universal" = false || continue + ;; + nosideeffect) + # After this tag, mechanisms are not by side-effect, so they'll + # only be used when explicitly requested. + if test "x$enable_dependency_tracking" = xyes; then + continue + else + break + fi + ;; + msvc7 | msvc7msys | msvisualcpp | msvcmsys) + # This compiler won't grok '-c -o', but also, the minuso test has + # not run yet. These depmodes are late enough in the game, and + # so weak that their functioning should not be impacted. + am__obj=conftest.${OBJEXT-o} + am__minus_obj= + ;; + none) break ;; + esac + if depmode=$depmode \ + source=sub/conftest.c object=$am__obj \ + depfile=sub/conftest.Po tmpdepfile=sub/conftest.TPo \ + $SHELL ./depcomp $depcc -c $am__minus_obj sub/conftest.c \ + >/dev/null 2>conftest.err && + grep sub/conftst1.h sub/conftest.Po > /dev/null 2>&1 && + grep sub/conftst6.h sub/conftest.Po > /dev/null 2>&1 && + grep $am__obj sub/conftest.Po > /dev/null 2>&1 && + ${MAKE-make} -s -f confmf > /dev/null 2>&1; then + # icc doesn't choke on unknown options, it will just issue warnings + # or remarks (even with -Werror). So we grep stderr for any message + # that says an option was ignored or not supported. + # When given -MP, icc 7.0 and 7.1 complain thusly: + # icc: Command line warning: ignoring option '-M'; no argument required + # The diagnosis changed in icc 8.0: + # icc: Command line remark: option '-MP' not supported + if (grep 'ignoring option' conftest.err || + grep 'not supported' conftest.err) >/dev/null 2>&1; then :; else + am_cv_$1_dependencies_compiler_type=$depmode + break + fi + fi + done + + cd .. + rm -rf conftest.dir +else + am_cv_$1_dependencies_compiler_type=none +fi +]) +AC_SUBST([$1DEPMODE], [depmode=$am_cv_$1_dependencies_compiler_type]) +AM_CONDITIONAL([am__fastdep$1], [ + test "x$enable_dependency_tracking" != xno \ + && test "$am_cv_$1_dependencies_compiler_type" = gcc3]) +]) + + +# AM_SET_DEPDIR +# ------------- +# Choose a directory name for dependency files. +# This macro is AC_REQUIREd in _AM_DEPENDENCIES. +AC_DEFUN([AM_SET_DEPDIR], +[AC_REQUIRE([AM_SET_LEADING_DOT])dnl +AC_SUBST([DEPDIR], ["${am__leading_dot}deps"])dnl +]) + + +# AM_DEP_TRACK +# ------------ +AC_DEFUN([AM_DEP_TRACK], +[AC_ARG_ENABLE([dependency-tracking], [dnl +AS_HELP_STRING( + [--enable-dependency-tracking], + [do not reject slow dependency extractors]) +AS_HELP_STRING( + [--disable-dependency-tracking], + [speeds up one-time build])]) +if test "x$enable_dependency_tracking" != xno; then + am_depcomp="$ac_aux_dir/depcomp" + AMDEPBACKSLASH='\' + am__nodep='_no' +fi +AM_CONDITIONAL([AMDEP], [test "x$enable_dependency_tracking" != xno]) +AC_SUBST([AMDEPBACKSLASH])dnl +_AM_SUBST_NOTMAKE([AMDEPBACKSLASH])dnl +AC_SUBST([am__nodep])dnl +_AM_SUBST_NOTMAKE([am__nodep])dnl +]) + +# Generate code to set up dependency tracking. -*- Autoconf -*- + +# Copyright (C) 1999-2017 Free Software Foundation, Inc. +# +# This file is free software; the Free Software Foundation +# gives unlimited permission to copy and/or distribute it, +# with or without modifications, as long as this notice is preserved. + + +# _AM_OUTPUT_DEPENDENCY_COMMANDS +# ------------------------------ +AC_DEFUN([_AM_OUTPUT_DEPENDENCY_COMMANDS], +[{ + # Older Autoconf quotes --file arguments for eval, but not when files + # are listed without --file. Let's play safe and only enable the eval + # if we detect the quoting. + case $CONFIG_FILES in + *\'*) eval set x "$CONFIG_FILES" ;; + *) set x $CONFIG_FILES ;; + esac + shift + for mf + do + # Strip MF so we end up with the name of the file. + mf=`echo "$mf" | sed -e 's/:.*$//'` + # Check whether this is an Automake generated Makefile or not. + # We used to match only the files named 'Makefile.in', but + # some people rename them; so instead we look at the file content. + # Grep'ing the first line is not enough: some people post-process + # each Makefile.in and add a new line on top of each file to say so. + # Grep'ing the whole file is not good either: AIX grep has a line + # limit of 2048, but all sed's we know have understand at least 4000. + if sed -n 's,^#.*generated by automake.*,X,p' "$mf" | grep X >/dev/null 2>&1; then + dirpart=`AS_DIRNAME("$mf")` + else + continue + fi + # Extract the definition of DEPDIR, am__include, and am__quote + # from the Makefile without running 'make'. + DEPDIR=`sed -n 's/^DEPDIR = //p' < "$mf"` + test -z "$DEPDIR" && continue + am__include=`sed -n 's/^am__include = //p' < "$mf"` + test -z "$am__include" && continue + am__quote=`sed -n 's/^am__quote = //p' < "$mf"` + # Find all dependency output files, they are included files with + # $(DEPDIR) in their names. We invoke sed twice because it is the + # simplest approach to changing $(DEPDIR) to its actual value in the + # expansion. + for file in `sed -n " + s/^$am__include $am__quote\(.*(DEPDIR).*\)$am__quote"'$/\1/p' <"$mf" | \ + sed -e 's/\$(DEPDIR)/'"$DEPDIR"'/g'`; do + # Make sure the directory exists. + test -f "$dirpart/$file" && continue + fdir=`AS_DIRNAME(["$file"])` + AS_MKDIR_P([$dirpart/$fdir]) + # echo "creating $dirpart/$file" + echo '# dummy' > "$dirpart/$file" + done + done +} +])# _AM_OUTPUT_DEPENDENCY_COMMANDS + + +# AM_OUTPUT_DEPENDENCY_COMMANDS +# ----------------------------- +# This macro should only be invoked once -- use via AC_REQUIRE. +# +# This code is only required when automatic dependency tracking +# is enabled. FIXME. This creates each '.P' file that we will +# need in order to bootstrap the dependency handling code. +AC_DEFUN([AM_OUTPUT_DEPENDENCY_COMMANDS], +[AC_CONFIG_COMMANDS([depfiles], + [test x"$AMDEP_TRUE" != x"" || _AM_OUTPUT_DEPENDENCY_COMMANDS], + [AMDEP_TRUE="$AMDEP_TRUE" ac_aux_dir="$ac_aux_dir"]) +]) + +# Do all the work for Automake. -*- Autoconf -*- + +# Copyright (C) 1996-2017 Free Software Foundation, Inc. +# +# This file is free software; the Free Software Foundation +# gives unlimited permission to copy and/or distribute it, +# with or without modifications, as long as this notice is preserved. + +# This macro actually does too much. Some checks are only needed if +# your package does certain things. But this isn't really a big deal. + +dnl Redefine AC_PROG_CC to automatically invoke _AM_PROG_CC_C_O. +m4_define([AC_PROG_CC], +m4_defn([AC_PROG_CC]) +[_AM_PROG_CC_C_O +]) + +# AM_INIT_AUTOMAKE(PACKAGE, VERSION, [NO-DEFINE]) +# AM_INIT_AUTOMAKE([OPTIONS]) +# ----------------------------------------------- +# The call with PACKAGE and VERSION arguments is the old style +# call (pre autoconf-2.50), which is being phased out. PACKAGE +# and VERSION should now be passed to AC_INIT and removed from +# the call to AM_INIT_AUTOMAKE. +# We support both call styles for the transition. After +# the next Automake release, Autoconf can make the AC_INIT +# arguments mandatory, and then we can depend on a new Autoconf +# release and drop the old call support. +AC_DEFUN([AM_INIT_AUTOMAKE], +[AC_PREREQ([2.65])dnl +dnl Autoconf wants to disallow AM_ names. We explicitly allow +dnl the ones we care about. +m4_pattern_allow([^AM_[A-Z]+FLAGS$])dnl +AC_REQUIRE([AM_SET_CURRENT_AUTOMAKE_VERSION])dnl +AC_REQUIRE([AC_PROG_INSTALL])dnl +if test "`cd $srcdir && pwd`" != "`pwd`"; then + # Use -I$(srcdir) only when $(srcdir) != ., so that make's output + # is not polluted with repeated "-I." + AC_SUBST([am__isrc], [' -I$(srcdir)'])_AM_SUBST_NOTMAKE([am__isrc])dnl + # test to see if srcdir already configured + if test -f $srcdir/config.status; then + AC_MSG_ERROR([source directory already configured; run "make distclean" there first]) + fi +fi + +# test whether we have cygpath +if test -z "$CYGPATH_W"; then + if (cygpath --version) >/dev/null 2>/dev/null; then + CYGPATH_W='cygpath -w' + else + CYGPATH_W=echo + fi +fi +AC_SUBST([CYGPATH_W]) + +# Define the identity of the package. +dnl Distinguish between old-style and new-style calls. +m4_ifval([$2], +[AC_DIAGNOSE([obsolete], + [$0: two- and three-arguments forms are deprecated.]) +m4_ifval([$3], [_AM_SET_OPTION([no-define])])dnl + AC_SUBST([PACKAGE], [$1])dnl + AC_SUBST([VERSION], [$2])], +[_AM_SET_OPTIONS([$1])dnl +dnl Diagnose old-style AC_INIT with new-style AM_AUTOMAKE_INIT. +m4_if( + m4_ifdef([AC_PACKAGE_NAME], [ok]):m4_ifdef([AC_PACKAGE_VERSION], [ok]), + [ok:ok],, + [m4_fatal([AC_INIT should be called with package and version arguments])])dnl + AC_SUBST([PACKAGE], ['AC_PACKAGE_TARNAME'])dnl + AC_SUBST([VERSION], ['AC_PACKAGE_VERSION'])])dnl + +_AM_IF_OPTION([no-define],, +[AC_DEFINE_UNQUOTED([PACKAGE], ["$PACKAGE"], [Name of package]) + AC_DEFINE_UNQUOTED([VERSION], ["$VERSION"], [Version number of package])])dnl + +# Some tools Automake needs. +AC_REQUIRE([AM_SANITY_CHECK])dnl +AC_REQUIRE([AC_ARG_PROGRAM])dnl +AM_MISSING_PROG([ACLOCAL], [aclocal-${am__api_version}]) +AM_MISSING_PROG([AUTOCONF], [autoconf]) +AM_MISSING_PROG([AUTOMAKE], [automake-${am__api_version}]) +AM_MISSING_PROG([AUTOHEADER], [autoheader]) +AM_MISSING_PROG([MAKEINFO], [makeinfo]) +AC_REQUIRE([AM_PROG_INSTALL_SH])dnl +AC_REQUIRE([AM_PROG_INSTALL_STRIP])dnl +AC_REQUIRE([AC_PROG_MKDIR_P])dnl +# For better backward compatibility. To be removed once Automake 1.9.x +# dies out for good. For more background, see: +# +# +AC_SUBST([mkdir_p], ['$(MKDIR_P)']) +# We need awk for the "check" target (and possibly the TAP driver). The +# system "awk" is bad on some platforms. +AC_REQUIRE([AC_PROG_AWK])dnl +AC_REQUIRE([AC_PROG_MAKE_SET])dnl +AC_REQUIRE([AM_SET_LEADING_DOT])dnl +_AM_IF_OPTION([tar-ustar], [_AM_PROG_TAR([ustar])], + [_AM_IF_OPTION([tar-pax], [_AM_PROG_TAR([pax])], + [_AM_PROG_TAR([v7])])]) +_AM_IF_OPTION([no-dependencies],, +[AC_PROVIDE_IFELSE([AC_PROG_CC], + [_AM_DEPENDENCIES([CC])], + [m4_define([AC_PROG_CC], + m4_defn([AC_PROG_CC])[_AM_DEPENDENCIES([CC])])])dnl +AC_PROVIDE_IFELSE([AC_PROG_CXX], + [_AM_DEPENDENCIES([CXX])], + [m4_define([AC_PROG_CXX], + m4_defn([AC_PROG_CXX])[_AM_DEPENDENCIES([CXX])])])dnl +AC_PROVIDE_IFELSE([AC_PROG_OBJC], + [_AM_DEPENDENCIES([OBJC])], + [m4_define([AC_PROG_OBJC], + m4_defn([AC_PROG_OBJC])[_AM_DEPENDENCIES([OBJC])])])dnl +AC_PROVIDE_IFELSE([AC_PROG_OBJCXX], + [_AM_DEPENDENCIES([OBJCXX])], + [m4_define([AC_PROG_OBJCXX], + m4_defn([AC_PROG_OBJCXX])[_AM_DEPENDENCIES([OBJCXX])])])dnl +]) +AC_REQUIRE([AM_SILENT_RULES])dnl +dnl The testsuite driver may need to know about EXEEXT, so add the +dnl 'am__EXEEXT' conditional if _AM_COMPILER_EXEEXT was seen. This +dnl macro is hooked onto _AC_COMPILER_EXEEXT early, see below. +AC_CONFIG_COMMANDS_PRE(dnl +[m4_provide_if([_AM_COMPILER_EXEEXT], + [AM_CONDITIONAL([am__EXEEXT], [test -n "$EXEEXT"])])])dnl + +# POSIX will say in a future version that running "rm -f" with no argument +# is OK; and we want to be able to make that assumption in our Makefile +# recipes. So use an aggressive probe to check that the usage we want is +# actually supported "in the wild" to an acceptable degree. +# See automake bug#10828. +# To make any issue more visible, cause the running configure to be aborted +# by default if the 'rm' program in use doesn't match our expectations; the +# user can still override this though. +if rm -f && rm -fr && rm -rf; then : OK; else + cat >&2 <<'END' +Oops! + +Your 'rm' program seems unable to run without file operands specified +on the command line, even when the '-f' option is present. This is contrary +to the behaviour of most rm programs out there, and not conforming with +the upcoming POSIX standard: + +Please tell bug-automake@gnu.org about your system, including the value +of your $PATH and any error possibly output before this message. This +can help us improve future automake versions. + +END + if test x"$ACCEPT_INFERIOR_RM_PROGRAM" = x"yes"; then + echo 'Configuration will proceed anyway, since you have set the' >&2 + echo 'ACCEPT_INFERIOR_RM_PROGRAM variable to "yes"' >&2 + echo >&2 + else + cat >&2 <<'END' +Aborting the configuration process, to ensure you take notice of the issue. + +You can download and install GNU coreutils to get an 'rm' implementation +that behaves properly: . + +If you want to complete the configuration process using your problematic +'rm' anyway, export the environment variable ACCEPT_INFERIOR_RM_PROGRAM +to "yes", and re-run configure. + +END + AC_MSG_ERROR([Your 'rm' program is bad, sorry.]) + fi +fi +dnl The trailing newline in this macro's definition is deliberate, for +dnl backward compatibility and to allow trailing 'dnl'-style comments +dnl after the AM_INIT_AUTOMAKE invocation. See automake bug#16841. +]) + +dnl Hook into '_AC_COMPILER_EXEEXT' early to learn its expansion. Do not +dnl add the conditional right here, as _AC_COMPILER_EXEEXT may be further +dnl mangled by Autoconf and run in a shell conditional statement. +m4_define([_AC_COMPILER_EXEEXT], +m4_defn([_AC_COMPILER_EXEEXT])[m4_provide([_AM_COMPILER_EXEEXT])]) + +# When config.status generates a header, we must update the stamp-h file. +# This file resides in the same directory as the config header +# that is generated. The stamp files are numbered to have different names. + +# Autoconf calls _AC_AM_CONFIG_HEADER_HOOK (when defined) in the +# loop where config.status creates the headers, so we can generate +# our stamp files there. +AC_DEFUN([_AC_AM_CONFIG_HEADER_HOOK], +[# Compute $1's index in $config_headers. +_am_arg=$1 +_am_stamp_count=1 +for _am_header in $config_headers :; do + case $_am_header in + $_am_arg | $_am_arg:* ) + break ;; + * ) + _am_stamp_count=`expr $_am_stamp_count + 1` ;; + esac +done +echo "timestamp for $_am_arg" >`AS_DIRNAME(["$_am_arg"])`/stamp-h[]$_am_stamp_count]) + +# Copyright (C) 2001-2017 Free Software Foundation, Inc. +# +# This file is free software; the Free Software Foundation +# gives unlimited permission to copy and/or distribute it, +# with or without modifications, as long as this notice is preserved. + +# AM_PROG_INSTALL_SH +# ------------------ +# Define $install_sh. +AC_DEFUN([AM_PROG_INSTALL_SH], +[AC_REQUIRE([AM_AUX_DIR_EXPAND])dnl +if test x"${install_sh+set}" != xset; then + case $am_aux_dir in + *\ * | *\ *) + install_sh="\${SHELL} '$am_aux_dir/install-sh'" ;; + *) + install_sh="\${SHELL} $am_aux_dir/install-sh" + esac +fi +AC_SUBST([install_sh])]) + +# Copyright (C) 2003-2017 Free Software Foundation, Inc. +# +# This file is free software; the Free Software Foundation +# gives unlimited permission to copy and/or distribute it, +# with or without modifications, as long as this notice is preserved. + +# Check whether the underlying file-system supports filenames +# with a leading dot. For instance MS-DOS doesn't. +AC_DEFUN([AM_SET_LEADING_DOT], +[rm -rf .tst 2>/dev/null +mkdir .tst 2>/dev/null +if test -d .tst; then + am__leading_dot=. +else + am__leading_dot=_ +fi +rmdir .tst 2>/dev/null +AC_SUBST([am__leading_dot])]) + +# Check to see how 'make' treats includes. -*- Autoconf -*- + +# Copyright (C) 2001-2017 Free Software Foundation, Inc. +# +# This file is free software; the Free Software Foundation +# gives unlimited permission to copy and/or distribute it, +# with or without modifications, as long as this notice is preserved. + +# AM_MAKE_INCLUDE() +# ----------------- +# Check to see how make treats includes. +AC_DEFUN([AM_MAKE_INCLUDE], +[am_make=${MAKE-make} +cat > confinc << 'END' +am__doit: + @echo this is the am__doit target +.PHONY: am__doit +END +# If we don't find an include directive, just comment out the code. +AC_MSG_CHECKING([for style of include used by $am_make]) +am__include="#" +am__quote= +_am_result=none +# First try GNU make style include. +echo "include confinc" > confmf +# Ignore all kinds of additional output from 'make'. +case `$am_make -s -f confmf 2> /dev/null` in #( +*the\ am__doit\ target*) + am__include=include + am__quote= + _am_result=GNU + ;; +esac +# Now try BSD make style include. +if test "$am__include" = "#"; then + echo '.include "confinc"' > confmf + case `$am_make -s -f confmf 2> /dev/null` in #( + *the\ am__doit\ target*) + am__include=.include + am__quote="\"" + _am_result=BSD + ;; + esac +fi +AC_SUBST([am__include]) +AC_SUBST([am__quote]) +AC_MSG_RESULT([$_am_result]) +rm -f confinc confmf +]) + +# Fake the existence of programs that GNU maintainers use. -*- Autoconf -*- + +# Copyright (C) 1997-2017 Free Software Foundation, Inc. +# +# This file is free software; the Free Software Foundation +# gives unlimited permission to copy and/or distribute it, +# with or without modifications, as long as this notice is preserved. + +# AM_MISSING_PROG(NAME, PROGRAM) +# ------------------------------ +AC_DEFUN([AM_MISSING_PROG], +[AC_REQUIRE([AM_MISSING_HAS_RUN]) +$1=${$1-"${am_missing_run}$2"} +AC_SUBST($1)]) + +# AM_MISSING_HAS_RUN +# ------------------ +# Define MISSING if not defined so far and test if it is modern enough. +# If it is, set am_missing_run to use it, otherwise, to nothing. +AC_DEFUN([AM_MISSING_HAS_RUN], +[AC_REQUIRE([AM_AUX_DIR_EXPAND])dnl +AC_REQUIRE_AUX_FILE([missing])dnl +if test x"${MISSING+set}" != xset; then + case $am_aux_dir in + *\ * | *\ *) + MISSING="\${SHELL} \"$am_aux_dir/missing\"" ;; + *) + MISSING="\${SHELL} $am_aux_dir/missing" ;; + esac +fi +# Use eval to expand $SHELL +if eval "$MISSING --is-lightweight"; then + am_missing_run="$MISSING " +else + am_missing_run= + AC_MSG_WARN(['missing' script is too old or missing]) +fi +]) + +# Helper functions for option handling. -*- Autoconf -*- + +# Copyright (C) 2001-2017 Free Software Foundation, Inc. +# +# This file is free software; the Free Software Foundation +# gives unlimited permission to copy and/or distribute it, +# with or without modifications, as long as this notice is preserved. + +# _AM_MANGLE_OPTION(NAME) +# ----------------------- +AC_DEFUN([_AM_MANGLE_OPTION], +[[_AM_OPTION_]m4_bpatsubst($1, [[^a-zA-Z0-9_]], [_])]) + +# _AM_SET_OPTION(NAME) +# -------------------- +# Set option NAME. Presently that only means defining a flag for this option. +AC_DEFUN([_AM_SET_OPTION], +[m4_define(_AM_MANGLE_OPTION([$1]), [1])]) + +# _AM_SET_OPTIONS(OPTIONS) +# ------------------------ +# OPTIONS is a space-separated list of Automake options. +AC_DEFUN([_AM_SET_OPTIONS], +[m4_foreach_w([_AM_Option], [$1], [_AM_SET_OPTION(_AM_Option)])]) + +# _AM_IF_OPTION(OPTION, IF-SET, [IF-NOT-SET]) +# ------------------------------------------- +# Execute IF-SET if OPTION is set, IF-NOT-SET otherwise. +AC_DEFUN([_AM_IF_OPTION], +[m4_ifset(_AM_MANGLE_OPTION([$1]), [$2], [$3])]) + +# Copyright (C) 1999-2017 Free Software Foundation, Inc. +# +# This file is free software; the Free Software Foundation +# gives unlimited permission to copy and/or distribute it, +# with or without modifications, as long as this notice is preserved. + +# _AM_PROG_CC_C_O +# --------------- +# Like AC_PROG_CC_C_O, but changed for automake. We rewrite AC_PROG_CC +# to automatically call this. +AC_DEFUN([_AM_PROG_CC_C_O], +[AC_REQUIRE([AM_AUX_DIR_EXPAND])dnl +AC_REQUIRE_AUX_FILE([compile])dnl +AC_LANG_PUSH([C])dnl +AC_CACHE_CHECK( + [whether $CC understands -c and -o together], + [am_cv_prog_cc_c_o], + [AC_LANG_CONFTEST([AC_LANG_PROGRAM([])]) + # Make sure it works both with $CC and with simple cc. + # Following AC_PROG_CC_C_O, we do the test twice because some + # compilers refuse to overwrite an existing .o file with -o, + # though they will create one. + am_cv_prog_cc_c_o=yes + for am_i in 1 2; do + if AM_RUN_LOG([$CC -c conftest.$ac_ext -o conftest2.$ac_objext]) \ + && test -f conftest2.$ac_objext; then + : OK + else + am_cv_prog_cc_c_o=no + break + fi + done + rm -f core conftest* + unset am_i]) +if test "$am_cv_prog_cc_c_o" != yes; then + # Losing compiler, so override with the script. + # FIXME: It is wrong to rewrite CC. + # But if we don't then we get into trouble of one sort or another. + # A longer-term fix would be to have automake use am__CC in this case, + # and then we could set am__CC="\$(top_srcdir)/compile \$(CC)" + CC="$am_aux_dir/compile $CC" +fi +AC_LANG_POP([C])]) + +# For backward compatibility. +AC_DEFUN_ONCE([AM_PROG_CC_C_O], [AC_REQUIRE([AC_PROG_CC])]) + +# Copyright (C) 2001-2017 Free Software Foundation, Inc. +# +# This file is free software; the Free Software Foundation +# gives unlimited permission to copy and/or distribute it, +# with or without modifications, as long as this notice is preserved. + +# AM_RUN_LOG(COMMAND) +# ------------------- +# Run COMMAND, save the exit status in ac_status, and log it. +# (This has been adapted from Autoconf's _AC_RUN_LOG macro.) +AC_DEFUN([AM_RUN_LOG], +[{ echo "$as_me:$LINENO: $1" >&AS_MESSAGE_LOG_FD + ($1) >&AS_MESSAGE_LOG_FD 2>&AS_MESSAGE_LOG_FD + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&AS_MESSAGE_LOG_FD + (exit $ac_status); }]) + +# Check to make sure that the build environment is sane. -*- Autoconf -*- + +# Copyright (C) 1996-2017 Free Software Foundation, Inc. +# +# This file is free software; the Free Software Foundation +# gives unlimited permission to copy and/or distribute it, +# with or without modifications, as long as this notice is preserved. + +# AM_SANITY_CHECK +# --------------- +AC_DEFUN([AM_SANITY_CHECK], +[AC_MSG_CHECKING([whether build environment is sane]) +# Reject unsafe characters in $srcdir or the absolute working directory +# name. Accept space and tab only in the latter. +am_lf=' +' +case `pwd` in + *[[\\\"\#\$\&\'\`$am_lf]]*) + AC_MSG_ERROR([unsafe absolute working directory name]);; +esac +case $srcdir in + *[[\\\"\#\$\&\'\`$am_lf\ \ ]]*) + AC_MSG_ERROR([unsafe srcdir value: '$srcdir']);; +esac + +# Do 'set' in a subshell so we don't clobber the current shell's +# arguments. Must try -L first in case configure is actually a +# symlink; some systems play weird games with the mod time of symlinks +# (eg FreeBSD returns the mod time of the symlink's containing +# directory). +if ( + am_has_slept=no + for am_try in 1 2; do + echo "timestamp, slept: $am_has_slept" > conftest.file + set X `ls -Lt "$srcdir/configure" conftest.file 2> /dev/null` + if test "$[*]" = "X"; then + # -L didn't work. + set X `ls -t "$srcdir/configure" conftest.file` + fi + if test "$[*]" != "X $srcdir/configure conftest.file" \ + && test "$[*]" != "X conftest.file $srcdir/configure"; then + + # If neither matched, then we have a broken ls. This can happen + # if, for instance, CONFIG_SHELL is bash and it inherits a + # broken ls alias from the environment. This has actually + # happened. Such a system could not be considered "sane". + AC_MSG_ERROR([ls -t appears to fail. Make sure there is not a broken + alias in your environment]) + fi + if test "$[2]" = conftest.file || test $am_try -eq 2; then + break + fi + # Just in case. + sleep 1 + am_has_slept=yes + done + test "$[2]" = conftest.file + ) +then + # Ok. + : +else + AC_MSG_ERROR([newly created file is older than distributed files! +Check your system clock]) +fi +AC_MSG_RESULT([yes]) +# If we didn't sleep, we still need to ensure time stamps of config.status and +# generated files are strictly newer. +am_sleep_pid= +if grep 'slept: no' conftest.file >/dev/null 2>&1; then + ( sleep 1 ) & + am_sleep_pid=$! +fi +AC_CONFIG_COMMANDS_PRE( + [AC_MSG_CHECKING([that generated files are newer than configure]) + if test -n "$am_sleep_pid"; then + # Hide warnings about reused PIDs. + wait $am_sleep_pid 2>/dev/null + fi + AC_MSG_RESULT([done])]) +rm -f conftest.file +]) + +# Copyright (C) 2009-2017 Free Software Foundation, Inc. +# +# This file is free software; the Free Software Foundation +# gives unlimited permission to copy and/or distribute it, +# with or without modifications, as long as this notice is preserved. + +# AM_SILENT_RULES([DEFAULT]) +# -------------------------- +# Enable less verbose build rules; with the default set to DEFAULT +# ("yes" being less verbose, "no" or empty being verbose). +AC_DEFUN([AM_SILENT_RULES], +[AC_ARG_ENABLE([silent-rules], [dnl +AS_HELP_STRING( + [--enable-silent-rules], + [less verbose build output (undo: "make V=1")]) +AS_HELP_STRING( + [--disable-silent-rules], + [verbose build output (undo: "make V=0")])dnl +]) +case $enable_silent_rules in @%:@ ((( + yes) AM_DEFAULT_VERBOSITY=0;; + no) AM_DEFAULT_VERBOSITY=1;; + *) AM_DEFAULT_VERBOSITY=m4_if([$1], [yes], [0], [1]);; +esac +dnl +dnl A few 'make' implementations (e.g., NonStop OS and NextStep) +dnl do not support nested variable expansions. +dnl See automake bug#9928 and bug#10237. +am_make=${MAKE-make} +AC_CACHE_CHECK([whether $am_make supports nested variables], + [am_cv_make_support_nested_variables], + [if AS_ECHO([['TRUE=$(BAR$(V)) +BAR0=false +BAR1=true +V=1 +am__doit: + @$(TRUE) +.PHONY: am__doit']]) | $am_make -f - >/dev/null 2>&1; then + am_cv_make_support_nested_variables=yes +else + am_cv_make_support_nested_variables=no +fi]) +if test $am_cv_make_support_nested_variables = yes; then + dnl Using '$V' instead of '$(V)' breaks IRIX make. + AM_V='$(V)' + AM_DEFAULT_V='$(AM_DEFAULT_VERBOSITY)' +else + AM_V=$AM_DEFAULT_VERBOSITY + AM_DEFAULT_V=$AM_DEFAULT_VERBOSITY +fi +AC_SUBST([AM_V])dnl +AM_SUBST_NOTMAKE([AM_V])dnl +AC_SUBST([AM_DEFAULT_V])dnl +AM_SUBST_NOTMAKE([AM_DEFAULT_V])dnl +AC_SUBST([AM_DEFAULT_VERBOSITY])dnl +AM_BACKSLASH='\' +AC_SUBST([AM_BACKSLASH])dnl +_AM_SUBST_NOTMAKE([AM_BACKSLASH])dnl +]) + +# Copyright (C) 2001-2017 Free Software Foundation, Inc. +# +# This file is free software; the Free Software Foundation +# gives unlimited permission to copy and/or distribute it, +# with or without modifications, as long as this notice is preserved. + +# AM_PROG_INSTALL_STRIP +# --------------------- +# One issue with vendor 'install' (even GNU) is that you can't +# specify the program used to strip binaries. This is especially +# annoying in cross-compiling environments, where the build's strip +# is unlikely to handle the host's binaries. +# Fortunately install-sh will honor a STRIPPROG variable, so we +# always use install-sh in "make install-strip", and initialize +# STRIPPROG with the value of the STRIP variable (set by the user). +AC_DEFUN([AM_PROG_INSTALL_STRIP], +[AC_REQUIRE([AM_PROG_INSTALL_SH])dnl +# Installed binaries are usually stripped using 'strip' when the user +# run "make install-strip". However 'strip' might not be the right +# tool to use in cross-compilation environments, therefore Automake +# will honor the 'STRIP' environment variable to overrule this program. +dnl Don't test for $cross_compiling = yes, because it might be 'maybe'. +if test "$cross_compiling" != no; then + AC_CHECK_TOOL([STRIP], [strip], :) +fi +INSTALL_STRIP_PROGRAM="\$(install_sh) -c -s" +AC_SUBST([INSTALL_STRIP_PROGRAM])]) + +# Copyright (C) 2006-2017 Free Software Foundation, Inc. +# +# This file is free software; the Free Software Foundation +# gives unlimited permission to copy and/or distribute it, +# with or without modifications, as long as this notice is preserved. + +# _AM_SUBST_NOTMAKE(VARIABLE) +# --------------------------- +# Prevent Automake from outputting VARIABLE = @VARIABLE@ in Makefile.in. +# This macro is traced by Automake. +AC_DEFUN([_AM_SUBST_NOTMAKE]) + +# AM_SUBST_NOTMAKE(VARIABLE) +# -------------------------- +# Public sister of _AM_SUBST_NOTMAKE. +AC_DEFUN([AM_SUBST_NOTMAKE], [_AM_SUBST_NOTMAKE($@)]) + +# Check how to create a tarball. -*- Autoconf -*- + +# Copyright (C) 2004-2017 Free Software Foundation, Inc. +# +# This file is free software; the Free Software Foundation +# gives unlimited permission to copy and/or distribute it, +# with or without modifications, as long as this notice is preserved. + +# _AM_PROG_TAR(FORMAT) +# -------------------- +# Check how to create a tarball in format FORMAT. +# FORMAT should be one of 'v7', 'ustar', or 'pax'. +# +# Substitute a variable $(am__tar) that is a command +# writing to stdout a FORMAT-tarball containing the directory +# $tardir. +# tardir=directory && $(am__tar) > result.tar +# +# Substitute a variable $(am__untar) that extract such +# a tarball read from stdin. +# $(am__untar) < result.tar +# +AC_DEFUN([_AM_PROG_TAR], +[# Always define AMTAR for backward compatibility. Yes, it's still used +# in the wild :-( We should find a proper way to deprecate it ... +AC_SUBST([AMTAR], ['$${TAR-tar}']) + +# We'll loop over all known methods to create a tar archive until one works. +_am_tools='gnutar m4_if([$1], [ustar], [plaintar]) pax cpio none' + +m4_if([$1], [v7], + [am__tar='$${TAR-tar} chof - "$$tardir"' am__untar='$${TAR-tar} xf -'], + + [m4_case([$1], + [ustar], + [# The POSIX 1988 'ustar' format is defined with fixed-size fields. + # There is notably a 21 bits limit for the UID and the GID. In fact, + # the 'pax' utility can hang on bigger UID/GID (see automake bug#8343 + # and bug#13588). + am_max_uid=2097151 # 2^21 - 1 + am_max_gid=$am_max_uid + # The $UID and $GID variables are not portable, so we need to resort + # to the POSIX-mandated id(1) utility. Errors in the 'id' calls + # below are definitely unexpected, so allow the users to see them + # (that is, avoid stderr redirection). + am_uid=`id -u || echo unknown` + am_gid=`id -g || echo unknown` + AC_MSG_CHECKING([whether UID '$am_uid' is supported by ustar format]) + if test $am_uid -le $am_max_uid; then + AC_MSG_RESULT([yes]) + else + AC_MSG_RESULT([no]) + _am_tools=none + fi + AC_MSG_CHECKING([whether GID '$am_gid' is supported by ustar format]) + if test $am_gid -le $am_max_gid; then + AC_MSG_RESULT([yes]) + else + AC_MSG_RESULT([no]) + _am_tools=none + fi], + + [pax], + [], + + [m4_fatal([Unknown tar format])]) + + AC_MSG_CHECKING([how to create a $1 tar archive]) + + # Go ahead even if we have the value already cached. We do so because we + # need to set the values for the 'am__tar' and 'am__untar' variables. + _am_tools=${am_cv_prog_tar_$1-$_am_tools} + + for _am_tool in $_am_tools; do + case $_am_tool in + gnutar) + for _am_tar in tar gnutar gtar; do + AM_RUN_LOG([$_am_tar --version]) && break + done + am__tar="$_am_tar --format=m4_if([$1], [pax], [posix], [$1]) -chf - "'"$$tardir"' + am__tar_="$_am_tar --format=m4_if([$1], [pax], [posix], [$1]) -chf - "'"$tardir"' + am__untar="$_am_tar -xf -" + ;; + plaintar) + # Must skip GNU tar: if it does not support --format= it doesn't create + # ustar tarball either. + (tar --version) >/dev/null 2>&1 && continue + am__tar='tar chf - "$$tardir"' + am__tar_='tar chf - "$tardir"' + am__untar='tar xf -' + ;; + pax) + am__tar='pax -L -x $1 -w "$$tardir"' + am__tar_='pax -L -x $1 -w "$tardir"' + am__untar='pax -r' + ;; + cpio) + am__tar='find "$$tardir" -print | cpio -o -H $1 -L' + am__tar_='find "$tardir" -print | cpio -o -H $1 -L' + am__untar='cpio -i -H $1 -d' + ;; + none) + am__tar=false + am__tar_=false + am__untar=false + ;; + esac + + # If the value was cached, stop now. We just wanted to have am__tar + # and am__untar set. + test -n "${am_cv_prog_tar_$1}" && break + + # tar/untar a dummy directory, and stop if the command works. + rm -rf conftest.dir + mkdir conftest.dir + echo GrepMe > conftest.dir/file + AM_RUN_LOG([tardir=conftest.dir && eval $am__tar_ >conftest.tar]) + rm -rf conftest.dir + if test -s conftest.tar; then + AM_RUN_LOG([$am__untar /dev/null 2>&1 && break + fi + done + rm -rf conftest.dir + + AC_CACHE_VAL([am_cv_prog_tar_$1], [am_cv_prog_tar_$1=$_am_tool]) + AC_MSG_RESULT([$am_cv_prog_tar_$1])]) + +AC_SUBST([am__tar]) +AC_SUBST([am__untar]) +]) # _AM_PROG_TAR + m4_include([m4/libtool.m4]) m4_include([m4/ltoptions.m4]) m4_include([m4/ltsugar.m4]) diff --git a/configure b/configure index 658b097..92701ea 100755 --- a/configure +++ b/configure @@ -1,6 +1,6 @@ #! /bin/sh # Guess values for system-dependent variables and create Makefiles. -# Generated by GNU Autoconf 2.69 for expat 2.2.3. +# Generated by GNU Autoconf 2.69 for expat 2.2.4. # # Report bugs to . # @@ -590,8 +590,8 @@ MAKEFLAGS= # Identity of this package. PACKAGE_NAME='expat' PACKAGE_TARNAME='expat' -PACKAGE_VERSION='2.2.3' -PACKAGE_STRING='expat 2.2.3' +PACKAGE_VERSION='2.2.4' +PACKAGE_STRING='expat 2.2.4' PACKAGE_BUGREPORT='expat-bugs@libexpat.org' PACKAGE_URL='' @@ -633,13 +633,17 @@ ac_includes_default="\ #endif" ac_header_list= -ac_subst_vars='LTLIBOBJS +ac_subst_vars='am__EXEEXT_FALSE +am__EXEEXT_TRUE +LTLIBOBJS LIBOBJS FILEMAP -INSTALL_DATA -INSTALL_SCRIPT -INSTALL_PROGRAM +WITH_XMLWF_FALSE +WITH_XMLWF_TRUE CXXCPP +am__fastdepCXX_FALSE +am__fastdepCXX_TRUE +CXXDEPMODE ac_ct_CXX CXXFLAGS CXX @@ -654,9 +658,7 @@ LIPO NMEDIT DSYMUTIL MANIFEST_TOOL -AWK RANLIB -STRIP ac_ct_AR AR LN_S @@ -668,6 +670,16 @@ FGREP EGREP GREP SED +am__fastdepCC_FALSE +am__fastdepCC_TRUE +CCDEPMODE +am__nodep +AMDEPBACKSLASH +AMDEP_FALSE +AMDEP_TRUE +am__quote +am__include +DEPDIR OBJEXT EXEEXT ac_ct_CC @@ -687,6 +699,33 @@ build_os build_vendor build_cpu build +AM_BACKSLASH +AM_DEFAULT_VERBOSITY +AM_DEFAULT_V +AM_V +am__untar +am__tar +AMTAR +am__leading_dot +SET_MAKE +AWK +mkdir_p +MKDIR_P +INSTALL_STRIP_PROGRAM +STRIP +install_sh +MAKEINFO +AUTOHEADER +AUTOMAKE +AUTOCONF +ACLOCAL +VERSION +PACKAGE +CYGPATH_W +am__isrc +INSTALL_DATA +INSTALL_SCRIPT +INSTALL_PROGRAM target_alias host_alias build_alias @@ -728,14 +767,17 @@ SHELL' ac_subst_files='' ac_user_opts=' enable_option_checking +enable_silent_rules enable_shared enable_static with_pic enable_fast_install with_aix_soname +enable_dependency_tracking with_gnu_ld with_sysroot enable_libtool_lock +with_xmlwf with_libbsd enable_xml_context ' @@ -1293,7 +1335,7 @@ if test "$ac_init_help" = "long"; then # Omit some internal or obsolete options to make the list less imposing. # This message is too long to be a string in the A/UX 3.1 sh. cat <<_ACEOF -\`configure' configures expat 2.2.3 to adapt to many kinds of systems. +\`configure' configures expat 2.2.4 to adapt to many kinds of systems. Usage: $0 [OPTION]... [VAR=VALUE]... @@ -1350,6 +1392,11 @@ _ACEOF cat <<\_ACEOF +Program names: + --program-prefix=PREFIX prepend PREFIX to installed program names + --program-suffix=SUFFIX append SUFFIX to installed program names + --program-transform-name=PROGRAM run sed PROGRAM on installed program names + System types: --build=BUILD configure for building on BUILD [guessed] --host=HOST cross-compile to build programs to run on HOST [BUILD] @@ -1358,7 +1405,7 @@ fi if test -n "$ac_init_help"; then case $ac_init_help in - short | recursive ) echo "Configuration of expat 2.2.3:";; + short | recursive ) echo "Configuration of expat 2.2.4:";; esac cat <<\_ACEOF @@ -1366,10 +1413,16 @@ Optional Features: --disable-option-checking ignore unrecognized --enable/--with options --disable-FEATURE do not include FEATURE (same as --enable-FEATURE=no) --enable-FEATURE[=ARG] include FEATURE [ARG=yes] + --enable-silent-rules less verbose build output (undo: "make V=1") + --disable-silent-rules verbose build output (undo: "make V=0") --enable-shared[=PKGS] build shared libraries [default=yes] --enable-static[=PKGS] build static libraries [default=yes] --enable-fast-install[=PKGS] optimize for fast installation [default=yes] + --enable-dependency-tracking + do not reject slow dependency extractors + --disable-dependency-tracking + speeds up one-time build --disable-libtool-lock avoid locking (might break parallel builds) --enable-xml-context [COUNT] Retain context around the current parse point; @@ -1388,6 +1441,8 @@ Optional Packages: --with-sysroot[=DIR] Search for dependent libraries within DIR (or the compiler's sysroot if not specified). + --without-xmlwf do not build xmlwf + --with-libbsd utilize libbsd (for arc4random_buf) @@ -1472,7 +1527,7 @@ fi test -n "$ac_init_help" && exit $ac_status if $ac_init_version; then cat <<\_ACEOF -expat configure 2.2.3 +expat configure 2.2.4 generated by GNU Autoconf 2.69 Copyright (C) 2012 Free Software Foundation, Inc. @@ -2016,7 +2071,7 @@ cat >config.log <<_ACEOF This file contains any messages produced by compilers while running configure, to aid debugging if configure makes a mistake. -It was created by expat $as_me 2.2.3, which was +It was created by expat $as_me 2.2.4, which was generated by GNU Autoconf 2.69. Invocation command line was $ $0 $@ @@ -2399,14 +2454,594 @@ ac_config_sub="$SHELL $ac_aux_dir/config.sub" # Please don't use this var. ac_configure="$SHELL $ac_aux_dir/configure" # Please don't use this var. +am__api_version='1.15' + +# Find a good install program. We prefer a C program (faster), +# so one script is as good as another. But avoid the broken or +# incompatible versions: +# SysV /etc/install, /usr/sbin/install +# SunOS /usr/etc/install +# IRIX /sbin/install +# AIX /bin/install +# AmigaOS /C/install, which installs bootblocks on floppy discs +# AIX 4 /usr/bin/installbsd, which doesn't work without a -g flag +# AFS /usr/afsws/bin/install, which mishandles nonexistent args +# SVR4 /usr/ucb/install, which tries to use the nonexistent group "staff" +# OS/2's system install, which has a completely different semantic +# ./install, which can be erroneously created by make from ./install.sh. +# Reject install programs that cannot install multiple files. +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for a BSD-compatible install" >&5 +$as_echo_n "checking for a BSD-compatible install... " >&6; } +if test -z "$INSTALL"; then +if ${ac_cv_path_install+:} false; then : + $as_echo_n "(cached) " >&6 +else + as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + # Account for people who put trailing slashes in PATH elements. +case $as_dir/ in #(( + ./ | .// | /[cC]/* | \ + /etc/* | /usr/sbin/* | /usr/etc/* | /sbin/* | /usr/afsws/bin/* | \ + ?:[\\/]os2[\\/]install[\\/]* | ?:[\\/]OS2[\\/]INSTALL[\\/]* | \ + /usr/ucb/* ) ;; + *) + # OSF1 and SCO ODT 3.0 have their own names for install. + # Don't use installbsd from OSF since it installs stuff as root + # by default. + for ac_prog in ginstall scoinst install; do + for ac_exec_ext in '' $ac_executable_extensions; do + if as_fn_executable_p "$as_dir/$ac_prog$ac_exec_ext"; then + if test $ac_prog = install && + grep dspmsg "$as_dir/$ac_prog$ac_exec_ext" >/dev/null 2>&1; then + # AIX install. It has an incompatible calling convention. + : + elif test $ac_prog = install && + grep pwplus "$as_dir/$ac_prog$ac_exec_ext" >/dev/null 2>&1; then + # program-specific install script used by HP pwplus--don't use. + : + else + rm -rf conftest.one conftest.two conftest.dir + echo one > conftest.one + echo two > conftest.two + mkdir conftest.dir + if "$as_dir/$ac_prog$ac_exec_ext" -c conftest.one conftest.two "`pwd`/conftest.dir" && + test -s conftest.one && test -s conftest.two && + test -s conftest.dir/conftest.one && + test -s conftest.dir/conftest.two + then + ac_cv_path_install="$as_dir/$ac_prog$ac_exec_ext -c" + break 3 + fi + fi + fi + done + done + ;; +esac + + done +IFS=$as_save_IFS + +rm -rf conftest.one conftest.two conftest.dir + +fi + if test "${ac_cv_path_install+set}" = set; then + INSTALL=$ac_cv_path_install + else + # As a last resort, use the slow shell script. Don't cache a + # value for INSTALL within a source directory, because that will + # break other packages using the cache if that directory is + # removed, or if the value is a relative name. + INSTALL=$ac_install_sh + fi +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $INSTALL" >&5 +$as_echo "$INSTALL" >&6; } + +# Use test -z because SunOS4 sh mishandles braces in ${var-val}. +# It thinks the first close brace ends the variable substitution. +test -z "$INSTALL_PROGRAM" && INSTALL_PROGRAM='${INSTALL}' + +test -z "$INSTALL_SCRIPT" && INSTALL_SCRIPT='${INSTALL}' + +test -z "$INSTALL_DATA" && INSTALL_DATA='${INSTALL} -m 644' + +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking whether build environment is sane" >&5 +$as_echo_n "checking whether build environment is sane... " >&6; } +# Reject unsafe characters in $srcdir or the absolute working directory +# name. Accept space and tab only in the latter. +am_lf=' +' +case `pwd` in + *[\\\"\#\$\&\'\`$am_lf]*) + as_fn_error $? "unsafe absolute working directory name" "$LINENO" 5;; +esac +case $srcdir in + *[\\\"\#\$\&\'\`$am_lf\ \ ]*) + as_fn_error $? "unsafe srcdir value: '$srcdir'" "$LINENO" 5;; +esac + +# Do 'set' in a subshell so we don't clobber the current shell's +# arguments. Must try -L first in case configure is actually a +# symlink; some systems play weird games with the mod time of symlinks +# (eg FreeBSD returns the mod time of the symlink's containing +# directory). +if ( + am_has_slept=no + for am_try in 1 2; do + echo "timestamp, slept: $am_has_slept" > conftest.file + set X `ls -Lt "$srcdir/configure" conftest.file 2> /dev/null` + if test "$*" = "X"; then + # -L didn't work. + set X `ls -t "$srcdir/configure" conftest.file` + fi + if test "$*" != "X $srcdir/configure conftest.file" \ + && test "$*" != "X conftest.file $srcdir/configure"; then + + # If neither matched, then we have a broken ls. This can happen + # if, for instance, CONFIG_SHELL is bash and it inherits a + # broken ls alias from the environment. This has actually + # happened. Such a system could not be considered "sane". + as_fn_error $? "ls -t appears to fail. Make sure there is not a broken + alias in your environment" "$LINENO" 5 + fi + if test "$2" = conftest.file || test $am_try -eq 2; then + break + fi + # Just in case. + sleep 1 + am_has_slept=yes + done + test "$2" = conftest.file + ) +then + # Ok. + : +else + as_fn_error $? "newly created file is older than distributed files! +Check your system clock" "$LINENO" 5 +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: yes" >&5 +$as_echo "yes" >&6; } +# If we didn't sleep, we still need to ensure time stamps of config.status and +# generated files are strictly newer. +am_sleep_pid= +if grep 'slept: no' conftest.file >/dev/null 2>&1; then + ( sleep 1 ) & + am_sleep_pid=$! +fi + +rm -f conftest.file + +test "$program_prefix" != NONE && + program_transform_name="s&^&$program_prefix&;$program_transform_name" +# Use a double $ so make ignores it. +test "$program_suffix" != NONE && + program_transform_name="s&\$&$program_suffix&;$program_transform_name" +# Double any \ or $. +# By default was `s,x,x', remove it if useless. +ac_script='s/[\\$]/&&/g;s/;s,x,x,$//' +program_transform_name=`$as_echo "$program_transform_name" | sed "$ac_script"` + +# Expand $ac_aux_dir to an absolute path. +am_aux_dir=`cd "$ac_aux_dir" && pwd` + +if test x"${MISSING+set}" != xset; then + case $am_aux_dir in + *\ * | *\ *) + MISSING="\${SHELL} \"$am_aux_dir/missing\"" ;; + *) + MISSING="\${SHELL} $am_aux_dir/missing" ;; + esac +fi +# Use eval to expand $SHELL +if eval "$MISSING --is-lightweight"; then + am_missing_run="$MISSING " +else + am_missing_run= + { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: 'missing' script is too old or missing" >&5 +$as_echo "$as_me: WARNING: 'missing' script is too old or missing" >&2;} +fi + +if test x"${install_sh+set}" != xset; then + case $am_aux_dir in + *\ * | *\ *) + install_sh="\${SHELL} '$am_aux_dir/install-sh'" ;; + *) + install_sh="\${SHELL} $am_aux_dir/install-sh" + esac +fi + +# Installed binaries are usually stripped using 'strip' when the user +# run "make install-strip". However 'strip' might not be the right +# tool to use in cross-compilation environments, therefore Automake +# will honor the 'STRIP' environment variable to overrule this program. +if test "$cross_compiling" != no; then + if test -n "$ac_tool_prefix"; then + # Extract the first word of "${ac_tool_prefix}strip", so it can be a program name with args. +set dummy ${ac_tool_prefix}strip; ac_word=$2 +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 +$as_echo_n "checking for $ac_word... " >&6; } +if ${ac_cv_prog_STRIP+:} false; then : + $as_echo_n "(cached) " >&6 +else + if test -n "$STRIP"; then + ac_cv_prog_STRIP="$STRIP" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then + ac_cv_prog_STRIP="${ac_tool_prefix}strip" + $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done + done +IFS=$as_save_IFS + +fi +fi +STRIP=$ac_cv_prog_STRIP +if test -n "$STRIP"; then + { $as_echo "$as_me:${as_lineno-$LINENO}: result: $STRIP" >&5 +$as_echo "$STRIP" >&6; } +else + { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 +$as_echo "no" >&6; } +fi + + +fi +if test -z "$ac_cv_prog_STRIP"; then + ac_ct_STRIP=$STRIP + # Extract the first word of "strip", so it can be a program name with args. +set dummy strip; ac_word=$2 +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 +$as_echo_n "checking for $ac_word... " >&6; } +if ${ac_cv_prog_ac_ct_STRIP+:} false; then : + $as_echo_n "(cached) " >&6 +else + if test -n "$ac_ct_STRIP"; then + ac_cv_prog_ac_ct_STRIP="$ac_ct_STRIP" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then + ac_cv_prog_ac_ct_STRIP="strip" + $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done + done +IFS=$as_save_IFS + +fi +fi +ac_ct_STRIP=$ac_cv_prog_ac_ct_STRIP +if test -n "$ac_ct_STRIP"; then + { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_ct_STRIP" >&5 +$as_echo "$ac_ct_STRIP" >&6; } +else + { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 +$as_echo "no" >&6; } +fi + + if test "x$ac_ct_STRIP" = x; then + STRIP=":" + else + case $cross_compiling:$ac_tool_warned in +yes:) +{ $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 +$as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} +ac_tool_warned=yes ;; +esac + STRIP=$ac_ct_STRIP + fi +else + STRIP="$ac_cv_prog_STRIP" +fi + +fi +INSTALL_STRIP_PROGRAM="\$(install_sh) -c -s" + +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for a thread-safe mkdir -p" >&5 +$as_echo_n "checking for a thread-safe mkdir -p... " >&6; } +if test -z "$MKDIR_P"; then + if ${ac_cv_path_mkdir+:} false; then : + $as_echo_n "(cached) " >&6 +else + as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH$PATH_SEPARATOR/opt/sfw/bin +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_prog in mkdir gmkdir; do + for ac_exec_ext in '' $ac_executable_extensions; do + as_fn_executable_p "$as_dir/$ac_prog$ac_exec_ext" || continue + case `"$as_dir/$ac_prog$ac_exec_ext" --version 2>&1` in #( + 'mkdir (GNU coreutils) '* | \ + 'mkdir (coreutils) '* | \ + 'mkdir (fileutils) '4.1*) + ac_cv_path_mkdir=$as_dir/$ac_prog$ac_exec_ext + break 3;; + esac + done + done + done +IFS=$as_save_IFS + +fi + + test -d ./--version && rmdir ./--version + if test "${ac_cv_path_mkdir+set}" = set; then + MKDIR_P="$ac_cv_path_mkdir -p" + else + # As a last resort, use the slow shell script. Don't cache a + # value for MKDIR_P within a source directory, because that will + # break other packages using the cache if that directory is + # removed, or if the value is a relative name. + MKDIR_P="$ac_install_sh -d" + fi +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $MKDIR_P" >&5 +$as_echo "$MKDIR_P" >&6; } + +for ac_prog in gawk mawk nawk awk +do + # Extract the first word of "$ac_prog", so it can be a program name with args. +set dummy $ac_prog; ac_word=$2 +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 +$as_echo_n "checking for $ac_word... " >&6; } +if ${ac_cv_prog_AWK+:} false; then : + $as_echo_n "(cached) " >&6 +else + if test -n "$AWK"; then + ac_cv_prog_AWK="$AWK" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then + ac_cv_prog_AWK="$ac_prog" + $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done + done +IFS=$as_save_IFS + +fi +fi +AWK=$ac_cv_prog_AWK +if test -n "$AWK"; then + { $as_echo "$as_me:${as_lineno-$LINENO}: result: $AWK" >&5 +$as_echo "$AWK" >&6; } +else + { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 +$as_echo "no" >&6; } +fi + + + test -n "$AWK" && break +done + +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking whether ${MAKE-make} sets \$(MAKE)" >&5 +$as_echo_n "checking whether ${MAKE-make} sets \$(MAKE)... " >&6; } +set x ${MAKE-make} +ac_make=`$as_echo "$2" | sed 's/+/p/g; s/[^a-zA-Z0-9_]/_/g'` +if eval \${ac_cv_prog_make_${ac_make}_set+:} false; then : + $as_echo_n "(cached) " >&6 +else + cat >conftest.make <<\_ACEOF +SHELL = /bin/sh +all: + @echo '@@@%%%=$(MAKE)=@@@%%%' +_ACEOF +# GNU make sometimes prints "make[1]: Entering ...", which would confuse us. +case `${MAKE-make} -f conftest.make 2>/dev/null` in + *@@@%%%=?*=@@@%%%*) + eval ac_cv_prog_make_${ac_make}_set=yes;; + *) + eval ac_cv_prog_make_${ac_make}_set=no;; +esac +rm -f conftest.make +fi +if eval test \$ac_cv_prog_make_${ac_make}_set = yes; then + { $as_echo "$as_me:${as_lineno-$LINENO}: result: yes" >&5 +$as_echo "yes" >&6; } + SET_MAKE= +else + { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 +$as_echo "no" >&6; } + SET_MAKE="MAKE=${MAKE-make}" +fi + +rm -rf .tst 2>/dev/null +mkdir .tst 2>/dev/null +if test -d .tst; then + am__leading_dot=. +else + am__leading_dot=_ +fi +rmdir .tst 2>/dev/null + +# Check whether --enable-silent-rules was given. +if test "${enable_silent_rules+set}" = set; then : + enableval=$enable_silent_rules; +fi + +case $enable_silent_rules in # ((( + yes) AM_DEFAULT_VERBOSITY=0;; + no) AM_DEFAULT_VERBOSITY=1;; + *) AM_DEFAULT_VERBOSITY=1;; +esac +am_make=${MAKE-make} +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking whether $am_make supports nested variables" >&5 +$as_echo_n "checking whether $am_make supports nested variables... " >&6; } +if ${am_cv_make_support_nested_variables+:} false; then : + $as_echo_n "(cached) " >&6 +else + if $as_echo 'TRUE=$(BAR$(V)) +BAR0=false +BAR1=true +V=1 +am__doit: + @$(TRUE) +.PHONY: am__doit' | $am_make -f - >/dev/null 2>&1; then + am_cv_make_support_nested_variables=yes +else + am_cv_make_support_nested_variables=no +fi +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $am_cv_make_support_nested_variables" >&5 +$as_echo "$am_cv_make_support_nested_variables" >&6; } +if test $am_cv_make_support_nested_variables = yes; then + AM_V='$(V)' + AM_DEFAULT_V='$(AM_DEFAULT_VERBOSITY)' +else + AM_V=$AM_DEFAULT_VERBOSITY + AM_DEFAULT_V=$AM_DEFAULT_VERBOSITY +fi +AM_BACKSLASH='\' + +if test "`cd $srcdir && pwd`" != "`pwd`"; then + # Use -I$(srcdir) only when $(srcdir) != ., so that make's output + # is not polluted with repeated "-I." + am__isrc=' -I$(srcdir)' + # test to see if srcdir already configured + if test -f $srcdir/config.status; then + as_fn_error $? "source directory already configured; run \"make distclean\" there first" "$LINENO" 5 + fi +fi + +# test whether we have cygpath +if test -z "$CYGPATH_W"; then + if (cygpath --version) >/dev/null 2>/dev/null; then + CYGPATH_W='cygpath -w' + else + CYGPATH_W=echo + fi +fi + + +# Define the identity of the package. + PACKAGE='expat' + VERSION='2.2.4' + + +cat >>confdefs.h <<_ACEOF +#define PACKAGE "$PACKAGE" +_ACEOF + + +cat >>confdefs.h <<_ACEOF +#define VERSION "$VERSION" +_ACEOF + +# Some tools Automake needs. + +ACLOCAL=${ACLOCAL-"${am_missing_run}aclocal-${am__api_version}"} + + +AUTOCONF=${AUTOCONF-"${am_missing_run}autoconf"} + + +AUTOMAKE=${AUTOMAKE-"${am_missing_run}automake-${am__api_version}"} + + +AUTOHEADER=${AUTOHEADER-"${am_missing_run}autoheader"} + + +MAKEINFO=${MAKEINFO-"${am_missing_run}makeinfo"} + +# For better backward compatibility. To be removed once Automake 1.9.x +# dies out for good. For more background, see: +# +# +mkdir_p='$(MKDIR_P)' + +# We need awk for the "check" target (and possibly the TAP driver). The +# system "awk" is bad on some platforms. +# Always define AMTAR for backward compatibility. Yes, it's still used +# in the wild :-( We should find a proper way to deprecate it ... +AMTAR='$${TAR-tar}' + + +# We'll loop over all known methods to create a tar archive until one works. +_am_tools='gnutar pax cpio none' + +am__tar='$${TAR-tar} chof - "$$tardir"' am__untar='$${TAR-tar} xf -' + + + + + + +# POSIX will say in a future version that running "rm -f" with no argument +# is OK; and we want to be able to make that assumption in our Makefile +# recipes. So use an aggressive probe to check that the usage we want is +# actually supported "in the wild" to an acceptable degree. +# See automake bug#10828. +# To make any issue more visible, cause the running configure to be aborted +# by default if the 'rm' program in use doesn't match our expectations; the +# user can still override this though. +if rm -f && rm -fr && rm -rf; then : OK; else + cat >&2 <<'END' +Oops! + +Your 'rm' program seems unable to run without file operands specified +on the command line, even when the '-f' option is present. This is contrary +to the behaviour of most rm programs out there, and not conforming with +the upcoming POSIX standard: + +Please tell bug-automake@gnu.org about your system, including the value +of your $PATH and any error possibly output before this message. This +can help us improve future automake versions. + +END + if test x"$ACCEPT_INFERIOR_RM_PROGRAM" = x"yes"; then + echo 'Configuration will proceed anyway, since you have set the' >&2 + echo 'ACCEPT_INFERIOR_RM_PROGRAM variable to "yes"' >&2 + echo >&2 + else + cat >&2 <<'END' +Aborting the configuration process, to ensure you take notice of the issue. + +You can download and install GNU coreutils to get an 'rm' implementation +that behaves properly: . + +If you want to complete the configuration process using your problematic +'rm' anyway, export the environment variable ACCEPT_INFERIOR_RM_PROGRAM +to "yes", and re-run configure. + +END + as_fn_error $? "Your 'rm' program is bad, sorry." "$LINENO" 5 + fi +fi + LIBCURRENT=7 # sync -LIBREVISION=5 # with +LIBREVISION=6 # with LIBAGE=6 # CMakeLists.txt! +CPPFLAGS="${CPPFLAGS} -DHAVE_EXPAT_CONFIG_H" ac_config_headers="$ac_config_headers expat_config.h" @@ -2881,6 +3516,69 @@ esac +DEPDIR="${am__leading_dot}deps" + +ac_config_commands="$ac_config_commands depfiles" + + +am_make=${MAKE-make} +cat > confinc << 'END' +am__doit: + @echo this is the am__doit target +.PHONY: am__doit +END +# If we don't find an include directive, just comment out the code. +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for style of include used by $am_make" >&5 +$as_echo_n "checking for style of include used by $am_make... " >&6; } +am__include="#" +am__quote= +_am_result=none +# First try GNU make style include. +echo "include confinc" > confmf +# Ignore all kinds of additional output from 'make'. +case `$am_make -s -f confmf 2> /dev/null` in #( +*the\ am__doit\ target*) + am__include=include + am__quote= + _am_result=GNU + ;; +esac +# Now try BSD make style include. +if test "$am__include" = "#"; then + echo '.include "confinc"' > confmf + case `$am_make -s -f confmf 2> /dev/null` in #( + *the\ am__doit\ target*) + am__include=.include + am__quote="\"" + _am_result=BSD + ;; + esac +fi + + +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $_am_result" >&5 +$as_echo "$_am_result" >&6; } +rm -f confinc confmf + +# Check whether --enable-dependency-tracking was given. +if test "${enable_dependency_tracking+set}" = set; then : + enableval=$enable_dependency_tracking; +fi + +if test "x$enable_dependency_tracking" != xno; then + am_depcomp="$ac_aux_dir/depcomp" + AMDEPBACKSLASH='\' + am__nodep='_no' +fi + if test "x$enable_dependency_tracking" != xno; then + AMDEP_TRUE= + AMDEP_FALSE='#' +else + AMDEP_TRUE='#' + AMDEP_FALSE= +fi + + ac_ext=c ac_cpp='$CPP $CPPFLAGS' ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' @@ -3664,11 +4362,198 @@ if test "x$ac_cv_prog_cc_c89" != xno; then : fi -ac_ext=c -ac_cpp='$CPP $CPPFLAGS' -ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' -ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' -ac_compiler_gnu=$ac_cv_c_compiler_gnu +ac_ext=c +ac_cpp='$CPP $CPPFLAGS' +ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' +ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' +ac_compiler_gnu=$ac_cv_c_compiler_gnu + +ac_ext=c +ac_cpp='$CPP $CPPFLAGS' +ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' +ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' +ac_compiler_gnu=$ac_cv_c_compiler_gnu +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking whether $CC understands -c and -o together" >&5 +$as_echo_n "checking whether $CC understands -c and -o together... " >&6; } +if ${am_cv_prog_cc_c_o+:} false; then : + $as_echo_n "(cached) " >&6 +else + cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ + +int +main () +{ + + ; + return 0; +} +_ACEOF + # Make sure it works both with $CC and with simple cc. + # Following AC_PROG_CC_C_O, we do the test twice because some + # compilers refuse to overwrite an existing .o file with -o, + # though they will create one. + am_cv_prog_cc_c_o=yes + for am_i in 1 2; do + if { echo "$as_me:$LINENO: $CC -c conftest.$ac_ext -o conftest2.$ac_objext" >&5 + ($CC -c conftest.$ac_ext -o conftest2.$ac_objext) >&5 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } \ + && test -f conftest2.$ac_objext; then + : OK + else + am_cv_prog_cc_c_o=no + break + fi + done + rm -f core conftest* + unset am_i +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $am_cv_prog_cc_c_o" >&5 +$as_echo "$am_cv_prog_cc_c_o" >&6; } +if test "$am_cv_prog_cc_c_o" != yes; then + # Losing compiler, so override with the script. + # FIXME: It is wrong to rewrite CC. + # But if we don't then we get into trouble of one sort or another. + # A longer-term fix would be to have automake use am__CC in this case, + # and then we could set am__CC="\$(top_srcdir)/compile \$(CC)" + CC="$am_aux_dir/compile $CC" +fi +ac_ext=c +ac_cpp='$CPP $CPPFLAGS' +ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' +ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' +ac_compiler_gnu=$ac_cv_c_compiler_gnu + + +depcc="$CC" am_compiler_list= + +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking dependency style of $depcc" >&5 +$as_echo_n "checking dependency style of $depcc... " >&6; } +if ${am_cv_CC_dependencies_compiler_type+:} false; then : + $as_echo_n "(cached) " >&6 +else + if test -z "$AMDEP_TRUE" && test -f "$am_depcomp"; then + # We make a subdir and do the tests there. Otherwise we can end up + # making bogus files that we don't know about and never remove. For + # instance it was reported that on HP-UX the gcc test will end up + # making a dummy file named 'D' -- because '-MD' means "put the output + # in D". + rm -rf conftest.dir + mkdir conftest.dir + # Copy depcomp to subdir because otherwise we won't find it if we're + # using a relative directory. + cp "$am_depcomp" conftest.dir + cd conftest.dir + # We will build objects and dependencies in a subdirectory because + # it helps to detect inapplicable dependency modes. For instance + # both Tru64's cc and ICC support -MD to output dependencies as a + # side effect of compilation, but ICC will put the dependencies in + # the current directory while Tru64 will put them in the object + # directory. + mkdir sub + + am_cv_CC_dependencies_compiler_type=none + if test "$am_compiler_list" = ""; then + am_compiler_list=`sed -n 's/^#*\([a-zA-Z0-9]*\))$/\1/p' < ./depcomp` + fi + am__universal=false + case " $depcc " in #( + *\ -arch\ *\ -arch\ *) am__universal=true ;; + esac + + for depmode in $am_compiler_list; do + # Setup a source with many dependencies, because some compilers + # like to wrap large dependency lists on column 80 (with \), and + # we should not choose a depcomp mode which is confused by this. + # + # We need to recreate these files for each test, as the compiler may + # overwrite some of them when testing with obscure command lines. + # This happens at least with the AIX C compiler. + : > sub/conftest.c + for i in 1 2 3 4 5 6; do + echo '#include "conftst'$i'.h"' >> sub/conftest.c + # Using ": > sub/conftst$i.h" creates only sub/conftst1.h with + # Solaris 10 /bin/sh. + echo '/* dummy */' > sub/conftst$i.h + done + echo "${am__include} ${am__quote}sub/conftest.Po${am__quote}" > confmf + + # We check with '-c' and '-o' for the sake of the "dashmstdout" + # mode. It turns out that the SunPro C++ compiler does not properly + # handle '-M -o', and we need to detect this. Also, some Intel + # versions had trouble with output in subdirs. + am__obj=sub/conftest.${OBJEXT-o} + am__minus_obj="-o $am__obj" + case $depmode in + gcc) + # This depmode causes a compiler race in universal mode. + test "$am__universal" = false || continue + ;; + nosideeffect) + # After this tag, mechanisms are not by side-effect, so they'll + # only be used when explicitly requested. + if test "x$enable_dependency_tracking" = xyes; then + continue + else + break + fi + ;; + msvc7 | msvc7msys | msvisualcpp | msvcmsys) + # This compiler won't grok '-c -o', but also, the minuso test has + # not run yet. These depmodes are late enough in the game, and + # so weak that their functioning should not be impacted. + am__obj=conftest.${OBJEXT-o} + am__minus_obj= + ;; + none) break ;; + esac + if depmode=$depmode \ + source=sub/conftest.c object=$am__obj \ + depfile=sub/conftest.Po tmpdepfile=sub/conftest.TPo \ + $SHELL ./depcomp $depcc -c $am__minus_obj sub/conftest.c \ + >/dev/null 2>conftest.err && + grep sub/conftst1.h sub/conftest.Po > /dev/null 2>&1 && + grep sub/conftst6.h sub/conftest.Po > /dev/null 2>&1 && + grep $am__obj sub/conftest.Po > /dev/null 2>&1 && + ${MAKE-make} -s -f confmf > /dev/null 2>&1; then + # icc doesn't choke on unknown options, it will just issue warnings + # or remarks (even with -Werror). So we grep stderr for any message + # that says an option was ignored or not supported. + # When given -MP, icc 7.0 and 7.1 complain thusly: + # icc: Command line warning: ignoring option '-M'; no argument required + # The diagnosis changed in icc 8.0: + # icc: Command line remark: option '-MP' not supported + if (grep 'ignoring option' conftest.err || + grep 'not supported' conftest.err) >/dev/null 2>&1; then :; else + am_cv_CC_dependencies_compiler_type=$depmode + break + fi + fi + done + + cd .. + rm -rf conftest.dir +else + am_cv_CC_dependencies_compiler_type=none +fi + +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $am_cv_CC_dependencies_compiler_type" >&5 +$as_echo "$am_cv_CC_dependencies_compiler_type" >&6; } +CCDEPMODE=depmode=$am_cv_CC_dependencies_compiler_type + + if + test "x$enable_dependency_tracking" != xno \ + && test "$am_cv_CC_dependencies_compiler_type" = gcc3; then + am__fastdepCC_TRUE= + am__fastdepCC_FALSE='#' +else + am__fastdepCC_TRUE='#' + am__fastdepCC_FALSE= +fi + { $as_echo "$as_me:${as_lineno-$LINENO}: checking for a sed that does not truncate output" >&5 $as_echo_n "checking for a sed that does not truncate output... " >&6; } @@ -5488,48 +6373,6 @@ esac -for ac_prog in gawk mawk nawk awk -do - # Extract the first word of "$ac_prog", so it can be a program name with args. -set dummy $ac_prog; ac_word=$2 -{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 -$as_echo_n "checking for $ac_word... " >&6; } -if ${ac_cv_prog_AWK+:} false; then : - $as_echo_n "(cached) " >&6 -else - if test -n "$AWK"; then - ac_cv_prog_AWK="$AWK" # Let the user override the test. -else -as_save_IFS=$IFS; IFS=$PATH_SEPARATOR -for as_dir in $PATH -do - IFS=$as_save_IFS - test -z "$as_dir" && as_dir=. - for ac_exec_ext in '' $ac_executable_extensions; do - if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then - ac_cv_prog_AWK="$ac_prog" - $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 - break 2 - fi -done - done -IFS=$as_save_IFS - -fi -fi -AWK=$ac_cv_prog_AWK -if test -n "$AWK"; then - { $as_echo "$as_me:${as_lineno-$LINENO}: result: $AWK" >&5 -$as_echo "$AWK" >&6; } -else - { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 -$as_echo "no" >&6; } -fi - - - test -n "$AWK" && break -done - @@ -12065,6 +12908,134 @@ ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' ac_compiler_gnu=$ac_cv_c_compiler_gnu +depcc="$CXX" am_compiler_list= + +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking dependency style of $depcc" >&5 +$as_echo_n "checking dependency style of $depcc... " >&6; } +if ${am_cv_CXX_dependencies_compiler_type+:} false; then : + $as_echo_n "(cached) " >&6 +else + if test -z "$AMDEP_TRUE" && test -f "$am_depcomp"; then + # We make a subdir and do the tests there. Otherwise we can end up + # making bogus files that we don't know about and never remove. For + # instance it was reported that on HP-UX the gcc test will end up + # making a dummy file named 'D' -- because '-MD' means "put the output + # in D". + rm -rf conftest.dir + mkdir conftest.dir + # Copy depcomp to subdir because otherwise we won't find it if we're + # using a relative directory. + cp "$am_depcomp" conftest.dir + cd conftest.dir + # We will build objects and dependencies in a subdirectory because + # it helps to detect inapplicable dependency modes. For instance + # both Tru64's cc and ICC support -MD to output dependencies as a + # side effect of compilation, but ICC will put the dependencies in + # the current directory while Tru64 will put them in the object + # directory. + mkdir sub + + am_cv_CXX_dependencies_compiler_type=none + if test "$am_compiler_list" = ""; then + am_compiler_list=`sed -n 's/^#*\([a-zA-Z0-9]*\))$/\1/p' < ./depcomp` + fi + am__universal=false + case " $depcc " in #( + *\ -arch\ *\ -arch\ *) am__universal=true ;; + esac + + for depmode in $am_compiler_list; do + # Setup a source with many dependencies, because some compilers + # like to wrap large dependency lists on column 80 (with \), and + # we should not choose a depcomp mode which is confused by this. + # + # We need to recreate these files for each test, as the compiler may + # overwrite some of them when testing with obscure command lines. + # This happens at least with the AIX C compiler. + : > sub/conftest.c + for i in 1 2 3 4 5 6; do + echo '#include "conftst'$i'.h"' >> sub/conftest.c + # Using ": > sub/conftst$i.h" creates only sub/conftst1.h with + # Solaris 10 /bin/sh. + echo '/* dummy */' > sub/conftst$i.h + done + echo "${am__include} ${am__quote}sub/conftest.Po${am__quote}" > confmf + + # We check with '-c' and '-o' for the sake of the "dashmstdout" + # mode. It turns out that the SunPro C++ compiler does not properly + # handle '-M -o', and we need to detect this. Also, some Intel + # versions had trouble with output in subdirs. + am__obj=sub/conftest.${OBJEXT-o} + am__minus_obj="-o $am__obj" + case $depmode in + gcc) + # This depmode causes a compiler race in universal mode. + test "$am__universal" = false || continue + ;; + nosideeffect) + # After this tag, mechanisms are not by side-effect, so they'll + # only be used when explicitly requested. + if test "x$enable_dependency_tracking" = xyes; then + continue + else + break + fi + ;; + msvc7 | msvc7msys | msvisualcpp | msvcmsys) + # This compiler won't grok '-c -o', but also, the minuso test has + # not run yet. These depmodes are late enough in the game, and + # so weak that their functioning should not be impacted. + am__obj=conftest.${OBJEXT-o} + am__minus_obj= + ;; + none) break ;; + esac + if depmode=$depmode \ + source=sub/conftest.c object=$am__obj \ + depfile=sub/conftest.Po tmpdepfile=sub/conftest.TPo \ + $SHELL ./depcomp $depcc -c $am__minus_obj sub/conftest.c \ + >/dev/null 2>conftest.err && + grep sub/conftst1.h sub/conftest.Po > /dev/null 2>&1 && + grep sub/conftst6.h sub/conftest.Po > /dev/null 2>&1 && + grep $am__obj sub/conftest.Po > /dev/null 2>&1 && + ${MAKE-make} -s -f confmf > /dev/null 2>&1; then + # icc doesn't choke on unknown options, it will just issue warnings + # or remarks (even with -Werror). So we grep stderr for any message + # that says an option was ignored or not supported. + # When given -MP, icc 7.0 and 7.1 complain thusly: + # icc: Command line warning: ignoring option '-M'; no argument required + # The diagnosis changed in icc 8.0: + # icc: Command line remark: option '-MP' not supported + if (grep 'ignoring option' conftest.err || + grep 'not supported' conftest.err) >/dev/null 2>&1; then :; else + am_cv_CXX_dependencies_compiler_type=$depmode + break + fi + fi + done + + cd .. + rm -rf conftest.dir +else + am_cv_CXX_dependencies_compiler_type=none +fi + +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $am_cv_CXX_dependencies_compiler_type" >&5 +$as_echo "$am_cv_CXX_dependencies_compiler_type" >&6; } +CXXDEPMODE=depmode=$am_cv_CXX_dependencies_compiler_type + + if + test "x$enable_dependency_tracking" != xno \ + && test "$am_cv_CXX_dependencies_compiler_type" = gcc3; then + am__fastdepCXX_TRUE= + am__fastdepCXX_FALSE='#' +else + am__fastdepCXX_TRUE='#' + am__fastdepCXX_FALSE= +fi + + func_stripname_cnf () @@ -15393,98 +16364,6 @@ ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $ ac_compiler_gnu=$ac_cv_c_compiler_gnu -# Find a good install program. We prefer a C program (faster), -# so one script is as good as another. But avoid the broken or -# incompatible versions: -# SysV /etc/install, /usr/sbin/install -# SunOS /usr/etc/install -# IRIX /sbin/install -# AIX /bin/install -# AmigaOS /C/install, which installs bootblocks on floppy discs -# AIX 4 /usr/bin/installbsd, which doesn't work without a -g flag -# AFS /usr/afsws/bin/install, which mishandles nonexistent args -# SVR4 /usr/ucb/install, which tries to use the nonexistent group "staff" -# OS/2's system install, which has a completely different semantic -# ./install, which can be erroneously created by make from ./install.sh. -# Reject install programs that cannot install multiple files. -{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for a BSD-compatible install" >&5 -$as_echo_n "checking for a BSD-compatible install... " >&6; } -if test -z "$INSTALL"; then -if ${ac_cv_path_install+:} false; then : - $as_echo_n "(cached) " >&6 -else - as_save_IFS=$IFS; IFS=$PATH_SEPARATOR -for as_dir in $PATH -do - IFS=$as_save_IFS - test -z "$as_dir" && as_dir=. - # Account for people who put trailing slashes in PATH elements. -case $as_dir/ in #(( - ./ | .// | /[cC]/* | \ - /etc/* | /usr/sbin/* | /usr/etc/* | /sbin/* | /usr/afsws/bin/* | \ - ?:[\\/]os2[\\/]install[\\/]* | ?:[\\/]OS2[\\/]INSTALL[\\/]* | \ - /usr/ucb/* ) ;; - *) - # OSF1 and SCO ODT 3.0 have their own names for install. - # Don't use installbsd from OSF since it installs stuff as root - # by default. - for ac_prog in ginstall scoinst install; do - for ac_exec_ext in '' $ac_executable_extensions; do - if as_fn_executable_p "$as_dir/$ac_prog$ac_exec_ext"; then - if test $ac_prog = install && - grep dspmsg "$as_dir/$ac_prog$ac_exec_ext" >/dev/null 2>&1; then - # AIX install. It has an incompatible calling convention. - : - elif test $ac_prog = install && - grep pwplus "$as_dir/$ac_prog$ac_exec_ext" >/dev/null 2>&1; then - # program-specific install script used by HP pwplus--don't use. - : - else - rm -rf conftest.one conftest.two conftest.dir - echo one > conftest.one - echo two > conftest.two - mkdir conftest.dir - if "$as_dir/$ac_prog$ac_exec_ext" -c conftest.one conftest.two "`pwd`/conftest.dir" && - test -s conftest.one && test -s conftest.two && - test -s conftest.dir/conftest.one && - test -s conftest.dir/conftest.two - then - ac_cv_path_install="$as_dir/$ac_prog$ac_exec_ext -c" - break 3 - fi - fi - fi - done - done - ;; -esac - - done -IFS=$as_save_IFS - -rm -rf conftest.one conftest.two conftest.dir - -fi - if test "${ac_cv_path_install+set}" = set; then - INSTALL=$ac_cv_path_install - else - # As a last resort, use the slow shell script. Don't cache a - # value for INSTALL within a source directory, because that will - # break other packages using the cache if that directory is - # removed, or if the value is a relative name. - INSTALL=$ac_install_sh - fi -fi -{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $INSTALL" >&5 -$as_echo "$INSTALL" >&6; } - -# Use test -z because SunOS4 sh mishandles braces in ${var-val}. -# It thinks the first close brace ends the variable substitution. -test -z "$INSTALL_PROGRAM" && INSTALL_PROGRAM='${INSTALL}' - -test -z "$INSTALL_SCRIPT" && INSTALL_SCRIPT='${INSTALL}' - -test -z "$INSTALL_DATA" && INSTALL_DATA='${INSTALL} -m 644' if test "$GCC" = yes ; then @@ -15870,6 +16749,24 @@ done +# Check whether --with-xmlwf was given. +if test "${with_xmlwf+set}" = set; then : + withval=$with_xmlwf; +else + with_xmlwf=yes +fi + + if test x${with_xmlwf} = xyes; then + WITH_XMLWF_TRUE= + WITH_XMLWF_FALSE='#' +else + WITH_XMLWF_TRUE='#' + WITH_XMLWF_FALSE= +fi + + + + # Check whether --with-libbsd was given. if test "${with_libbsd+set}" = set; then : withval=$with_libbsd; @@ -16328,6 +17225,8 @@ fi ac_config_files="$ac_config_files Makefile expat.pc" +ac_config_files="$ac_config_files doc/Makefile examples/Makefile lib/Makefile tests/Makefile tests/benchmark/Makefile xmlwf/Makefile" + ac_config_files="$ac_config_files run.sh" cat >confcache <<\_ACEOF @@ -16439,6 +17338,38 @@ LIBOBJS=$ac_libobjs LTLIBOBJS=$ac_ltlibobjs +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking that generated files are newer than configure" >&5 +$as_echo_n "checking that generated files are newer than configure... " >&6; } + if test -n "$am_sleep_pid"; then + # Hide warnings about reused PIDs. + wait $am_sleep_pid 2>/dev/null + fi + { $as_echo "$as_me:${as_lineno-$LINENO}: result: done" >&5 +$as_echo "done" >&6; } + if test -n "$EXEEXT"; then + am__EXEEXT_TRUE= + am__EXEEXT_FALSE='#' +else + am__EXEEXT_TRUE='#' + am__EXEEXT_FALSE= +fi + +if test -z "${AMDEP_TRUE}" && test -z "${AMDEP_FALSE}"; then + as_fn_error $? "conditional \"AMDEP\" was never defined. +Usually this means the macro was only invoked conditionally." "$LINENO" 5 +fi +if test -z "${am__fastdepCC_TRUE}" && test -z "${am__fastdepCC_FALSE}"; then + as_fn_error $? "conditional \"am__fastdepCC\" was never defined. +Usually this means the macro was only invoked conditionally." "$LINENO" 5 +fi +if test -z "${am__fastdepCXX_TRUE}" && test -z "${am__fastdepCXX_FALSE}"; then + as_fn_error $? "conditional \"am__fastdepCXX\" was never defined. +Usually this means the macro was only invoked conditionally." "$LINENO" 5 +fi +if test -z "${WITH_XMLWF_TRUE}" && test -z "${WITH_XMLWF_FALSE}"; then + as_fn_error $? "conditional \"WITH_XMLWF\" was never defined. +Usually this means the macro was only invoked conditionally." "$LINENO" 5 +fi : "${CONFIG_STATUS=./config.status}" ac_write_fail=0 @@ -16836,7 +17767,7 @@ cat >>$CONFIG_STATUS <<\_ACEOF || ac_write_fail=1 # report actual input values of CONFIG_FILES etc. instead of their # values after options handling. ac_log=" -This file was extended by expat $as_me 2.2.3, which was +This file was extended by expat $as_me 2.2.4, which was generated by GNU Autoconf 2.69. Invocation command line was CONFIG_FILES = $CONFIG_FILES @@ -16902,7 +17833,7 @@ _ACEOF cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1 ac_cs_config="`$as_echo "$ac_configure_args" | sed 's/^ //; s/[\\""\`\$]/\\\\&/g'`" ac_cs_version="\\ -expat config.status 2.2.3 +expat config.status 2.2.4 configured by $0, generated by GNU Autoconf 2.69, with options \\"\$ac_cs_config\\" @@ -16913,6 +17844,7 @@ gives unlimited permission to copy, distribute and modify it." ac_pwd='$ac_pwd' srcdir='$srcdir' INSTALL='$INSTALL' +MKDIR_P='$MKDIR_P' AWK='$AWK' test -n "\$AWK" || AWK=awk _ACEOF @@ -17020,6 +17952,7 @@ cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1 # # INIT-COMMANDS # +AMDEP_TRUE="$AMDEP_TRUE" ac_aux_dir="$ac_aux_dir" # The HP-UX ksh and POSIX shell print the target directory to stdout @@ -17413,9 +18346,16 @@ for ac_config_target in $ac_config_targets do case $ac_config_target in "expat_config.h") CONFIG_HEADERS="$CONFIG_HEADERS expat_config.h" ;; + "depfiles") CONFIG_COMMANDS="$CONFIG_COMMANDS depfiles" ;; "libtool") CONFIG_COMMANDS="$CONFIG_COMMANDS libtool" ;; "Makefile") CONFIG_FILES="$CONFIG_FILES Makefile" ;; "expat.pc") CONFIG_FILES="$CONFIG_FILES expat.pc" ;; + "doc/Makefile") CONFIG_FILES="$CONFIG_FILES doc/Makefile" ;; + "examples/Makefile") CONFIG_FILES="$CONFIG_FILES examples/Makefile" ;; + "lib/Makefile") CONFIG_FILES="$CONFIG_FILES lib/Makefile" ;; + "tests/Makefile") CONFIG_FILES="$CONFIG_FILES tests/Makefile" ;; + "tests/benchmark/Makefile") CONFIG_FILES="$CONFIG_FILES tests/benchmark/Makefile" ;; + "xmlwf/Makefile") CONFIG_FILES="$CONFIG_FILES xmlwf/Makefile" ;; "run.sh") CONFIG_FILES="$CONFIG_FILES run.sh" ;; *) as_fn_error $? "invalid argument: \`$ac_config_target'" "$LINENO" 5;; @@ -17865,6 +18805,11 @@ ac_abs_srcdir=$ac_abs_top_srcdir$ac_dir_suffix [\\/$]* | ?:[\\/]* ) ac_INSTALL=$INSTALL ;; *) ac_INSTALL=$ac_top_build_prefix$INSTALL ;; esac + ac_MKDIR_P=$MKDIR_P + case $MKDIR_P in + [\\/$]* | ?:[\\/]* ) ;; + */*) ac_MKDIR_P=$ac_top_build_prefix$MKDIR_P ;; + esac _ACEOF cat >>$CONFIG_STATUS <<\_ACEOF || ac_write_fail=1 @@ -17919,6 +18864,7 @@ s&@builddir@&$ac_builddir&;t t s&@abs_builddir@&$ac_abs_builddir&;t t s&@abs_top_builddir@&$ac_abs_top_builddir&;t t s&@INSTALL@&$ac_INSTALL&;t t +s&@MKDIR_P@&$ac_MKDIR_P&;t t $ac_datarootdir_hack " eval sed \"\$ac_sed_extra\" "$ac_file_inputs" | $AWK -f "$ac_tmp/subs.awk" \ @@ -17963,6 +18909,40 @@ $as_echo "$as_me: $ac_file is unchanged" >&6;} && eval '$AWK -f "$ac_tmp/defines.awk"' "$ac_file_inputs" \ || as_fn_error $? "could not create -" "$LINENO" 5 fi +# Compute "$ac_file"'s index in $config_headers. +_am_arg="$ac_file" +_am_stamp_count=1 +for _am_header in $config_headers :; do + case $_am_header in + $_am_arg | $_am_arg:* ) + break ;; + * ) + _am_stamp_count=`expr $_am_stamp_count + 1` ;; + esac +done +echo "timestamp for $_am_arg" >`$as_dirname -- "$_am_arg" || +$as_expr X"$_am_arg" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \ + X"$_am_arg" : 'X\(//\)[^/]' \| \ + X"$_am_arg" : 'X\(//\)$' \| \ + X"$_am_arg" : 'X\(/\)' \| . 2>/dev/null || +$as_echo X"$_am_arg" | + sed '/^X\(.*[^/]\)\/\/*[^/][^/]*\/*$/{ + s//\1/ + q + } + /^X\(\/\/\)[^/].*/{ + s//\1/ + q + } + /^X\(\/\/\)$/{ + s//\1/ + q + } + /^X\(\/\).*/{ + s//\1/ + q + } + s/.*/./; q'`/stamp-h$_am_stamp_count ;; :C) { $as_echo "$as_me:${as_lineno-$LINENO}: executing $ac_file commands" >&5 @@ -17972,6 +18952,99 @@ $as_echo "$as_me: executing $ac_file commands" >&6;} case $ac_file$ac_mode in + "depfiles":C) test x"$AMDEP_TRUE" != x"" || { + # Older Autoconf quotes --file arguments for eval, but not when files + # are listed without --file. Let's play safe and only enable the eval + # if we detect the quoting. + case $CONFIG_FILES in + *\'*) eval set x "$CONFIG_FILES" ;; + *) set x $CONFIG_FILES ;; + esac + shift + for mf + do + # Strip MF so we end up with the name of the file. + mf=`echo "$mf" | sed -e 's/:.*$//'` + # Check whether this is an Automake generated Makefile or not. + # We used to match only the files named 'Makefile.in', but + # some people rename them; so instead we look at the file content. + # Grep'ing the first line is not enough: some people post-process + # each Makefile.in and add a new line on top of each file to say so. + # Grep'ing the whole file is not good either: AIX grep has a line + # limit of 2048, but all sed's we know have understand at least 4000. + if sed -n 's,^#.*generated by automake.*,X,p' "$mf" | grep X >/dev/null 2>&1; then + dirpart=`$as_dirname -- "$mf" || +$as_expr X"$mf" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \ + X"$mf" : 'X\(//\)[^/]' \| \ + X"$mf" : 'X\(//\)$' \| \ + X"$mf" : 'X\(/\)' \| . 2>/dev/null || +$as_echo X"$mf" | + sed '/^X\(.*[^/]\)\/\/*[^/][^/]*\/*$/{ + s//\1/ + q + } + /^X\(\/\/\)[^/].*/{ + s//\1/ + q + } + /^X\(\/\/\)$/{ + s//\1/ + q + } + /^X\(\/\).*/{ + s//\1/ + q + } + s/.*/./; q'` + else + continue + fi + # Extract the definition of DEPDIR, am__include, and am__quote + # from the Makefile without running 'make'. + DEPDIR=`sed -n 's/^DEPDIR = //p' < "$mf"` + test -z "$DEPDIR" && continue + am__include=`sed -n 's/^am__include = //p' < "$mf"` + test -z "$am__include" && continue + am__quote=`sed -n 's/^am__quote = //p' < "$mf"` + # Find all dependency output files, they are included files with + # $(DEPDIR) in their names. We invoke sed twice because it is the + # simplest approach to changing $(DEPDIR) to its actual value in the + # expansion. + for file in `sed -n " + s/^$am__include $am__quote\(.*(DEPDIR).*\)$am__quote"'$/\1/p' <"$mf" | \ + sed -e 's/\$(DEPDIR)/'"$DEPDIR"'/g'`; do + # Make sure the directory exists. + test -f "$dirpart/$file" && continue + fdir=`$as_dirname -- "$file" || +$as_expr X"$file" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \ + X"$file" : 'X\(//\)[^/]' \| \ + X"$file" : 'X\(//\)$' \| \ + X"$file" : 'X\(/\)' \| . 2>/dev/null || +$as_echo X"$file" | + sed '/^X\(.*[^/]\)\/\/*[^/][^/]*\/*$/{ + s//\1/ + q + } + /^X\(\/\/\)[^/].*/{ + s//\1/ + q + } + /^X\(\/\/\)$/{ + s//\1/ + q + } + /^X\(\/\).*/{ + s//\1/ + q + } + s/.*/./; q'` + as_dir=$dirpart/$fdir; as_fn_mkdir_p + # echo "creating $dirpart/$file" + echo '# dummy' > "$dirpart/$file" + done + done +} + ;; "libtool":C) # See if we are running on zsh, and set the options that allow our @@ -18724,9 +19797,3 @@ if test -n "$ac_unrecognized_opts" && test "$enable_option_checking" != no; then $as_echo "$as_me: WARNING: unrecognized options: $ac_unrecognized_opts" >&2;} fi - -abs_srcdir="`cd $srcdir && pwd`" -abs_builddir="`pwd`" -if test "$abs_srcdir" != "$abs_builddir"; then - make mkdir-init -fi diff --git a/configure.ac b/configure.ac index 6198707..650d858 100644 --- a/configure.ac +++ b/configure.ac @@ -31,6 +31,7 @@ undefine([expat_version]) AC_CONFIG_SRCDIR(Makefile.in) AC_CONFIG_AUX_DIR(conftools) +AM_INIT_AUTOMAKE AC_CONFIG_MACRO_DIR([m4]) @@ -46,9 +47,10 @@ dnl If the API changes incompatibly set LIBAGE back to 0 dnl LIBCURRENT=7 # sync -LIBREVISION=5 # with +LIBREVISION=6 # with LIBAGE=6 # CMakeLists.txt! +CPPFLAGS="${CPPFLAGS} -DHAVE_EXPAT_CONFIG_H" AC_CONFIG_HEADER(expat_config.h) sinclude(conftools/ac_c_bigendian_cross.m4) @@ -100,6 +102,11 @@ AC_TYPE_SIZE_T AC_CHECK_FUNCS(memmove bcopy) +AC_ARG_WITH([xmlwf], [ +AS_HELP_STRING([--without-xmlwf], [do not build xmlwf])], [], [with_xmlwf=yes]) +AM_CONDITIONAL([WITH_XMLWF], [test x${with_xmlwf} = xyes]) + + AC_ARG_WITH([libbsd], [ AS_HELP_STRING([--with-libbsd], [utilize libbsd (for arc4random_buf)]) ], [], [with_libbsd=no]) @@ -219,11 +226,13 @@ AS_IF([test "x${enable_xml_context}" != "xno"], [ ]) AC_CONFIG_FILES([Makefile expat.pc]) +AC_CONFIG_FILES([ + doc/Makefile + examples/Makefile + lib/Makefile + tests/Makefile + tests/benchmark/Makefile + xmlwf/Makefile +]) AC_CONFIG_FILES([run.sh], [chmod +x run.sh]) AC_OUTPUT - -abs_srcdir="`cd $srcdir && pwd`" -abs_builddir="`pwd`" -if test "$abs_srcdir" != "$abs_builddir"; then - make mkdir-init -fi diff --git a/conftools/compile b/conftools/compile new file mode 100755 index 0000000..2ab71e4 --- /dev/null +++ b/conftools/compile @@ -0,0 +1,348 @@ +#! /bin/sh +# Wrapper for compilers which do not understand '-c -o'. + +scriptversion=2016-01-11.22; # UTC + +# Copyright (C) 1999-2017 Free Software Foundation, Inc. +# Written by Tom Tromey . +# +# This program is free software; you can redistribute it and/or modify +# it under the terms of the GNU General Public License as published by +# the Free Software Foundation; either version 2, or (at your option) +# any later version. +# +# This program is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +# GNU General Public License for more details. +# +# You should have received a copy of the GNU General Public License +# along with this program. If not, see . + +# As a special exception to the GNU General Public License, if you +# distribute this file as part of a program that contains a +# configuration script generated by Autoconf, you may include it under +# the same distribution terms that you use for the rest of that program. + +# This file is maintained in Automake, please report +# bugs to or send patches to +# . + +nl=' +' + +# We need space, tab and new line, in precisely that order. Quoting is +# there to prevent tools from complaining about whitespace usage. +IFS=" "" $nl" + +file_conv= + +# func_file_conv build_file lazy +# Convert a $build file to $host form and store it in $file +# Currently only supports Windows hosts. If the determined conversion +# type is listed in (the comma separated) LAZY, no conversion will +# take place. +func_file_conv () +{ + file=$1 + case $file in + / | /[!/]*) # absolute file, and not a UNC file + if test -z "$file_conv"; then + # lazily determine how to convert abs files + case `uname -s` in + MINGW*) + file_conv=mingw + ;; + CYGWIN*) + file_conv=cygwin + ;; + *) + file_conv=wine + ;; + esac + fi + case $file_conv/,$2, in + *,$file_conv,*) + ;; + mingw/*) + file=`cmd //C echo "$file " | sed -e 's/"\(.*\) " *$/\1/'` + ;; + cygwin/*) + file=`cygpath -m "$file" || echo "$file"` + ;; + wine/*) + file=`winepath -w "$file" || echo "$file"` + ;; + esac + ;; + esac +} + +# func_cl_dashL linkdir +# Make cl look for libraries in LINKDIR +func_cl_dashL () +{ + func_file_conv "$1" + if test -z "$lib_path"; then + lib_path=$file + else + lib_path="$lib_path;$file" + fi + linker_opts="$linker_opts -LIBPATH:$file" +} + +# func_cl_dashl library +# Do a library search-path lookup for cl +func_cl_dashl () +{ + lib=$1 + found=no + save_IFS=$IFS + IFS=';' + for dir in $lib_path $LIB + do + IFS=$save_IFS + if $shared && test -f "$dir/$lib.dll.lib"; then + found=yes + lib=$dir/$lib.dll.lib + break + fi + if test -f "$dir/$lib.lib"; then + found=yes + lib=$dir/$lib.lib + break + fi + if test -f "$dir/lib$lib.a"; then + found=yes + lib=$dir/lib$lib.a + break + fi + done + IFS=$save_IFS + + if test "$found" != yes; then + lib=$lib.lib + fi +} + +# func_cl_wrapper cl arg... +# Adjust compile command to suit cl +func_cl_wrapper () +{ + # Assume a capable shell + lib_path= + shared=: + linker_opts= + for arg + do + if test -n "$eat"; then + eat= + else + case $1 in + -o) + # configure might choose to run compile as 'compile cc -o foo foo.c'. + eat=1 + case $2 in + *.o | *.[oO][bB][jJ]) + func_file_conv "$2" + set x "$@" -Fo"$file" + shift + ;; + *) + func_file_conv "$2" + set x "$@" -Fe"$file" + shift + ;; + esac + ;; + -I) + eat=1 + func_file_conv "$2" mingw + set x "$@" -I"$file" + shift + ;; + -I*) + func_file_conv "${1#-I}" mingw + set x "$@" -I"$file" + shift + ;; + -l) + eat=1 + func_cl_dashl "$2" + set x "$@" "$lib" + shift + ;; + -l*) + func_cl_dashl "${1#-l}" + set x "$@" "$lib" + shift + ;; + -L) + eat=1 + func_cl_dashL "$2" + ;; + -L*) + func_cl_dashL "${1#-L}" + ;; + -static) + shared=false + ;; + -Wl,*) + arg=${1#-Wl,} + save_ifs="$IFS"; IFS=',' + for flag in $arg; do + IFS="$save_ifs" + linker_opts="$linker_opts $flag" + done + IFS="$save_ifs" + ;; + -Xlinker) + eat=1 + linker_opts="$linker_opts $2" + ;; + -*) + set x "$@" "$1" + shift + ;; + *.cc | *.CC | *.cxx | *.CXX | *.[cC]++) + func_file_conv "$1" + set x "$@" -Tp"$file" + shift + ;; + *.c | *.cpp | *.CPP | *.lib | *.LIB | *.Lib | *.OBJ | *.obj | *.[oO]) + func_file_conv "$1" mingw + set x "$@" "$file" + shift + ;; + *) + set x "$@" "$1" + shift + ;; + esac + fi + shift + done + if test -n "$linker_opts"; then + linker_opts="-link$linker_opts" + fi + exec "$@" $linker_opts + exit 1 +} + +eat= + +case $1 in + '') + echo "$0: No command. Try '$0 --help' for more information." 1>&2 + exit 1; + ;; + -h | --h*) + cat <<\EOF +Usage: compile [--help] [--version] PROGRAM [ARGS] + +Wrapper for compilers which do not understand '-c -o'. +Remove '-o dest.o' from ARGS, run PROGRAM with the remaining +arguments, and rename the output as expected. + +If you are trying to build a whole package this is not the +right script to run: please start by reading the file 'INSTALL'. + +Report bugs to . +EOF + exit $? + ;; + -v | --v*) + echo "compile $scriptversion" + exit $? + ;; + cl | *[/\\]cl | cl.exe | *[/\\]cl.exe | \ + icl | *[/\\]icl | icl.exe | *[/\\]icl.exe ) + func_cl_wrapper "$@" # Doesn't return... + ;; +esac + +ofile= +cfile= + +for arg +do + if test -n "$eat"; then + eat= + else + case $1 in + -o) + # configure might choose to run compile as 'compile cc -o foo foo.c'. + # So we strip '-o arg' only if arg is an object. + eat=1 + case $2 in + *.o | *.obj) + ofile=$2 + ;; + *) + set x "$@" -o "$2" + shift + ;; + esac + ;; + *.c) + cfile=$1 + set x "$@" "$1" + shift + ;; + *) + set x "$@" "$1" + shift + ;; + esac + fi + shift +done + +if test -z "$ofile" || test -z "$cfile"; then + # If no '-o' option was seen then we might have been invoked from a + # pattern rule where we don't need one. That is ok -- this is a + # normal compilation that the losing compiler can handle. If no + # '.c' file was seen then we are probably linking. That is also + # ok. + exec "$@" +fi + +# Name of file we expect compiler to create. +cofile=`echo "$cfile" | sed 's|^.*[\\/]||; s|^[a-zA-Z]:||; s/\.c$/.o/'` + +# Create the lock directory. +# Note: use '[/\\:.-]' here to ensure that we don't use the same name +# that we are using for the .o file. Also, base the name on the expected +# object file name, since that is what matters with a parallel build. +lockdir=`echo "$cofile" | sed -e 's|[/\\:.-]|_|g'`.d +while true; do + if mkdir "$lockdir" >/dev/null 2>&1; then + break + fi + sleep 1 +done +# FIXME: race condition here if user kills between mkdir and trap. +trap "rmdir '$lockdir'; exit 1" 1 2 15 + +# Run the compile. +"$@" +ret=$? + +if test -f "$cofile"; then + test "$cofile" = "$ofile" || mv "$cofile" "$ofile" +elif test -f "${cofile}bj"; then + test "${cofile}bj" = "$ofile" || mv "${cofile}bj" "$ofile" +fi + +rmdir "$lockdir" +exit $ret + +# Local Variables: +# mode: shell-script +# sh-indentation: 2 +# eval: (add-hook 'write-file-hooks 'time-stamp) +# time-stamp-start: "scriptversion=" +# time-stamp-format: "%:y-%02m-%02d.%02H" +# time-stamp-time-zone: "UTC0" +# time-stamp-end: "; # UTC" +# End: diff --git a/conftools/depcomp b/conftools/depcomp new file mode 100755 index 0000000..b39f98f --- /dev/null +++ b/conftools/depcomp @@ -0,0 +1,791 @@ +#! /bin/sh +# depcomp - compile a program generating dependencies as side-effects + +scriptversion=2016-01-11.22; # UTC + +# Copyright (C) 1999-2017 Free Software Foundation, Inc. + +# This program is free software; you can redistribute it and/or modify +# it under the terms of the GNU General Public License as published by +# the Free Software Foundation; either version 2, or (at your option) +# any later version. + +# This program is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +# GNU General Public License for more details. + +# You should have received a copy of the GNU General Public License +# along with this program. If not, see . + +# As a special exception to the GNU General Public License, if you +# distribute this file as part of a program that contains a +# configuration script generated by Autoconf, you may include it under +# the same distribution terms that you use for the rest of that program. + +# Originally written by Alexandre Oliva . + +case $1 in + '') + echo "$0: No command. Try '$0 --help' for more information." 1>&2 + exit 1; + ;; + -h | --h*) + cat <<\EOF +Usage: depcomp [--help] [--version] PROGRAM [ARGS] + +Run PROGRAMS ARGS to compile a file, generating dependencies +as side-effects. + +Environment variables: + depmode Dependency tracking mode. + source Source file read by 'PROGRAMS ARGS'. + object Object file output by 'PROGRAMS ARGS'. + DEPDIR directory where to store dependencies. + depfile Dependency file to output. + tmpdepfile Temporary file to use when outputting dependencies. + libtool Whether libtool is used (yes/no). + +Report bugs to . +EOF + exit $? + ;; + -v | --v*) + echo "depcomp $scriptversion" + exit $? + ;; +esac + +# Get the directory component of the given path, and save it in the +# global variables '$dir'. Note that this directory component will +# be either empty or ending with a '/' character. This is deliberate. +set_dir_from () +{ + case $1 in + */*) dir=`echo "$1" | sed -e 's|/[^/]*$|/|'`;; + *) dir=;; + esac +} + +# Get the suffix-stripped basename of the given path, and save it the +# global variable '$base'. +set_base_from () +{ + base=`echo "$1" | sed -e 's|^.*/||' -e 's/\.[^.]*$//'` +} + +# If no dependency file was actually created by the compiler invocation, +# we still have to create a dummy depfile, to avoid errors with the +# Makefile "include basename.Plo" scheme. +make_dummy_depfile () +{ + echo "#dummy" > "$depfile" +} + +# Factor out some common post-processing of the generated depfile. +# Requires the auxiliary global variable '$tmpdepfile' to be set. +aix_post_process_depfile () +{ + # If the compiler actually managed to produce a dependency file, + # post-process it. + if test -f "$tmpdepfile"; then + # Each line is of the form 'foo.o: dependency.h'. + # Do two passes, one to just change these to + # $object: dependency.h + # and one to simply output + # dependency.h: + # which is needed to avoid the deleted-header problem. + { sed -e "s,^.*\.[$lower]*:,$object:," < "$tmpdepfile" + sed -e "s,^.*\.[$lower]*:[$tab ]*,," -e 's,$,:,' < "$tmpdepfile" + } > "$depfile" + rm -f "$tmpdepfile" + else + make_dummy_depfile + fi +} + +# A tabulation character. +tab=' ' +# A newline character. +nl=' +' +# Character ranges might be problematic outside the C locale. +# These definitions help. +upper=ABCDEFGHIJKLMNOPQRSTUVWXYZ +lower=abcdefghijklmnopqrstuvwxyz +digits=0123456789 +alpha=${upper}${lower} + +if test -z "$depmode" || test -z "$source" || test -z "$object"; then + echo "depcomp: Variables source, object and depmode must be set" 1>&2 + exit 1 +fi + +# Dependencies for sub/bar.o or sub/bar.obj go into sub/.deps/bar.Po. +depfile=${depfile-`echo "$object" | + sed 's|[^\\/]*$|'${DEPDIR-.deps}'/&|;s|\.\([^.]*\)$|.P\1|;s|Pobj$|Po|'`} +tmpdepfile=${tmpdepfile-`echo "$depfile" | sed 's/\.\([^.]*\)$/.T\1/'`} + +rm -f "$tmpdepfile" + +# Avoid interferences from the environment. +gccflag= dashmflag= + +# Some modes work just like other modes, but use different flags. We +# parameterize here, but still list the modes in the big case below, +# to make depend.m4 easier to write. Note that we *cannot* use a case +# here, because this file can only contain one case statement. +if test "$depmode" = hp; then + # HP compiler uses -M and no extra arg. + gccflag=-M + depmode=gcc +fi + +if test "$depmode" = dashXmstdout; then + # This is just like dashmstdout with a different argument. + dashmflag=-xM + depmode=dashmstdout +fi + +cygpath_u="cygpath -u -f -" +if test "$depmode" = msvcmsys; then + # This is just like msvisualcpp but w/o cygpath translation. + # Just convert the backslash-escaped backslashes to single forward + # slashes to satisfy depend.m4 + cygpath_u='sed s,\\\\,/,g' + depmode=msvisualcpp +fi + +if test "$depmode" = msvc7msys; then + # This is just like msvc7 but w/o cygpath translation. + # Just convert the backslash-escaped backslashes to single forward + # slashes to satisfy depend.m4 + cygpath_u='sed s,\\\\,/,g' + depmode=msvc7 +fi + +if test "$depmode" = xlc; then + # IBM C/C++ Compilers xlc/xlC can output gcc-like dependency information. + gccflag=-qmakedep=gcc,-MF + depmode=gcc +fi + +case "$depmode" in +gcc3) +## gcc 3 implements dependency tracking that does exactly what +## we want. Yay! Note: for some reason libtool 1.4 doesn't like +## it if -MD -MP comes after the -MF stuff. Hmm. +## Unfortunately, FreeBSD c89 acceptance of flags depends upon +## the command line argument order; so add the flags where they +## appear in depend2.am. Note that the slowdown incurred here +## affects only configure: in makefiles, %FASTDEP% shortcuts this. + for arg + do + case $arg in + -c) set fnord "$@" -MT "$object" -MD -MP -MF "$tmpdepfile" "$arg" ;; + *) set fnord "$@" "$arg" ;; + esac + shift # fnord + shift # $arg + done + "$@" + stat=$? + if test $stat -ne 0; then + rm -f "$tmpdepfile" + exit $stat + fi + mv "$tmpdepfile" "$depfile" + ;; + +gcc) +## Note that this doesn't just cater to obsosete pre-3.x GCC compilers. +## but also to in-use compilers like IMB xlc/xlC and the HP C compiler. +## (see the conditional assignment to $gccflag above). +## There are various ways to get dependency output from gcc. Here's +## why we pick this rather obscure method: +## - Don't want to use -MD because we'd like the dependencies to end +## up in a subdir. Having to rename by hand is ugly. +## (We might end up doing this anyway to support other compilers.) +## - The DEPENDENCIES_OUTPUT environment variable makes gcc act like +## -MM, not -M (despite what the docs say). Also, it might not be +## supported by the other compilers which use the 'gcc' depmode. +## - Using -M directly means running the compiler twice (even worse +## than renaming). + if test -z "$gccflag"; then + gccflag=-MD, + fi + "$@" -Wp,"$gccflag$tmpdepfile" + stat=$? + if test $stat -ne 0; then + rm -f "$tmpdepfile" + exit $stat + fi + rm -f "$depfile" + echo "$object : \\" > "$depfile" + # The second -e expression handles DOS-style file names with drive + # letters. + sed -e 's/^[^:]*: / /' \ + -e 's/^['$alpha']:\/[^:]*: / /' < "$tmpdepfile" >> "$depfile" +## This next piece of magic avoids the "deleted header file" problem. +## The problem is that when a header file which appears in a .P file +## is deleted, the dependency causes make to die (because there is +## typically no way to rebuild the header). We avoid this by adding +## dummy dependencies for each header file. Too bad gcc doesn't do +## this for us directly. +## Some versions of gcc put a space before the ':'. On the theory +## that the space means something, we add a space to the output as +## well. hp depmode also adds that space, but also prefixes the VPATH +## to the object. Take care to not repeat it in the output. +## Some versions of the HPUX 10.20 sed can't process this invocation +## correctly. Breaking it into two sed invocations is a workaround. + tr ' ' "$nl" < "$tmpdepfile" \ + | sed -e 's/^\\$//' -e '/^$/d' -e "s|.*$object$||" -e '/:$/d' \ + | sed -e 's/$/ :/' >> "$depfile" + rm -f "$tmpdepfile" + ;; + +hp) + # This case exists only to let depend.m4 do its work. It works by + # looking at the text of this script. This case will never be run, + # since it is checked for above. + exit 1 + ;; + +sgi) + if test "$libtool" = yes; then + "$@" "-Wp,-MDupdate,$tmpdepfile" + else + "$@" -MDupdate "$tmpdepfile" + fi + stat=$? + if test $stat -ne 0; then + rm -f "$tmpdepfile" + exit $stat + fi + rm -f "$depfile" + + if test -f "$tmpdepfile"; then # yes, the sourcefile depend on other files + echo "$object : \\" > "$depfile" + # Clip off the initial element (the dependent). Don't try to be + # clever and replace this with sed code, as IRIX sed won't handle + # lines with more than a fixed number of characters (4096 in + # IRIX 6.2 sed, 8192 in IRIX 6.5). We also remove comment lines; + # the IRIX cc adds comments like '#:fec' to the end of the + # dependency line. + tr ' ' "$nl" < "$tmpdepfile" \ + | sed -e 's/^.*\.o://' -e 's/#.*$//' -e '/^$/ d' \ + | tr "$nl" ' ' >> "$depfile" + echo >> "$depfile" + # The second pass generates a dummy entry for each header file. + tr ' ' "$nl" < "$tmpdepfile" \ + | sed -e 's/^.*\.o://' -e 's/#.*$//' -e '/^$/ d' -e 's/$/:/' \ + >> "$depfile" + else + make_dummy_depfile + fi + rm -f "$tmpdepfile" + ;; + +xlc) + # This case exists only to let depend.m4 do its work. It works by + # looking at the text of this script. This case will never be run, + # since it is checked for above. + exit 1 + ;; + +aix) + # The C for AIX Compiler uses -M and outputs the dependencies + # in a .u file. In older versions, this file always lives in the + # current directory. Also, the AIX compiler puts '$object:' at the + # start of each line; $object doesn't have directory information. + # Version 6 uses the directory in both cases. + set_dir_from "$object" + set_base_from "$object" + if test "$libtool" = yes; then + tmpdepfile1=$dir$base.u + tmpdepfile2=$base.u + tmpdepfile3=$dir.libs/$base.u + "$@" -Wc,-M + else + tmpdepfile1=$dir$base.u + tmpdepfile2=$dir$base.u + tmpdepfile3=$dir$base.u + "$@" -M + fi + stat=$? + if test $stat -ne 0; then + rm -f "$tmpdepfile1" "$tmpdepfile2" "$tmpdepfile3" + exit $stat + fi + + for tmpdepfile in "$tmpdepfile1" "$tmpdepfile2" "$tmpdepfile3" + do + test -f "$tmpdepfile" && break + done + aix_post_process_depfile + ;; + +tcc) + # tcc (Tiny C Compiler) understand '-MD -MF file' since version 0.9.26 + # FIXME: That version still under development at the moment of writing. + # Make that this statement remains true also for stable, released + # versions. + # It will wrap lines (doesn't matter whether long or short) with a + # trailing '\', as in: + # + # foo.o : \ + # foo.c \ + # foo.h \ + # + # It will put a trailing '\' even on the last line, and will use leading + # spaces rather than leading tabs (at least since its commit 0394caf7 + # "Emit spaces for -MD"). + "$@" -MD -MF "$tmpdepfile" + stat=$? + if test $stat -ne 0; then + rm -f "$tmpdepfile" + exit $stat + fi + rm -f "$depfile" + # Each non-empty line is of the form 'foo.o : \' or ' dep.h \'. + # We have to change lines of the first kind to '$object: \'. + sed -e "s|.*:|$object :|" < "$tmpdepfile" > "$depfile" + # And for each line of the second kind, we have to emit a 'dep.h:' + # dummy dependency, to avoid the deleted-header problem. + sed -n -e 's|^ *\(.*\) *\\$|\1:|p' < "$tmpdepfile" >> "$depfile" + rm -f "$tmpdepfile" + ;; + +## The order of this option in the case statement is important, since the +## shell code in configure will try each of these formats in the order +## listed in this file. A plain '-MD' option would be understood by many +## compilers, so we must ensure this comes after the gcc and icc options. +pgcc) + # Portland's C compiler understands '-MD'. + # Will always output deps to 'file.d' where file is the root name of the + # source file under compilation, even if file resides in a subdirectory. + # The object file name does not affect the name of the '.d' file. + # pgcc 10.2 will output + # foo.o: sub/foo.c sub/foo.h + # and will wrap long lines using '\' : + # foo.o: sub/foo.c ... \ + # sub/foo.h ... \ + # ... + set_dir_from "$object" + # Use the source, not the object, to determine the base name, since + # that's sadly what pgcc will do too. + set_base_from "$source" + tmpdepfile=$base.d + + # For projects that build the same source file twice into different object + # files, the pgcc approach of using the *source* file root name can cause + # problems in parallel builds. Use a locking strategy to avoid stomping on + # the same $tmpdepfile. + lockdir=$base.d-lock + trap " + echo '$0: caught signal, cleaning up...' >&2 + rmdir '$lockdir' + exit 1 + " 1 2 13 15 + numtries=100 + i=$numtries + while test $i -gt 0; do + # mkdir is a portable test-and-set. + if mkdir "$lockdir" 2>/dev/null; then + # This process acquired the lock. + "$@" -MD + stat=$? + # Release the lock. + rmdir "$lockdir" + break + else + # If the lock is being held by a different process, wait + # until the winning process is done or we timeout. + while test -d "$lockdir" && test $i -gt 0; do + sleep 1 + i=`expr $i - 1` + done + fi + i=`expr $i - 1` + done + trap - 1 2 13 15 + if test $i -le 0; then + echo "$0: failed to acquire lock after $numtries attempts" >&2 + echo "$0: check lockdir '$lockdir'" >&2 + exit 1 + fi + + if test $stat -ne 0; then + rm -f "$tmpdepfile" + exit $stat + fi + rm -f "$depfile" + # Each line is of the form `foo.o: dependent.h', + # or `foo.o: dep1.h dep2.h \', or ` dep3.h dep4.h \'. + # Do two passes, one to just change these to + # `$object: dependent.h' and one to simply `dependent.h:'. + sed "s,^[^:]*:,$object :," < "$tmpdepfile" > "$depfile" + # Some versions of the HPUX 10.20 sed can't process this invocation + # correctly. Breaking it into two sed invocations is a workaround. + sed 's,^[^:]*: \(.*\)$,\1,;s/^\\$//;/^$/d;/:$/d' < "$tmpdepfile" \ + | sed -e 's/$/ :/' >> "$depfile" + rm -f "$tmpdepfile" + ;; + +hp2) + # The "hp" stanza above does not work with aCC (C++) and HP's ia64 + # compilers, which have integrated preprocessors. The correct option + # to use with these is +Maked; it writes dependencies to a file named + # 'foo.d', which lands next to the object file, wherever that + # happens to be. + # Much of this is similar to the tru64 case; see comments there. + set_dir_from "$object" + set_base_from "$object" + if test "$libtool" = yes; then + tmpdepfile1=$dir$base.d + tmpdepfile2=$dir.libs/$base.d + "$@" -Wc,+Maked + else + tmpdepfile1=$dir$base.d + tmpdepfile2=$dir$base.d + "$@" +Maked + fi + stat=$? + if test $stat -ne 0; then + rm -f "$tmpdepfile1" "$tmpdepfile2" + exit $stat + fi + + for tmpdepfile in "$tmpdepfile1" "$tmpdepfile2" + do + test -f "$tmpdepfile" && break + done + if test -f "$tmpdepfile"; then + sed -e "s,^.*\.[$lower]*:,$object:," "$tmpdepfile" > "$depfile" + # Add 'dependent.h:' lines. + sed -ne '2,${ + s/^ *// + s/ \\*$// + s/$/:/ + p + }' "$tmpdepfile" >> "$depfile" + else + make_dummy_depfile + fi + rm -f "$tmpdepfile" "$tmpdepfile2" + ;; + +tru64) + # The Tru64 compiler uses -MD to generate dependencies as a side + # effect. 'cc -MD -o foo.o ...' puts the dependencies into 'foo.o.d'. + # At least on Alpha/Redhat 6.1, Compaq CCC V6.2-504 seems to put + # dependencies in 'foo.d' instead, so we check for that too. + # Subdirectories are respected. + set_dir_from "$object" + set_base_from "$object" + + if test "$libtool" = yes; then + # Libtool generates 2 separate objects for the 2 libraries. These + # two compilations output dependencies in $dir.libs/$base.o.d and + # in $dir$base.o.d. We have to check for both files, because + # one of the two compilations can be disabled. We should prefer + # $dir$base.o.d over $dir.libs/$base.o.d because the latter is + # automatically cleaned when .libs/ is deleted, while ignoring + # the former would cause a distcleancheck panic. + tmpdepfile1=$dir$base.o.d # libtool 1.5 + tmpdepfile2=$dir.libs/$base.o.d # Likewise. + tmpdepfile3=$dir.libs/$base.d # Compaq CCC V6.2-504 + "$@" -Wc,-MD + else + tmpdepfile1=$dir$base.d + tmpdepfile2=$dir$base.d + tmpdepfile3=$dir$base.d + "$@" -MD + fi + + stat=$? + if test $stat -ne 0; then + rm -f "$tmpdepfile1" "$tmpdepfile2" "$tmpdepfile3" + exit $stat + fi + + for tmpdepfile in "$tmpdepfile1" "$tmpdepfile2" "$tmpdepfile3" + do + test -f "$tmpdepfile" && break + done + # Same post-processing that is required for AIX mode. + aix_post_process_depfile + ;; + +msvc7) + if test "$libtool" = yes; then + showIncludes=-Wc,-showIncludes + else + showIncludes=-showIncludes + fi + "$@" $showIncludes > "$tmpdepfile" + stat=$? + grep -v '^Note: including file: ' "$tmpdepfile" + if test $stat -ne 0; then + rm -f "$tmpdepfile" + exit $stat + fi + rm -f "$depfile" + echo "$object : \\" > "$depfile" + # The first sed program below extracts the file names and escapes + # backslashes for cygpath. The second sed program outputs the file + # name when reading, but also accumulates all include files in the + # hold buffer in order to output them again at the end. This only + # works with sed implementations that can handle large buffers. + sed < "$tmpdepfile" -n ' +/^Note: including file: *\(.*\)/ { + s//\1/ + s/\\/\\\\/g + p +}' | $cygpath_u | sort -u | sed -n ' +s/ /\\ /g +s/\(.*\)/'"$tab"'\1 \\/p +s/.\(.*\) \\/\1:/ +H +$ { + s/.*/'"$tab"'/ + G + p +}' >> "$depfile" + echo >> "$depfile" # make sure the fragment doesn't end with a backslash + rm -f "$tmpdepfile" + ;; + +msvc7msys) + # This case exists only to let depend.m4 do its work. It works by + # looking at the text of this script. This case will never be run, + # since it is checked for above. + exit 1 + ;; + +#nosideeffect) + # This comment above is used by automake to tell side-effect + # dependency tracking mechanisms from slower ones. + +dashmstdout) + # Important note: in order to support this mode, a compiler *must* + # always write the preprocessed file to stdout, regardless of -o. + "$@" || exit $? + + # Remove the call to Libtool. + if test "$libtool" = yes; then + while test "X$1" != 'X--mode=compile'; do + shift + done + shift + fi + + # Remove '-o $object'. + IFS=" " + for arg + do + case $arg in + -o) + shift + ;; + $object) + shift + ;; + *) + set fnord "$@" "$arg" + shift # fnord + shift # $arg + ;; + esac + done + + test -z "$dashmflag" && dashmflag=-M + # Require at least two characters before searching for ':' + # in the target name. This is to cope with DOS-style filenames: + # a dependency such as 'c:/foo/bar' could be seen as target 'c' otherwise. + "$@" $dashmflag | + sed "s|^[$tab ]*[^:$tab ][^:][^:]*:[$tab ]*|$object: |" > "$tmpdepfile" + rm -f "$depfile" + cat < "$tmpdepfile" > "$depfile" + # Some versions of the HPUX 10.20 sed can't process this sed invocation + # correctly. Breaking it into two sed invocations is a workaround. + tr ' ' "$nl" < "$tmpdepfile" \ + | sed -e 's/^\\$//' -e '/^$/d' -e '/:$/d' \ + | sed -e 's/$/ :/' >> "$depfile" + rm -f "$tmpdepfile" + ;; + +dashXmstdout) + # This case only exists to satisfy depend.m4. It is never actually + # run, as this mode is specially recognized in the preamble. + exit 1 + ;; + +makedepend) + "$@" || exit $? + # Remove any Libtool call + if test "$libtool" = yes; then + while test "X$1" != 'X--mode=compile'; do + shift + done + shift + fi + # X makedepend + shift + cleared=no eat=no + for arg + do + case $cleared in + no) + set ""; shift + cleared=yes ;; + esac + if test $eat = yes; then + eat=no + continue + fi + case "$arg" in + -D*|-I*) + set fnord "$@" "$arg"; shift ;; + # Strip any option that makedepend may not understand. Remove + # the object too, otherwise makedepend will parse it as a source file. + -arch) + eat=yes ;; + -*|$object) + ;; + *) + set fnord "$@" "$arg"; shift ;; + esac + done + obj_suffix=`echo "$object" | sed 's/^.*\././'` + touch "$tmpdepfile" + ${MAKEDEPEND-makedepend} -o"$obj_suffix" -f"$tmpdepfile" "$@" + rm -f "$depfile" + # makedepend may prepend the VPATH from the source file name to the object. + # No need to regex-escape $object, excess matching of '.' is harmless. + sed "s|^.*\($object *:\)|\1|" "$tmpdepfile" > "$depfile" + # Some versions of the HPUX 10.20 sed can't process the last invocation + # correctly. Breaking it into two sed invocations is a workaround. + sed '1,2d' "$tmpdepfile" \ + | tr ' ' "$nl" \ + | sed -e 's/^\\$//' -e '/^$/d' -e '/:$/d' \ + | sed -e 's/$/ :/' >> "$depfile" + rm -f "$tmpdepfile" "$tmpdepfile".bak + ;; + +cpp) + # Important note: in order to support this mode, a compiler *must* + # always write the preprocessed file to stdout. + "$@" || exit $? + + # Remove the call to Libtool. + if test "$libtool" = yes; then + while test "X$1" != 'X--mode=compile'; do + shift + done + shift + fi + + # Remove '-o $object'. + IFS=" " + for arg + do + case $arg in + -o) + shift + ;; + $object) + shift + ;; + *) + set fnord "$@" "$arg" + shift # fnord + shift # $arg + ;; + esac + done + + "$@" -E \ + | sed -n -e '/^# [0-9][0-9]* "\([^"]*\)".*/ s:: \1 \\:p' \ + -e '/^#line [0-9][0-9]* "\([^"]*\)".*/ s:: \1 \\:p' \ + | sed '$ s: \\$::' > "$tmpdepfile" + rm -f "$depfile" + echo "$object : \\" > "$depfile" + cat < "$tmpdepfile" >> "$depfile" + sed < "$tmpdepfile" '/^$/d;s/^ //;s/ \\$//;s/$/ :/' >> "$depfile" + rm -f "$tmpdepfile" + ;; + +msvisualcpp) + # Important note: in order to support this mode, a compiler *must* + # always write the preprocessed file to stdout. + "$@" || exit $? + + # Remove the call to Libtool. + if test "$libtool" = yes; then + while test "X$1" != 'X--mode=compile'; do + shift + done + shift + fi + + IFS=" " + for arg + do + case "$arg" in + -o) + shift + ;; + $object) + shift + ;; + "-Gm"|"/Gm"|"-Gi"|"/Gi"|"-ZI"|"/ZI") + set fnord "$@" + shift + shift + ;; + *) + set fnord "$@" "$arg" + shift + shift + ;; + esac + done + "$@" -E 2>/dev/null | + sed -n '/^#line [0-9][0-9]* "\([^"]*\)"/ s::\1:p' | $cygpath_u | sort -u > "$tmpdepfile" + rm -f "$depfile" + echo "$object : \\" > "$depfile" + sed < "$tmpdepfile" -n -e 's% %\\ %g' -e '/^\(.*\)$/ s::'"$tab"'\1 \\:p' >> "$depfile" + echo "$tab" >> "$depfile" + sed < "$tmpdepfile" -n -e 's% %\\ %g' -e '/^\(.*\)$/ s::\1\::p' >> "$depfile" + rm -f "$tmpdepfile" + ;; + +msvcmsys) + # This case exists only to let depend.m4 do its work. It works by + # looking at the text of this script. This case will never be run, + # since it is checked for above. + exit 1 + ;; + +none) + exec "$@" + ;; + +*) + echo "Unknown depmode $depmode" 1>&2 + exit 1 + ;; +esac + +exit 0 + +# Local Variables: +# mode: shell-script +# sh-indentation: 2 +# eval: (add-hook 'write-file-hooks 'time-stamp) +# time-stamp-start: "scriptversion=" +# time-stamp-format: "%:y-%02m-%02d.%02H" +# time-stamp-time-zone: "UTC0" +# time-stamp-end: "; # UTC" +# End: diff --git a/conftools/missing b/conftools/missing new file mode 100755 index 0000000..c6e3795 --- /dev/null +++ b/conftools/missing @@ -0,0 +1,215 @@ +#! /bin/sh +# Common wrapper for a few potentially missing GNU programs. + +scriptversion=2016-01-11.22; # UTC + +# Copyright (C) 1996-2017 Free Software Foundation, Inc. +# Originally written by Fran,cois Pinard , 1996. + +# This program is free software; you can redistribute it and/or modify +# it under the terms of the GNU General Public License as published by +# the Free Software Foundation; either version 2, or (at your option) +# any later version. + +# This program is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +# GNU General Public License for more details. + +# You should have received a copy of the GNU General Public License +# along with this program. If not, see . + +# As a special exception to the GNU General Public License, if you +# distribute this file as part of a program that contains a +# configuration script generated by Autoconf, you may include it under +# the same distribution terms that you use for the rest of that program. + +if test $# -eq 0; then + echo 1>&2 "Try '$0 --help' for more information" + exit 1 +fi + +case $1 in + + --is-lightweight) + # Used by our autoconf macros to check whether the available missing + # script is modern enough. + exit 0 + ;; + + --run) + # Back-compat with the calling convention used by older automake. + shift + ;; + + -h|--h|--he|--hel|--help) + echo "\ +$0 [OPTION]... PROGRAM [ARGUMENT]... + +Run 'PROGRAM [ARGUMENT]...', returning a proper advice when this fails due +to PROGRAM being missing or too old. + +Options: + -h, --help display this help and exit + -v, --version output version information and exit + +Supported PROGRAM values: + aclocal autoconf autoheader autom4te automake makeinfo + bison yacc flex lex help2man + +Version suffixes to PROGRAM as well as the prefixes 'gnu-', 'gnu', and +'g' are ignored when checking the name. + +Send bug reports to ." + exit $? + ;; + + -v|--v|--ve|--ver|--vers|--versi|--versio|--version) + echo "missing $scriptversion (GNU Automake)" + exit $? + ;; + + -*) + echo 1>&2 "$0: unknown '$1' option" + echo 1>&2 "Try '$0 --help' for more information" + exit 1 + ;; + +esac + +# Run the given program, remember its exit status. +"$@"; st=$? + +# If it succeeded, we are done. +test $st -eq 0 && exit 0 + +# Also exit now if we it failed (or wasn't found), and '--version' was +# passed; such an option is passed most likely to detect whether the +# program is present and works. +case $2 in --version|--help) exit $st;; esac + +# Exit code 63 means version mismatch. This often happens when the user +# tries to use an ancient version of a tool on a file that requires a +# minimum version. +if test $st -eq 63; then + msg="probably too old" +elif test $st -eq 127; then + # Program was missing. + msg="missing on your system" +else + # Program was found and executed, but failed. Give up. + exit $st +fi + +perl_URL=http://www.perl.org/ +flex_URL=http://flex.sourceforge.net/ +gnu_software_URL=http://www.gnu.org/software + +program_details () +{ + case $1 in + aclocal|automake) + echo "The '$1' program is part of the GNU Automake package:" + echo "<$gnu_software_URL/automake>" + echo "It also requires GNU Autoconf, GNU m4 and Perl in order to run:" + echo "<$gnu_software_URL/autoconf>" + echo "<$gnu_software_URL/m4/>" + echo "<$perl_URL>" + ;; + autoconf|autom4te|autoheader) + echo "The '$1' program is part of the GNU Autoconf package:" + echo "<$gnu_software_URL/autoconf/>" + echo "It also requires GNU m4 and Perl in order to run:" + echo "<$gnu_software_URL/m4/>" + echo "<$perl_URL>" + ;; + esac +} + +give_advice () +{ + # Normalize program name to check for. + normalized_program=`echo "$1" | sed ' + s/^gnu-//; t + s/^gnu//; t + s/^g//; t'` + + printf '%s\n' "'$1' is $msg." + + configure_deps="'configure.ac' or m4 files included by 'configure.ac'" + case $normalized_program in + autoconf*) + echo "You should only need it if you modified 'configure.ac'," + echo "or m4 files included by it." + program_details 'autoconf' + ;; + autoheader*) + echo "You should only need it if you modified 'acconfig.h' or" + echo "$configure_deps." + program_details 'autoheader' + ;; + automake*) + echo "You should only need it if you modified 'Makefile.am' or" + echo "$configure_deps." + program_details 'automake' + ;; + aclocal*) + echo "You should only need it if you modified 'acinclude.m4' or" + echo "$configure_deps." + program_details 'aclocal' + ;; + autom4te*) + echo "You might have modified some maintainer files that require" + echo "the 'autom4te' program to be rebuilt." + program_details 'autom4te' + ;; + bison*|yacc*) + echo "You should only need it if you modified a '.y' file." + echo "You may want to install the GNU Bison package:" + echo "<$gnu_software_URL/bison/>" + ;; + lex*|flex*) + echo "You should only need it if you modified a '.l' file." + echo "You may want to install the Fast Lexical Analyzer package:" + echo "<$flex_URL>" + ;; + help2man*) + echo "You should only need it if you modified a dependency" \ + "of a man page." + echo "You may want to install the GNU Help2man package:" + echo "<$gnu_software_URL/help2man/>" + ;; + makeinfo*) + echo "You should only need it if you modified a '.texi' file, or" + echo "any other file indirectly affecting the aspect of the manual." + echo "You might want to install the Texinfo package:" + echo "<$gnu_software_URL/texinfo/>" + echo "The spurious makeinfo call might also be the consequence of" + echo "using a buggy 'make' (AIX, DU, IRIX), in which case you might" + echo "want to install GNU make:" + echo "<$gnu_software_URL/make/>" + ;; + *) + echo "You might have modified some files without having the proper" + echo "tools for further handling them. Check the 'README' file, it" + echo "often tells you about the needed prerequisites for installing" + echo "this package. You may also peek at any GNU archive site, in" + echo "case some other package contains this missing '$1' program." + ;; + esac +} + +give_advice "$1" | sed -e '1s/^/WARNING: /' \ + -e '2,$s/^/ /' >&2 + +# Propagate the correct exit status (expected to be 127 for a program +# not found, 63 for a program that failed due to version mismatch). +exit $st + +# Local variables: +# eval: (add-hook 'write-file-hooks 'time-stamp) +# time-stamp-start: "scriptversion=" +# time-stamp-format: "%:y-%02m-%02d.%02H" +# time-stamp-time-zone: "UTC0" +# time-stamp-end: "; # UTC" +# End: diff --git a/conftools/mkinstalldirs b/conftools/mkinstalldirs deleted file mode 100755 index 4f58503..0000000 --- a/conftools/mkinstalldirs +++ /dev/null @@ -1,40 +0,0 @@ -#! /bin/sh -# mkinstalldirs --- make directory hierarchy -# Author: Noah Friedman -# Created: 1993-05-16 -# Public domain - -# $Id: mkinstalldirs,v 1.13 1999/01/05 03:18:55 bje Exp $ - -errstatus=0 - -for file -do - set fnord `echo ":$file" | sed -ne 's/^:\//#/;s/^://;s/\// /g;s/^#/\//;p'` - shift - - pathcomp= - for d - do - pathcomp="$pathcomp$d" - case "$pathcomp" in - -* ) pathcomp=./$pathcomp ;; - esac - - if test ! -d "$pathcomp"; then - echo "mkdir $pathcomp" - - mkdir "$pathcomp" || lasterr=$? - - if test ! -d "$pathcomp"; then - errstatus=$lasterr - fi - fi - - pathcomp="$pathcomp/" - done -done - -exit $errstatus - -# mkinstalldirs ends here diff --git a/conftools/test-driver b/conftools/test-driver new file mode 100755 index 0000000..0218a01 --- /dev/null +++ b/conftools/test-driver @@ -0,0 +1,148 @@ +#! /bin/sh +# test-driver - basic testsuite driver script. + +scriptversion=2016-01-11.22; # UTC + +# Copyright (C) 2011-2017 Free Software Foundation, Inc. +# +# This program is free software; you can redistribute it and/or modify +# it under the terms of the GNU General Public License as published by +# the Free Software Foundation; either version 2, or (at your option) +# any later version. +# +# This program is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +# GNU General Public License for more details. +# +# You should have received a copy of the GNU General Public License +# along with this program. If not, see . + +# As a special exception to the GNU General Public License, if you +# distribute this file as part of a program that contains a +# configuration script generated by Autoconf, you may include it under +# the same distribution terms that you use for the rest of that program. + +# This file is maintained in Automake, please report +# bugs to or send patches to +# . + +# Make unconditional expansion of undefined variables an error. This +# helps a lot in preventing typo-related bugs. +set -u + +usage_error () +{ + echo "$0: $*" >&2 + print_usage >&2 + exit 2 +} + +print_usage () +{ + cat <$log_file 2>&1 +estatus=$? + +if test $enable_hard_errors = no && test $estatus -eq 99; then + tweaked_estatus=1 +else + tweaked_estatus=$estatus +fi + +case $tweaked_estatus:$expect_failure in + 0:yes) col=$red res=XPASS recheck=yes gcopy=yes;; + 0:*) col=$grn res=PASS recheck=no gcopy=no;; + 77:*) col=$blu res=SKIP recheck=no gcopy=yes;; + 99:*) col=$mgn res=ERROR recheck=yes gcopy=yes;; + *:yes) col=$lgn res=XFAIL recheck=no gcopy=yes;; + *:*) col=$red res=FAIL recheck=yes gcopy=yes;; +esac + +# Report the test outcome and exit status in the logs, so that one can +# know whether the test passed or failed simply by looking at the '.log' +# file, without the need of also peaking into the corresponding '.trs' +# file (automake bug#11814). +echo "$res $test_name (exit status: $estatus)" >>$log_file + +# Report outcome to console. +echo "${col}${res}${std}: $test_name" + +# Register the test result, and other relevant metadata. +echo ":test-result: $res" > $trs_file +echo ":global-test-result: $res" >> $trs_file +echo ":recheck: $recheck" >> $trs_file +echo ":copy-in-global-log: $gcopy" >> $trs_file + +# Local Variables: +# mode: shell-script +# sh-indentation: 2 +# eval: (add-hook 'write-file-hooks 'time-stamp) +# time-stamp-start: "scriptversion=" +# time-stamp-format: "%:y-%02m-%02d.%02H" +# time-stamp-time-zone: "UTC0" +# time-stamp-end: "; # UTC" +# End: diff --git a/doc/Makefile.am b/doc/Makefile.am new file mode 100644 index 0000000..8bb74e3 --- /dev/null +++ b/doc/Makefile.am @@ -0,0 +1,50 @@ +# +# __ __ _ +# ___\ \/ /_ __ __ _| |_ +# / _ \\ /| '_ \ / _` | __| +# | __// \| |_) | (_| | |_ +# \___/_/\_\ .__/ \__,_|\__| +# |_| XML parser +# +# Copyright (c) 2017 Expat development team +# Licensed under the MIT license: +# +# Permission is hereby granted, free of charge, to any person obtaining +# a copy of this software and associated documentation files (the +# "Software"), to deal in the Software without restriction, including +# without limitation the rights to use, copy, modify, merge, publish, +# distribute, sublicense, and/or sell copies of the Software, and to permit +# persons to whom the Software is furnished to do so, subject to the +# following conditions: +# +# The above copyright notice and this permission notice shall be included +# in all copies or substantial portions of the Software. +# +# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, +# EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF +# MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN +# NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, +# DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR +# OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE +# USE OR OTHER DEALINGS IN THE SOFTWARE. + +dist_man_MANS = xmlwf.1 + +xmlwf.1: doc.mk xmlwf.xml + $(MAKE) -f $(srcdir)/doc.mk xmlwf.1 srcdir=$(srcdir) + +# https://www.gnu.org/software/automake/manual/automake.html#What-Gets-Cleaned +.PHONY: clean-local +clean-local: clean-local-check + +.PHONY: clean-local-check +clean-local-check: + $(MAKE) -f $(srcdir)/doc.mk clean + +EXTRA_DIST = \ + doc.mk \ + expat.png \ + reference.html \ + style.css \ + valid-xhtml10.png \ + xmlwf.xml diff --git a/doc/Makefile.in b/doc/Makefile.in new file mode 100644 index 0000000..401ee6c --- /dev/null +++ b/doc/Makefile.in @@ -0,0 +1,575 @@ +# Makefile.in generated by automake 1.15.1 from Makefile.am. +# @configure_input@ + +# Copyright (C) 1994-2017 Free Software Foundation, Inc. + +# This Makefile.in is free software; the Free Software Foundation +# gives unlimited permission to copy and/or distribute it, +# with or without modifications, as long as this notice is preserved. + +# This program is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY, to the extent permitted by law; without +# even the implied warranty of MERCHANTABILITY or FITNESS FOR A +# PARTICULAR PURPOSE. + +@SET_MAKE@ + +# +# __ __ _ +# ___\ \/ /_ __ __ _| |_ +# / _ \\ /| '_ \ / _` | __| +# | __// \| |_) | (_| | |_ +# \___/_/\_\ .__/ \__,_|\__| +# |_| XML parser +# +# Copyright (c) 2017 Expat development team +# Licensed under the MIT license: +# +# Permission is hereby granted, free of charge, to any person obtaining +# a copy of this software and associated documentation files (the +# "Software"), to deal in the Software without restriction, including +# without limitation the rights to use, copy, modify, merge, publish, +# distribute, sublicense, and/or sell copies of the Software, and to permit +# persons to whom the Software is furnished to do so, subject to the +# following conditions: +# +# The above copyright notice and this permission notice shall be included +# in all copies or substantial portions of the Software. +# +# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, +# EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF +# MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN +# NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, +# DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR +# OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE +# USE OR OTHER DEALINGS IN THE SOFTWARE. +VPATH = @srcdir@ +am__is_gnu_make = { \ + if test -z '$(MAKELEVEL)'; then \ + false; \ + elif test -n '$(MAKE_HOST)'; then \ + true; \ + elif test -n '$(MAKE_VERSION)' && test -n '$(CURDIR)'; then \ + true; \ + else \ + false; \ + fi; \ +} +am__make_running_with_option = \ + case $${target_option-} in \ + ?) ;; \ + *) echo "am__make_running_with_option: internal error: invalid" \ + "target option '$${target_option-}' specified" >&2; \ + exit 1;; \ + esac; \ + has_opt=no; \ + sane_makeflags=$$MAKEFLAGS; \ + if $(am__is_gnu_make); then \ + sane_makeflags=$$MFLAGS; \ + else \ + case $$MAKEFLAGS in \ + *\\[\ \ ]*) \ + bs=\\; \ + sane_makeflags=`printf '%s\n' "$$MAKEFLAGS" \ + | sed "s/$$bs$$bs[$$bs $$bs ]*//g"`;; \ + esac; \ + fi; \ + skip_next=no; \ + strip_trailopt () \ + { \ + flg=`printf '%s\n' "$$flg" | sed "s/$$1.*$$//"`; \ + }; \ + for flg in $$sane_makeflags; do \ + test $$skip_next = yes && { skip_next=no; continue; }; \ + case $$flg in \ + *=*|--*) continue;; \ + -*I) strip_trailopt 'I'; skip_next=yes;; \ + -*I?*) strip_trailopt 'I';; \ + -*O) strip_trailopt 'O'; skip_next=yes;; \ + -*O?*) strip_trailopt 'O';; \ + -*l) strip_trailopt 'l'; skip_next=yes;; \ + -*l?*) strip_trailopt 'l';; \ + -[dEDm]) skip_next=yes;; \ + -[JT]) skip_next=yes;; \ + esac; \ + case $$flg in \ + *$$target_option*) has_opt=yes; break;; \ + esac; \ + done; \ + test $$has_opt = yes +am__make_dryrun = (target_option=n; $(am__make_running_with_option)) +am__make_keepgoing = (target_option=k; $(am__make_running_with_option)) +pkgdatadir = $(datadir)/@PACKAGE@ +pkgincludedir = $(includedir)/@PACKAGE@ +pkglibdir = $(libdir)/@PACKAGE@ +pkglibexecdir = $(libexecdir)/@PACKAGE@ +am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd +install_sh_DATA = $(install_sh) -c -m 644 +install_sh_PROGRAM = $(install_sh) -c +install_sh_SCRIPT = $(install_sh) -c +INSTALL_HEADER = $(INSTALL_DATA) +transform = $(program_transform_name) +NORMAL_INSTALL = : +PRE_INSTALL = : +POST_INSTALL = : +NORMAL_UNINSTALL = : +PRE_UNINSTALL = : +POST_UNINSTALL = : +build_triplet = @build@ +host_triplet = @host@ +subdir = doc +ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 +am__aclocal_m4_deps = $(top_srcdir)/m4/libtool.m4 \ + $(top_srcdir)/m4/ltoptions.m4 $(top_srcdir)/m4/ltsugar.m4 \ + $(top_srcdir)/m4/ltversion.m4 $(top_srcdir)/m4/lt~obsolete.m4 \ + $(top_srcdir)/conftools/ac_c_bigendian_cross.m4 \ + $(top_srcdir)/configure.ac +am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \ + $(ACLOCAL_M4) +DIST_COMMON = $(srcdir)/Makefile.am $(am__DIST_COMMON) +mkinstalldirs = $(install_sh) -d +CONFIG_HEADER = $(top_builddir)/expat_config.h +CONFIG_CLEAN_FILES = +CONFIG_CLEAN_VPATH_FILES = +AM_V_P = $(am__v_P_@AM_V@) +am__v_P_ = $(am__v_P_@AM_DEFAULT_V@) +am__v_P_0 = false +am__v_P_1 = : +AM_V_GEN = $(am__v_GEN_@AM_V@) +am__v_GEN_ = $(am__v_GEN_@AM_DEFAULT_V@) +am__v_GEN_0 = @echo " GEN " $@; +am__v_GEN_1 = +AM_V_at = $(am__v_at_@AM_V@) +am__v_at_ = $(am__v_at_@AM_DEFAULT_V@) +am__v_at_0 = @ +am__v_at_1 = +SOURCES = +DIST_SOURCES = +am__can_run_installinfo = \ + case $$AM_UPDATE_INFO_DIR in \ + n|no|NO) false;; \ + *) (install-info --version) >/dev/null 2>&1;; \ + esac +am__vpath_adj_setup = srcdirstrip=`echo "$(srcdir)" | sed 's|.|.|g'`; +am__vpath_adj = case $$p in \ + $(srcdir)/*) f=`echo "$$p" | sed "s|^$$srcdirstrip/||"`;; \ + *) f=$$p;; \ + esac; +am__strip_dir = f=`echo $$p | sed -e 's|^.*/||'`; +am__install_max = 40 +am__nobase_strip_setup = \ + srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*|]/\\\\&/g'` +am__nobase_strip = \ + for p in $$list; do echo "$$p"; done | sed -e "s|$$srcdirstrip/||" +am__nobase_list = $(am__nobase_strip_setup); \ + for p in $$list; do echo "$$p $$p"; done | \ + sed "s| $$srcdirstrip/| |;"' / .*\//!s/ .*/ ./; s,\( .*\)/[^/]*$$,\1,' | \ + $(AWK) 'BEGIN { files["."] = "" } { files[$$2] = files[$$2] " " $$1; \ + if (++n[$$2] == $(am__install_max)) \ + { print $$2, files[$$2]; n[$$2] = 0; files[$$2] = "" } } \ + END { for (dir in files) print dir, files[dir] }' +am__base_list = \ + sed '$$!N;$$!N;$$!N;$$!N;$$!N;$$!N;$$!N;s/\n/ /g' | \ + sed '$$!N;$$!N;$$!N;$$!N;s/\n/ /g' +am__uninstall_files_from_dir = { \ + test -z "$$files" \ + || { test ! -d "$$dir" && test ! -f "$$dir" && test ! -r "$$dir"; } \ + || { echo " ( cd '$$dir' && rm -f" $$files ")"; \ + $(am__cd) "$$dir" && rm -f $$files; }; \ + } +man1dir = $(mandir)/man1 +am__installdirs = "$(DESTDIR)$(man1dir)" +NROFF = nroff +MANS = $(dist_man_MANS) +am__tagged_files = $(HEADERS) $(SOURCES) $(TAGS_FILES) $(LISP) +am__DIST_COMMON = $(dist_man_MANS) $(srcdir)/Makefile.in +DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST) +ACLOCAL = @ACLOCAL@ +AMTAR = @AMTAR@ +AM_DEFAULT_VERBOSITY = @AM_DEFAULT_VERBOSITY@ +AR = @AR@ +AS = @AS@ +AUTOCONF = @AUTOCONF@ +AUTOHEADER = @AUTOHEADER@ +AUTOMAKE = @AUTOMAKE@ +AWK = @AWK@ +CC = @CC@ +CCDEPMODE = @CCDEPMODE@ +CFLAGS = @CFLAGS@ +CPP = @CPP@ +CPPFLAGS = @CPPFLAGS@ +CXX = @CXX@ +CXXCPP = @CXXCPP@ +CXXDEPMODE = @CXXDEPMODE@ +CXXFLAGS = @CXXFLAGS@ +CYGPATH_W = @CYGPATH_W@ +DEFS = @DEFS@ +DEPDIR = @DEPDIR@ +DLLTOOL = @DLLTOOL@ +DSYMUTIL = @DSYMUTIL@ +DUMPBIN = @DUMPBIN@ +ECHO_C = @ECHO_C@ +ECHO_N = @ECHO_N@ +ECHO_T = @ECHO_T@ +EGREP = @EGREP@ +EXEEXT = @EXEEXT@ +FGREP = @FGREP@ +FILEMAP = @FILEMAP@ +GREP = @GREP@ +INSTALL = @INSTALL@ +INSTALL_DATA = @INSTALL_DATA@ +INSTALL_PROGRAM = @INSTALL_PROGRAM@ +INSTALL_SCRIPT = @INSTALL_SCRIPT@ +INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ +LD = @LD@ +LDFLAGS = @LDFLAGS@ +LIBAGE = @LIBAGE@ +LIBCURRENT = @LIBCURRENT@ +LIBOBJS = @LIBOBJS@ +LIBREVISION = @LIBREVISION@ +LIBS = @LIBS@ +LIBTOOL = @LIBTOOL@ +LIPO = @LIPO@ +LN_S = @LN_S@ +LTLIBOBJS = @LTLIBOBJS@ +LT_SYS_LIBRARY_PATH = @LT_SYS_LIBRARY_PATH@ +MAKEINFO = @MAKEINFO@ +MANIFEST_TOOL = @MANIFEST_TOOL@ +MKDIR_P = @MKDIR_P@ +NM = @NM@ +NMEDIT = @NMEDIT@ +OBJDUMP = @OBJDUMP@ +OBJEXT = @OBJEXT@ +OTOOL = @OTOOL@ +OTOOL64 = @OTOOL64@ +PACKAGE = @PACKAGE@ +PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@ +PACKAGE_NAME = @PACKAGE_NAME@ +PACKAGE_STRING = @PACKAGE_STRING@ +PACKAGE_TARNAME = @PACKAGE_TARNAME@ +PACKAGE_URL = @PACKAGE_URL@ +PACKAGE_VERSION = @PACKAGE_VERSION@ +PATH_SEPARATOR = @PATH_SEPARATOR@ +RANLIB = @RANLIB@ +SED = @SED@ +SET_MAKE = @SET_MAKE@ +SHELL = @SHELL@ +STRIP = @STRIP@ +VERSION = @VERSION@ +abs_builddir = @abs_builddir@ +abs_srcdir = @abs_srcdir@ +abs_top_builddir = @abs_top_builddir@ +abs_top_srcdir = @abs_top_srcdir@ +ac_ct_AR = @ac_ct_AR@ +ac_ct_CC = @ac_ct_CC@ +ac_ct_CXX = @ac_ct_CXX@ +ac_ct_DUMPBIN = @ac_ct_DUMPBIN@ +am__include = @am__include@ +am__leading_dot = @am__leading_dot@ +am__quote = @am__quote@ +am__tar = @am__tar@ +am__untar = @am__untar@ +bindir = @bindir@ +build = @build@ +build_alias = @build_alias@ +build_cpu = @build_cpu@ +build_os = @build_os@ +build_vendor = @build_vendor@ +builddir = @builddir@ +datadir = @datadir@ +datarootdir = @datarootdir@ +docdir = @docdir@ +dvidir = @dvidir@ +exec_prefix = @exec_prefix@ +host = @host@ +host_alias = @host_alias@ +host_cpu = @host_cpu@ +host_os = @host_os@ +host_vendor = @host_vendor@ +htmldir = @htmldir@ +includedir = @includedir@ +infodir = @infodir@ +install_sh = @install_sh@ +libdir = @libdir@ +libexecdir = @libexecdir@ +localedir = @localedir@ +localstatedir = @localstatedir@ +mandir = @mandir@ +mkdir_p = @mkdir_p@ +oldincludedir = @oldincludedir@ +pdfdir = @pdfdir@ +prefix = @prefix@ +program_transform_name = @program_transform_name@ +psdir = @psdir@ +sbindir = @sbindir@ +sharedstatedir = @sharedstatedir@ +srcdir = @srcdir@ +sysconfdir = @sysconfdir@ +target_alias = @target_alias@ +top_build_prefix = @top_build_prefix@ +top_builddir = @top_builddir@ +top_srcdir = @top_srcdir@ +dist_man_MANS = xmlwf.1 +EXTRA_DIST = \ + doc.mk \ + expat.png \ + reference.html \ + style.css \ + valid-xhtml10.png \ + xmlwf.xml + +all: all-am + +.SUFFIXES: +$(srcdir)/Makefile.in: $(srcdir)/Makefile.am $(am__configure_deps) + @for dep in $?; do \ + case '$(am__configure_deps)' in \ + *$$dep*) \ + ( cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh ) \ + && { if test -f $@; then exit 0; else break; fi; }; \ + exit 1;; \ + esac; \ + done; \ + echo ' cd $(top_srcdir) && $(AUTOMAKE) --gnu doc/Makefile'; \ + $(am__cd) $(top_srcdir) && \ + $(AUTOMAKE) --gnu doc/Makefile +Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status + @case '$?' in \ + *config.status*) \ + cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh;; \ + *) \ + echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe)'; \ + cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe);; \ + esac; + +$(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES) + cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh + +$(top_srcdir)/configure: $(am__configure_deps) + cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh +$(ACLOCAL_M4): $(am__aclocal_m4_deps) + cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh +$(am__aclocal_m4_deps): + +mostlyclean-libtool: + -rm -f *.lo + +clean-libtool: + -rm -rf .libs _libs +install-man1: $(dist_man_MANS) + @$(NORMAL_INSTALL) + @list1=''; \ + list2='$(dist_man_MANS)'; \ + test -n "$(man1dir)" \ + && test -n "`echo $$list1$$list2`" \ + || exit 0; \ + echo " $(MKDIR_P) '$(DESTDIR)$(man1dir)'"; \ + $(MKDIR_P) "$(DESTDIR)$(man1dir)" || exit 1; \ + { for i in $$list1; do echo "$$i"; done; \ + if test -n "$$list2"; then \ + for i in $$list2; do echo "$$i"; done \ + | sed -n '/\.1[a-z]*$$/p'; \ + fi; \ + } | while read p; do \ + if test -f $$p; then d=; else d="$(srcdir)/"; fi; \ + echo "$$d$$p"; echo "$$p"; \ + done | \ + sed -e 'n;s,.*/,,;p;h;s,.*\.,,;s,^[^1][0-9a-z]*$$,1,;x' \ + -e 's,\.[0-9a-z]*$$,,;$(transform);G;s,\n,.,' | \ + sed 'N;N;s,\n, ,g' | { \ + list=; while read file base inst; do \ + if test "$$base" = "$$inst"; then list="$$list $$file"; else \ + echo " $(INSTALL_DATA) '$$file' '$(DESTDIR)$(man1dir)/$$inst'"; \ + $(INSTALL_DATA) "$$file" "$(DESTDIR)$(man1dir)/$$inst" || exit $$?; \ + fi; \ + done; \ + for i in $$list; do echo "$$i"; done | $(am__base_list) | \ + while read files; do \ + test -z "$$files" || { \ + echo " $(INSTALL_DATA) $$files '$(DESTDIR)$(man1dir)'"; \ + $(INSTALL_DATA) $$files "$(DESTDIR)$(man1dir)" || exit $$?; }; \ + done; } + +uninstall-man1: + @$(NORMAL_UNINSTALL) + @list=''; test -n "$(man1dir)" || exit 0; \ + files=`{ for i in $$list; do echo "$$i"; done; \ + l2='$(dist_man_MANS)'; for i in $$l2; do echo "$$i"; done | \ + sed -n '/\.1[a-z]*$$/p'; \ + } | sed -e 's,.*/,,;h;s,.*\.,,;s,^[^1][0-9a-z]*$$,1,;x' \ + -e 's,\.[0-9a-z]*$$,,;$(transform);G;s,\n,.,'`; \ + dir='$(DESTDIR)$(man1dir)'; $(am__uninstall_files_from_dir) +tags TAGS: + +ctags CTAGS: + +cscope cscopelist: + + +distdir: $(DISTFILES) + @srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ + topsrcdirstrip=`echo "$(top_srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ + list='$(DISTFILES)'; \ + dist_files=`for file in $$list; do echo $$file; done | \ + sed -e "s|^$$srcdirstrip/||;t" \ + -e "s|^$$topsrcdirstrip/|$(top_builddir)/|;t"`; \ + case $$dist_files in \ + */*) $(MKDIR_P) `echo "$$dist_files" | \ + sed '/\//!d;s|^|$(distdir)/|;s,/[^/]*$$,,' | \ + sort -u` ;; \ + esac; \ + for file in $$dist_files; do \ + if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \ + if test -d $$d/$$file; then \ + dir=`echo "/$$file" | sed -e 's,/[^/]*$$,,'`; \ + if test -d "$(distdir)/$$file"; then \ + find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ + fi; \ + if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \ + cp -fpR $(srcdir)/$$file "$(distdir)$$dir" || exit 1; \ + find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ + fi; \ + cp -fpR $$d/$$file "$(distdir)$$dir" || exit 1; \ + else \ + test -f "$(distdir)/$$file" \ + || cp -p $$d/$$file "$(distdir)/$$file" \ + || exit 1; \ + fi; \ + done +check-am: all-am +check: check-am +all-am: Makefile $(MANS) +installdirs: + for dir in "$(DESTDIR)$(man1dir)"; do \ + test -z "$$dir" || $(MKDIR_P) "$$dir"; \ + done +install: install-am +install-exec: install-exec-am +install-data: install-data-am +uninstall: uninstall-am + +install-am: all-am + @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am + +installcheck: installcheck-am +install-strip: + if test -z '$(STRIP)'; then \ + $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ + install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ + install; \ + else \ + $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ + install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ + "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'" install; \ + fi +mostlyclean-generic: + +clean-generic: + +distclean-generic: + -test -z "$(CONFIG_CLEAN_FILES)" || rm -f $(CONFIG_CLEAN_FILES) + -test . = "$(srcdir)" || test -z "$(CONFIG_CLEAN_VPATH_FILES)" || rm -f $(CONFIG_CLEAN_VPATH_FILES) + +maintainer-clean-generic: + @echo "This command is intended for maintainers to use" + @echo "it deletes files that may require special tools to rebuild." +clean: clean-am + +clean-am: clean-generic clean-libtool clean-local mostlyclean-am + +distclean: distclean-am + -rm -f Makefile +distclean-am: clean-am distclean-generic + +dvi: dvi-am + +dvi-am: + +html: html-am + +html-am: + +info: info-am + +info-am: + +install-data-am: install-man + +install-dvi: install-dvi-am + +install-dvi-am: + +install-exec-am: + +install-html: install-html-am + +install-html-am: + +install-info: install-info-am + +install-info-am: + +install-man: install-man1 + +install-pdf: install-pdf-am + +install-pdf-am: + +install-ps: install-ps-am + +install-ps-am: + +installcheck-am: + +maintainer-clean: maintainer-clean-am + -rm -f Makefile +maintainer-clean-am: distclean-am maintainer-clean-generic + +mostlyclean: mostlyclean-am + +mostlyclean-am: mostlyclean-generic mostlyclean-libtool + +pdf: pdf-am + +pdf-am: + +ps: ps-am + +ps-am: + +uninstall-am: uninstall-man + +uninstall-man: uninstall-man1 + +.MAKE: install-am install-strip + +.PHONY: all all-am check check-am clean clean-generic clean-libtool \ + clean-local cscopelist-am ctags-am distclean distclean-generic \ + distclean-libtool distdir dvi dvi-am html html-am info info-am \ + install install-am install-data install-data-am install-dvi \ + install-dvi-am install-exec install-exec-am install-html \ + install-html-am install-info install-info-am install-man \ + install-man1 install-pdf install-pdf-am install-ps \ + install-ps-am install-strip installcheck installcheck-am \ + installdirs maintainer-clean maintainer-clean-generic \ + mostlyclean mostlyclean-generic mostlyclean-libtool pdf pdf-am \ + ps ps-am tags-am uninstall uninstall-am uninstall-man \ + uninstall-man1 + +.PRECIOUS: Makefile + + +xmlwf.1: doc.mk xmlwf.xml + $(MAKE) -f $(srcdir)/doc.mk xmlwf.1 srcdir=$(srcdir) + +# https://www.gnu.org/software/automake/manual/automake.html#What-Gets-Cleaned +.PHONY: clean-local +clean-local: clean-local-check + +.PHONY: clean-local-check +clean-local-check: + $(MAKE) -f $(srcdir)/doc.mk clean + +# Tell versions [3.59,3.63) of GNU make to not export all variables. +# Otherwise a system limit (for SysV at least) may be exceeded. +.NOEXPORT: diff --git a/doc/doc.mk b/doc/doc.mk new file mode 100644 index 0000000..828bc7f --- /dev/null +++ b/doc/doc.mk @@ -0,0 +1,20 @@ +# Copyright (C) Sebastian Pipping +# Licensed under MIT/X License + +DOCBOOK_TO_MAN = docbook2x-man + +srcdir = . + + +.PHONY: all +all: xmlwf.1 + +xmlwf.1: XMLWF.1 + cp $< $@ + +XMLWF.1: $(srcdir)/xmlwf.xml + $(DOCBOOK_TO_MAN) $(srcdir)/xmlwf.xml + +.PHONY: clean +clean: + $(RM) xmlwf.1 XMLWF.1 diff --git a/doc/reference.html b/doc/reference.html index 350b9b6..efc19f4 100644 --- a/doc/reference.html +++ b/doc/reference.html @@ -31,7 +31,7 @@ the underlying XML parser for the open source Mozilla project, Perl's other open-source XML parsers.

This library is the creation of James Clark, who's also given us -groff (an nroff look-alike), Jade (an implemention of ISO's DSSSL +groff (an nroff look-alike), Jade (an implementation of ISO's DSSSL stylesheet language for SGML), XP (a Java XML parser package), XT (a Java XSL engine). James was also the technical lead on the XML Working Group at W3C that produced the XML specification.

@@ -360,7 +360,7 @@ off by default.
The number of input bytes of markup context which the parser will ensure are available for reporting via XML_GetInputContext. This is -normally set to 1024, and must be set to a positive interger. If this +normally set to 1024, and must be set to a positive integer. If this is not defined, the input context will not be available and XML_GetInputContext will always report NULL. Without this, Expat has a smaller memory @@ -373,7 +373,7 @@ the right MSVC magic annotations correct. This is ignored on other platforms.
XML_ATTR_INFO
-
If defined, makes the the additional function If defined, makes the additional function XML_GetAttributeInfo available for reporting attribute byte offsets.
@@ -739,7 +739,7 @@ arguments:

XML_PARAM_ENTITY_PARSING_NEVER
Don't parse parameter entities or the external subset
XML_PARAM_ENTITY_PARSING_UNLESS_STANDALONE
-
Parse parameter entites and the external subset unless +
Parse parameter entities and the external subset unless standalone was set to "yes" in the XML declaration.
XML_PARAM_ENTITY_PARSING_ALWAYS
Always parse parameter entities and the external subset
@@ -767,7 +767,7 @@ include

  • Stopping parsing completely (simply free or reset the parser instead of resuming in the outer parsing loop). This can be useful - if a application-domain error is found in the XML being parsed or if + if an application-domain error is found in the XML being parsed or if the result of the parse is determined not to be useful after all.
  • @@ -1564,7 +1564,7 @@ at most once per parsed (external) entity. The optional application data pointer encodingHandlerData will be passed back to the handler.

    -

    The map array contains information for every possible possible leading +

    The map array contains information for every possible leading byte in a byte sequence. If the corresponding value is >= 0, then it's a single byte sequence and the byte encodes that Unicode value. If the value is -1, then that byte is invalid as the initial byte in a sequence. @@ -1999,7 +1999,7 @@ return NULL.

    Miscellaneous functions

    The functions in this section either obtain state information from -the parser or can be used to dynamicly set parser options.

    +the parser or can be used to dynamically set parser options.

     void XMLCALL
    diff --git a/examples/Makefile.am b/examples/Makefile.am
    new file mode 100644
    index 0000000..99edf21
    --- /dev/null
    +++ b/examples/Makefile.am
    @@ -0,0 +1,39 @@
    +#
    +#                          __  __            _
    +#                       ___\ \/ /_ __   __ _| |_
    +#                      / _ \\  /| '_ \ / _` | __|
    +#                     |  __//  \| |_) | (_| | |_
    +#                      \___/_/\_\ .__/ \__,_|\__|
    +#                               |_| XML parser
    +#
    +# Copyright (c) 2017 Expat development team
    +# Licensed under the MIT license:
    +#
    +# Permission is  hereby granted,  free of charge,  to any  person obtaining
    +# a  copy  of  this  software   and  associated  documentation  files  (the
    +# "Software"),  to  deal in  the  Software  without restriction,  including
    +# without  limitation the  rights  to use,  copy,  modify, merge,  publish,
    +# distribute, sublicense, and/or sell copies of the Software, and to permit
    +# persons  to whom  the Software  is  furnished to  do so,  subject to  the
    +# following conditions:
    +#
    +# The above copyright  notice and this permission notice  shall be included
    +# in all copies or substantial portions of the Software.
    +#
    +# THE  SOFTWARE  IS  PROVIDED  "AS  IS",  WITHOUT  WARRANTY  OF  ANY  KIND,
    +# EXPRESS  OR IMPLIED,  INCLUDING  BUT  NOT LIMITED  TO  THE WARRANTIES  OF
    +# MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN
    +# NO EVENT SHALL THE AUTHORS OR  COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
    +# DAMAGES OR  OTHER LIABILITY, WHETHER  IN AN  ACTION OF CONTRACT,  TORT OR
    +# OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE
    +# USE OR OTHER DEALINGS IN THE SOFTWARE.
    +
    +AM_CPPFLAGS = -I$(srcdir)/../lib
    +
    +noinst_PROGRAMS = elements outline
    +
    +elements_SOURCES = elements.c
    +elements_LDADD = ../lib/libexpat.la
    +
    +outline_SOURCES = outline.c
    +outline_LDADD = ../lib/libexpat.la
    diff --git a/examples/Makefile.in b/examples/Makefile.in
    new file mode 100644
    index 0000000..4aa665e
    --- /dev/null
    +++ b/examples/Makefile.in
    @@ -0,0 +1,635 @@
    +# Makefile.in generated by automake 1.15.1 from Makefile.am.
    +# @configure_input@
    +
    +# Copyright (C) 1994-2017 Free Software Foundation, Inc.
    +
    +# This Makefile.in is free software; the Free Software Foundation
    +# gives unlimited permission to copy and/or distribute it,
    +# with or without modifications, as long as this notice is preserved.
    +
    +# This program is distributed in the hope that it will be useful,
    +# but WITHOUT ANY WARRANTY, to the extent permitted by law; without
    +# even the implied warranty of MERCHANTABILITY or FITNESS FOR A
    +# PARTICULAR PURPOSE.
    +
    +@SET_MAKE@
    +
    +#
    +#                          __  __            _
    +#                       ___\ \/ /_ __   __ _| |_
    +#                      / _ \\  /| '_ \ / _` | __|
    +#                     |  __//  \| |_) | (_| | |_
    +#                      \___/_/\_\ .__/ \__,_|\__|
    +#                               |_| XML parser
    +#
    +# Copyright (c) 2017 Expat development team
    +# Licensed under the MIT license:
    +#
    +# Permission is  hereby granted,  free of charge,  to any  person obtaining
    +# a  copy  of  this  software   and  associated  documentation  files  (the
    +# "Software"),  to  deal in  the  Software  without restriction,  including
    +# without  limitation the  rights  to use,  copy,  modify, merge,  publish,
    +# distribute, sublicense, and/or sell copies of the Software, and to permit
    +# persons  to whom  the Software  is  furnished to  do so,  subject to  the
    +# following conditions:
    +#
    +# The above copyright  notice and this permission notice  shall be included
    +# in all copies or substantial portions of the Software.
    +#
    +# THE  SOFTWARE  IS  PROVIDED  "AS  IS",  WITHOUT  WARRANTY  OF  ANY  KIND,
    +# EXPRESS  OR IMPLIED,  INCLUDING  BUT  NOT LIMITED  TO  THE WARRANTIES  OF
    +# MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN
    +# NO EVENT SHALL THE AUTHORS OR  COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
    +# DAMAGES OR  OTHER LIABILITY, WHETHER  IN AN  ACTION OF CONTRACT,  TORT OR
    +# OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE
    +# USE OR OTHER DEALINGS IN THE SOFTWARE.
    +
    +VPATH = @srcdir@
    +am__is_gnu_make = { \
    +  if test -z '$(MAKELEVEL)'; then \
    +    false; \
    +  elif test -n '$(MAKE_HOST)'; then \
    +    true; \
    +  elif test -n '$(MAKE_VERSION)' && test -n '$(CURDIR)'; then \
    +    true; \
    +  else \
    +    false; \
    +  fi; \
    +}
    +am__make_running_with_option = \
    +  case $${target_option-} in \
    +      ?) ;; \
    +      *) echo "am__make_running_with_option: internal error: invalid" \
    +              "target option '$${target_option-}' specified" >&2; \
    +         exit 1;; \
    +  esac; \
    +  has_opt=no; \
    +  sane_makeflags=$$MAKEFLAGS; \
    +  if $(am__is_gnu_make); then \
    +    sane_makeflags=$$MFLAGS; \
    +  else \
    +    case $$MAKEFLAGS in \
    +      *\\[\ \	]*) \
    +        bs=\\; \
    +        sane_makeflags=`printf '%s\n' "$$MAKEFLAGS" \
    +          | sed "s/$$bs$$bs[$$bs $$bs	]*//g"`;; \
    +    esac; \
    +  fi; \
    +  skip_next=no; \
    +  strip_trailopt () \
    +  { \
    +    flg=`printf '%s\n' "$$flg" | sed "s/$$1.*$$//"`; \
    +  }; \
    +  for flg in $$sane_makeflags; do \
    +    test $$skip_next = yes && { skip_next=no; continue; }; \
    +    case $$flg in \
    +      *=*|--*) continue;; \
    +        -*I) strip_trailopt 'I'; skip_next=yes;; \
    +      -*I?*) strip_trailopt 'I';; \
    +        -*O) strip_trailopt 'O'; skip_next=yes;; \
    +      -*O?*) strip_trailopt 'O';; \
    +        -*l) strip_trailopt 'l'; skip_next=yes;; \
    +      -*l?*) strip_trailopt 'l';; \
    +      -[dEDm]) skip_next=yes;; \
    +      -[JT]) skip_next=yes;; \
    +    esac; \
    +    case $$flg in \
    +      *$$target_option*) has_opt=yes; break;; \
    +    esac; \
    +  done; \
    +  test $$has_opt = yes
    +am__make_dryrun = (target_option=n; $(am__make_running_with_option))
    +am__make_keepgoing = (target_option=k; $(am__make_running_with_option))
    +pkgdatadir = $(datadir)/@PACKAGE@
    +pkgincludedir = $(includedir)/@PACKAGE@
    +pkglibdir = $(libdir)/@PACKAGE@
    +pkglibexecdir = $(libexecdir)/@PACKAGE@
    +am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd
    +install_sh_DATA = $(install_sh) -c -m 644
    +install_sh_PROGRAM = $(install_sh) -c
    +install_sh_SCRIPT = $(install_sh) -c
    +INSTALL_HEADER = $(INSTALL_DATA)
    +transform = $(program_transform_name)
    +NORMAL_INSTALL = :
    +PRE_INSTALL = :
    +POST_INSTALL = :
    +NORMAL_UNINSTALL = :
    +PRE_UNINSTALL = :
    +POST_UNINSTALL = :
    +build_triplet = @build@
    +host_triplet = @host@
    +noinst_PROGRAMS = elements$(EXEEXT) outline$(EXEEXT)
    +subdir = examples
    +ACLOCAL_M4 = $(top_srcdir)/aclocal.m4
    +am__aclocal_m4_deps = $(top_srcdir)/m4/libtool.m4 \
    +	$(top_srcdir)/m4/ltoptions.m4 $(top_srcdir)/m4/ltsugar.m4 \
    +	$(top_srcdir)/m4/ltversion.m4 $(top_srcdir)/m4/lt~obsolete.m4 \
    +	$(top_srcdir)/conftools/ac_c_bigendian_cross.m4 \
    +	$(top_srcdir)/configure.ac
    +am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \
    +	$(ACLOCAL_M4)
    +DIST_COMMON = $(srcdir)/Makefile.am $(am__DIST_COMMON)
    +mkinstalldirs = $(install_sh) -d
    +CONFIG_HEADER = $(top_builddir)/expat_config.h
    +CONFIG_CLEAN_FILES =
    +CONFIG_CLEAN_VPATH_FILES =
    +PROGRAMS = $(noinst_PROGRAMS)
    +am_elements_OBJECTS = elements.$(OBJEXT)
    +elements_OBJECTS = $(am_elements_OBJECTS)
    +elements_DEPENDENCIES = ../lib/libexpat.la
    +AM_V_lt = $(am__v_lt_@AM_V@)
    +am__v_lt_ = $(am__v_lt_@AM_DEFAULT_V@)
    +am__v_lt_0 = --silent
    +am__v_lt_1 = 
    +am_outline_OBJECTS = outline.$(OBJEXT)
    +outline_OBJECTS = $(am_outline_OBJECTS)
    +outline_DEPENDENCIES = ../lib/libexpat.la
    +AM_V_P = $(am__v_P_@AM_V@)
    +am__v_P_ = $(am__v_P_@AM_DEFAULT_V@)
    +am__v_P_0 = false
    +am__v_P_1 = :
    +AM_V_GEN = $(am__v_GEN_@AM_V@)
    +am__v_GEN_ = $(am__v_GEN_@AM_DEFAULT_V@)
    +am__v_GEN_0 = @echo "  GEN     " $@;
    +am__v_GEN_1 = 
    +AM_V_at = $(am__v_at_@AM_V@)
    +am__v_at_ = $(am__v_at_@AM_DEFAULT_V@)
    +am__v_at_0 = @
    +am__v_at_1 = 
    +DEFAULT_INCLUDES = -I.@am__isrc@ -I$(top_builddir)
    +depcomp = $(SHELL) $(top_srcdir)/conftools/depcomp
    +am__depfiles_maybe = depfiles
    +am__mv = mv -f
    +COMPILE = $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) \
    +	$(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS)
    +LTCOMPILE = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \
    +	$(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) \
    +	$(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) \
    +	$(AM_CFLAGS) $(CFLAGS)
    +AM_V_CC = $(am__v_CC_@AM_V@)
    +am__v_CC_ = $(am__v_CC_@AM_DEFAULT_V@)
    +am__v_CC_0 = @echo "  CC      " $@;
    +am__v_CC_1 = 
    +CCLD = $(CC)
    +LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \
    +	$(LIBTOOLFLAGS) --mode=link $(CCLD) $(AM_CFLAGS) $(CFLAGS) \
    +	$(AM_LDFLAGS) $(LDFLAGS) -o $@
    +AM_V_CCLD = $(am__v_CCLD_@AM_V@)
    +am__v_CCLD_ = $(am__v_CCLD_@AM_DEFAULT_V@)
    +am__v_CCLD_0 = @echo "  CCLD    " $@;
    +am__v_CCLD_1 = 
    +SOURCES = $(elements_SOURCES) $(outline_SOURCES)
    +DIST_SOURCES = $(elements_SOURCES) $(outline_SOURCES)
    +am__can_run_installinfo = \
    +  case $$AM_UPDATE_INFO_DIR in \
    +    n|no|NO) false;; \
    +    *) (install-info --version) >/dev/null 2>&1;; \
    +  esac
    +am__tagged_files = $(HEADERS) $(SOURCES) $(TAGS_FILES) $(LISP)
    +# Read a list of newline-separated strings from the standard input,
    +# and print each of them once, without duplicates.  Input order is
    +# *not* preserved.
    +am__uniquify_input = $(AWK) '\
    +  BEGIN { nonempty = 0; } \
    +  { items[$$0] = 1; nonempty = 1; } \
    +  END { if (nonempty) { for (i in items) print i; }; } \
    +'
    +# Make sure the list of sources is unique.  This is necessary because,
    +# e.g., the same source file might be shared among _SOURCES variables
    +# for different programs/libraries.
    +am__define_uniq_tagged_files = \
    +  list='$(am__tagged_files)'; \
    +  unique=`for i in $$list; do \
    +    if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \
    +  done | $(am__uniquify_input)`
    +ETAGS = etags
    +CTAGS = ctags
    +am__DIST_COMMON = $(srcdir)/Makefile.in \
    +	$(top_srcdir)/conftools/depcomp
    +DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST)
    +ACLOCAL = @ACLOCAL@
    +AMTAR = @AMTAR@
    +AM_DEFAULT_VERBOSITY = @AM_DEFAULT_VERBOSITY@
    +AR = @AR@
    +AS = @AS@
    +AUTOCONF = @AUTOCONF@
    +AUTOHEADER = @AUTOHEADER@
    +AUTOMAKE = @AUTOMAKE@
    +AWK = @AWK@
    +CC = @CC@
    +CCDEPMODE = @CCDEPMODE@
    +CFLAGS = @CFLAGS@
    +CPP = @CPP@
    +CPPFLAGS = @CPPFLAGS@
    +CXX = @CXX@
    +CXXCPP = @CXXCPP@
    +CXXDEPMODE = @CXXDEPMODE@
    +CXXFLAGS = @CXXFLAGS@
    +CYGPATH_W = @CYGPATH_W@
    +DEFS = @DEFS@
    +DEPDIR = @DEPDIR@
    +DLLTOOL = @DLLTOOL@
    +DSYMUTIL = @DSYMUTIL@
    +DUMPBIN = @DUMPBIN@
    +ECHO_C = @ECHO_C@
    +ECHO_N = @ECHO_N@
    +ECHO_T = @ECHO_T@
    +EGREP = @EGREP@
    +EXEEXT = @EXEEXT@
    +FGREP = @FGREP@
    +FILEMAP = @FILEMAP@
    +GREP = @GREP@
    +INSTALL = @INSTALL@
    +INSTALL_DATA = @INSTALL_DATA@
    +INSTALL_PROGRAM = @INSTALL_PROGRAM@
    +INSTALL_SCRIPT = @INSTALL_SCRIPT@
    +INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@
    +LD = @LD@
    +LDFLAGS = @LDFLAGS@
    +LIBAGE = @LIBAGE@
    +LIBCURRENT = @LIBCURRENT@
    +LIBOBJS = @LIBOBJS@
    +LIBREVISION = @LIBREVISION@
    +LIBS = @LIBS@
    +LIBTOOL = @LIBTOOL@
    +LIPO = @LIPO@
    +LN_S = @LN_S@
    +LTLIBOBJS = @LTLIBOBJS@
    +LT_SYS_LIBRARY_PATH = @LT_SYS_LIBRARY_PATH@
    +MAKEINFO = @MAKEINFO@
    +MANIFEST_TOOL = @MANIFEST_TOOL@
    +MKDIR_P = @MKDIR_P@
    +NM = @NM@
    +NMEDIT = @NMEDIT@
    +OBJDUMP = @OBJDUMP@
    +OBJEXT = @OBJEXT@
    +OTOOL = @OTOOL@
    +OTOOL64 = @OTOOL64@
    +PACKAGE = @PACKAGE@
    +PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@
    +PACKAGE_NAME = @PACKAGE_NAME@
    +PACKAGE_STRING = @PACKAGE_STRING@
    +PACKAGE_TARNAME = @PACKAGE_TARNAME@
    +PACKAGE_URL = @PACKAGE_URL@
    +PACKAGE_VERSION = @PACKAGE_VERSION@
    +PATH_SEPARATOR = @PATH_SEPARATOR@
    +RANLIB = @RANLIB@
    +SED = @SED@
    +SET_MAKE = @SET_MAKE@
    +SHELL = @SHELL@
    +STRIP = @STRIP@
    +VERSION = @VERSION@
    +abs_builddir = @abs_builddir@
    +abs_srcdir = @abs_srcdir@
    +abs_top_builddir = @abs_top_builddir@
    +abs_top_srcdir = @abs_top_srcdir@
    +ac_ct_AR = @ac_ct_AR@
    +ac_ct_CC = @ac_ct_CC@
    +ac_ct_CXX = @ac_ct_CXX@
    +ac_ct_DUMPBIN = @ac_ct_DUMPBIN@
    +am__include = @am__include@
    +am__leading_dot = @am__leading_dot@
    +am__quote = @am__quote@
    +am__tar = @am__tar@
    +am__untar = @am__untar@
    +bindir = @bindir@
    +build = @build@
    +build_alias = @build_alias@
    +build_cpu = @build_cpu@
    +build_os = @build_os@
    +build_vendor = @build_vendor@
    +builddir = @builddir@
    +datadir = @datadir@
    +datarootdir = @datarootdir@
    +docdir = @docdir@
    +dvidir = @dvidir@
    +exec_prefix = @exec_prefix@
    +host = @host@
    +host_alias = @host_alias@
    +host_cpu = @host_cpu@
    +host_os = @host_os@
    +host_vendor = @host_vendor@
    +htmldir = @htmldir@
    +includedir = @includedir@
    +infodir = @infodir@
    +install_sh = @install_sh@
    +libdir = @libdir@
    +libexecdir = @libexecdir@
    +localedir = @localedir@
    +localstatedir = @localstatedir@
    +mandir = @mandir@
    +mkdir_p = @mkdir_p@
    +oldincludedir = @oldincludedir@
    +pdfdir = @pdfdir@
    +prefix = @prefix@
    +program_transform_name = @program_transform_name@
    +psdir = @psdir@
    +sbindir = @sbindir@
    +sharedstatedir = @sharedstatedir@
    +srcdir = @srcdir@
    +sysconfdir = @sysconfdir@
    +target_alias = @target_alias@
    +top_build_prefix = @top_build_prefix@
    +top_builddir = @top_builddir@
    +top_srcdir = @top_srcdir@
    +AM_CPPFLAGS = -I$(srcdir)/../lib
    +elements_SOURCES = elements.c
    +elements_LDADD = ../lib/libexpat.la
    +outline_SOURCES = outline.c
    +outline_LDADD = ../lib/libexpat.la
    +all: all-am
    +
    +.SUFFIXES:
    +.SUFFIXES: .c .lo .o .obj
    +$(srcdir)/Makefile.in:  $(srcdir)/Makefile.am  $(am__configure_deps)
    +	@for dep in $?; do \
    +	  case '$(am__configure_deps)' in \
    +	    *$$dep*) \
    +	      ( cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh ) \
    +	        && { if test -f $@; then exit 0; else break; fi; }; \
    +	      exit 1;; \
    +	  esac; \
    +	done; \
    +	echo ' cd $(top_srcdir) && $(AUTOMAKE) --gnu examples/Makefile'; \
    +	$(am__cd) $(top_srcdir) && \
    +	  $(AUTOMAKE) --gnu examples/Makefile
    +Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status
    +	@case '$?' in \
    +	  *config.status*) \
    +	    cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh;; \
    +	  *) \
    +	    echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe)'; \
    +	    cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe);; \
    +	esac;
    +
    +$(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES)
    +	cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh
    +
    +$(top_srcdir)/configure:  $(am__configure_deps)
    +	cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh
    +$(ACLOCAL_M4):  $(am__aclocal_m4_deps)
    +	cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh
    +$(am__aclocal_m4_deps):
    +
    +clean-noinstPROGRAMS:
    +	@list='$(noinst_PROGRAMS)'; test -n "$$list" || exit 0; \
    +	echo " rm -f" $$list; \
    +	rm -f $$list || exit $$?; \
    +	test -n "$(EXEEXT)" || exit 0; \
    +	list=`for p in $$list; do echo "$$p"; done | sed 's/$(EXEEXT)$$//'`; \
    +	echo " rm -f" $$list; \
    +	rm -f $$list
    +
    +elements$(EXEEXT): $(elements_OBJECTS) $(elements_DEPENDENCIES) $(EXTRA_elements_DEPENDENCIES) 
    +	@rm -f elements$(EXEEXT)
    +	$(AM_V_CCLD)$(LINK) $(elements_OBJECTS) $(elements_LDADD) $(LIBS)
    +
    +outline$(EXEEXT): $(outline_OBJECTS) $(outline_DEPENDENCIES) $(EXTRA_outline_DEPENDENCIES) 
    +	@rm -f outline$(EXEEXT)
    +	$(AM_V_CCLD)$(LINK) $(outline_OBJECTS) $(outline_LDADD) $(LIBS)
    +
    +mostlyclean-compile:
    +	-rm -f *.$(OBJEXT)
    +
    +distclean-compile:
    +	-rm -f *.tab.c
    +
    +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/elements.Po@am__quote@
    +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/outline.Po@am__quote@
    +
    +.c.o:
    +@am__fastdepCC_TRUE@	$(AM_V_CC)$(COMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ $<
    +@am__fastdepCC_TRUE@	$(AM_V_at)$(am__mv) $(DEPDIR)/$*.Tpo $(DEPDIR)/$*.Po
    +@AMDEP_TRUE@@am__fastdepCC_FALSE@	$(AM_V_CC)source='$<' object='$@' libtool=no @AMDEPBACKSLASH@
    +@AMDEP_TRUE@@am__fastdepCC_FALSE@	DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
    +@am__fastdepCC_FALSE@	$(AM_V_CC@am__nodep@)$(COMPILE) -c -o $@ $<
    +
    +.c.obj:
    +@am__fastdepCC_TRUE@	$(AM_V_CC)$(COMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ `$(CYGPATH_W) '$<'`
    +@am__fastdepCC_TRUE@	$(AM_V_at)$(am__mv) $(DEPDIR)/$*.Tpo $(DEPDIR)/$*.Po
    +@AMDEP_TRUE@@am__fastdepCC_FALSE@	$(AM_V_CC)source='$<' object='$@' libtool=no @AMDEPBACKSLASH@
    +@AMDEP_TRUE@@am__fastdepCC_FALSE@	DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
    +@am__fastdepCC_FALSE@	$(AM_V_CC@am__nodep@)$(COMPILE) -c -o $@ `$(CYGPATH_W) '$<'`
    +
    +.c.lo:
    +@am__fastdepCC_TRUE@	$(AM_V_CC)$(LTCOMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ $<
    +@am__fastdepCC_TRUE@	$(AM_V_at)$(am__mv) $(DEPDIR)/$*.Tpo $(DEPDIR)/$*.Plo
    +@AMDEP_TRUE@@am__fastdepCC_FALSE@	$(AM_V_CC)source='$<' object='$@' libtool=yes @AMDEPBACKSLASH@
    +@AMDEP_TRUE@@am__fastdepCC_FALSE@	DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
    +@am__fastdepCC_FALSE@	$(AM_V_CC@am__nodep@)$(LTCOMPILE) -c -o $@ $<
    +
    +mostlyclean-libtool:
    +	-rm -f *.lo
    +
    +clean-libtool:
    +	-rm -rf .libs _libs
    +
    +ID: $(am__tagged_files)
    +	$(am__define_uniq_tagged_files); mkid -fID $$unique
    +tags: tags-am
    +TAGS: tags
    +
    +tags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files)
    +	set x; \
    +	here=`pwd`; \
    +	$(am__define_uniq_tagged_files); \
    +	shift; \
    +	if test -z "$(ETAGS_ARGS)$$*$$unique"; then :; else \
    +	  test -n "$$unique" || unique=$$empty_fix; \
    +	  if test $$# -gt 0; then \
    +	    $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \
    +	      "$$@" $$unique; \
    +	  else \
    +	    $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \
    +	      $$unique; \
    +	  fi; \
    +	fi
    +ctags: ctags-am
    +
    +CTAGS: ctags
    +ctags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files)
    +	$(am__define_uniq_tagged_files); \
    +	test -z "$(CTAGS_ARGS)$$unique" \
    +	  || $(CTAGS) $(CTAGSFLAGS) $(AM_CTAGSFLAGS) $(CTAGS_ARGS) \
    +	     $$unique
    +
    +GTAGS:
    +	here=`$(am__cd) $(top_builddir) && pwd` \
    +	  && $(am__cd) $(top_srcdir) \
    +	  && gtags -i $(GTAGS_ARGS) "$$here"
    +cscopelist: cscopelist-am
    +
    +cscopelist-am: $(am__tagged_files)
    +	list='$(am__tagged_files)'; \
    +	case "$(srcdir)" in \
    +	  [\\/]* | ?:[\\/]*) sdir="$(srcdir)" ;; \
    +	  *) sdir=$(subdir)/$(srcdir) ;; \
    +	esac; \
    +	for i in $$list; do \
    +	  if test -f "$$i"; then \
    +	    echo "$(subdir)/$$i"; \
    +	  else \
    +	    echo "$$sdir/$$i"; \
    +	  fi; \
    +	done >> $(top_builddir)/cscope.files
    +
    +distclean-tags:
    +	-rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH tags
    +
    +distdir: $(DISTFILES)
    +	@srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \
    +	topsrcdirstrip=`echo "$(top_srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \
    +	list='$(DISTFILES)'; \
    +	  dist_files=`for file in $$list; do echo $$file; done | \
    +	  sed -e "s|^$$srcdirstrip/||;t" \
    +	      -e "s|^$$topsrcdirstrip/|$(top_builddir)/|;t"`; \
    +	case $$dist_files in \
    +	  */*) $(MKDIR_P) `echo "$$dist_files" | \
    +			   sed '/\//!d;s|^|$(distdir)/|;s,/[^/]*$$,,' | \
    +			   sort -u` ;; \
    +	esac; \
    +	for file in $$dist_files; do \
    +	  if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \
    +	  if test -d $$d/$$file; then \
    +	    dir=`echo "/$$file" | sed -e 's,/[^/]*$$,,'`; \
    +	    if test -d "$(distdir)/$$file"; then \
    +	      find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \
    +	    fi; \
    +	    if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \
    +	      cp -fpR $(srcdir)/$$file "$(distdir)$$dir" || exit 1; \
    +	      find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \
    +	    fi; \
    +	    cp -fpR $$d/$$file "$(distdir)$$dir" || exit 1; \
    +	  else \
    +	    test -f "$(distdir)/$$file" \
    +	    || cp -p $$d/$$file "$(distdir)/$$file" \
    +	    || exit 1; \
    +	  fi; \
    +	done
    +check-am: all-am
    +check: check-am
    +all-am: Makefile $(PROGRAMS)
    +installdirs:
    +install: install-am
    +install-exec: install-exec-am
    +install-data: install-data-am
    +uninstall: uninstall-am
    +
    +install-am: all-am
    +	@$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am
    +
    +installcheck: installcheck-am
    +install-strip:
    +	if test -z '$(STRIP)'; then \
    +	  $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \
    +	    install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \
    +	      install; \
    +	else \
    +	  $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \
    +	    install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \
    +	    "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'" install; \
    +	fi
    +mostlyclean-generic:
    +
    +clean-generic:
    +
    +distclean-generic:
    +	-test -z "$(CONFIG_CLEAN_FILES)" || rm -f $(CONFIG_CLEAN_FILES)
    +	-test . = "$(srcdir)" || test -z "$(CONFIG_CLEAN_VPATH_FILES)" || rm -f $(CONFIG_CLEAN_VPATH_FILES)
    +
    +maintainer-clean-generic:
    +	@echo "This command is intended for maintainers to use"
    +	@echo "it deletes files that may require special tools to rebuild."
    +clean: clean-am
    +
    +clean-am: clean-generic clean-libtool clean-noinstPROGRAMS \
    +	mostlyclean-am
    +
    +distclean: distclean-am
    +	-rm -rf ./$(DEPDIR)
    +	-rm -f Makefile
    +distclean-am: clean-am distclean-compile distclean-generic \
    +	distclean-tags
    +
    +dvi: dvi-am
    +
    +dvi-am:
    +
    +html: html-am
    +
    +html-am:
    +
    +info: info-am
    +
    +info-am:
    +
    +install-data-am:
    +
    +install-dvi: install-dvi-am
    +
    +install-dvi-am:
    +
    +install-exec-am:
    +
    +install-html: install-html-am
    +
    +install-html-am:
    +
    +install-info: install-info-am
    +
    +install-info-am:
    +
    +install-man:
    +
    +install-pdf: install-pdf-am
    +
    +install-pdf-am:
    +
    +install-ps: install-ps-am
    +
    +install-ps-am:
    +
    +installcheck-am:
    +
    +maintainer-clean: maintainer-clean-am
    +	-rm -rf ./$(DEPDIR)
    +	-rm -f Makefile
    +maintainer-clean-am: distclean-am maintainer-clean-generic
    +
    +mostlyclean: mostlyclean-am
    +
    +mostlyclean-am: mostlyclean-compile mostlyclean-generic \
    +	mostlyclean-libtool
    +
    +pdf: pdf-am
    +
    +pdf-am:
    +
    +ps: ps-am
    +
    +ps-am:
    +
    +uninstall-am:
    +
    +.MAKE: install-am install-strip
    +
    +.PHONY: CTAGS GTAGS TAGS all all-am check check-am clean clean-generic \
    +	clean-libtool clean-noinstPROGRAMS cscopelist-am ctags \
    +	ctags-am distclean distclean-compile distclean-generic \
    +	distclean-libtool distclean-tags distdir dvi dvi-am html \
    +	html-am info info-am install install-am install-data \
    +	install-data-am install-dvi install-dvi-am install-exec \
    +	install-exec-am install-html install-html-am install-info \
    +	install-info-am install-man install-pdf install-pdf-am \
    +	install-ps install-ps-am install-strip installcheck \
    +	installcheck-am installdirs maintainer-clean \
    +	maintainer-clean-generic mostlyclean mostlyclean-compile \
    +	mostlyclean-generic mostlyclean-libtool pdf pdf-am ps ps-am \
    +	tags tags-am uninstall uninstall-am
    +
    +.PRECIOUS: Makefile
    +
    +
    +# Tell versions [3.59,3.63) of GNU make to not export all variables.
    +# Otherwise a system limit (for SysV at least) may be exceeded.
    +.NOEXPORT:
    diff --git a/examples/elements.c b/examples/elements.c
    index fe1699c..e3605f3 100644
    --- a/examples/elements.c
    +++ b/examples/elements.c
    @@ -3,6 +3,35 @@
        the name of each element to standard output indenting child
        elements by one tab stop more than their parent element.
        It must be used with Expat compiled for UTF-8 output.
    +                            __  __            _
    +                         ___\ \/ /_ __   __ _| |_
    +                        / _ \\  /| '_ \ / _` | __|
    +                       |  __//  \| |_) | (_| | |_
    +                        \___/_/\_\ .__/ \__,_|\__|
    +                                 |_| XML parser
    +
    +   Copyright (c) 1997-2000 Thai Open Source Software Center Ltd
    +   Copyright (c) 2000-2017 Expat development team
    +   Licensed under the MIT license:
    +
    +   Permission is  hereby granted,  free of charge,  to any  person obtaining
    +   a  copy  of  this  software   and  associated  documentation  files  (the
    +   "Software"),  to  deal in  the  Software  without restriction,  including
    +   without  limitation the  rights  to use,  copy,  modify, merge,  publish,
    +   distribute, sublicense, and/or sell copies of the Software, and to permit
    +   persons  to whom  the Software  is  furnished to  do so,  subject to  the
    +   following conditions:
    +
    +   The above copyright  notice and this permission notice  shall be included
    +   in all copies or substantial portions of the Software.
    +
    +   THE  SOFTWARE  IS  PROVIDED  "AS  IS",  WITHOUT  WARRANTY  OF  ANY  KIND,
    +   EXPRESS  OR IMPLIED,  INCLUDING  BUT  NOT LIMITED  TO  THE WARRANTIES  OF
    +   MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN
    +   NO EVENT SHALL THE AUTHORS OR  COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
    +   DAMAGES OR  OTHER LIABILITY, WHETHER  IN AN  ACTION OF CONTRACT,  TORT OR
    +   OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE
    +   USE OR OTHER DEALINGS IN THE SOFTWARE.
     */
     
     #include 
    diff --git a/examples/elements.vcxproj b/examples/elements.vcxproj
    new file mode 100644
    index 0000000..20da9b2
    --- /dev/null
    +++ b/examples/elements.vcxproj
    @@ -0,0 +1,139 @@
    +
    +
    +  
    +    
    +      Debug
    +      Win32
    +    
    +    
    +      Release
    +      Win32
    +    
    +  
    +  
    +    
    +    
    +    {35262250-C85F-463A-9F6D-670088BFA17E}
    +  
    +  
    +  
    +    Application
    +    v120
    +    false
    +    MultiByte
    +  
    +  
    +    Application
    +    v120
    +    false
    +    MultiByte
    +  
    +  
    +  
    +  
    +  
    +    
    +    
    +  
    +  
    +    
    +    
    +  
    +  
    +  
    +    .\..\win32\bin\Release\
    +    .\..\win32\tmp\Release-elements\
    +    false
    +  
    +  
    +    .\..\win32\bin\Debug\
    +    .\..\win32\tmp\Debug-elements\
    +    true
    +  
    +  
    +    
    +      MultiThreaded
    +      Default
    +      true
    +      true
    +      MaxSpeed
    +      true
    +      Level3
    +      false
    +      ..\lib;%(AdditionalIncludeDirectories)
    +      NDEBUG;_CONSOLE;XML_STATIC;%(PreprocessorDefinitions)
    +      .\..\win32\tmp\Release-elements\
    +      .\..\win32\tmp\Release-elements\elements.pch
    +      .\..\win32\tmp\Release-elements\
    +      .\..\win32\tmp\Release-elements\
    +    
    +    
    +      .\..\win32\bin\Release\elements.tlb
    +    
    +    
    +      0x0409
    +      NDEBUG;%(PreprocessorDefinitions)
    +    
    +    
    +      true
    +      .\..\win32\bin\Release\elements.bsc
    +    
    +    
    +      true
    +      Console
    +      ..\win32\bin\Release\elements.exe
    +      ..\win32\bin\Release;%(AdditionalLibraryDirectories)
    +      libexpatMT.lib;%(AdditionalDependencies)
    +    
    +  
    +  
    +    
    +      MultiThreadedDebug
    +      Default
    +      true
    +      Disabled
    +      true
    +      Level3
    +      EditAndContinue
    +      ..\lib;%(AdditionalIncludeDirectories)
    +      _DEBUG;_CONSOLE;XML_STATIC;%(PreprocessorDefinitions)
    +      .\..\win32\tmp\Debug-elements\
    +      true
    +      .\..\win32\tmp\Debug-elements\elements.pch
    +      .\..\win32\tmp\Debug-elements\
    +      .\..\win32\tmp\Debug-elements\
    +      EnableFastChecks
    +    
    +    
    +      .\..\win32\bin\Debug\elements.tlb
    +    
    +    
    +      0x0409
    +      _DEBUG;%(PreprocessorDefinitions)
    +    
    +    
    +      true
    +      .\..\win32\bin\Debug\elements.bsc
    +    
    +    
    +      true
    +      true
    +      Console
    +      ..\win32\bin\Debug\elements.exe
    +      ..\win32\bin\Debug;%(AdditionalLibraryDirectories)
    +      libexpatMT.lib;%(AdditionalDependencies)
    +    
    +  
    +  
    +    
    +  
    +  
    +    
    +      {58a821bc-e4af-4df4-9a54-2baa22b92615}
    +      false
    +    
    +  
    +  
    +  
    +  
    +
    \ No newline at end of file
    diff --git a/examples/elements.vcxproj.filters b/examples/elements.vcxproj.filters
    new file mode 100644
    index 0000000..ab374c1
    --- /dev/null
    +++ b/examples/elements.vcxproj.filters
    @@ -0,0 +1,22 @@
    +
    +
    +  
    +    
    +      {95d10a62-f554-4b10-a08b-cc74ba9fe102}
    +      cpp;c;cxx;rc;def;r;odl;idl;hpj;bat
    +    
    +    
    +      {21ef9308-545b-4d8d-8bde-012f925efa3a}
    +      h;hpp;hxx;hm;inl
    +    
    +    
    +      {ddac4f51-12d6-4e8f-817c-12c85eb1ffd2}
    +      ico;cur;bmp;dlg;rc2;rct;bin;rgs;gif;jpg;jpeg;jpe
    +    
    +  
    +  
    +    
    +      Source Files
    +    
    +  
    +
    \ No newline at end of file
    diff --git a/examples/outline.c b/examples/outline.c
    index 2d1e63c..0909b75 100644
    --- a/examples/outline.c
    +++ b/examples/outline.c
    @@ -1,26 +1,36 @@
    -/*****************************************************************
    - * outline.c
    - *
    - * Copyright 1999, Clark Cooper
    - * All rights reserved.
    - *
    - * This program is free software; you can redistribute it and/or
    - * modify it under the terms of the license contained in the
    - * COPYING file that comes with the expat distribution.
    - *
    - * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
    - * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
    - * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
    - * IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY
    - * CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
    - * TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
    - * SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
    - *
    - * Read an XML document from standard input and print an element
    - * outline on standard output.
    - * Must be used with Expat compiled for UTF-8 output.
    - */
    -
    +/* Read an XML document from standard input and print an element
    +   outline on standard output.
    +   Must be used with Expat compiled for UTF-8 output.
    +                            __  __            _
    +                         ___\ \/ /_ __   __ _| |_
    +                        / _ \\  /| '_ \ / _` | __|
    +                       |  __//  \| |_) | (_| | |_
    +                        \___/_/\_\ .__/ \__,_|\__|
    +                                 |_| XML parser
    +
    +   Copyright (c) 1997-2000 Thai Open Source Software Center Ltd
    +   Copyright (c) 2000-2017 Expat development team
    +   Licensed under the MIT license:
    +
    +   Permission is  hereby granted,  free of charge,  to any  person obtaining
    +   a  copy  of  this  software   and  associated  documentation  files  (the
    +   "Software"),  to  deal in  the  Software  without restriction,  including
    +   without  limitation the  rights  to use,  copy,  modify, merge,  publish,
    +   distribute, sublicense, and/or sell copies of the Software, and to permit
    +   persons  to whom  the Software  is  furnished to  do so,  subject to  the
    +   following conditions:
    +
    +   The above copyright  notice and this permission notice  shall be included
    +   in all copies or substantial portions of the Software.
    +
    +   THE  SOFTWARE  IS  PROVIDED  "AS  IS",  WITHOUT  WARRANTY  OF  ANY  KIND,
    +   EXPRESS  OR IMPLIED,  INCLUDING  BUT  NOT LIMITED  TO  THE WARRANTIES  OF
    +   MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN
    +   NO EVENT SHALL THE AUTHORS OR  COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
    +   DAMAGES OR  OTHER LIABILITY, WHETHER  IN AN  ACTION OF CONTRACT,  TORT OR
    +   OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE
    +   USE OR OTHER DEALINGS IN THE SOFTWARE.
    +*/
     
     #include 
     #include 
    diff --git a/examples/outline.vcxproj b/examples/outline.vcxproj
    new file mode 100644
    index 0000000..56a065f
    --- /dev/null
    +++ b/examples/outline.vcxproj
    @@ -0,0 +1,150 @@
    +
    +
    +  
    +    
    +      Debug
    +      Win32
    +    
    +    
    +      Release
    +      Win32
    +    
    +    
    +      Template
    +      Win32
    +    
    +  
    +  
    +    
    +    
    +    {DE74E6FD-E107-4326-B1B0-A0CFEEB64F25}
    +  
    +  
    +  
    +    Application
    +    v120
    +  
    +  
    +    Application
    +    v120
    +    false
    +    MultiByte
    +  
    +  
    +    Application
    +    v120
    +    false
    +    MultiByte
    +  
    +  
    +  
    +  
    +  
    +    
    +  
    +  
    +    
    +    
    +  
    +  
    +    
    +    
    +  
    +  
    +  
    +    .\..\win32\bin\Debug\
    +    .\..\win32\tmp\Debug-outline\
    +    true
    +  
    +  
    +    .\..\win32\bin\Release\
    +    .\..\win32\tmp\Release-outline\
    +    false
    +  
    +  
    +    
    +      MultiThreadedDebug
    +      Default
    +      true
    +      Disabled
    +      true
    +      Level3
    +      true
    +      EditAndContinue
    +      ..\lib;%(AdditionalIncludeDirectories)
    +      _DEBUG;_CONSOLE;%(PreprocessorDefinitions)
    +      .\..\win32\tmp\Debug-outline\
    +      .\..\win32\tmp\Debug-outline\outline.pch
    +      .\..\win32\tmp\Debug-outline\
    +      .\..\win32\tmp\Debug-outline\
    +      EnableFastChecks
    +    
    +    
    +      .\..\win32\bin\Debug\outline.tlb
    +    
    +    
    +      0x0409
    +      _DEBUG;%(PreprocessorDefinitions)
    +    
    +    
    +      true
    +      .\..\win32\bin\Debug\outline.bsc
    +    
    +    
    +      true
    +      true
    +      Console
    +      ..\win32\bin\Debug\outline.exe
    +      ..\win32\bin\Debug;%(AdditionalLibraryDirectories)
    +      libexpat.lib;%(AdditionalDependencies)
    +    
    +  
    +  
    +    
    +      MultiThreaded
    +      Default
    +      true
    +      true
    +      MaxSpeed
    +      true
    +      Level3
    +      false
    +      ..\lib;%(AdditionalIncludeDirectories)
    +      NDEBUG;_CONSOLE;%(PreprocessorDefinitions)
    +      .\..\win32\tmp\Release-outline\
    +      .\..\win32\tmp\Release-outline\outline.pch
    +      .\..\win32\tmp\Release-outline\
    +      .\..\win32\tmp\Release-outline\
    +    
    +    
    +      .\..\win32\bin\Release\outline.tlb
    +    
    +    
    +      0x0409
    +      NDEBUG;%(PreprocessorDefinitions)
    +    
    +    
    +      true
    +      .\..\win32\bin\Release\outline.bsc
    +    
    +    
    +      true
    +      Console
    +      ..\win32\bin\Release\outline.exe
    +      ..\win32\bin\Release;%(AdditionalLibraryDirectories)
    +      libexpat.lib;%(AdditionalDependencies)
    +    
    +  
    +  
    +    
    +  
    +  
    +    
    +      {45a5074d-66e8-44a4-a03f-018027b528d6}
    +      false
    +    
    +  
    +  
    +  
    +  
    +
    \ No newline at end of file
    diff --git a/examples/outline.vcxproj.filters b/examples/outline.vcxproj.filters
    new file mode 100644
    index 0000000..0c23f35
    --- /dev/null
    +++ b/examples/outline.vcxproj.filters
    @@ -0,0 +1,22 @@
    +
    +
    +  
    +    
    +      {48092a1f-486d-4bd8-a9ea-d087423ab371}
    +      cpp;c;cxx;rc;def;r;odl;idl;hpj;bat
    +    
    +    
    +      {d9494f7e-987c-467b-a3e0-ea577aea229d}
    +      h;hpp;hxx;hm;inl
    +    
    +    
    +      {7e3cfca9-158f-4e78-be6c-02d599fd9254}
    +      ico;cur;bmp;dlg;rc2;rct;bin;rgs;gif;jpg;jpeg;jpe
    +    
    +  
    +  
    +    
    +      Source Files
    +    
    +  
    +
    \ No newline at end of file
    diff --git a/expat.sln b/expat.sln
    new file mode 100644
    index 0000000..d1c4efc
    --- /dev/null
    +++ b/expat.sln
    @@ -0,0 +1,73 @@
    +
    +Microsoft Visual Studio Solution File, Format Version 12.00
    +# Visual Studio 2013
    +VisualStudioVersion = 12.0.40629.0
    +MinimumVisualStudioVersion = 10.0.40219.1
    +Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "elements", "examples\elements.vcxproj", "{35262250-C85F-463A-9F6D-670088BFA17E}"
    +EndProject
    +Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "expat", "lib\expat.vcxproj", "{45A5074D-66E8-44A4-A03F-018027B528D6}"
    +EndProject
    +Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "expat_static", "lib\expat_static.vcxproj", "{58A821BC-E4AF-4DF4-9A54-2BAA22B92615}"
    +EndProject
    +Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "expatw", "lib\expatw.vcxproj", "{C04F1C11-7079-48AD-A90B-6F59B7A55BEF}"
    +EndProject
    +Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "expatw_static", "lib\expatw_static.vcxproj", "{9220B0F2-C895-4CB2-91D1-1C16C4ECB759}"
    +EndProject
    +Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "outline", "examples\outline.vcxproj", "{DE74E6FD-E107-4326-B1B0-A0CFEEB64F25}"
    +EndProject
    +Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "xmlwf", "xmlwf\xmlwf.vcxproj", "{E3C5991F-5238-4168-A179-275D1AC98D7E}"
    +EndProject
    +Global
    +	GlobalSection(SolutionConfigurationPlatforms) = preSolution
    +		Debug|Win32 = Debug|Win32
    +		Release|Win32 = Release|Win32
    +		Template|Win32 = Template|Win32
    +	EndGlobalSection
    +	GlobalSection(ProjectConfigurationPlatforms) = postSolution
    +		{35262250-C85F-463A-9F6D-670088BFA17E}.Debug|Win32.ActiveCfg = Debug|Win32
    +		{35262250-C85F-463A-9F6D-670088BFA17E}.Debug|Win32.Build.0 = Debug|Win32
    +		{35262250-C85F-463A-9F6D-670088BFA17E}.Release|Win32.ActiveCfg = Release|Win32
    +		{35262250-C85F-463A-9F6D-670088BFA17E}.Release|Win32.Build.0 = Release|Win32
    +		{35262250-C85F-463A-9F6D-670088BFA17E}.Template|Win32.ActiveCfg = Release|Win32
    +		{35262250-C85F-463A-9F6D-670088BFA17E}.Template|Win32.Build.0 = Release|Win32
    +		{45A5074D-66E8-44A4-A03F-018027B528D6}.Debug|Win32.ActiveCfg = Debug|Win32
    +		{45A5074D-66E8-44A4-A03F-018027B528D6}.Debug|Win32.Build.0 = Debug|Win32
    +		{45A5074D-66E8-44A4-A03F-018027B528D6}.Release|Win32.ActiveCfg = Release|Win32
    +		{45A5074D-66E8-44A4-A03F-018027B528D6}.Release|Win32.Build.0 = Release|Win32
    +		{45A5074D-66E8-44A4-A03F-018027B528D6}.Template|Win32.ActiveCfg = Template|Win32
    +		{45A5074D-66E8-44A4-A03F-018027B528D6}.Template|Win32.Build.0 = Template|Win32
    +		{58A821BC-E4AF-4DF4-9A54-2BAA22B92615}.Debug|Win32.ActiveCfg = Debug|Win32
    +		{58A821BC-E4AF-4DF4-9A54-2BAA22B92615}.Debug|Win32.Build.0 = Debug|Win32
    +		{58A821BC-E4AF-4DF4-9A54-2BAA22B92615}.Release|Win32.ActiveCfg = Release|Win32
    +		{58A821BC-E4AF-4DF4-9A54-2BAA22B92615}.Release|Win32.Build.0 = Release|Win32
    +		{58A821BC-E4AF-4DF4-9A54-2BAA22B92615}.Template|Win32.ActiveCfg = Template|Win32
    +		{58A821BC-E4AF-4DF4-9A54-2BAA22B92615}.Template|Win32.Build.0 = Template|Win32
    +		{C04F1C11-7079-48AD-A90B-6F59B7A55BEF}.Debug|Win32.ActiveCfg = Debug|Win32
    +		{C04F1C11-7079-48AD-A90B-6F59B7A55BEF}.Debug|Win32.Build.0 = Debug|Win32
    +		{C04F1C11-7079-48AD-A90B-6F59B7A55BEF}.Release|Win32.ActiveCfg = Release|Win32
    +		{C04F1C11-7079-48AD-A90B-6F59B7A55BEF}.Release|Win32.Build.0 = Release|Win32
    +		{C04F1C11-7079-48AD-A90B-6F59B7A55BEF}.Template|Win32.ActiveCfg = Template|Win32
    +		{C04F1C11-7079-48AD-A90B-6F59B7A55BEF}.Template|Win32.Build.0 = Template|Win32
    +		{9220B0F2-C895-4CB2-91D1-1C16C4ECB759}.Debug|Win32.ActiveCfg = Debug|Win32
    +		{9220B0F2-C895-4CB2-91D1-1C16C4ECB759}.Debug|Win32.Build.0 = Debug|Win32
    +		{9220B0F2-C895-4CB2-91D1-1C16C4ECB759}.Release|Win32.ActiveCfg = Release|Win32
    +		{9220B0F2-C895-4CB2-91D1-1C16C4ECB759}.Release|Win32.Build.0 = Release|Win32
    +		{9220B0F2-C895-4CB2-91D1-1C16C4ECB759}.Template|Win32.ActiveCfg = Template|Win32
    +		{9220B0F2-C895-4CB2-91D1-1C16C4ECB759}.Template|Win32.Build.0 = Template|Win32
    +		{DE74E6FD-E107-4326-B1B0-A0CFEEB64F25}.Debug|Win32.ActiveCfg = Debug|Win32
    +		{DE74E6FD-E107-4326-B1B0-A0CFEEB64F25}.Debug|Win32.Build.0 = Debug|Win32
    +		{DE74E6FD-E107-4326-B1B0-A0CFEEB64F25}.Release|Win32.ActiveCfg = Release|Win32
    +		{DE74E6FD-E107-4326-B1B0-A0CFEEB64F25}.Release|Win32.Build.0 = Release|Win32
    +		{DE74E6FD-E107-4326-B1B0-A0CFEEB64F25}.Template|Win32.ActiveCfg = Template|Win32
    +		{DE74E6FD-E107-4326-B1B0-A0CFEEB64F25}.Template|Win32.Build.0 = Template|Win32
    +		{E3C5991F-5238-4168-A179-275D1AC98D7E}.Debug|Win32.ActiveCfg = Debug|Win32
    +		{E3C5991F-5238-4168-A179-275D1AC98D7E}.Debug|Win32.Build.0 = Debug|Win32
    +		{E3C5991F-5238-4168-A179-275D1AC98D7E}.Release|Win32.ActiveCfg = Release|Win32
    +		{E3C5991F-5238-4168-A179-275D1AC98D7E}.Release|Win32.Build.0 = Release|Win32
    +		{E3C5991F-5238-4168-A179-275D1AC98D7E}.Template|Win32.ActiveCfg = Template|Win32
    +		{E3C5991F-5238-4168-A179-275D1AC98D7E}.Template|Win32.Build.0 = Template|Win32
    +	EndGlobalSection
    +	GlobalSection(SolutionProperties) = preSolution
    +		HideSolutionNode = FALSE
    +	EndGlobalSection
    +EndGlobal
    diff --git a/expat_config.h b/expat_config.h
    new file mode 100644
    index 0000000..232bc3b
    --- /dev/null
    +++ b/expat_config.h
    @@ -0,0 +1,123 @@
    +/* expat_config.h.  Generated from expat_config.h.in by configure.  */
    +/* expat_config.h.in.  Generated from configure.ac by autoheader.  */
    +
    +/* 1234 = LIL_ENDIAN, 4321 = BIGENDIAN */
    +#define BYTEORDER 1234
    +
    +/* Define to 1 if you have the `arc4random' function. */
    +/* #undef HAVE_ARC4RANDOM */
    +
    +/* Define to 1 if you have the `arc4random_buf' function. */
    +/* #undef HAVE_ARC4RANDOM_BUF */
    +
    +/* Define to 1 if you have the `bcopy' function. */
    +#define HAVE_BCOPY 1
    +
    +/* Define to 1 if you have the  header file. */
    +#define HAVE_DLFCN_H 1
    +
    +/* Define to 1 if you have the  header file. */
    +#define HAVE_FCNTL_H 1
    +
    +/* Define to 1 if you have the `getpagesize' function. */
    +#define HAVE_GETPAGESIZE 1
    +
    +/* Define to 1 if you have the `getrandom' function. */
    +/* #undef HAVE_GETRANDOM */
    +
    +/* Define to 1 if you have the  header file. */
    +#define HAVE_INTTYPES_H 1
    +
    +/* Define to 1 if you have the `bsd' library (-lbsd). */
    +/* #undef HAVE_LIBBSD */
    +
    +/* Define to 1 if you have the `memmove' function. */
    +#define HAVE_MEMMOVE 1
    +
    +/* Define to 1 if you have the  header file. */
    +#define HAVE_MEMORY_H 1
    +
    +/* Define to 1 if you have a working `mmap' system call. */
    +#define HAVE_MMAP 1
    +
    +/* Define to 1 if you have the  header file. */
    +#define HAVE_STDINT_H 1
    +
    +/* Define to 1 if you have the  header file. */
    +#define HAVE_STDLIB_H 1
    +
    +/* Define to 1 if you have the  header file. */
    +#define HAVE_STRINGS_H 1
    +
    +/* Define to 1 if you have the  header file. */
    +#define HAVE_STRING_H 1
    +
    +/* Define to 1 if you have `syscall' and `SYS_getrandom'. */
    +#define HAVE_SYSCALL_GETRANDOM 1
    +
    +/* Define to 1 if you have the  header file. */
    +#define HAVE_SYS_PARAM_H 1
    +
    +/* Define to 1 if you have the  header file. */
    +#define HAVE_SYS_STAT_H 1
    +
    +/* Define to 1 if you have the  header file. */
    +#define HAVE_SYS_TYPES_H 1
    +
    +/* Define to 1 if you have the  header file. */
    +#define HAVE_UNISTD_H 1
    +
    +/* Define to the sub-directory where libtool stores uninstalled libraries. */
    +#define LT_OBJDIR ".libs/"
    +
    +/* Name of package */
    +#define PACKAGE "expat"
    +
    +/* Define to the address where bug reports for this package should be sent. */
    +#define PACKAGE_BUGREPORT "expat-bugs@libexpat.org"
    +
    +/* Define to the full name of this package. */
    +#define PACKAGE_NAME "expat"
    +
    +/* Define to the full name and version of this package. */
    +#define PACKAGE_STRING "expat 2.2.4"
    +
    +/* Define to the one symbol short name of this package. */
    +#define PACKAGE_TARNAME "expat"
    +
    +/* Define to the home page for this package. */
    +#define PACKAGE_URL ""
    +
    +/* Define to the version of this package. */
    +#define PACKAGE_VERSION "2.2.4"
    +
    +/* Define to 1 if you have the ANSI C header files. */
    +#define STDC_HEADERS 1
    +
    +/* Version number of package */
    +#define VERSION "2.2.4"
    +
    +/* whether byteorder is bigendian */
    +/* #undef WORDS_BIGENDIAN */
    +
    +/* Define to specify how much context to retain around the current parse
    +   point. */
    +#define XML_CONTEXT_BYTES 1024
    +
    +/* Define to include code reading entropy from `/dev/urandom'. */
    +#define XML_DEV_URANDOM 1
    +
    +/* Define to make parameter entity parsing functionality available. */
    +#define XML_DTD 1
    +
    +/* Define to make XML Namespaces functionality available. */
    +#define XML_NS 1
    +
    +/* Define to empty if `const' does not conform to ANSI C. */
    +/* #undef const */
    +
    +/* Define to `long int' if  does not define. */
    +/* #undef off_t */
    +
    +/* Define to `unsigned int' if  does not define. */
    +/* #undef size_t */
    diff --git a/expat_config.h.cmake b/expat_config.h.cmake
    index e514791..a93c971 100644
    --- a/expat_config.h.cmake
    +++ b/expat_config.h.cmake
    @@ -1,8 +1,14 @@
    -/* expat_config.h.in.  Generated from configure.in by autoheader.  */
    +/* expat_config.h.cmake.  Based upon generated expat_config.h.in.  */
     
     /* 1234 = LIL_ENDIAN, 4321 = BIGENDIAN */
     #cmakedefine BYTEORDER @BYTEORDER@
     
    +/* Define to 1 if you have the `arc4random' function. */
    +#cmakedefine HAVE_ARC4RANDOM
    +
    +/* Define to 1 if you have the `arc4random_buf' function. */
    +#cmakedefine HAVE_ARC4RANDOM_BUF
    +
     /* Define to 1 if you have the `bcopy' function. */
     #cmakedefine HAVE_BCOPY
     
    @@ -15,9 +21,15 @@
     /* Define to 1 if you have the `getpagesize' function. */
     #cmakedefine HAVE_GETPAGESIZE
     
    +/* Define to 1 if you have the `getrandom' function. */
    +#cmakedefine HAVE_GETRANDOM
    +
     /* Define to 1 if you have the  header file. */
     #cmakedefine HAVE_INTTYPES_H
     
    +/* Define to 1 if you have the `bsd' library (-lbsd). */
    +#cmakedefine HAVE_LIBBSD
    +
     /* Define to 1 if you have the `memmove' function. */
     #cmakedefine HAVE_MEMMOVE
     
    @@ -39,6 +51,9 @@
     /* Define to 1 if you have the  header file. */
     #cmakedefine HAVE_STRING_H
     
    +/* Define to 1 if you have `syscall' and `SYS_getrandom'. */
    +#cmakedefine HAVE_SYSCALL_GETRANDOM
    +
     /* Define to 1 if you have the  header file. */
     #cmakedefine HAVE_SYS_STAT_H
     
    diff --git a/expat_config.h.in b/expat_config.h.in
    index 65b1aa9..63c0d03 100644
    --- a/expat_config.h.in
    +++ b/expat_config.h.in
    @@ -69,6 +69,9 @@
     /* Define to the sub-directory where libtool stores uninstalled libraries. */
     #undef LT_OBJDIR
     
    +/* Name of package */
    +#undef PACKAGE
    +
     /* Define to the address where bug reports for this package should be sent. */
     #undef PACKAGE_BUGREPORT
     
    @@ -90,6 +93,9 @@
     /* Define to 1 if you have the ANSI C header files. */
     #undef STDC_HEADERS
     
    +/* Version number of package */
    +#undef VERSION
    +
     /* whether byteorder is bigendian */
     #undef WORDS_BIGENDIAN
     
    diff --git a/lib/Makefile.am b/lib/Makefile.am
    new file mode 100644
    index 0000000..d655a29
    --- /dev/null
    +++ b/lib/Makefile.am
    @@ -0,0 +1,77 @@
    +#
    +#                          __  __            _
    +#                       ___\ \/ /_ __   __ _| |_
    +#                      / _ \\  /| '_ \ / _` | __|
    +#                     |  __//  \| |_) | (_| | |_
    +#                      \___/_/\_\ .__/ \__,_|\__|
    +#                               |_| XML parser
    +#
    +# Copyright (c) 2017 Expat development team
    +# Licensed under the MIT license:
    +#
    +# Permission is  hereby granted,  free of charge,  to any  person obtaining
    +# a  copy  of  this  software   and  associated  documentation  files  (the
    +# "Software"),  to  deal in  the  Software  without restriction,  including
    +# without  limitation the  rights  to use,  copy,  modify, merge,  publish,
    +# distribute, sublicense, and/or sell copies of the Software, and to permit
    +# persons  to whom  the Software  is  furnished to  do so,  subject to  the
    +# following conditions:
    +#
    +# The above copyright  notice and this permission notice  shall be included
    +# in all copies or substantial portions of the Software.
    +#
    +# THE  SOFTWARE  IS  PROVIDED  "AS  IS",  WITHOUT  WARRANTY  OF  ANY  KIND,
    +# EXPRESS  OR IMPLIED,  INCLUDING  BUT  NOT LIMITED  TO  THE WARRANTIES  OF
    +# MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN
    +# NO EVENT SHALL THE AUTHORS OR  COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
    +# DAMAGES OR  OTHER LIABILITY, WHETHER  IN AN  ACTION OF CONTRACT,  TORT OR
    +# OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE
    +# USE OR OTHER DEALINGS IN THE SOFTWARE.
    +
    +include_HEADERS = \
    +    ../expat_config.h \
    +    expat.h \
    +    expat_external.h
    +
    +lib_LTLIBRARIES = libexpat.la
    +
    +libexpat_la_LDFLAGS = \
    +    -no-undefined \
    +    -version-info @LIBCURRENT@:@LIBREVISION@:@LIBAGE@ \
    +    -rpath $(libdir)
    +
    +libexpat_la_SOURCES = \
    +    loadlibrary.c \
    +    xmlparse.c \
    +    xmltok.c \
    +    xmlrole.c
    +
    +doc_DATA = \
    +    ../AUTHORS \
    +    ../Changes
    +
    +install-data-hook:
    +	cd "$(DESTDIR)$(docdir)" && $(am__mv) Changes changelog
    +
    +uninstall-local:
    +	$(RM) "$(DESTDIR)$(docdir)/changelog"
    +
    +EXTRA_DIST = \
    +    ascii.h \
    +    asciitab.h \
    +    expat_external.h \
    +    expat.h \
    +    iasciitab.h \
    +    internal.h \
    +    latin1tab.h \
    +    libexpat.def \
    +    libexpatw.def \
    +    nametab.h \
    +    siphash.h \
    +    utf8tab.h \
    +    winconfig.h \
    +    xmlrole.h \
    +    xmltok.h \
    +    xmltok_impl.c \
    +    xmltok_impl.h \
    +    xmltok_ns.c
    diff --git a/lib/Makefile.in b/lib/Makefile.in
    new file mode 100644
    index 0000000..d350077
    --- /dev/null
    +++ b/lib/Makefile.in
    @@ -0,0 +1,784 @@
    +# Makefile.in generated by automake 1.15.1 from Makefile.am.
    +# @configure_input@
    +
    +# Copyright (C) 1994-2017 Free Software Foundation, Inc.
    +
    +# This Makefile.in is free software; the Free Software Foundation
    +# gives unlimited permission to copy and/or distribute it,
    +# with or without modifications, as long as this notice is preserved.
    +
    +# This program is distributed in the hope that it will be useful,
    +# but WITHOUT ANY WARRANTY, to the extent permitted by law; without
    +# even the implied warranty of MERCHANTABILITY or FITNESS FOR A
    +# PARTICULAR PURPOSE.
    +
    +@SET_MAKE@
    +
    +#
    +#                          __  __            _
    +#                       ___\ \/ /_ __   __ _| |_
    +#                      / _ \\  /| '_ \ / _` | __|
    +#                     |  __//  \| |_) | (_| | |_
    +#                      \___/_/\_\ .__/ \__,_|\__|
    +#                               |_| XML parser
    +#
    +# Copyright (c) 2017 Expat development team
    +# Licensed under the MIT license:
    +#
    +# Permission is  hereby granted,  free of charge,  to any  person obtaining
    +# a  copy  of  this  software   and  associated  documentation  files  (the
    +# "Software"),  to  deal in  the  Software  without restriction,  including
    +# without  limitation the  rights  to use,  copy,  modify, merge,  publish,
    +# distribute, sublicense, and/or sell copies of the Software, and to permit
    +# persons  to whom  the Software  is  furnished to  do so,  subject to  the
    +# following conditions:
    +#
    +# The above copyright  notice and this permission notice  shall be included
    +# in all copies or substantial portions of the Software.
    +#
    +# THE  SOFTWARE  IS  PROVIDED  "AS  IS",  WITHOUT  WARRANTY  OF  ANY  KIND,
    +# EXPRESS  OR IMPLIED,  INCLUDING  BUT  NOT LIMITED  TO  THE WARRANTIES  OF
    +# MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN
    +# NO EVENT SHALL THE AUTHORS OR  COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
    +# DAMAGES OR  OTHER LIABILITY, WHETHER  IN AN  ACTION OF CONTRACT,  TORT OR
    +# OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE
    +# USE OR OTHER DEALINGS IN THE SOFTWARE.
    +
    +
    +
    +VPATH = @srcdir@
    +am__is_gnu_make = { \
    +  if test -z '$(MAKELEVEL)'; then \
    +    false; \
    +  elif test -n '$(MAKE_HOST)'; then \
    +    true; \
    +  elif test -n '$(MAKE_VERSION)' && test -n '$(CURDIR)'; then \
    +    true; \
    +  else \
    +    false; \
    +  fi; \
    +}
    +am__make_running_with_option = \
    +  case $${target_option-} in \
    +      ?) ;; \
    +      *) echo "am__make_running_with_option: internal error: invalid" \
    +              "target option '$${target_option-}' specified" >&2; \
    +         exit 1;; \
    +  esac; \
    +  has_opt=no; \
    +  sane_makeflags=$$MAKEFLAGS; \
    +  if $(am__is_gnu_make); then \
    +    sane_makeflags=$$MFLAGS; \
    +  else \
    +    case $$MAKEFLAGS in \
    +      *\\[\ \	]*) \
    +        bs=\\; \
    +        sane_makeflags=`printf '%s\n' "$$MAKEFLAGS" \
    +          | sed "s/$$bs$$bs[$$bs $$bs	]*//g"`;; \
    +    esac; \
    +  fi; \
    +  skip_next=no; \
    +  strip_trailopt () \
    +  { \
    +    flg=`printf '%s\n' "$$flg" | sed "s/$$1.*$$//"`; \
    +  }; \
    +  for flg in $$sane_makeflags; do \
    +    test $$skip_next = yes && { skip_next=no; continue; }; \
    +    case $$flg in \
    +      *=*|--*) continue;; \
    +        -*I) strip_trailopt 'I'; skip_next=yes;; \
    +      -*I?*) strip_trailopt 'I';; \
    +        -*O) strip_trailopt 'O'; skip_next=yes;; \
    +      -*O?*) strip_trailopt 'O';; \
    +        -*l) strip_trailopt 'l'; skip_next=yes;; \
    +      -*l?*) strip_trailopt 'l';; \
    +      -[dEDm]) skip_next=yes;; \
    +      -[JT]) skip_next=yes;; \
    +    esac; \
    +    case $$flg in \
    +      *$$target_option*) has_opt=yes; break;; \
    +    esac; \
    +  done; \
    +  test $$has_opt = yes
    +am__make_dryrun = (target_option=n; $(am__make_running_with_option))
    +am__make_keepgoing = (target_option=k; $(am__make_running_with_option))
    +pkgdatadir = $(datadir)/@PACKAGE@
    +pkgincludedir = $(includedir)/@PACKAGE@
    +pkglibdir = $(libdir)/@PACKAGE@
    +pkglibexecdir = $(libexecdir)/@PACKAGE@
    +am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd
    +install_sh_DATA = $(install_sh) -c -m 644
    +install_sh_PROGRAM = $(install_sh) -c
    +install_sh_SCRIPT = $(install_sh) -c
    +INSTALL_HEADER = $(INSTALL_DATA)
    +transform = $(program_transform_name)
    +NORMAL_INSTALL = :
    +PRE_INSTALL = :
    +POST_INSTALL = :
    +NORMAL_UNINSTALL = :
    +PRE_UNINSTALL = :
    +POST_UNINSTALL = :
    +build_triplet = @build@
    +host_triplet = @host@
    +subdir = lib
    +ACLOCAL_M4 = $(top_srcdir)/aclocal.m4
    +am__aclocal_m4_deps = $(top_srcdir)/m4/libtool.m4 \
    +	$(top_srcdir)/m4/ltoptions.m4 $(top_srcdir)/m4/ltsugar.m4 \
    +	$(top_srcdir)/m4/ltversion.m4 $(top_srcdir)/m4/lt~obsolete.m4 \
    +	$(top_srcdir)/conftools/ac_c_bigendian_cross.m4 \
    +	$(top_srcdir)/configure.ac
    +am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \
    +	$(ACLOCAL_M4)
    +DIST_COMMON = $(srcdir)/Makefile.am $(include_HEADERS) \
    +	$(am__DIST_COMMON)
    +mkinstalldirs = $(install_sh) -d
    +CONFIG_HEADER = $(top_builddir)/expat_config.h
    +CONFIG_CLEAN_FILES =
    +CONFIG_CLEAN_VPATH_FILES =
    +am__vpath_adj_setup = srcdirstrip=`echo "$(srcdir)" | sed 's|.|.|g'`;
    +am__vpath_adj = case $$p in \
    +    $(srcdir)/*) f=`echo "$$p" | sed "s|^$$srcdirstrip/||"`;; \
    +    *) f=$$p;; \
    +  esac;
    +am__strip_dir = f=`echo $$p | sed -e 's|^.*/||'`;
    +am__install_max = 40
    +am__nobase_strip_setup = \
    +  srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*|]/\\\\&/g'`
    +am__nobase_strip = \
    +  for p in $$list; do echo "$$p"; done | sed -e "s|$$srcdirstrip/||"
    +am__nobase_list = $(am__nobase_strip_setup); \
    +  for p in $$list; do echo "$$p $$p"; done | \
    +  sed "s| $$srcdirstrip/| |;"' / .*\//!s/ .*/ ./; s,\( .*\)/[^/]*$$,\1,' | \
    +  $(AWK) 'BEGIN { files["."] = "" } { files[$$2] = files[$$2] " " $$1; \
    +    if (++n[$$2] == $(am__install_max)) \
    +      { print $$2, files[$$2]; n[$$2] = 0; files[$$2] = "" } } \
    +    END { for (dir in files) print dir, files[dir] }'
    +am__base_list = \
    +  sed '$$!N;$$!N;$$!N;$$!N;$$!N;$$!N;$$!N;s/\n/ /g' | \
    +  sed '$$!N;$$!N;$$!N;$$!N;s/\n/ /g'
    +am__uninstall_files_from_dir = { \
    +  test -z "$$files" \
    +    || { test ! -d "$$dir" && test ! -f "$$dir" && test ! -r "$$dir"; } \
    +    || { echo " ( cd '$$dir' && rm -f" $$files ")"; \
    +         $(am__cd) "$$dir" && rm -f $$files; }; \
    +  }
    +am__installdirs = "$(DESTDIR)$(libdir)" "$(DESTDIR)$(docdir)" \
    +	"$(DESTDIR)$(includedir)"
    +LTLIBRARIES = $(lib_LTLIBRARIES)
    +libexpat_la_LIBADD =
    +am_libexpat_la_OBJECTS = loadlibrary.lo xmlparse.lo xmltok.lo \
    +	xmlrole.lo
    +libexpat_la_OBJECTS = $(am_libexpat_la_OBJECTS)
    +AM_V_lt = $(am__v_lt_@AM_V@)
    +am__v_lt_ = $(am__v_lt_@AM_DEFAULT_V@)
    +am__v_lt_0 = --silent
    +am__v_lt_1 = 
    +libexpat_la_LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \
    +	$(LIBTOOLFLAGS) --mode=link $(CCLD) $(AM_CFLAGS) $(CFLAGS) \
    +	$(libexpat_la_LDFLAGS) $(LDFLAGS) -o $@
    +AM_V_P = $(am__v_P_@AM_V@)
    +am__v_P_ = $(am__v_P_@AM_DEFAULT_V@)
    +am__v_P_0 = false
    +am__v_P_1 = :
    +AM_V_GEN = $(am__v_GEN_@AM_V@)
    +am__v_GEN_ = $(am__v_GEN_@AM_DEFAULT_V@)
    +am__v_GEN_0 = @echo "  GEN     " $@;
    +am__v_GEN_1 = 
    +AM_V_at = $(am__v_at_@AM_V@)
    +am__v_at_ = $(am__v_at_@AM_DEFAULT_V@)
    +am__v_at_0 = @
    +am__v_at_1 = 
    +DEFAULT_INCLUDES = -I.@am__isrc@ -I$(top_builddir)
    +depcomp = $(SHELL) $(top_srcdir)/conftools/depcomp
    +am__depfiles_maybe = depfiles
    +am__mv = mv -f
    +COMPILE = $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) \
    +	$(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS)
    +LTCOMPILE = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \
    +	$(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) \
    +	$(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) \
    +	$(AM_CFLAGS) $(CFLAGS)
    +AM_V_CC = $(am__v_CC_@AM_V@)
    +am__v_CC_ = $(am__v_CC_@AM_DEFAULT_V@)
    +am__v_CC_0 = @echo "  CC      " $@;
    +am__v_CC_1 = 
    +CCLD = $(CC)
    +LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \
    +	$(LIBTOOLFLAGS) --mode=link $(CCLD) $(AM_CFLAGS) $(CFLAGS) \
    +	$(AM_LDFLAGS) $(LDFLAGS) -o $@
    +AM_V_CCLD = $(am__v_CCLD_@AM_V@)
    +am__v_CCLD_ = $(am__v_CCLD_@AM_DEFAULT_V@)
    +am__v_CCLD_0 = @echo "  CCLD    " $@;
    +am__v_CCLD_1 = 
    +SOURCES = $(libexpat_la_SOURCES)
    +DIST_SOURCES = $(libexpat_la_SOURCES)
    +am__can_run_installinfo = \
    +  case $$AM_UPDATE_INFO_DIR in \
    +    n|no|NO) false;; \
    +    *) (install-info --version) >/dev/null 2>&1;; \
    +  esac
    +DATA = $(doc_DATA)
    +HEADERS = $(include_HEADERS)
    +am__tagged_files = $(HEADERS) $(SOURCES) $(TAGS_FILES) $(LISP)
    +# Read a list of newline-separated strings from the standard input,
    +# and print each of them once, without duplicates.  Input order is
    +# *not* preserved.
    +am__uniquify_input = $(AWK) '\
    +  BEGIN { nonempty = 0; } \
    +  { items[$$0] = 1; nonempty = 1; } \
    +  END { if (nonempty) { for (i in items) print i; }; } \
    +'
    +# Make sure the list of sources is unique.  This is necessary because,
    +# e.g., the same source file might be shared among _SOURCES variables
    +# for different programs/libraries.
    +am__define_uniq_tagged_files = \
    +  list='$(am__tagged_files)'; \
    +  unique=`for i in $$list; do \
    +    if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \
    +  done | $(am__uniquify_input)`
    +ETAGS = etags
    +CTAGS = ctags
    +am__DIST_COMMON = $(srcdir)/Makefile.in \
    +	$(top_srcdir)/conftools/depcomp
    +DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST)
    +ACLOCAL = @ACLOCAL@
    +AMTAR = @AMTAR@
    +AM_DEFAULT_VERBOSITY = @AM_DEFAULT_VERBOSITY@
    +AR = @AR@
    +AS = @AS@
    +AUTOCONF = @AUTOCONF@
    +AUTOHEADER = @AUTOHEADER@
    +AUTOMAKE = @AUTOMAKE@
    +AWK = @AWK@
    +CC = @CC@
    +CCDEPMODE = @CCDEPMODE@
    +CFLAGS = @CFLAGS@
    +CPP = @CPP@
    +CPPFLAGS = @CPPFLAGS@
    +CXX = @CXX@
    +CXXCPP = @CXXCPP@
    +CXXDEPMODE = @CXXDEPMODE@
    +CXXFLAGS = @CXXFLAGS@
    +CYGPATH_W = @CYGPATH_W@
    +DEFS = @DEFS@
    +DEPDIR = @DEPDIR@
    +DLLTOOL = @DLLTOOL@
    +DSYMUTIL = @DSYMUTIL@
    +DUMPBIN = @DUMPBIN@
    +ECHO_C = @ECHO_C@
    +ECHO_N = @ECHO_N@
    +ECHO_T = @ECHO_T@
    +EGREP = @EGREP@
    +EXEEXT = @EXEEXT@
    +FGREP = @FGREP@
    +FILEMAP = @FILEMAP@
    +GREP = @GREP@
    +INSTALL = @INSTALL@
    +INSTALL_DATA = @INSTALL_DATA@
    +INSTALL_PROGRAM = @INSTALL_PROGRAM@
    +INSTALL_SCRIPT = @INSTALL_SCRIPT@
    +INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@
    +LD = @LD@
    +LDFLAGS = @LDFLAGS@
    +LIBAGE = @LIBAGE@
    +LIBCURRENT = @LIBCURRENT@
    +LIBOBJS = @LIBOBJS@
    +LIBREVISION = @LIBREVISION@
    +LIBS = @LIBS@
    +LIBTOOL = @LIBTOOL@
    +LIPO = @LIPO@
    +LN_S = @LN_S@
    +LTLIBOBJS = @LTLIBOBJS@
    +LT_SYS_LIBRARY_PATH = @LT_SYS_LIBRARY_PATH@
    +MAKEINFO = @MAKEINFO@
    +MANIFEST_TOOL = @MANIFEST_TOOL@
    +MKDIR_P = @MKDIR_P@
    +NM = @NM@
    +NMEDIT = @NMEDIT@
    +OBJDUMP = @OBJDUMP@
    +OBJEXT = @OBJEXT@
    +OTOOL = @OTOOL@
    +OTOOL64 = @OTOOL64@
    +PACKAGE = @PACKAGE@
    +PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@
    +PACKAGE_NAME = @PACKAGE_NAME@
    +PACKAGE_STRING = @PACKAGE_STRING@
    +PACKAGE_TARNAME = @PACKAGE_TARNAME@
    +PACKAGE_URL = @PACKAGE_URL@
    +PACKAGE_VERSION = @PACKAGE_VERSION@
    +PATH_SEPARATOR = @PATH_SEPARATOR@
    +RANLIB = @RANLIB@
    +SED = @SED@
    +SET_MAKE = @SET_MAKE@
    +SHELL = @SHELL@
    +STRIP = @STRIP@
    +VERSION = @VERSION@
    +abs_builddir = @abs_builddir@
    +abs_srcdir = @abs_srcdir@
    +abs_top_builddir = @abs_top_builddir@
    +abs_top_srcdir = @abs_top_srcdir@
    +ac_ct_AR = @ac_ct_AR@
    +ac_ct_CC = @ac_ct_CC@
    +ac_ct_CXX = @ac_ct_CXX@
    +ac_ct_DUMPBIN = @ac_ct_DUMPBIN@
    +am__include = @am__include@
    +am__leading_dot = @am__leading_dot@
    +am__quote = @am__quote@
    +am__tar = @am__tar@
    +am__untar = @am__untar@
    +bindir = @bindir@
    +build = @build@
    +build_alias = @build_alias@
    +build_cpu = @build_cpu@
    +build_os = @build_os@
    +build_vendor = @build_vendor@
    +builddir = @builddir@
    +datadir = @datadir@
    +datarootdir = @datarootdir@
    +docdir = @docdir@
    +dvidir = @dvidir@
    +exec_prefix = @exec_prefix@
    +host = @host@
    +host_alias = @host_alias@
    +host_cpu = @host_cpu@
    +host_os = @host_os@
    +host_vendor = @host_vendor@
    +htmldir = @htmldir@
    +includedir = @includedir@
    +infodir = @infodir@
    +install_sh = @install_sh@
    +libdir = @libdir@
    +libexecdir = @libexecdir@
    +localedir = @localedir@
    +localstatedir = @localstatedir@
    +mandir = @mandir@
    +mkdir_p = @mkdir_p@
    +oldincludedir = @oldincludedir@
    +pdfdir = @pdfdir@
    +prefix = @prefix@
    +program_transform_name = @program_transform_name@
    +psdir = @psdir@
    +sbindir = @sbindir@
    +sharedstatedir = @sharedstatedir@
    +srcdir = @srcdir@
    +sysconfdir = @sysconfdir@
    +target_alias = @target_alias@
    +top_build_prefix = @top_build_prefix@
    +top_builddir = @top_builddir@
    +top_srcdir = @top_srcdir@
    +include_HEADERS = \
    +    ../expat_config.h \
    +    expat.h \
    +    expat_external.h
    +
    +lib_LTLIBRARIES = libexpat.la
    +libexpat_la_LDFLAGS = \
    +    -no-undefined \
    +    -version-info @LIBCURRENT@:@LIBREVISION@:@LIBAGE@ \
    +    -rpath $(libdir)
    +
    +libexpat_la_SOURCES = \
    +    loadlibrary.c \
    +    xmlparse.c \
    +    xmltok.c \
    +    xmlrole.c
    +
    +doc_DATA = \
    +    ../AUTHORS \
    +    ../Changes
    +
    +EXTRA_DIST = \
    +    ascii.h \
    +    asciitab.h \
    +    expat_external.h \
    +    expat.h \
    +    iasciitab.h \
    +    internal.h \
    +    latin1tab.h \
    +    libexpat.def \
    +    libexpatw.def \
    +    nametab.h \
    +    siphash.h \
    +    utf8tab.h \
    +    winconfig.h \
    +    xmlrole.h \
    +    xmltok.h \
    +    xmltok_impl.c \
    +    xmltok_impl.h \
    +    xmltok_ns.c
    +
    +all: all-am
    +
    +.SUFFIXES:
    +.SUFFIXES: .c .lo .o .obj
    +$(srcdir)/Makefile.in:  $(srcdir)/Makefile.am  $(am__configure_deps)
    +	@for dep in $?; do \
    +	  case '$(am__configure_deps)' in \
    +	    *$$dep*) \
    +	      ( cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh ) \
    +	        && { if test -f $@; then exit 0; else break; fi; }; \
    +	      exit 1;; \
    +	  esac; \
    +	done; \
    +	echo ' cd $(top_srcdir) && $(AUTOMAKE) --gnu lib/Makefile'; \
    +	$(am__cd) $(top_srcdir) && \
    +	  $(AUTOMAKE) --gnu lib/Makefile
    +Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status
    +	@case '$?' in \
    +	  *config.status*) \
    +	    cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh;; \
    +	  *) \
    +	    echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe)'; \
    +	    cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe);; \
    +	esac;
    +
    +$(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES)
    +	cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh
    +
    +$(top_srcdir)/configure:  $(am__configure_deps)
    +	cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh
    +$(ACLOCAL_M4):  $(am__aclocal_m4_deps)
    +	cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh
    +$(am__aclocal_m4_deps):
    +
    +install-libLTLIBRARIES: $(lib_LTLIBRARIES)
    +	@$(NORMAL_INSTALL)
    +	@list='$(lib_LTLIBRARIES)'; test -n "$(libdir)" || list=; \
    +	list2=; for p in $$list; do \
    +	  if test -f $$p; then \
    +	    list2="$$list2 $$p"; \
    +	  else :; fi; \
    +	done; \
    +	test -z "$$list2" || { \
    +	  echo " $(MKDIR_P) '$(DESTDIR)$(libdir)'"; \
    +	  $(MKDIR_P) "$(DESTDIR)$(libdir)" || exit 1; \
    +	  echo " $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=install $(INSTALL) $(INSTALL_STRIP_FLAG) $$list2 '$(DESTDIR)$(libdir)'"; \
    +	  $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=install $(INSTALL) $(INSTALL_STRIP_FLAG) $$list2 "$(DESTDIR)$(libdir)"; \
    +	}
    +
    +uninstall-libLTLIBRARIES:
    +	@$(NORMAL_UNINSTALL)
    +	@list='$(lib_LTLIBRARIES)'; test -n "$(libdir)" || list=; \
    +	for p in $$list; do \
    +	  $(am__strip_dir) \
    +	  echo " $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=uninstall rm -f '$(DESTDIR)$(libdir)/$$f'"; \
    +	  $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=uninstall rm -f "$(DESTDIR)$(libdir)/$$f"; \
    +	done
    +
    +clean-libLTLIBRARIES:
    +	-test -z "$(lib_LTLIBRARIES)" || rm -f $(lib_LTLIBRARIES)
    +	@list='$(lib_LTLIBRARIES)'; \
    +	locs=`for p in $$list; do echo $$p; done | \
    +	      sed 's|^[^/]*$$|.|; s|/[^/]*$$||; s|$$|/so_locations|' | \
    +	      sort -u`; \
    +	test -z "$$locs" || { \
    +	  echo rm -f $${locs}; \
    +	  rm -f $${locs}; \
    +	}
    +
    +libexpat.la: $(libexpat_la_OBJECTS) $(libexpat_la_DEPENDENCIES) $(EXTRA_libexpat_la_DEPENDENCIES) 
    +	$(AM_V_CCLD)$(libexpat_la_LINK) -rpath $(libdir) $(libexpat_la_OBJECTS) $(libexpat_la_LIBADD) $(LIBS)
    +
    +mostlyclean-compile:
    +	-rm -f *.$(OBJEXT)
    +
    +distclean-compile:
    +	-rm -f *.tab.c
    +
    +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/loadlibrary.Plo@am__quote@
    +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/xmlparse.Plo@am__quote@
    +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/xmlrole.Plo@am__quote@
    +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/xmltok.Plo@am__quote@
    +
    +.c.o:
    +@am__fastdepCC_TRUE@	$(AM_V_CC)$(COMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ $<
    +@am__fastdepCC_TRUE@	$(AM_V_at)$(am__mv) $(DEPDIR)/$*.Tpo $(DEPDIR)/$*.Po
    +@AMDEP_TRUE@@am__fastdepCC_FALSE@	$(AM_V_CC)source='$<' object='$@' libtool=no @AMDEPBACKSLASH@
    +@AMDEP_TRUE@@am__fastdepCC_FALSE@	DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
    +@am__fastdepCC_FALSE@	$(AM_V_CC@am__nodep@)$(COMPILE) -c -o $@ $<
    +
    +.c.obj:
    +@am__fastdepCC_TRUE@	$(AM_V_CC)$(COMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ `$(CYGPATH_W) '$<'`
    +@am__fastdepCC_TRUE@	$(AM_V_at)$(am__mv) $(DEPDIR)/$*.Tpo $(DEPDIR)/$*.Po
    +@AMDEP_TRUE@@am__fastdepCC_FALSE@	$(AM_V_CC)source='$<' object='$@' libtool=no @AMDEPBACKSLASH@
    +@AMDEP_TRUE@@am__fastdepCC_FALSE@	DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
    +@am__fastdepCC_FALSE@	$(AM_V_CC@am__nodep@)$(COMPILE) -c -o $@ `$(CYGPATH_W) '$<'`
    +
    +.c.lo:
    +@am__fastdepCC_TRUE@	$(AM_V_CC)$(LTCOMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ $<
    +@am__fastdepCC_TRUE@	$(AM_V_at)$(am__mv) $(DEPDIR)/$*.Tpo $(DEPDIR)/$*.Plo
    +@AMDEP_TRUE@@am__fastdepCC_FALSE@	$(AM_V_CC)source='$<' object='$@' libtool=yes @AMDEPBACKSLASH@
    +@AMDEP_TRUE@@am__fastdepCC_FALSE@	DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
    +@am__fastdepCC_FALSE@	$(AM_V_CC@am__nodep@)$(LTCOMPILE) -c -o $@ $<
    +
    +mostlyclean-libtool:
    +	-rm -f *.lo
    +
    +clean-libtool:
    +	-rm -rf .libs _libs
    +install-docDATA: $(doc_DATA)
    +	@$(NORMAL_INSTALL)
    +	@list='$(doc_DATA)'; test -n "$(docdir)" || list=; \
    +	if test -n "$$list"; then \
    +	  echo " $(MKDIR_P) '$(DESTDIR)$(docdir)'"; \
    +	  $(MKDIR_P) "$(DESTDIR)$(docdir)" || exit 1; \
    +	fi; \
    +	for p in $$list; do \
    +	  if test -f "$$p"; then d=; else d="$(srcdir)/"; fi; \
    +	  echo "$$d$$p"; \
    +	done | $(am__base_list) | \
    +	while read files; do \
    +	  echo " $(INSTALL_DATA) $$files '$(DESTDIR)$(docdir)'"; \
    +	  $(INSTALL_DATA) $$files "$(DESTDIR)$(docdir)" || exit $$?; \
    +	done
    +
    +uninstall-docDATA:
    +	@$(NORMAL_UNINSTALL)
    +	@list='$(doc_DATA)'; test -n "$(docdir)" || list=; \
    +	files=`for p in $$list; do echo $$p; done | sed -e 's|^.*/||'`; \
    +	dir='$(DESTDIR)$(docdir)'; $(am__uninstall_files_from_dir)
    +install-includeHEADERS: $(include_HEADERS)
    +	@$(NORMAL_INSTALL)
    +	@list='$(include_HEADERS)'; test -n "$(includedir)" || list=; \
    +	if test -n "$$list"; then \
    +	  echo " $(MKDIR_P) '$(DESTDIR)$(includedir)'"; \
    +	  $(MKDIR_P) "$(DESTDIR)$(includedir)" || exit 1; \
    +	fi; \
    +	for p in $$list; do \
    +	  if test -f "$$p"; then d=; else d="$(srcdir)/"; fi; \
    +	  echo "$$d$$p"; \
    +	done | $(am__base_list) | \
    +	while read files; do \
    +	  echo " $(INSTALL_HEADER) $$files '$(DESTDIR)$(includedir)'"; \
    +	  $(INSTALL_HEADER) $$files "$(DESTDIR)$(includedir)" || exit $$?; \
    +	done
    +
    +uninstall-includeHEADERS:
    +	@$(NORMAL_UNINSTALL)
    +	@list='$(include_HEADERS)'; test -n "$(includedir)" || list=; \
    +	files=`for p in $$list; do echo $$p; done | sed -e 's|^.*/||'`; \
    +	dir='$(DESTDIR)$(includedir)'; $(am__uninstall_files_from_dir)
    +
    +ID: $(am__tagged_files)
    +	$(am__define_uniq_tagged_files); mkid -fID $$unique
    +tags: tags-am
    +TAGS: tags
    +
    +tags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files)
    +	set x; \
    +	here=`pwd`; \
    +	$(am__define_uniq_tagged_files); \
    +	shift; \
    +	if test -z "$(ETAGS_ARGS)$$*$$unique"; then :; else \
    +	  test -n "$$unique" || unique=$$empty_fix; \
    +	  if test $$# -gt 0; then \
    +	    $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \
    +	      "$$@" $$unique; \
    +	  else \
    +	    $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \
    +	      $$unique; \
    +	  fi; \
    +	fi
    +ctags: ctags-am
    +
    +CTAGS: ctags
    +ctags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files)
    +	$(am__define_uniq_tagged_files); \
    +	test -z "$(CTAGS_ARGS)$$unique" \
    +	  || $(CTAGS) $(CTAGSFLAGS) $(AM_CTAGSFLAGS) $(CTAGS_ARGS) \
    +	     $$unique
    +
    +GTAGS:
    +	here=`$(am__cd) $(top_builddir) && pwd` \
    +	  && $(am__cd) $(top_srcdir) \
    +	  && gtags -i $(GTAGS_ARGS) "$$here"
    +cscopelist: cscopelist-am
    +
    +cscopelist-am: $(am__tagged_files)
    +	list='$(am__tagged_files)'; \
    +	case "$(srcdir)" in \
    +	  [\\/]* | ?:[\\/]*) sdir="$(srcdir)" ;; \
    +	  *) sdir=$(subdir)/$(srcdir) ;; \
    +	esac; \
    +	for i in $$list; do \
    +	  if test -f "$$i"; then \
    +	    echo "$(subdir)/$$i"; \
    +	  else \
    +	    echo "$$sdir/$$i"; \
    +	  fi; \
    +	done >> $(top_builddir)/cscope.files
    +
    +distclean-tags:
    +	-rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH tags
    +
    +distdir: $(DISTFILES)
    +	@srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \
    +	topsrcdirstrip=`echo "$(top_srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \
    +	list='$(DISTFILES)'; \
    +	  dist_files=`for file in $$list; do echo $$file; done | \
    +	  sed -e "s|^$$srcdirstrip/||;t" \
    +	      -e "s|^$$topsrcdirstrip/|$(top_builddir)/|;t"`; \
    +	case $$dist_files in \
    +	  */*) $(MKDIR_P) `echo "$$dist_files" | \
    +			   sed '/\//!d;s|^|$(distdir)/|;s,/[^/]*$$,,' | \
    +			   sort -u` ;; \
    +	esac; \
    +	for file in $$dist_files; do \
    +	  if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \
    +	  if test -d $$d/$$file; then \
    +	    dir=`echo "/$$file" | sed -e 's,/[^/]*$$,,'`; \
    +	    if test -d "$(distdir)/$$file"; then \
    +	      find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \
    +	    fi; \
    +	    if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \
    +	      cp -fpR $(srcdir)/$$file "$(distdir)$$dir" || exit 1; \
    +	      find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \
    +	    fi; \
    +	    cp -fpR $$d/$$file "$(distdir)$$dir" || exit 1; \
    +	  else \
    +	    test -f "$(distdir)/$$file" \
    +	    || cp -p $$d/$$file "$(distdir)/$$file" \
    +	    || exit 1; \
    +	  fi; \
    +	done
    +check-am: all-am
    +check: check-am
    +all-am: Makefile $(LTLIBRARIES) $(DATA) $(HEADERS)
    +installdirs:
    +	for dir in "$(DESTDIR)$(libdir)" "$(DESTDIR)$(docdir)" "$(DESTDIR)$(includedir)"; do \
    +	  test -z "$$dir" || $(MKDIR_P) "$$dir"; \
    +	done
    +install: install-am
    +install-exec: install-exec-am
    +install-data: install-data-am
    +uninstall: uninstall-am
    +
    +install-am: all-am
    +	@$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am
    +
    +installcheck: installcheck-am
    +install-strip:
    +	if test -z '$(STRIP)'; then \
    +	  $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \
    +	    install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \
    +	      install; \
    +	else \
    +	  $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \
    +	    install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \
    +	    "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'" install; \
    +	fi
    +mostlyclean-generic:
    +
    +clean-generic:
    +
    +distclean-generic:
    +	-test -z "$(CONFIG_CLEAN_FILES)" || rm -f $(CONFIG_CLEAN_FILES)
    +	-test . = "$(srcdir)" || test -z "$(CONFIG_CLEAN_VPATH_FILES)" || rm -f $(CONFIG_CLEAN_VPATH_FILES)
    +
    +maintainer-clean-generic:
    +	@echo "This command is intended for maintainers to use"
    +	@echo "it deletes files that may require special tools to rebuild."
    +clean: clean-am
    +
    +clean-am: clean-generic clean-libLTLIBRARIES clean-libtool \
    +	mostlyclean-am
    +
    +distclean: distclean-am
    +	-rm -rf ./$(DEPDIR)
    +	-rm -f Makefile
    +distclean-am: clean-am distclean-compile distclean-generic \
    +	distclean-tags
    +
    +dvi: dvi-am
    +
    +dvi-am:
    +
    +html: html-am
    +
    +html-am:
    +
    +info: info-am
    +
    +info-am:
    +
    +install-data-am: install-docDATA install-includeHEADERS
    +	@$(NORMAL_INSTALL)
    +	$(MAKE) $(AM_MAKEFLAGS) install-data-hook
    +install-dvi: install-dvi-am
    +
    +install-dvi-am:
    +
    +install-exec-am: install-libLTLIBRARIES
    +
    +install-html: install-html-am
    +
    +install-html-am:
    +
    +install-info: install-info-am
    +
    +install-info-am:
    +
    +install-man:
    +
    +install-pdf: install-pdf-am
    +
    +install-pdf-am:
    +
    +install-ps: install-ps-am
    +
    +install-ps-am:
    +
    +installcheck-am:
    +
    +maintainer-clean: maintainer-clean-am
    +	-rm -rf ./$(DEPDIR)
    +	-rm -f Makefile
    +maintainer-clean-am: distclean-am maintainer-clean-generic
    +
    +mostlyclean: mostlyclean-am
    +
    +mostlyclean-am: mostlyclean-compile mostlyclean-generic \
    +	mostlyclean-libtool
    +
    +pdf: pdf-am
    +
    +pdf-am:
    +
    +ps: ps-am
    +
    +ps-am:
    +
    +uninstall-am: uninstall-docDATA uninstall-includeHEADERS \
    +	uninstall-libLTLIBRARIES uninstall-local
    +
    +.MAKE: install-am install-data-am install-strip
    +
    +.PHONY: CTAGS GTAGS TAGS all all-am check check-am clean clean-generic \
    +	clean-libLTLIBRARIES clean-libtool cscopelist-am ctags \
    +	ctags-am distclean distclean-compile distclean-generic \
    +	distclean-libtool distclean-tags distdir dvi dvi-am html \
    +	html-am info info-am install install-am install-data \
    +	install-data-am install-data-hook install-docDATA install-dvi \
    +	install-dvi-am install-exec install-exec-am install-html \
    +	install-html-am install-includeHEADERS install-info \
    +	install-info-am install-libLTLIBRARIES install-man install-pdf \
    +	install-pdf-am install-ps install-ps-am install-strip \
    +	installcheck installcheck-am installdirs maintainer-clean \
    +	maintainer-clean-generic mostlyclean mostlyclean-compile \
    +	mostlyclean-generic mostlyclean-libtool pdf pdf-am ps ps-am \
    +	tags tags-am uninstall uninstall-am uninstall-docDATA \
    +	uninstall-includeHEADERS uninstall-libLTLIBRARIES \
    +	uninstall-local
    +
    +.PRECIOUS: Makefile
    +
    +
    +install-data-hook:
    +	cd "$(DESTDIR)$(docdir)" && $(am__mv) Changes changelog
    +
    +uninstall-local:
    +	$(RM) "$(DESTDIR)$(docdir)/changelog"
    +
    +# Tell versions [3.59,3.63) of GNU make to not export all variables.
    +# Otherwise a system limit (for SysV at least) may be exceeded.
    +.NOEXPORT:
    diff --git a/lib/ascii.h b/lib/ascii.h
    index d10530b..c3587e5 100644
    --- a/lib/ascii.h
    +++ b/lib/ascii.h
    @@ -1,5 +1,33 @@
    -/* Copyright (c) 1998, 1999 Thai Open Source Software Center Ltd
    -   See the file COPYING for copying permission.
    +/*
    +                            __  __            _
    +                         ___\ \/ /_ __   __ _| |_
    +                        / _ \\  /| '_ \ / _` | __|
    +                       |  __//  \| |_) | (_| | |_
    +                        \___/_/\_\ .__/ \__,_|\__|
    +                                 |_| XML parser
    +
    +   Copyright (c) 1997-2000 Thai Open Source Software Center Ltd
    +   Copyright (c) 2000-2017 Expat development team
    +   Licensed under the MIT license:
    +
    +   Permission is  hereby granted,  free of charge,  to any  person obtaining
    +   a  copy  of  this  software   and  associated  documentation  files  (the
    +   "Software"),  to  deal in  the  Software  without restriction,  including
    +   without  limitation the  rights  to use,  copy,  modify, merge,  publish,
    +   distribute, sublicense, and/or sell copies of the Software, and to permit
    +   persons  to whom  the Software  is  furnished to  do so,  subject to  the
    +   following conditions:
    +
    +   The above copyright  notice and this permission notice  shall be included
    +   in all copies or substantial portions of the Software.
    +
    +   THE  SOFTWARE  IS  PROVIDED  "AS  IS",  WITHOUT  WARRANTY  OF  ANY  KIND,
    +   EXPRESS  OR IMPLIED,  INCLUDING  BUT  NOT LIMITED  TO  THE WARRANTIES  OF
    +   MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN
    +   NO EVENT SHALL THE AUTHORS OR  COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
    +   DAMAGES OR  OTHER LIABILITY, WHETHER  IN AN  ACTION OF CONTRACT,  TORT OR
    +   OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE
    +   USE OR OTHER DEALINGS IN THE SOFTWARE.
     */
     
     #define ASCII_A 0x41
    diff --git a/lib/asciitab.h b/lib/asciitab.h
    index 79a15c2..2f59fd9 100644
    --- a/lib/asciitab.h
    +++ b/lib/asciitab.h
    @@ -1,5 +1,33 @@
    -/* Copyright (c) 1998, 1999 Thai Open Source Software Center Ltd
    -   See the file COPYING for copying permission.
    +/*
    +                            __  __            _
    +                         ___\ \/ /_ __   __ _| |_
    +                        / _ \\  /| '_ \ / _` | __|
    +                       |  __//  \| |_) | (_| | |_
    +                        \___/_/\_\ .__/ \__,_|\__|
    +                                 |_| XML parser
    +
    +   Copyright (c) 1997-2000 Thai Open Source Software Center Ltd
    +   Copyright (c) 2000-2017 Expat development team
    +   Licensed under the MIT license:
    +
    +   Permission is  hereby granted,  free of charge,  to any  person obtaining
    +   a  copy  of  this  software   and  associated  documentation  files  (the
    +   "Software"),  to  deal in  the  Software  without restriction,  including
    +   without  limitation the  rights  to use,  copy,  modify, merge,  publish,
    +   distribute, sublicense, and/or sell copies of the Software, and to permit
    +   persons  to whom  the Software  is  furnished to  do so,  subject to  the
    +   following conditions:
    +
    +   The above copyright  notice and this permission notice  shall be included
    +   in all copies or substantial portions of the Software.
    +
    +   THE  SOFTWARE  IS  PROVIDED  "AS  IS",  WITHOUT  WARRANTY  OF  ANY  KIND,
    +   EXPRESS  OR IMPLIED,  INCLUDING  BUT  NOT LIMITED  TO  THE WARRANTIES  OF
    +   MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN
    +   NO EVENT SHALL THE AUTHORS OR  COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
    +   DAMAGES OR  OTHER LIABILITY, WHETHER  IN AN  ACTION OF CONTRACT,  TORT OR
    +   OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE
    +   USE OR OTHER DEALINGS IN THE SOFTWARE.
     */
     
     /* 0x00 */ BT_NONXML, BT_NONXML, BT_NONXML, BT_NONXML,
    diff --git a/lib/expat.h b/lib/expat.h
    index 7e5bbb7..d0735bb 100644
    --- a/lib/expat.h
    +++ b/lib/expat.h
    @@ -1,5 +1,33 @@
    -/* Copyright (c) 1998, 1999, 2000 Thai Open Source Software Center Ltd
    -   See the file COPYING for copying permission.
    +/*
    +                            __  __            _
    +                         ___\ \/ /_ __   __ _| |_
    +                        / _ \\  /| '_ \ / _` | __|
    +                       |  __//  \| |_) | (_| | |_
    +                        \___/_/\_\ .__/ \__,_|\__|
    +                                 |_| XML parser
    +
    +   Copyright (c) 1997-2000 Thai Open Source Software Center Ltd
    +   Copyright (c) 2000-2017 Expat development team
    +   Licensed under the MIT license:
    +
    +   Permission is  hereby granted,  free of charge,  to any  person obtaining
    +   a  copy  of  this  software   and  associated  documentation  files  (the
    +   "Software"),  to  deal in  the  Software  without restriction,  including
    +   without  limitation the  rights  to use,  copy,  modify, merge,  publish,
    +   distribute, sublicense, and/or sell copies of the Software, and to permit
    +   persons  to whom  the Software  is  furnished to  do so,  subject to  the
    +   following conditions:
    +
    +   The above copyright  notice and this permission notice  shall be included
    +   in all copies or substantial portions of the Software.
    +
    +   THE  SOFTWARE  IS  PROVIDED  "AS  IS",  WITHOUT  WARRANTY  OF  ANY  KIND,
    +   EXPRESS  OR IMPLIED,  INCLUDING  BUT  NOT LIMITED  TO  THE WARRANTIES  OF
    +   MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN
    +   NO EVENT SHALL THE AUTHORS OR  COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
    +   DAMAGES OR  OTHER LIABILITY, WHETHER  IN AN  ACTION OF CONTRACT,  TORT OR
    +   OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE
    +   USE OR OTHER DEALINGS IN THE SOFTWARE.
     */
     
     #ifndef Expat_INCLUDED
    @@ -1048,7 +1076,7 @@ XML_GetFeatureList(void);
     */
     #define XML_MAJOR_VERSION 2
     #define XML_MINOR_VERSION 2
    -#define XML_MICRO_VERSION 3
    +#define XML_MICRO_VERSION 4
     
     #ifdef __cplusplus
     }
    diff --git a/lib/expat.vcxproj b/lib/expat.vcxproj
    new file mode 100644
    index 0000000..7270b87
    --- /dev/null
    +++ b/lib/expat.vcxproj
    @@ -0,0 +1,178 @@
    +
    +
    +  
    +    
    +      Debug
    +      Win32
    +    
    +    
    +      Release
    +      Win32
    +    
    +    
    +      Template
    +      Win32
    +    
    +  
    +  
    +    
    +    
    +    {45A5074D-66E8-44A4-A03F-018027B528D6}
    +  
    +  
    +  
    +    Application
    +    v120
    +  
    +  
    +    DynamicLibrary
    +    v120
    +    false
    +    MultiByte
    +  
    +  
    +    DynamicLibrary
    +    v120
    +    false
    +    MultiByte
    +  
    +  
    +  
    +  
    +  
    +    
    +  
    +  
    +    
    +    
    +  
    +  
    +    
    +    
    +  
    +  
    +  
    +    .\..\win32\bin\Debug\
    +    .\..\win32\tmp\Debug\
    +    true
    +  
    +  
    +    .\..\win32\bin\Release\
    +    .\..\win32\tmp\Release\
    +    false
    +  
    +  
    +    
    +      MultiThreadedDebug
    +      Default
    +      true
    +      Disabled
    +      true
    +      Level3
    +      EditAndContinue
    +      _DEBUG;_WINDOWS;_USRDLL;%(PreprocessorDefinitions)
    +      .\..\win32\tmp\Debug\
    +      true
    +      .\..\win32\tmp\Debug\expat.pch
    +      .\..\win32\tmp\Debug\
    +      .\..\win32\tmp\Debug\
    +      EnableFastChecks
    +    
    +    
    +      true
    +      _DEBUG;%(PreprocessorDefinitions)
    +      .\..\win32\bin\Debug\expat.tlb
    +      true
    +      Win32
    +    
    +    
    +      0x0409
    +      _DEBUG;%(PreprocessorDefinitions)
    +    
    +    
    +      true
    +      .\..\win32\bin\Debug\expat.bsc
    +    
    +    
    +      true
    +      true
    +      true
    +      Console
    +      ..\win32\bin\Debug\libexpat.dll
    +      .\..\win32\bin\Debug\libexpat.lib
    +      .\libexpat.def
    +    
    +  
    +  
    +    
    +      MultiThreaded
    +      Default
    +      true
    +      true
    +      MaxSpeed
    +      true
    +      Level3
    +      NDEBUG;_WINDOWS;_USRDLL;%(PreprocessorDefinitions)
    +      .\..\win32\tmp\Release\
    +      .\..\win32\tmp\Release\expat.pch
    +      
    +      .\..\win32\tmp\Release\
    +      .\..\win32\tmp\Release\
    +    
    +    
    +      true
    +      NDEBUG;%(PreprocessorDefinitions)
    +      .\..\win32\bin\Release\expat.tlb
    +      true
    +      Win32
    +    
    +    
    +      0x0409
    +      NDEBUG;%(PreprocessorDefinitions)
    +    
    +    
    +      true
    +      .\..\win32\bin\Release\expat.bsc
    +    
    +    
    +      true
    +      true
    +      Console
    +      ..\win32\bin\Release\libexpat.dll
    +      .\..\win32\bin\Release\libexpat.lib
    +      .\libexpat.def
    +    
    +  
    +  
    +    
    +  
    +  
    +    
    +    
    +      
    +      
    +    
    +    
    +    
    +    
    +    
    +  
    +  
    +    
    +    
    +    
    +    
    +    
    +    
    +    
    +    
    +    
    +    
    +    
    +    
    +    
    +  
    +  
    +  
    +  
    +
    \ No newline at end of file
    diff --git a/lib/expat.vcxproj.filters b/lib/expat.vcxproj.filters
    new file mode 100644
    index 0000000..61c52b5
    --- /dev/null
    +++ b/lib/expat.vcxproj.filters
    @@ -0,0 +1,83 @@
    +
    +
    +  
    +    
    +      {f01bb743-0ef8-4601-bc44-378fc0abe768}
    +      cpp;c;cxx;rc;def;r;odl;idl;hpj;bat
    +    
    +    
    +      {c22177dc-5748-4bb1-816e-df311093bf72}
    +      h;hpp;hxx;hm;inl
    +    
    +    
    +      {41146e15-3129-4e5e-bb0f-6b78bb4701b9}
    +      ico;cur;bmp;dlg;rc2;rct;bin;rgs;gif;jpg;jpeg;jpe
    +    
    +  
    +  
    +    
    +      Source Files
    +    
    +    
    +      Source Files
    +    
    +    
    +      Source Files
    +    
    +    
    +      Source Files
    +    
    +    
    +      Source Files
    +    
    +    
    +      Source Files
    +    
    +  
    +  
    +    
    +      Header Files
    +    
    +    
    +      Header Files
    +    
    +    
    +      Header Files
    +    
    +    
    +      Header Files
    +    
    +    
    +      Header Files
    +    
    +    
    +      Header Files
    +    
    +    
    +      Header Files
    +    
    +    
    +      Header Files
    +    
    +    
    +      Header Files
    +    
    +    
    +      Header Files
    +    
    +    
    +      Header Files
    +    
    +    
    +      Header Files
    +    
    +    
    +      Header Files
    +    
    +  
    +  
    +    
    +      Source Files
    +    
    +  
    +
    \ No newline at end of file
    diff --git a/lib/expat_external.h b/lib/expat_external.h
    index 892eb4b..055be1b 100644
    --- a/lib/expat_external.h
    +++ b/lib/expat_external.h
    @@ -1,5 +1,33 @@
    -/* Copyright (c) 1998, 1999, 2000 Thai Open Source Software Center Ltd
    -   See the file COPYING for copying permission.
    +/*
    +                            __  __            _
    +                         ___\ \/ /_ __   __ _| |_
    +                        / _ \\  /| '_ \ / _` | __|
    +                       |  __//  \| |_) | (_| | |_
    +                        \___/_/\_\ .__/ \__,_|\__|
    +                                 |_| XML parser
    +
    +   Copyright (c) 1997-2000 Thai Open Source Software Center Ltd
    +   Copyright (c) 2000-2017 Expat development team
    +   Licensed under the MIT license:
    +
    +   Permission is  hereby granted,  free of charge,  to any  person obtaining
    +   a  copy  of  this  software   and  associated  documentation  files  (the
    +   "Software"),  to  deal in  the  Software  without restriction,  including
    +   without  limitation the  rights  to use,  copy,  modify, merge,  publish,
    +   distribute, sublicense, and/or sell copies of the Software, and to permit
    +   persons  to whom  the Software  is  furnished to  do so,  subject to  the
    +   following conditions:
    +
    +   The above copyright  notice and this permission notice  shall be included
    +   in all copies or substantial portions of the Software.
    +
    +   THE  SOFTWARE  IS  PROVIDED  "AS  IS",  WITHOUT  WARRANTY  OF  ANY  KIND,
    +   EXPRESS  OR IMPLIED,  INCLUDING  BUT  NOT LIMITED  TO  THE WARRANTIES  OF
    +   MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN
    +   NO EVENT SHALL THE AUTHORS OR  COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
    +   DAMAGES OR  OTHER LIABILITY, WHETHER  IN AN  ACTION OF CONTRACT,  TORT OR
    +   OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE
    +   USE OR OTHER DEALINGS IN THE SOFTWARE.
     */
     
     #ifndef Expat_External_INCLUDED
    diff --git a/lib/expat_static.vcxproj b/lib/expat_static.vcxproj
    new file mode 100644
    index 0000000..512e4c9
    --- /dev/null
    +++ b/lib/expat_static.vcxproj
    @@ -0,0 +1,148 @@
    +
    +
    +  
    +    
    +      Debug
    +      Win32
    +    
    +    
    +      Release
    +      Win32
    +    
    +    
    +      Template
    +      Win32
    +    
    +  
    +  
    +    
    +    
    +    {58A821BC-E4AF-4DF4-9A54-2BAA22B92615}
    +  
    +  
    +  
    +    Application
    +    v120
    +  
    +  
    +    StaticLibrary
    +    v120
    +    false
    +    MultiByte
    +  
    +  
    +    StaticLibrary
    +    v120
    +    false
    +    MultiByte
    +  
    +  
    +  
    +  
    +  
    +    
    +  
    +  
    +    
    +    
    +  
    +  
    +    
    +    
    +  
    +  
    +  
    +    .\..\win32\bin\Release\
    +    .\..\win32\tmp\Release_static\
    +    false
    +  
    +  
    +    .\..\win32\bin\Debug\
    +    .\..\win32\tmp\Debug_static\
    +    true
    +  
    +  
    +    
    +      MultiThreaded
    +      Default
    +      true
    +      true
    +      MaxSpeed
    +      true
    +      Level3
    +      _WINDOWS;NDEBUG;_LIB;%(PreprocessorDefinitions)
    +      .\..\win32\tmp\Release_static\
    +      .\..\win32\tmp\Release_static\expat_static.pch
    +      .\..\win32\tmp\Release_static\
    +      .\..\win32\tmp\Release_static\
    +    
    +    
    +      0x0409
    +      NDEBUG;%(PreprocessorDefinitions)
    +    
    +    
    +      true
    +      .\..\win32\bin\Release\expat_static.bsc
    +    
    +    
    +      true
    +      ..\win32\bin\Release\libexpatMT.lib
    +    
    +  
    +  
    +    
    +      MultiThreadedDebug
    +      Default
    +      true
    +      Disabled
    +      true
    +      Level3
    +      EditAndContinue
    +      _DEBUG;_WINDOWS;_LIB;%(PreprocessorDefinitions)
    +      .\..\win32\tmp\Debug_static\
    +      true
    +      .\..\win32\tmp\Debug_static\expat_static.pch
    +      .\..\win32\tmp\Debug_static\
    +      .\..\win32\tmp\Debug_static\
    +      EnableFastChecks
    +    
    +    
    +      0x0409
    +      _DEBUG;%(PreprocessorDefinitions)
    +    
    +    
    +      true
    +      .\..\win32\bin\Debug\expat_static.bsc
    +    
    +    
    +      true
    +      ..\win32\bin\Debug\libexpatMT.lib
    +    
    +  
    +  
    +    
    +    
    +    
    +    
    +    
    +    
    +  
    +  
    +    
    +    
    +    
    +    
    +    
    +    
    +    
    +    
    +    
    +    
    +    
    +    
    +    
    +  
    +  
    +  
    +  
    +
    \ No newline at end of file
    diff --git a/lib/expat_static.vcxproj.filters b/lib/expat_static.vcxproj.filters
    new file mode 100644
    index 0000000..a2fe03e
    --- /dev/null
    +++ b/lib/expat_static.vcxproj.filters
    @@ -0,0 +1,74 @@
    +
    +
    +  
    +    
    +      {ef375f25-3490-4376-8deb-a8a8bebc0194}
    +      cpp;c;cxx;rc;def;r;odl;idl;hpj;bat
    +    
    +    
    +      {f1cd6f85-7111-4c1b-abad-37c79851ca34}
    +      h;hpp;hxx;hm;inl
    +    
    +  
    +  
    +    
    +      Source Files
    +    
    +    
    +      Source Files
    +    
    +    
    +      Source Files
    +    
    +    
    +      Source Files
    +    
    +    
    +      Source Files
    +    
    +    
    +      Source Files
    +    
    +  
    +  
    +    
    +      Header Files
    +    
    +    
    +      Header Files
    +    
    +    
    +      Header Files
    +    
    +    
    +      Header Files
    +    
    +    
    +      Header Files
    +    
    +    
    +      Header Files
    +    
    +    
    +      Header Files
    +    
    +    
    +      Header Files
    +    
    +    
    +      Header Files
    +    
    +    
    +      Header Files
    +    
    +    
    +      Header Files
    +    
    +    
    +      Header Files
    +    
    +    
    +      Header Files
    +    
    +  
    +
    \ No newline at end of file
    diff --git a/lib/expatw.vcxproj b/lib/expatw.vcxproj
    new file mode 100644
    index 0000000..d42944d
    --- /dev/null
    +++ b/lib/expatw.vcxproj
    @@ -0,0 +1,178 @@
    +
    +
    +  
    +    
    +      Debug
    +      Win32
    +    
    +    
    +      Release
    +      Win32
    +    
    +    
    +      Template
    +      Win32
    +    
    +  
    +  
    +    
    +    
    +    {C04F1C11-7079-48AD-A90B-6F59B7A55BEF}
    +  
    +  
    +  
    +    Application
    +    v120
    +  
    +  
    +    DynamicLibrary
    +    v120
    +    false
    +    MultiByte
    +  
    +  
    +    DynamicLibrary
    +    v120
    +    false
    +    MultiByte
    +  
    +  
    +  
    +  
    +  
    +    
    +  
    +  
    +    
    +    
    +  
    +  
    +    
    +    
    +  
    +  
    +  
    +    .\..\win32\bin\Release\
    +    .\..\win32\tmp\Release-w\
    +    false
    +  
    +  
    +    .\..\win32\bin\Debug\
    +    .\..\win32\tmp\Debug-w\
    +    true
    +  
    +  
    +    
    +      MultiThreaded
    +      Default
    +      true
    +      true
    +      MaxSpeed
    +      true
    +      Level3
    +      NDEBUG;_WINDOWS;_USRDLL;XML_UNICODE_WCHAR_T;%(PreprocessorDefinitions)
    +      .\..\win32\tmp\Release-w\
    +      .\..\win32\tmp\Release-w\expatw.pch
    +      
    +      .\..\win32\tmp\Release-w\
    +      .\..\win32\tmp\Release-w\
    +    
    +    
    +      true
    +      NDEBUG;%(PreprocessorDefinitions)
    +      .\..\win32\bin\Release\expatw.tlb
    +      true
    +      Win32
    +    
    +    
    +      0x0409
    +      NDEBUG;%(PreprocessorDefinitions)
    +    
    +    
    +      true
    +      .\..\win32\bin\Release\expatw.bsc
    +    
    +    
    +      true
    +      true
    +      Console
    +      ..\win32\bin\Release\libexpatw.dll
    +      .\..\win32\bin\Release\libexpatw.lib
    +      .\libexpatw.def
    +    
    +  
    +  
    +    
    +      MultiThreadedDebug
    +      Default
    +      true
    +      Disabled
    +      true
    +      Level3
    +      EditAndContinue
    +      _DEBUG;_WINDOWS;_USRDLL;XML_UNICODE_WCHAR_T;%(PreprocessorDefinitions)
    +      .\..\win32\tmp\Debug-w\
    +      true
    +      .\..\win32\tmp\Debug-w\expatw.pch
    +      .\..\win32\tmp\Debug-w\
    +      .\..\win32\tmp\Debug-w\
    +      EnableFastChecks
    +    
    +    
    +      true
    +      _DEBUG;%(PreprocessorDefinitions)
    +      .\..\win32\bin\Debug\expatw.tlb
    +      true
    +      Win32
    +    
    +    
    +      0x0409
    +      _DEBUG;%(PreprocessorDefinitions)
    +    
    +    
    +      true
    +      .\..\win32\bin\Debug\expatw.bsc
    +    
    +    
    +      true
    +      true
    +      true
    +      Console
    +      ..\win32\bin\Debug\libexpatw.dll
    +      .\..\win32\bin\Debug\libexpatw.lib
    +      .\libexpatw.def
    +    
    +  
    +  
    +    
    +  
    +  
    +    
    +    
    +      
    +      
    +    
    +    
    +    
    +    
    +    
    +  
    +  
    +    
    +    
    +    
    +    
    +    
    +    
    +    
    +    
    +    
    +    
    +    
    +    
    +    
    +  
    +  
    +  
    +  
    +
    \ No newline at end of file
    diff --git a/lib/expatw.vcxproj.filters b/lib/expatw.vcxproj.filters
    new file mode 100644
    index 0000000..fb3909c
    --- /dev/null
    +++ b/lib/expatw.vcxproj.filters
    @@ -0,0 +1,83 @@
    +
    +
    +  
    +    
    +      {fea8fd20-7d6d-4664-a821-1ab5a29dadbd}
    +      cpp;c;cxx;rc;def;r;odl;idl;hpj;bat
    +    
    +    
    +      {0ceb9aa0-672d-4a6b-bff9-345c51aab04c}
    +      h;hpp;hxx;hm;inl
    +    
    +    
    +      {d62ff6fc-7f74-443d-a048-31ef02a6f99f}
    +      ico;cur;bmp;dlg;rc2;rct;bin;rgs;gif;jpg;jpeg;jpe
    +    
    +  
    +  
    +    
    +      Source Files
    +    
    +    
    +      Source Files
    +    
    +    
    +      Source Files
    +    
    +    
    +      Source Files
    +    
    +    
    +      Source Files
    +    
    +    
    +      Source Files
    +    
    +  
    +  
    +    
    +      Header Files
    +    
    +    
    +      Header Files
    +    
    +    
    +      Header Files
    +    
    +    
    +      Header Files
    +    
    +    
    +      Header Files
    +    
    +    
    +      Header Files
    +    
    +    
    +      Header Files
    +    
    +    
    +      Header Files
    +    
    +    
    +      Header Files
    +    
    +    
    +      Header Files
    +    
    +    
    +      Header Files
    +    
    +    
    +      Header Files
    +    
    +    
    +      Header Files
    +    
    +  
    +  
    +    
    +      Source Files
    +    
    +  
    +
    \ No newline at end of file
    diff --git a/lib/expatw_static.vcxproj b/lib/expatw_static.vcxproj
    new file mode 100644
    index 0000000..e7a2116
    --- /dev/null
    +++ b/lib/expatw_static.vcxproj
    @@ -0,0 +1,148 @@
    +
    +
    +  
    +    
    +      Debug
    +      Win32
    +    
    +    
    +      Release
    +      Win32
    +    
    +    
    +      Template
    +      Win32
    +    
    +  
    +  
    +    
    +    
    +    {9220B0F2-C895-4CB2-91D1-1C16C4ECB759}
    +  
    +  
    +  
    +    Application
    +    v120
    +  
    +  
    +    StaticLibrary
    +    v120
    +    false
    +    MultiByte
    +  
    +  
    +    StaticLibrary
    +    v120
    +    false
    +    MultiByte
    +  
    +  
    +  
    +  
    +  
    +    
    +  
    +  
    +    
    +    
    +  
    +  
    +    
    +    
    +  
    +  
    +  
    +    .\..\win32\bin\Debug\
    +    .\..\win32\tmp\Debug-w_static\
    +    true
    +  
    +  
    +    .\..\win32\bin\Release\
    +    .\..\win32\tmp\Release-w_static\
    +    false
    +  
    +  
    +    
    +      MultiThreadedDebug
    +      Default
    +      true
    +      Disabled
    +      true
    +      Level3
    +      EditAndContinue
    +      _DEBUG;_WINDOWS;_LIB;XML_UNICODE_WCHAR_T;%(PreprocessorDefinitions)
    +      .\..\win32\tmp\Debug-w_static\
    +      true
    +      .\..\win32\tmp\Debug-w_static\expatw_static.pch
    +      .\..\win32\tmp\Debug-w_static\
    +      .\..\win32\tmp\Debug-w_static\
    +      EnableFastChecks
    +    
    +    
    +      0x0409
    +      _DEBUG;%(PreprocessorDefinitions)
    +    
    +    
    +      true
    +      .\..\win32\bin\Debug\expatw_static.bsc
    +    
    +    
    +      true
    +      ..\win32\bin\Debug\libexpatwMT.lib
    +    
    +  
    +  
    +    
    +      MultiThreaded
    +      Default
    +      true
    +      true
    +      MaxSpeed
    +      true
    +      Level3
    +      _WINDOWS;NDEBUG;_LIB;XML_UNICODE_WCHAR_T;%(PreprocessorDefinitions)
    +      .\..\win32\tmp\Release-w_static\
    +      .\..\win32\tmp\Release-w_static\expatw_static.pch
    +      .\..\win32\tmp\Release-w_static\
    +      .\..\win32\tmp\Release-w_static\
    +    
    +    
    +      0x0409
    +      NDEBUG;%(PreprocessorDefinitions)
    +    
    +    
    +      true
    +      .\..\win32\bin\Release\expatw_static.bsc
    +    
    +    
    +      true
    +      ..\win32\bin\Release\libexpatwMT.lib
    +    
    +  
    +  
    +    
    +    
    +    
    +    
    +    
    +    
    +  
    +  
    +    
    +    
    +    
    +    
    +    
    +    
    +    
    +    
    +    
    +    
    +    
    +    
    +    
    +  
    +  
    +  
    +  
    +
    \ No newline at end of file
    diff --git a/lib/expatw_static.vcxproj.filters b/lib/expatw_static.vcxproj.filters
    new file mode 100644
    index 0000000..724d9f8
    --- /dev/null
    +++ b/lib/expatw_static.vcxproj.filters
    @@ -0,0 +1,74 @@
    +
    +
    +  
    +    
    +      {c0226397-04be-42b5-ba75-257ac91ef7fa}
    +      cpp;c;cxx;rc;def;r;odl;idl;hpj;bat
    +    
    +    
    +      {3d74dc56-3aec-4ee9-b700-7203f44e015d}
    +      h;hpp;hxx;hm;inl
    +    
    +  
    +  
    +    
    +      Source Files
    +    
    +    
    +      Source Files
    +    
    +    
    +      Source Files
    +    
    +    
    +      Source Files
    +    
    +    
    +      Source Files
    +    
    +    
    +      Source Files
    +    
    +  
    +  
    +    
    +      Header Files
    +    
    +    
    +      Header Files
    +    
    +    
    +      Header Files
    +    
    +    
    +      Header Files
    +    
    +    
    +      Header Files
    +    
    +    
    +      Header Files
    +    
    +    
    +      Header Files
    +    
    +    
    +      Header Files
    +    
    +    
    +      Header Files
    +    
    +    
    +      Header Files
    +    
    +    
    +      Header Files
    +    
    +    
    +      Header Files
    +    
    +    
    +      Header Files
    +    
    +  
    +
    \ No newline at end of file
    diff --git a/lib/iasciitab.h b/lib/iasciitab.h
    index 24a1d5c..ce4a4bf 100644
    --- a/lib/iasciitab.h
    +++ b/lib/iasciitab.h
    @@ -1,5 +1,33 @@
    -/* Copyright (c) 1998, 1999 Thai Open Source Software Center Ltd
    -   See the file COPYING for copying permission.
    +/*
    +                            __  __            _
    +                         ___\ \/ /_ __   __ _| |_
    +                        / _ \\  /| '_ \ / _` | __|
    +                       |  __//  \| |_) | (_| | |_
    +                        \___/_/\_\ .__/ \__,_|\__|
    +                                 |_| XML parser
    +
    +   Copyright (c) 1997-2000 Thai Open Source Software Center Ltd
    +   Copyright (c) 2000-2017 Expat development team
    +   Licensed under the MIT license:
    +
    +   Permission is  hereby granted,  free of charge,  to any  person obtaining
    +   a  copy  of  this  software   and  associated  documentation  files  (the
    +   "Software"),  to  deal in  the  Software  without restriction,  including
    +   without  limitation the  rights  to use,  copy,  modify, merge,  publish,
    +   distribute, sublicense, and/or sell copies of the Software, and to permit
    +   persons  to whom  the Software  is  furnished to  do so,  subject to  the
    +   following conditions:
    +
    +   The above copyright  notice and this permission notice  shall be included
    +   in all copies or substantial portions of the Software.
    +
    +   THE  SOFTWARE  IS  PROVIDED  "AS  IS",  WITHOUT  WARRANTY  OF  ANY  KIND,
    +   EXPRESS  OR IMPLIED,  INCLUDING  BUT  NOT LIMITED  TO  THE WARRANTIES  OF
    +   MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN
    +   NO EVENT SHALL THE AUTHORS OR  COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
    +   DAMAGES OR  OTHER LIABILITY, WHETHER  IN AN  ACTION OF CONTRACT,  TORT OR
    +   OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE
    +   USE OR OTHER DEALINGS IN THE SOFTWARE.
     */
     
     /* Like asciitab.h, except that 0xD has code BT_S rather than BT_CR */
    diff --git a/lib/internal.h b/lib/internal.h
    index 94cb98e..3c5d6e9 100644
    --- a/lib/internal.h
    +++ b/lib/internal.h
    @@ -18,6 +18,35 @@
     
        Note: Use of these macros is based on judgement, not hard rules,
              and therefore subject to change.
    +                            __  __            _
    +                         ___\ \/ /_ __   __ _| |_
    +                        / _ \\  /| '_ \ / _` | __|
    +                       |  __//  \| |_) | (_| | |_
    +                        \___/_/\_\ .__/ \__,_|\__|
    +                                 |_| XML parser
    +
    +   Copyright (c) 1997-2000 Thai Open Source Software Center Ltd
    +   Copyright (c) 2000-2017 Expat development team
    +   Licensed under the MIT license:
    +
    +   Permission is  hereby granted,  free of charge,  to any  person obtaining
    +   a  copy  of  this  software   and  associated  documentation  files  (the
    +   "Software"),  to  deal in  the  Software  without restriction,  including
    +   without  limitation the  rights  to use,  copy,  modify, merge,  publish,
    +   distribute, sublicense, and/or sell copies of the Software, and to permit
    +   persons  to whom  the Software  is  furnished to  do so,  subject to  the
    +   following conditions:
    +
    +   The above copyright  notice and this permission notice  shall be included
    +   in all copies or substantial portions of the Software.
    +
    +   THE  SOFTWARE  IS  PROVIDED  "AS  IS",  WITHOUT  WARRANTY  OF  ANY  KIND,
    +   EXPRESS  OR IMPLIED,  INCLUDING  BUT  NOT LIMITED  TO  THE WARRANTIES  OF
    +   MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN
    +   NO EVENT SHALL THE AUTHORS OR  COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
    +   DAMAGES OR  OTHER LIABILITY, WHETHER  IN AN  ACTION OF CONTRACT,  TORT OR
    +   OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE
    +   USE OR OTHER DEALINGS IN THE SOFTWARE.
     */
     
     #if defined(__GNUC__) && defined(__i386__) && !defined(__MINGW32__)
    diff --git a/lib/latin1tab.h b/lib/latin1tab.h
    index 53c25d7..95dfa52 100644
    --- a/lib/latin1tab.h
    +++ b/lib/latin1tab.h
    @@ -1,5 +1,33 @@
    -/* Copyright (c) 1998, 1999 Thai Open Source Software Center Ltd
    -   See the file COPYING for copying permission.
    +/*
    +                            __  __            _
    +                         ___\ \/ /_ __   __ _| |_
    +                        / _ \\  /| '_ \ / _` | __|
    +                       |  __//  \| |_) | (_| | |_
    +                        \___/_/\_\ .__/ \__,_|\__|
    +                                 |_| XML parser
    +
    +   Copyright (c) 1997-2000 Thai Open Source Software Center Ltd
    +   Copyright (c) 2000-2017 Expat development team
    +   Licensed under the MIT license:
    +
    +   Permission is  hereby granted,  free of charge,  to any  person obtaining
    +   a  copy  of  this  software   and  associated  documentation  files  (the
    +   "Software"),  to  deal in  the  Software  without restriction,  including
    +   without  limitation the  rights  to use,  copy,  modify, merge,  publish,
    +   distribute, sublicense, and/or sell copies of the Software, and to permit
    +   persons  to whom  the Software  is  furnished to  do so,  subject to  the
    +   following conditions:
    +
    +   The above copyright  notice and this permission notice  shall be included
    +   in all copies or substantial portions of the Software.
    +
    +   THE  SOFTWARE  IS  PROVIDED  "AS  IS",  WITHOUT  WARRANTY  OF  ANY  KIND,
    +   EXPRESS  OR IMPLIED,  INCLUDING  BUT  NOT LIMITED  TO  THE WARRANTIES  OF
    +   MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN
    +   NO EVENT SHALL THE AUTHORS OR  COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
    +   DAMAGES OR  OTHER LIABILITY, WHETHER  IN AN  ACTION OF CONTRACT,  TORT OR
    +   OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE
    +   USE OR OTHER DEALINGS IN THE SOFTWARE.
     */
     
     /* 0x80 */ BT_OTHER, BT_OTHER, BT_OTHER, BT_OTHER,
    diff --git a/lib/loadlibrary.c b/lib/loadlibrary.c
    index ffce868..452ae92 100644
    --- a/lib/loadlibrary.c
    +++ b/lib/loadlibrary.c
    @@ -6,8 +6,10 @@
      *                             \___|\___/|_| \_\_____|
      *
      * Copyright (C) 2016 - 2017, Steve Holme, .
    + * Copyright (C) 2017, Expat development team
      *
      * All rights reserved.
    + * Licensed under the MIT license:
      *
      * Permission to  use, copy,  modify, and distribute  this software  for any
      * purpose with  or without fee is  hereby granted, provided that  the above
    diff --git a/lib/nametab.h b/lib/nametab.h
    index b05e62c..bfa2bd3 100644
    --- a/lib/nametab.h
    +++ b/lib/nametab.h
    @@ -1,3 +1,35 @@
    +/*
    +                            __  __            _
    +                         ___\ \/ /_ __   __ _| |_
    +                        / _ \\  /| '_ \ / _` | __|
    +                       |  __//  \| |_) | (_| | |_
    +                        \___/_/\_\ .__/ \__,_|\__|
    +                                 |_| XML parser
    +
    +   Copyright (c) 1997-2000 Thai Open Source Software Center Ltd
    +   Copyright (c) 2000-2017 Expat development team
    +   Licensed under the MIT license:
    +
    +   Permission is  hereby granted,  free of charge,  to any  person obtaining
    +   a  copy  of  this  software   and  associated  documentation  files  (the
    +   "Software"),  to  deal in  the  Software  without restriction,  including
    +   without  limitation the  rights  to use,  copy,  modify, merge,  publish,
    +   distribute, sublicense, and/or sell copies of the Software, and to permit
    +   persons  to whom  the Software  is  furnished to  do so,  subject to  the
    +   following conditions:
    +
    +   The above copyright  notice and this permission notice  shall be included
    +   in all copies or substantial portions of the Software.
    +
    +   THE  SOFTWARE  IS  PROVIDED  "AS  IS",  WITHOUT  WARRANTY  OF  ANY  KIND,
    +   EXPRESS  OR IMPLIED,  INCLUDING  BUT  NOT LIMITED  TO  THE WARRANTIES  OF
    +   MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN
    +   NO EVENT SHALL THE AUTHORS OR  COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
    +   DAMAGES OR  OTHER LIABILITY, WHETHER  IN AN  ACTION OF CONTRACT,  TORT OR
    +   OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE
    +   USE OR OTHER DEALINGS IN THE SOFTWARE.
    +*/
    +
     static const unsigned namingBitmap[] = {
     0x00000000, 0x00000000, 0x00000000, 0x00000000,
     0x00000000, 0x00000000, 0x00000000, 0x00000000,
    diff --git a/lib/utf8tab.h b/lib/utf8tab.h
    index 7bb3e77..fa0bed6 100644
    --- a/lib/utf8tab.h
    +++ b/lib/utf8tab.h
    @@ -1,7 +1,34 @@
    -/* Copyright (c) 1998, 1999 Thai Open Source Software Center Ltd
    -   See the file COPYING for copying permission.
    -*/
    +/*
    +                            __  __            _
    +                         ___\ \/ /_ __   __ _| |_
    +                        / _ \\  /| '_ \ / _` | __|
    +                       |  __//  \| |_) | (_| | |_
    +                        \___/_/\_\ .__/ \__,_|\__|
    +                                 |_| XML parser
    +
    +   Copyright (c) 1997-2000 Thai Open Source Software Center Ltd
    +   Copyright (c) 2000-2017 Expat development team
    +   Licensed under the MIT license:
    +
    +   Permission is  hereby granted,  free of charge,  to any  person obtaining
    +   a  copy  of  this  software   and  associated  documentation  files  (the
    +   "Software"),  to  deal in  the  Software  without restriction,  including
    +   without  limitation the  rights  to use,  copy,  modify, merge,  publish,
    +   distribute, sublicense, and/or sell copies of the Software, and to permit
    +   persons  to whom  the Software  is  furnished to  do so,  subject to  the
    +   following conditions:
     
    +   The above copyright  notice and this permission notice  shall be included
    +   in all copies or substantial portions of the Software.
    +
    +   THE  SOFTWARE  IS  PROVIDED  "AS  IS",  WITHOUT  WARRANTY  OF  ANY  KIND,
    +   EXPRESS  OR IMPLIED,  INCLUDING  BUT  NOT LIMITED  TO  THE WARRANTIES  OF
    +   MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN
    +   NO EVENT SHALL THE AUTHORS OR  COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
    +   DAMAGES OR  OTHER LIABILITY, WHETHER  IN AN  ACTION OF CONTRACT,  TORT OR
    +   OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE
    +   USE OR OTHER DEALINGS IN THE SOFTWARE.
    +*/
     
     /* 0x80 */ BT_TRAIL, BT_TRAIL, BT_TRAIL, BT_TRAIL,
     /* 0x84 */ BT_TRAIL, BT_TRAIL, BT_TRAIL, BT_TRAIL,
    diff --git a/lib/winconfig.h b/lib/winconfig.h
    index 9bf014d..17fea46 100644
    --- a/lib/winconfig.h
    +++ b/lib/winconfig.h
    @@ -1,10 +1,33 @@
    -/*================================================================
    -** Copyright 2000, Clark Cooper
    -** All rights reserved.
    -**
    -** This is free software. You are permitted to copy, distribute, or modify
    -** it under the terms of the MIT/X license (contained in the COPYING file
    -** with this distribution.)
    +/*
    +                            __  __            _
    +                         ___\ \/ /_ __   __ _| |_
    +                        / _ \\  /| '_ \ / _` | __|
    +                       |  __//  \| |_) | (_| | |_
    +                        \___/_/\_\ .__/ \__,_|\__|
    +                                 |_| XML parser
    +
    +   Copyright (c) 1997-2000 Thai Open Source Software Center Ltd
    +   Copyright (c) 2000-2017 Expat development team
    +   Licensed under the MIT license:
    +
    +   Permission is  hereby granted,  free of charge,  to any  person obtaining
    +   a  copy  of  this  software   and  associated  documentation  files  (the
    +   "Software"),  to  deal in  the  Software  without restriction,  including
    +   without  limitation the  rights  to use,  copy,  modify, merge,  publish,
    +   distribute, sublicense, and/or sell copies of the Software, and to permit
    +   persons  to whom  the Software  is  furnished to  do so,  subject to  the
    +   following conditions:
    +
    +   The above copyright  notice and this permission notice  shall be included
    +   in all copies or substantial portions of the Software.
    +
    +   THE  SOFTWARE  IS  PROVIDED  "AS  IS",  WITHOUT  WARRANTY  OF  ANY  KIND,
    +   EXPRESS  OR IMPLIED,  INCLUDING  BUT  NOT LIMITED  TO  THE WARRANTIES  OF
    +   MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN
    +   NO EVENT SHALL THE AUTHORS OR  COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
    +   DAMAGES OR  OTHER LIABILITY, WHETHER  IN AN  ACTION OF CONTRACT,  TORT OR
    +   OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE
    +   USE OR OTHER DEALINGS IN THE SOFTWARE.
     */
     
     #ifndef WINCONFIG_H
    diff --git a/lib/xmlparse.c b/lib/xmlparse.c
    index b703e61..0df6883 100644
    --- a/lib/xmlparse.c
    +++ b/lib/xmlparse.c
    @@ -1,7 +1,33 @@
    -/* Copyright (c) 1998, 1999, 2000 Thai Open Source Software Center Ltd
    -   See the file COPYING for copying permission.
    -
    -   101bfd65d1ff3d1511cf6671e6aae65f82cd97df6f4da137d46d510731830ad9 (2.2.3+)
    +/* 8c6b2be7c6281da65ce05218fc15c339f02a811706340824ab596aa86e1fd51a (2.2.4+)
    +                            __  __            _
    +                         ___\ \/ /_ __   __ _| |_
    +                        / _ \\  /| '_ \ / _` | __|
    +                       |  __//  \| |_) | (_| | |_
    +                        \___/_/\_\ .__/ \__,_|\__|
    +                                 |_| XML parser
    +
    +   Copyright (c) 1997-2000 Thai Open Source Software Center Ltd
    +   Copyright (c) 2000-2017 Expat development team
    +   Licensed under the MIT license:
    +
    +   Permission is  hereby granted,  free of charge,  to any  person obtaining
    +   a  copy  of  this  software   and  associated  documentation  files  (the
    +   "Software"),  to  deal in  the  Software  without restriction,  including
    +   without  limitation the  rights  to use,  copy,  modify, merge,  publish,
    +   distribute, sublicense, and/or sell copies of the Software, and to permit
    +   persons  to whom  the Software  is  furnished to  do so,  subject to  the
    +   following conditions:
    +
    +   The above copyright  notice and this permission notice  shall be included
    +   in all copies or substantial portions of the Software.
    +
    +   THE  SOFTWARE  IS  PROVIDED  "AS  IS",  WITHOUT  WARRANTY  OF  ANY  KIND,
    +   EXPRESS  OR IMPLIED,  INCLUDING  BUT  NOT LIMITED  TO  THE WARRANTIES  OF
    +   MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN
    +   NO EVENT SHALL THE AUTHORS OR  COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
    +   DAMAGES OR  OTHER LIABILITY, WHETHER  IN AN  ACTION OF CONTRACT,  TORT OR
    +   OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE
    +   USE OR OTHER DEALINGS IN THE SOFTWARE.
     */
     
     #if !defined(_GNU_SOURCE)
    @@ -80,9 +106,6 @@
         If insist on not using any of these, bypass this error by defining \
         XML_POOR_ENTROPY; you have been warned. \
         \
    -    For CMake, one way to pass the define is: \
    -        cmake -DCMAKE_C_FLAGS="-pipe -O2 -DHAVE_SYSCALL_GETRANDOM" . \
    -    \
         If you have reasons to patch this detection code away or need changes \
         to the build system, please open a bug.  Thank you!
     #endif
    diff --git a/lib/xmlrole.c b/lib/xmlrole.c
    index c809ee5..708507d 100644
    --- a/lib/xmlrole.c
    +++ b/lib/xmlrole.c
    @@ -1,5 +1,33 @@
    -/* Copyright (c) 1998, 1999 Thai Open Source Software Center Ltd
    -   See the file COPYING for copying permission.
    +/*
    +                            __  __            _
    +                         ___\ \/ /_ __   __ _| |_
    +                        / _ \\  /| '_ \ / _` | __|
    +                       |  __//  \| |_) | (_| | |_
    +                        \___/_/\_\ .__/ \__,_|\__|
    +                                 |_| XML parser
    +
    +   Copyright (c) 1997-2000 Thai Open Source Software Center Ltd
    +   Copyright (c) 2000-2017 Expat development team
    +   Licensed under the MIT license:
    +
    +   Permission is  hereby granted,  free of charge,  to any  person obtaining
    +   a  copy  of  this  software   and  associated  documentation  files  (the
    +   "Software"),  to  deal in  the  Software  without restriction,  including
    +   without  limitation the  rights  to use,  copy,  modify, merge,  publish,
    +   distribute, sublicense, and/or sell copies of the Software, and to permit
    +   persons  to whom  the Software  is  furnished to  do so,  subject to  the
    +   following conditions:
    +
    +   The above copyright  notice and this permission notice  shall be included
    +   in all copies or substantial portions of the Software.
    +
    +   THE  SOFTWARE  IS  PROVIDED  "AS  IS",  WITHOUT  WARRANTY  OF  ANY  KIND,
    +   EXPRESS  OR IMPLIED,  INCLUDING  BUT  NOT LIMITED  TO  THE WARRANTIES  OF
    +   MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN
    +   NO EVENT SHALL THE AUTHORS OR  COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
    +   DAMAGES OR  OTHER LIABILITY, WHETHER  IN AN  ACTION OF CONTRACT,  TORT OR
    +   OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE
    +   USE OR OTHER DEALINGS IN THE SOFTWARE.
     */
     
     #include 
    diff --git a/lib/xmlrole.h b/lib/xmlrole.h
    index 4dd9f06..e5f048e 100644
    --- a/lib/xmlrole.h
    +++ b/lib/xmlrole.h
    @@ -1,5 +1,33 @@
    -/* Copyright (c) 1998, 1999 Thai Open Source Software Center Ltd
    -   See the file COPYING for copying permission.
    +/*
    +                            __  __            _
    +                         ___\ \/ /_ __   __ _| |_
    +                        / _ \\  /| '_ \ / _` | __|
    +                       |  __//  \| |_) | (_| | |_
    +                        \___/_/\_\ .__/ \__,_|\__|
    +                                 |_| XML parser
    +
    +   Copyright (c) 1997-2000 Thai Open Source Software Center Ltd
    +   Copyright (c) 2000-2017 Expat development team
    +   Licensed under the MIT license:
    +
    +   Permission is  hereby granted,  free of charge,  to any  person obtaining
    +   a  copy  of  this  software   and  associated  documentation  files  (the
    +   "Software"),  to  deal in  the  Software  without restriction,  including
    +   without  limitation the  rights  to use,  copy,  modify, merge,  publish,
    +   distribute, sublicense, and/or sell copies of the Software, and to permit
    +   persons  to whom  the Software  is  furnished to  do so,  subject to  the
    +   following conditions:
    +
    +   The above copyright  notice and this permission notice  shall be included
    +   in all copies or substantial portions of the Software.
    +
    +   THE  SOFTWARE  IS  PROVIDED  "AS  IS",  WITHOUT  WARRANTY  OF  ANY  KIND,
    +   EXPRESS  OR IMPLIED,  INCLUDING  BUT  NOT LIMITED  TO  THE WARRANTIES  OF
    +   MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN
    +   NO EVENT SHALL THE AUTHORS OR  COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
    +   DAMAGES OR  OTHER LIABILITY, WHETHER  IN AN  ACTION OF CONTRACT,  TORT OR
    +   OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE
    +   USE OR OTHER DEALINGS IN THE SOFTWARE.
     */
     
     #ifndef XmlRole_INCLUDED
    diff --git a/lib/xmltok.c b/lib/xmltok.c
    index db4a5c8..007aed0 100644
    --- a/lib/xmltok.c
    +++ b/lib/xmltok.c
    @@ -1,8 +1,38 @@
    -/* Copyright (c) 1998, 1999 Thai Open Source Software Center Ltd
    -   See the file COPYING for copying permission.
    +/*
    +                            __  __            _
    +                         ___\ \/ /_ __   __ _| |_
    +                        / _ \\  /| '_ \ / _` | __|
    +                       |  __//  \| |_) | (_| | |_
    +                        \___/_/\_\ .__/ \__,_|\__|
    +                                 |_| XML parser
    +
    +   Copyright (c) 1997-2000 Thai Open Source Software Center Ltd
    +   Copyright (c) 2000-2017 Expat development team
    +   Licensed under the MIT license:
    +
    +   Permission is  hereby granted,  free of charge,  to any  person obtaining
    +   a  copy  of  this  software   and  associated  documentation  files  (the
    +   "Software"),  to  deal in  the  Software  without restriction,  including
    +   without  limitation the  rights  to use,  copy,  modify, merge,  publish,
    +   distribute, sublicense, and/or sell copies of the Software, and to permit
    +   persons  to whom  the Software  is  furnished to  do so,  subject to  the
    +   following conditions:
    +
    +   The above copyright  notice and this permission notice  shall be included
    +   in all copies or substantial portions of the Software.
    +
    +   THE  SOFTWARE  IS  PROVIDED  "AS  IS",  WITHOUT  WARRANTY  OF  ANY  KIND,
    +   EXPRESS  OR IMPLIED,  INCLUDING  BUT  NOT LIMITED  TO  THE WARRANTIES  OF
    +   MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN
    +   NO EVENT SHALL THE AUTHORS OR  COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
    +   DAMAGES OR  OTHER LIABILITY, WHETHER  IN AN  ACTION OF CONTRACT,  TORT OR
    +   OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE
    +   USE OR OTHER DEALINGS IN THE SOFTWARE.
     */
     
     #include 
    +#include 
    +#include   // memcpy
     
     #ifdef _WIN32
     #include "winconfig.h"
    @@ -363,22 +393,33 @@ utf8_toUtf8(const ENCODING *UNUSED_P(enc),
                 const char **fromP, const char *fromLim,
                 char **toP, const char *toLim)
     {
    -  char *to;
    -  const char *from;
    -  const char *fromLimInitial = fromLim;
    +  bool input_incomplete = false;
    +  bool output_exhausted = false;
    +
    +  /* Avoid copying partial characters (due to limited space). */
    +  const ptrdiff_t bytesAvailable = fromLim - *fromP;
    +  const ptrdiff_t bytesStorable = toLim - *toP;
    +  if (bytesAvailable > bytesStorable) {
    +    fromLim = *fromP + bytesStorable;
    +    output_exhausted = true;
    +  }
     
    -  /* Avoid copying partial characters. */
    +  /* Avoid copying partial characters (from incomplete input). */
    +  const char * const fromLimBefore = fromLim;
       align_limit_to_full_utf8_characters(*fromP, &fromLim);
    +  if (fromLim < fromLimBefore) {
    +    input_incomplete = true;
    +  }
     
    -  for (to = *toP, from = *fromP; (from < fromLim) && (to < toLim); from++, to++)
    -    *to = *from;
    -  *fromP = from;
    -  *toP = to;
    +  const ptrdiff_t bytesToCopy = fromLim - *fromP;
    +  memcpy((void *)*toP, (const void *)*fromP, (size_t)bytesToCopy);
    +  *fromP += bytesToCopy;
    +  *toP += bytesToCopy;
     
    -  if (fromLim < fromLimInitial)
    -    return XML_CONVERT_INPUT_INCOMPLETE;
    -  else if ((to == toLim) && (from < fromLim))
    +  if (output_exhausted)  // needs to go first
         return XML_CONVERT_OUTPUT_EXHAUSTED;
    +  else if (input_incomplete)
    +    return XML_CONVERT_INPUT_INCOMPLETE;
       else
         return XML_CONVERT_COMPLETED;
     }
    diff --git a/lib/xmltok.h b/lib/xmltok.h
    index 752007e..6d31879 100644
    --- a/lib/xmltok.h
    +++ b/lib/xmltok.h
    @@ -1,5 +1,33 @@
    -/* Copyright (c) 1998, 1999 Thai Open Source Software Center Ltd
    -   See the file COPYING for copying permission.
    +/*
    +                            __  __            _
    +                         ___\ \/ /_ __   __ _| |_
    +                        / _ \\  /| '_ \ / _` | __|
    +                       |  __//  \| |_) | (_| | |_
    +                        \___/_/\_\ .__/ \__,_|\__|
    +                                 |_| XML parser
    +
    +   Copyright (c) 1997-2000 Thai Open Source Software Center Ltd
    +   Copyright (c) 2000-2017 Expat development team
    +   Licensed under the MIT license:
    +
    +   Permission is  hereby granted,  free of charge,  to any  person obtaining
    +   a  copy  of  this  software   and  associated  documentation  files  (the
    +   "Software"),  to  deal in  the  Software  without restriction,  including
    +   without  limitation the  rights  to use,  copy,  modify, merge,  publish,
    +   distribute, sublicense, and/or sell copies of the Software, and to permit
    +   persons  to whom  the Software  is  furnished to  do so,  subject to  the
    +   following conditions:
    +
    +   The above copyright  notice and this permission notice  shall be included
    +   in all copies or substantial portions of the Software.
    +
    +   THE  SOFTWARE  IS  PROVIDED  "AS  IS",  WITHOUT  WARRANTY  OF  ANY  KIND,
    +   EXPRESS  OR IMPLIED,  INCLUDING  BUT  NOT LIMITED  TO  THE WARRANTIES  OF
    +   MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN
    +   NO EVENT SHALL THE AUTHORS OR  COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
    +   DAMAGES OR  OTHER LIABILITY, WHETHER  IN AN  ACTION OF CONTRACT,  TORT OR
    +   OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE
    +   USE OR OTHER DEALINGS IN THE SOFTWARE.
     */
     
     #ifndef XmlTok_INCLUDED
    diff --git a/lib/xmltok_impl.c b/lib/xmltok_impl.c
    index 4fa1ff6..93328b8 100644
    --- a/lib/xmltok_impl.c
    +++ b/lib/xmltok_impl.c
    @@ -1,8 +1,35 @@
    -/* Copyright (c) 1998, 1999 Thai Open Source Software Center Ltd
    -   See the file COPYING for copying permission.
    +/* This file is included!
    +                            __  __            _
    +                         ___\ \/ /_ __   __ _| |_
    +                        / _ \\  /| '_ \ / _` | __|
    +                       |  __//  \| |_) | (_| | |_
    +                        \___/_/\_\ .__/ \__,_|\__|
    +                                 |_| XML parser
    +
    +   Copyright (c) 1997-2000 Thai Open Source Software Center Ltd
    +   Copyright (c) 2000-2017 Expat development team
    +   Licensed under the MIT license:
    +
    +   Permission is  hereby granted,  free of charge,  to any  person obtaining
    +   a  copy  of  this  software   and  associated  documentation  files  (the
    +   "Software"),  to  deal in  the  Software  without restriction,  including
    +   without  limitation the  rights  to use,  copy,  modify, merge,  publish,
    +   distribute, sublicense, and/or sell copies of the Software, and to permit
    +   persons  to whom  the Software  is  furnished to  do so,  subject to  the
    +   following conditions:
    +
    +   The above copyright  notice and this permission notice  shall be included
    +   in all copies or substantial portions of the Software.
    +
    +   THE  SOFTWARE  IS  PROVIDED  "AS  IS",  WITHOUT  WARRANTY  OF  ANY  KIND,
    +   EXPRESS  OR IMPLIED,  INCLUDING  BUT  NOT LIMITED  TO  THE WARRANTIES  OF
    +   MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN
    +   NO EVENT SHALL THE AUTHORS OR  COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
    +   DAMAGES OR  OTHER LIABILITY, WHETHER  IN AN  ACTION OF CONTRACT,  TORT OR
    +   OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE
    +   USE OR OTHER DEALINGS IN THE SOFTWARE.
     */
     
    -/* This file is included! */
     #ifdef XML_TOK_IMPL_C
     
     #ifndef IS_INVALID_CHAR
    diff --git a/lib/xmltok_impl.h b/lib/xmltok_impl.h
    index da0ea60..a6420f4 100644
    --- a/lib/xmltok_impl.h
    +++ b/lib/xmltok_impl.h
    @@ -1,6 +1,33 @@
     /*
    -Copyright (c) 1998, 1999 Thai Open Source Software Center Ltd
    -See the file COPYING for copying permission.
    +                            __  __            _
    +                         ___\ \/ /_ __   __ _| |_
    +                        / _ \\  /| '_ \ / _` | __|
    +                       |  __//  \| |_) | (_| | |_
    +                        \___/_/\_\ .__/ \__,_|\__|
    +                                 |_| XML parser
    +
    +   Copyright (c) 1997-2000 Thai Open Source Software Center Ltd
    +   Copyright (c) 2000-2017 Expat development team
    +   Licensed under the MIT license:
    +
    +   Permission is  hereby granted,  free of charge,  to any  person obtaining
    +   a  copy  of  this  software   and  associated  documentation  files  (the
    +   "Software"),  to  deal in  the  Software  without restriction,  including
    +   without  limitation the  rights  to use,  copy,  modify, merge,  publish,
    +   distribute, sublicense, and/or sell copies of the Software, and to permit
    +   persons  to whom  the Software  is  furnished to  do so,  subject to  the
    +   following conditions:
    +
    +   The above copyright  notice and this permission notice  shall be included
    +   in all copies or substantial portions of the Software.
    +
    +   THE  SOFTWARE  IS  PROVIDED  "AS  IS",  WITHOUT  WARRANTY  OF  ANY  KIND,
    +   EXPRESS  OR IMPLIED,  INCLUDING  BUT  NOT LIMITED  TO  THE WARRANTIES  OF
    +   MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN
    +   NO EVENT SHALL THE AUTHORS OR  COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
    +   DAMAGES OR  OTHER LIABILITY, WHETHER  IN AN  ACTION OF CONTRACT,  TORT OR
    +   OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE
    +   USE OR OTHER DEALINGS IN THE SOFTWARE.
     */
     
     enum {
    diff --git a/lib/xmltok_ns.c b/lib/xmltok_ns.c
    index c3b88fd..23d31e8 100644
    --- a/lib/xmltok_ns.c
    +++ b/lib/xmltok_ns.c
    @@ -1,8 +1,35 @@
    -/* Copyright (c) 1998, 1999 Thai Open Source Software Center Ltd
    -   See the file COPYING for copying permission.
    +/* This file is included!
    +                            __  __            _
    +                         ___\ \/ /_ __   __ _| |_
    +                        / _ \\  /| '_ \ / _` | __|
    +                       |  __//  \| |_) | (_| | |_
    +                        \___/_/\_\ .__/ \__,_|\__|
    +                                 |_| XML parser
    +
    +   Copyright (c) 1997-2000 Thai Open Source Software Center Ltd
    +   Copyright (c) 2000-2017 Expat development team
    +   Licensed under the MIT license:
    +
    +   Permission is  hereby granted,  free of charge,  to any  person obtaining
    +   a  copy  of  this  software   and  associated  documentation  files  (the
    +   "Software"),  to  deal in  the  Software  without restriction,  including
    +   without  limitation the  rights  to use,  copy,  modify, merge,  publish,
    +   distribute, sublicense, and/or sell copies of the Software, and to permit
    +   persons  to whom  the Software  is  furnished to  do so,  subject to  the
    +   following conditions:
    +
    +   The above copyright  notice and this permission notice  shall be included
    +   in all copies or substantial portions of the Software.
    +
    +   THE  SOFTWARE  IS  PROVIDED  "AS  IS",  WITHOUT  WARRANTY  OF  ANY  KIND,
    +   EXPRESS  OR IMPLIED,  INCLUDING  BUT  NOT LIMITED  TO  THE WARRANTIES  OF
    +   MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN
    +   NO EVENT SHALL THE AUTHORS OR  COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
    +   DAMAGES OR  OTHER LIABILITY, WHETHER  IN AN  ACTION OF CONTRACT,  TORT OR
    +   OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE
    +   USE OR OTHER DEALINGS IN THE SOFTWARE.
     */
     
    -/* This file is included! */
     #ifdef XML_TOK_NS_C
     
     const ENCODING *
    diff --git a/test-driver-wrapper.sh b/test-driver-wrapper.sh
    new file mode 100755
    index 0000000..30b34d5
    --- /dev/null
    +++ b/test-driver-wrapper.sh
    @@ -0,0 +1,43 @@
    +#! /bin/bash
    +#                          __  __            _
    +#                       ___\ \/ /_ __   __ _| |_
    +#                      / _ \\  /| '_ \ / _` | __|
    +#                     |  __//  \| |_) | (_| | |_
    +#                      \___/_/\_\ .__/ \__,_|\__|
    +#                               |_| XML parser
    +#
    +# Copyright (c) 2017 Expat development team
    +# Licensed under the MIT license:
    +#
    +# Permission is  hereby granted,  free of charge,  to any  person obtaining
    +# a  copy  of  this  software   and  associated  documentation  files  (the
    +# "Software"),  to  deal in  the  Software  without restriction,  including
    +# without  limitation the  rights  to use,  copy,  modify, merge,  publish,
    +# distribute, sublicense, and/or sell copies of the Software, and to permit
    +# persons  to whom  the Software  is  furnished to  do so,  subject to  the
    +# following conditions:
    +#
    +# The above copyright  notice and this permission notice  shall be included
    +# in all copies or substantial portions of the Software.
    +#
    +# THE  SOFTWARE  IS  PROVIDED  "AS  IS",  WITHOUT  WARRANTY  OF  ANY  KIND,
    +# EXPRESS  OR IMPLIED,  INCLUDING  BUT  NOT LIMITED  TO  THE WARRANTIES  OF
    +# MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN
    +# NO EVENT SHALL THE AUTHORS OR  COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
    +# DAMAGES OR  OTHER LIABILITY, WHETHER  IN AN  ACTION OF CONTRACT,  TORT OR
    +# OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE
    +# USE OR OTHER DEALINGS IN THE SOFTWARE.
    +
    +set -e
    +top_srcdir="$(dirname "$(type -p "$0")")"
    +top_builddir=..
    +
    +# Suck up all dash-dash test-driver arguments
    +test_driver_args=()
    +while [[ ${1} != '--' ]]; do
    +    test_driver_args=( "${test_driver_args[@]}" "${1}" )
    +    shift
    +done
    +shift  # drop "--"
    +
    +exec "${top_srcdir}"/conftools/test-driver "${test_driver_args[@]}" "${top_builddir}"/run.sh "$@"
    diff --git a/tests/Makefile.am b/tests/Makefile.am
    new file mode 100644
    index 0000000..ff19bd7
    --- /dev/null
    +++ b/tests/Makefile.am
    @@ -0,0 +1,63 @@
    +#
    +#                          __  __            _
    +#                       ___\ \/ /_ __   __ _| |_
    +#                      / _ \\  /| '_ \ / _` | __|
    +#                     |  __//  \| |_) | (_| | |_
    +#                      \___/_/\_\ .__/ \__,_|\__|
    +#                               |_| XML parser
    +#
    +# Copyright (c) 2017 Expat development team
    +# Licensed under the MIT license:
    +#
    +# Permission is  hereby granted,  free of charge,  to any  person obtaining
    +# a  copy  of  this  software   and  associated  documentation  files  (the
    +# "Software"),  to  deal in  the  Software  without restriction,  including
    +# without  limitation the  rights  to use,  copy,  modify, merge,  publish,
    +# distribute, sublicense, and/or sell copies of the Software, and to permit
    +# persons  to whom  the Software  is  furnished to  do so,  subject to  the
    +# following conditions:
    +#
    +# The above copyright  notice and this permission notice  shall be included
    +# in all copies or substantial portions of the Software.
    +#
    +# THE  SOFTWARE  IS  PROVIDED  "AS  IS",  WITHOUT  WARRANTY  OF  ANY  KIND,
    +# EXPRESS  OR IMPLIED,  INCLUDING  BUT  NOT LIMITED  TO  THE WARRANTIES  OF
    +# MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN
    +# NO EVENT SHALL THE AUTHORS OR  COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
    +# DAMAGES OR  OTHER LIABILITY, WHETHER  IN AN  ACTION OF CONTRACT,  TORT OR
    +# OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE
    +# USE OR OTHER DEALINGS IN THE SOFTWARE.
    +
    +SUBDIRS = . benchmark
    +
    +AM_CPPFLAGS = -I$(srcdir)/../lib
    +
    +noinst_LIBRARIES = libruntests.a
    +
    +check_PROGRAMS = runtests runtestspp
    +TESTS = runtests runtestspp
    +
    +# To support MinGW and Non-MinGW at the same time:
    +LOG_DRIVER = $(srcdir)/../test-driver-wrapper.sh
    +
    +libruntests_a_SOURCES = \
    +    chardata.c \
    +    memcheck.c \
    +    minicheck.c
    +
    +runtests_SOURCES = \
    +    runtests.c
    +
    +runtestspp_SOURCES = \
    +    runtestspp.cpp
    +
    +runtests_LDADD = libruntests.a ../lib/libexpat.la
    +runtestspp_LDADD = libruntests.a ../lib/libexpat.la
    +
    +EXTRA_DIST = \
    +    chardata.h \
    +    minicheck.h \
    +    memcheck.h \
    +    README.txt \
    +    xmltest.log.expected \
    +    xmltest.sh
    diff --git a/tests/Makefile.in b/tests/Makefile.in
    new file mode 100644
    index 0000000..2c6f482
    --- /dev/null
    +++ b/tests/Makefile.in
    @@ -0,0 +1,1214 @@
    +# Makefile.in generated by automake 1.15.1 from Makefile.am.
    +# @configure_input@
    +
    +# Copyright (C) 1994-2017 Free Software Foundation, Inc.
    +
    +# This Makefile.in is free software; the Free Software Foundation
    +# gives unlimited permission to copy and/or distribute it,
    +# with or without modifications, as long as this notice is preserved.
    +
    +# This program is distributed in the hope that it will be useful,
    +# but WITHOUT ANY WARRANTY, to the extent permitted by law; without
    +# even the implied warranty of MERCHANTABILITY or FITNESS FOR A
    +# PARTICULAR PURPOSE.
    +
    +@SET_MAKE@
    +
    +#
    +#                          __  __            _
    +#                       ___\ \/ /_ __   __ _| |_
    +#                      / _ \\  /| '_ \ / _` | __|
    +#                     |  __//  \| |_) | (_| | |_
    +#                      \___/_/\_\ .__/ \__,_|\__|
    +#                               |_| XML parser
    +#
    +# Copyright (c) 2017 Expat development team
    +# Licensed under the MIT license:
    +#
    +# Permission is  hereby granted,  free of charge,  to any  person obtaining
    +# a  copy  of  this  software   and  associated  documentation  files  (the
    +# "Software"),  to  deal in  the  Software  without restriction,  including
    +# without  limitation the  rights  to use,  copy,  modify, merge,  publish,
    +# distribute, sublicense, and/or sell copies of the Software, and to permit
    +# persons  to whom  the Software  is  furnished to  do so,  subject to  the
    +# following conditions:
    +#
    +# The above copyright  notice and this permission notice  shall be included
    +# in all copies or substantial portions of the Software.
    +#
    +# THE  SOFTWARE  IS  PROVIDED  "AS  IS",  WITHOUT  WARRANTY  OF  ANY  KIND,
    +# EXPRESS  OR IMPLIED,  INCLUDING  BUT  NOT LIMITED  TO  THE WARRANTIES  OF
    +# MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN
    +# NO EVENT SHALL THE AUTHORS OR  COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
    +# DAMAGES OR  OTHER LIABILITY, WHETHER  IN AN  ACTION OF CONTRACT,  TORT OR
    +# OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE
    +# USE OR OTHER DEALINGS IN THE SOFTWARE.
    +
    +VPATH = @srcdir@
    +am__is_gnu_make = { \
    +  if test -z '$(MAKELEVEL)'; then \
    +    false; \
    +  elif test -n '$(MAKE_HOST)'; then \
    +    true; \
    +  elif test -n '$(MAKE_VERSION)' && test -n '$(CURDIR)'; then \
    +    true; \
    +  else \
    +    false; \
    +  fi; \
    +}
    +am__make_running_with_option = \
    +  case $${target_option-} in \
    +      ?) ;; \
    +      *) echo "am__make_running_with_option: internal error: invalid" \
    +              "target option '$${target_option-}' specified" >&2; \
    +         exit 1;; \
    +  esac; \
    +  has_opt=no; \
    +  sane_makeflags=$$MAKEFLAGS; \
    +  if $(am__is_gnu_make); then \
    +    sane_makeflags=$$MFLAGS; \
    +  else \
    +    case $$MAKEFLAGS in \
    +      *\\[\ \	]*) \
    +        bs=\\; \
    +        sane_makeflags=`printf '%s\n' "$$MAKEFLAGS" \
    +          | sed "s/$$bs$$bs[$$bs $$bs	]*//g"`;; \
    +    esac; \
    +  fi; \
    +  skip_next=no; \
    +  strip_trailopt () \
    +  { \
    +    flg=`printf '%s\n' "$$flg" | sed "s/$$1.*$$//"`; \
    +  }; \
    +  for flg in $$sane_makeflags; do \
    +    test $$skip_next = yes && { skip_next=no; continue; }; \
    +    case $$flg in \
    +      *=*|--*) continue;; \
    +        -*I) strip_trailopt 'I'; skip_next=yes;; \
    +      -*I?*) strip_trailopt 'I';; \
    +        -*O) strip_trailopt 'O'; skip_next=yes;; \
    +      -*O?*) strip_trailopt 'O';; \
    +        -*l) strip_trailopt 'l'; skip_next=yes;; \
    +      -*l?*) strip_trailopt 'l';; \
    +      -[dEDm]) skip_next=yes;; \
    +      -[JT]) skip_next=yes;; \
    +    esac; \
    +    case $$flg in \
    +      *$$target_option*) has_opt=yes; break;; \
    +    esac; \
    +  done; \
    +  test $$has_opt = yes
    +am__make_dryrun = (target_option=n; $(am__make_running_with_option))
    +am__make_keepgoing = (target_option=k; $(am__make_running_with_option))
    +pkgdatadir = $(datadir)/@PACKAGE@
    +pkgincludedir = $(includedir)/@PACKAGE@
    +pkglibdir = $(libdir)/@PACKAGE@
    +pkglibexecdir = $(libexecdir)/@PACKAGE@
    +am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd
    +install_sh_DATA = $(install_sh) -c -m 644
    +install_sh_PROGRAM = $(install_sh) -c
    +install_sh_SCRIPT = $(install_sh) -c
    +INSTALL_HEADER = $(INSTALL_DATA)
    +transform = $(program_transform_name)
    +NORMAL_INSTALL = :
    +PRE_INSTALL = :
    +POST_INSTALL = :
    +NORMAL_UNINSTALL = :
    +PRE_UNINSTALL = :
    +POST_UNINSTALL = :
    +build_triplet = @build@
    +host_triplet = @host@
    +check_PROGRAMS = runtests$(EXEEXT) runtestspp$(EXEEXT)
    +TESTS = runtests$(EXEEXT) runtestspp$(EXEEXT)
    +subdir = tests
    +ACLOCAL_M4 = $(top_srcdir)/aclocal.m4
    +am__aclocal_m4_deps = $(top_srcdir)/m4/libtool.m4 \
    +	$(top_srcdir)/m4/ltoptions.m4 $(top_srcdir)/m4/ltsugar.m4 \
    +	$(top_srcdir)/m4/ltversion.m4 $(top_srcdir)/m4/lt~obsolete.m4 \
    +	$(top_srcdir)/conftools/ac_c_bigendian_cross.m4 \
    +	$(top_srcdir)/configure.ac
    +am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \
    +	$(ACLOCAL_M4)
    +DIST_COMMON = $(srcdir)/Makefile.am $(am__DIST_COMMON)
    +mkinstalldirs = $(install_sh) -d
    +CONFIG_HEADER = $(top_builddir)/expat_config.h
    +CONFIG_CLEAN_FILES =
    +CONFIG_CLEAN_VPATH_FILES =
    +LIBRARIES = $(noinst_LIBRARIES)
    +ARFLAGS = cru
    +AM_V_AR = $(am__v_AR_@AM_V@)
    +am__v_AR_ = $(am__v_AR_@AM_DEFAULT_V@)
    +am__v_AR_0 = @echo "  AR      " $@;
    +am__v_AR_1 = 
    +libruntests_a_AR = $(AR) $(ARFLAGS)
    +libruntests_a_LIBADD =
    +am_libruntests_a_OBJECTS = chardata.$(OBJEXT) memcheck.$(OBJEXT) \
    +	minicheck.$(OBJEXT)
    +libruntests_a_OBJECTS = $(am_libruntests_a_OBJECTS)
    +am_runtests_OBJECTS = runtests.$(OBJEXT)
    +runtests_OBJECTS = $(am_runtests_OBJECTS)
    +runtests_DEPENDENCIES = libruntests.a ../lib/libexpat.la
    +AM_V_lt = $(am__v_lt_@AM_V@)
    +am__v_lt_ = $(am__v_lt_@AM_DEFAULT_V@)
    +am__v_lt_0 = --silent
    +am__v_lt_1 = 
    +am_runtestspp_OBJECTS = runtestspp.$(OBJEXT)
    +runtestspp_OBJECTS = $(am_runtestspp_OBJECTS)
    +runtestspp_DEPENDENCIES = libruntests.a ../lib/libexpat.la
    +AM_V_P = $(am__v_P_@AM_V@)
    +am__v_P_ = $(am__v_P_@AM_DEFAULT_V@)
    +am__v_P_0 = false
    +am__v_P_1 = :
    +AM_V_GEN = $(am__v_GEN_@AM_V@)
    +am__v_GEN_ = $(am__v_GEN_@AM_DEFAULT_V@)
    +am__v_GEN_0 = @echo "  GEN     " $@;
    +am__v_GEN_1 = 
    +AM_V_at = $(am__v_at_@AM_V@)
    +am__v_at_ = $(am__v_at_@AM_DEFAULT_V@)
    +am__v_at_0 = @
    +am__v_at_1 = 
    +DEFAULT_INCLUDES = -I.@am__isrc@ -I$(top_builddir)
    +depcomp = $(SHELL) $(top_srcdir)/conftools/depcomp
    +am__depfiles_maybe = depfiles
    +am__mv = mv -f
    +COMPILE = $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) \
    +	$(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS)
    +LTCOMPILE = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \
    +	$(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) \
    +	$(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) \
    +	$(AM_CFLAGS) $(CFLAGS)
    +AM_V_CC = $(am__v_CC_@AM_V@)
    +am__v_CC_ = $(am__v_CC_@AM_DEFAULT_V@)
    +am__v_CC_0 = @echo "  CC      " $@;
    +am__v_CC_1 = 
    +CCLD = $(CC)
    +LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \
    +	$(LIBTOOLFLAGS) --mode=link $(CCLD) $(AM_CFLAGS) $(CFLAGS) \
    +	$(AM_LDFLAGS) $(LDFLAGS) -o $@
    +AM_V_CCLD = $(am__v_CCLD_@AM_V@)
    +am__v_CCLD_ = $(am__v_CCLD_@AM_DEFAULT_V@)
    +am__v_CCLD_0 = @echo "  CCLD    " $@;
    +am__v_CCLD_1 = 
    +CXXCOMPILE = $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) \
    +	$(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS)
    +LTCXXCOMPILE = $(LIBTOOL) $(AM_V_lt) --tag=CXX $(AM_LIBTOOLFLAGS) \
    +	$(LIBTOOLFLAGS) --mode=compile $(CXX) $(DEFS) \
    +	$(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) \
    +	$(AM_CXXFLAGS) $(CXXFLAGS)
    +AM_V_CXX = $(am__v_CXX_@AM_V@)
    +am__v_CXX_ = $(am__v_CXX_@AM_DEFAULT_V@)
    +am__v_CXX_0 = @echo "  CXX     " $@;
    +am__v_CXX_1 = 
    +CXXLD = $(CXX)
    +CXXLINK = $(LIBTOOL) $(AM_V_lt) --tag=CXX $(AM_LIBTOOLFLAGS) \
    +	$(LIBTOOLFLAGS) --mode=link $(CXXLD) $(AM_CXXFLAGS) \
    +	$(CXXFLAGS) $(AM_LDFLAGS) $(LDFLAGS) -o $@
    +AM_V_CXXLD = $(am__v_CXXLD_@AM_V@)
    +am__v_CXXLD_ = $(am__v_CXXLD_@AM_DEFAULT_V@)
    +am__v_CXXLD_0 = @echo "  CXXLD   " $@;
    +am__v_CXXLD_1 = 
    +SOURCES = $(libruntests_a_SOURCES) $(runtests_SOURCES) \
    +	$(runtestspp_SOURCES)
    +DIST_SOURCES = $(libruntests_a_SOURCES) $(runtests_SOURCES) \
    +	$(runtestspp_SOURCES)
    +RECURSIVE_TARGETS = all-recursive check-recursive cscopelist-recursive \
    +	ctags-recursive dvi-recursive html-recursive info-recursive \
    +	install-data-recursive install-dvi-recursive \
    +	install-exec-recursive install-html-recursive \
    +	install-info-recursive install-pdf-recursive \
    +	install-ps-recursive install-recursive installcheck-recursive \
    +	installdirs-recursive pdf-recursive ps-recursive \
    +	tags-recursive uninstall-recursive
    +am__can_run_installinfo = \
    +  case $$AM_UPDATE_INFO_DIR in \
    +    n|no|NO) false;; \
    +    *) (install-info --version) >/dev/null 2>&1;; \
    +  esac
    +RECURSIVE_CLEAN_TARGETS = mostlyclean-recursive clean-recursive	\
    +  distclean-recursive maintainer-clean-recursive
    +am__recursive_targets = \
    +  $(RECURSIVE_TARGETS) \
    +  $(RECURSIVE_CLEAN_TARGETS) \
    +  $(am__extra_recursive_targets)
    +AM_RECURSIVE_TARGETS = $(am__recursive_targets:-recursive=) TAGS CTAGS \
    +	check recheck distdir
    +am__tagged_files = $(HEADERS) $(SOURCES) $(TAGS_FILES) $(LISP)
    +# Read a list of newline-separated strings from the standard input,
    +# and print each of them once, without duplicates.  Input order is
    +# *not* preserved.
    +am__uniquify_input = $(AWK) '\
    +  BEGIN { nonempty = 0; } \
    +  { items[$$0] = 1; nonempty = 1; } \
    +  END { if (nonempty) { for (i in items) print i; }; } \
    +'
    +# Make sure the list of sources is unique.  This is necessary because,
    +# e.g., the same source file might be shared among _SOURCES variables
    +# for different programs/libraries.
    +am__define_uniq_tagged_files = \
    +  list='$(am__tagged_files)'; \
    +  unique=`for i in $$list; do \
    +    if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \
    +  done | $(am__uniquify_input)`
    +ETAGS = etags
    +CTAGS = ctags
    +am__tty_colors_dummy = \
    +  mgn= red= grn= lgn= blu= brg= std=; \
    +  am__color_tests=no
    +am__tty_colors = { \
    +  $(am__tty_colors_dummy); \
    +  if test "X$(AM_COLOR_TESTS)" = Xno; then \
    +    am__color_tests=no; \
    +  elif test "X$(AM_COLOR_TESTS)" = Xalways; then \
    +    am__color_tests=yes; \
    +  elif test "X$$TERM" != Xdumb && { test -t 1; } 2>/dev/null; then \
    +    am__color_tests=yes; \
    +  fi; \
    +  if test $$am__color_tests = yes; then \
    +    red=''; \
    +    grn=''; \
    +    lgn=''; \
    +    blu=''; \
    +    mgn=''; \
    +    brg=''; \
    +    std=''; \
    +  fi; \
    +}
    +am__vpath_adj_setup = srcdirstrip=`echo "$(srcdir)" | sed 's|.|.|g'`;
    +am__vpath_adj = case $$p in \
    +    $(srcdir)/*) f=`echo "$$p" | sed "s|^$$srcdirstrip/||"`;; \
    +    *) f=$$p;; \
    +  esac;
    +am__strip_dir = f=`echo $$p | sed -e 's|^.*/||'`;
    +am__install_max = 40
    +am__nobase_strip_setup = \
    +  srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*|]/\\\\&/g'`
    +am__nobase_strip = \
    +  for p in $$list; do echo "$$p"; done | sed -e "s|$$srcdirstrip/||"
    +am__nobase_list = $(am__nobase_strip_setup); \
    +  for p in $$list; do echo "$$p $$p"; done | \
    +  sed "s| $$srcdirstrip/| |;"' / .*\//!s/ .*/ ./; s,\( .*\)/[^/]*$$,\1,' | \
    +  $(AWK) 'BEGIN { files["."] = "" } { files[$$2] = files[$$2] " " $$1; \
    +    if (++n[$$2] == $(am__install_max)) \
    +      { print $$2, files[$$2]; n[$$2] = 0; files[$$2] = "" } } \
    +    END { for (dir in files) print dir, files[dir] }'
    +am__base_list = \
    +  sed '$$!N;$$!N;$$!N;$$!N;$$!N;$$!N;$$!N;s/\n/ /g' | \
    +  sed '$$!N;$$!N;$$!N;$$!N;s/\n/ /g'
    +am__uninstall_files_from_dir = { \
    +  test -z "$$files" \
    +    || { test ! -d "$$dir" && test ! -f "$$dir" && test ! -r "$$dir"; } \
    +    || { echo " ( cd '$$dir' && rm -f" $$files ")"; \
    +         $(am__cd) "$$dir" && rm -f $$files; }; \
    +  }
    +am__recheck_rx = ^[ 	]*:recheck:[ 	]*
    +am__global_test_result_rx = ^[ 	]*:global-test-result:[ 	]*
    +am__copy_in_global_log_rx = ^[ 	]*:copy-in-global-log:[ 	]*
    +# A command that, given a newline-separated list of test names on the
    +# standard input, print the name of the tests that are to be re-run
    +# upon "make recheck".
    +am__list_recheck_tests = $(AWK) '{ \
    +  recheck = 1; \
    +  while ((rc = (getline line < ($$0 ".trs"))) != 0) \
    +    { \
    +      if (rc < 0) \
    +        { \
    +          if ((getline line2 < ($$0 ".log")) < 0) \
    +	    recheck = 0; \
    +          break; \
    +        } \
    +      else if (line ~ /$(am__recheck_rx)[nN][Oo]/) \
    +        { \
    +          recheck = 0; \
    +          break; \
    +        } \
    +      else if (line ~ /$(am__recheck_rx)[yY][eE][sS]/) \
    +        { \
    +          break; \
    +        } \
    +    }; \
    +  if (recheck) \
    +    print $$0; \
    +  close ($$0 ".trs"); \
    +  close ($$0 ".log"); \
    +}'
    +# A command that, given a newline-separated list of test names on the
    +# standard input, create the global log from their .trs and .log files.
    +am__create_global_log = $(AWK) ' \
    +function fatal(msg) \
    +{ \
    +  print "fatal: making $@: " msg | "cat >&2"; \
    +  exit 1; \
    +} \
    +function rst_section(header) \
    +{ \
    +  print header; \
    +  len = length(header); \
    +  for (i = 1; i <= len; i = i + 1) \
    +    printf "="; \
    +  printf "\n\n"; \
    +} \
    +{ \
    +  copy_in_global_log = 1; \
    +  global_test_result = "RUN"; \
    +  while ((rc = (getline line < ($$0 ".trs"))) != 0) \
    +    { \
    +      if (rc < 0) \
    +         fatal("failed to read from " $$0 ".trs"); \
    +      if (line ~ /$(am__global_test_result_rx)/) \
    +        { \
    +          sub("$(am__global_test_result_rx)", "", line); \
    +          sub("[ 	]*$$", "", line); \
    +          global_test_result = line; \
    +        } \
    +      else if (line ~ /$(am__copy_in_global_log_rx)[nN][oO]/) \
    +        copy_in_global_log = 0; \
    +    }; \
    +  if (copy_in_global_log) \
    +    { \
    +      rst_section(global_test_result ": " $$0); \
    +      while ((rc = (getline line < ($$0 ".log"))) != 0) \
    +      { \
    +        if (rc < 0) \
    +          fatal("failed to read from " $$0 ".log"); \
    +        print line; \
    +      }; \
    +      printf "\n"; \
    +    }; \
    +  close ($$0 ".trs"); \
    +  close ($$0 ".log"); \
    +}'
    +# Restructured Text title.
    +am__rst_title = { sed 's/.*/   &   /;h;s/./=/g;p;x;s/ *$$//;p;g' && echo; }
    +# Solaris 10 'make', and several other traditional 'make' implementations,
    +# pass "-e" to $(SHELL), and POSIX 2008 even requires this.  Work around it
    +# by disabling -e (using the XSI extension "set +e") if it's set.
    +am__sh_e_setup = case $$- in *e*) set +e;; esac
    +# Default flags passed to test drivers.
    +am__common_driver_flags = \
    +  --color-tests "$$am__color_tests" \
    +  --enable-hard-errors "$$am__enable_hard_errors" \
    +  --expect-failure "$$am__expect_failure"
    +# To be inserted before the command running the test.  Creates the
    +# directory for the log if needed.  Stores in $dir the directory
    +# containing $f, in $tst the test, in $log the log.  Executes the
    +# developer- defined test setup AM_TESTS_ENVIRONMENT (if any), and
    +# passes TESTS_ENVIRONMENT.  Set up options for the wrapper that
    +# will run the test scripts (or their associated LOG_COMPILER, if
    +# thy have one).
    +am__check_pre = \
    +$(am__sh_e_setup);					\
    +$(am__vpath_adj_setup) $(am__vpath_adj)			\
    +$(am__tty_colors);					\
    +srcdir=$(srcdir); export srcdir;			\
    +case "$@" in						\
    +  */*) am__odir=`echo "./$@" | sed 's|/[^/]*$$||'`;;	\
    +    *) am__odir=.;; 					\
    +esac;							\
    +test "x$$am__odir" = x"." || test -d "$$am__odir" 	\
    +  || $(MKDIR_P) "$$am__odir" || exit $$?;		\
    +if test -f "./$$f"; then dir=./;			\
    +elif test -f "$$f"; then dir=;				\
    +else dir="$(srcdir)/"; fi;				\
    +tst=$$dir$$f; log='$@'; 				\
    +if test -n '$(DISABLE_HARD_ERRORS)'; then		\
    +  am__enable_hard_errors=no; 				\
    +else							\
    +  am__enable_hard_errors=yes; 				\
    +fi; 							\
    +case " $(XFAIL_TESTS) " in				\
    +  *[\ \	]$$f[\ \	]* | *[\ \	]$$dir$$f[\ \	]*) \
    +    am__expect_failure=yes;;				\
    +  *)							\
    +    am__expect_failure=no;;				\
    +esac; 							\
    +$(AM_TESTS_ENVIRONMENT) $(TESTS_ENVIRONMENT)
    +# A shell command to get the names of the tests scripts with any registered
    +# extension removed (i.e., equivalently, the names of the test logs, with
    +# the '.log' extension removed).  The result is saved in the shell variable
    +# '$bases'.  This honors runtime overriding of TESTS and TEST_LOGS.  Sadly,
    +# we cannot use something simpler, involving e.g., "$(TEST_LOGS:.log=)",
    +# since that might cause problem with VPATH rewrites for suffix-less tests.
    +# See also 'test-harness-vpath-rewrite.sh' and 'test-trs-basic.sh'.
    +am__set_TESTS_bases = \
    +  bases='$(TEST_LOGS)'; \
    +  bases=`for i in $$bases; do echo $$i; done | sed 's/\.log$$//'`; \
    +  bases=`echo $$bases`
    +RECHECK_LOGS = $(TEST_LOGS)
    +TEST_SUITE_LOG = test-suite.log
    +TEST_EXTENSIONS = @EXEEXT@ .test
    +LOG_COMPILE = $(LOG_COMPILER) $(AM_LOG_FLAGS) $(LOG_FLAGS)
    +am__set_b = \
    +  case '$@' in \
    +    */*) \
    +      case '$*' in \
    +        */*) b='$*';; \
    +          *) b=`echo '$@' | sed 's/\.log$$//'`; \
    +       esac;; \
    +    *) \
    +      b='$*';; \
    +  esac
    +am__test_logs1 = $(TESTS:=.log)
    +am__test_logs2 = $(am__test_logs1:@EXEEXT@.log=.log)
    +TEST_LOGS = $(am__test_logs2:.test.log=.log)
    +TEST_LOG_DRIVER = $(SHELL) $(top_srcdir)/conftools/test-driver
    +TEST_LOG_COMPILE = $(TEST_LOG_COMPILER) $(AM_TEST_LOG_FLAGS) \
    +	$(TEST_LOG_FLAGS)
    +DIST_SUBDIRS = $(SUBDIRS)
    +am__DIST_COMMON = $(srcdir)/Makefile.in \
    +	$(top_srcdir)/conftools/depcomp \
    +	$(top_srcdir)/conftools/test-driver
    +DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST)
    +am__relativize = \
    +  dir0=`pwd`; \
    +  sed_first='s,^\([^/]*\)/.*$$,\1,'; \
    +  sed_rest='s,^[^/]*/*,,'; \
    +  sed_last='s,^.*/\([^/]*\)$$,\1,'; \
    +  sed_butlast='s,/*[^/]*$$,,'; \
    +  while test -n "$$dir1"; do \
    +    first=`echo "$$dir1" | sed -e "$$sed_first"`; \
    +    if test "$$first" != "."; then \
    +      if test "$$first" = ".."; then \
    +        dir2=`echo "$$dir0" | sed -e "$$sed_last"`/"$$dir2"; \
    +        dir0=`echo "$$dir0" | sed -e "$$sed_butlast"`; \
    +      else \
    +        first2=`echo "$$dir2" | sed -e "$$sed_first"`; \
    +        if test "$$first2" = "$$first"; then \
    +          dir2=`echo "$$dir2" | sed -e "$$sed_rest"`; \
    +        else \
    +          dir2="../$$dir2"; \
    +        fi; \
    +        dir0="$$dir0"/"$$first"; \
    +      fi; \
    +    fi; \
    +    dir1=`echo "$$dir1" | sed -e "$$sed_rest"`; \
    +  done; \
    +  reldir="$$dir2"
    +ACLOCAL = @ACLOCAL@
    +AMTAR = @AMTAR@
    +AM_DEFAULT_VERBOSITY = @AM_DEFAULT_VERBOSITY@
    +AR = @AR@
    +AS = @AS@
    +AUTOCONF = @AUTOCONF@
    +AUTOHEADER = @AUTOHEADER@
    +AUTOMAKE = @AUTOMAKE@
    +AWK = @AWK@
    +CC = @CC@
    +CCDEPMODE = @CCDEPMODE@
    +CFLAGS = @CFLAGS@
    +CPP = @CPP@
    +CPPFLAGS = @CPPFLAGS@
    +CXX = @CXX@
    +CXXCPP = @CXXCPP@
    +CXXDEPMODE = @CXXDEPMODE@
    +CXXFLAGS = @CXXFLAGS@
    +CYGPATH_W = @CYGPATH_W@
    +DEFS = @DEFS@
    +DEPDIR = @DEPDIR@
    +DLLTOOL = @DLLTOOL@
    +DSYMUTIL = @DSYMUTIL@
    +DUMPBIN = @DUMPBIN@
    +ECHO_C = @ECHO_C@
    +ECHO_N = @ECHO_N@
    +ECHO_T = @ECHO_T@
    +EGREP = @EGREP@
    +EXEEXT = @EXEEXT@
    +FGREP = @FGREP@
    +FILEMAP = @FILEMAP@
    +GREP = @GREP@
    +INSTALL = @INSTALL@
    +INSTALL_DATA = @INSTALL_DATA@
    +INSTALL_PROGRAM = @INSTALL_PROGRAM@
    +INSTALL_SCRIPT = @INSTALL_SCRIPT@
    +INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@
    +LD = @LD@
    +LDFLAGS = @LDFLAGS@
    +LIBAGE = @LIBAGE@
    +LIBCURRENT = @LIBCURRENT@
    +LIBOBJS = @LIBOBJS@
    +LIBREVISION = @LIBREVISION@
    +LIBS = @LIBS@
    +LIBTOOL = @LIBTOOL@
    +LIPO = @LIPO@
    +LN_S = @LN_S@
    +LTLIBOBJS = @LTLIBOBJS@
    +LT_SYS_LIBRARY_PATH = @LT_SYS_LIBRARY_PATH@
    +MAKEINFO = @MAKEINFO@
    +MANIFEST_TOOL = @MANIFEST_TOOL@
    +MKDIR_P = @MKDIR_P@
    +NM = @NM@
    +NMEDIT = @NMEDIT@
    +OBJDUMP = @OBJDUMP@
    +OBJEXT = @OBJEXT@
    +OTOOL = @OTOOL@
    +OTOOL64 = @OTOOL64@
    +PACKAGE = @PACKAGE@
    +PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@
    +PACKAGE_NAME = @PACKAGE_NAME@
    +PACKAGE_STRING = @PACKAGE_STRING@
    +PACKAGE_TARNAME = @PACKAGE_TARNAME@
    +PACKAGE_URL = @PACKAGE_URL@
    +PACKAGE_VERSION = @PACKAGE_VERSION@
    +PATH_SEPARATOR = @PATH_SEPARATOR@
    +RANLIB = @RANLIB@
    +SED = @SED@
    +SET_MAKE = @SET_MAKE@
    +SHELL = @SHELL@
    +STRIP = @STRIP@
    +VERSION = @VERSION@
    +abs_builddir = @abs_builddir@
    +abs_srcdir = @abs_srcdir@
    +abs_top_builddir = @abs_top_builddir@
    +abs_top_srcdir = @abs_top_srcdir@
    +ac_ct_AR = @ac_ct_AR@
    +ac_ct_CC = @ac_ct_CC@
    +ac_ct_CXX = @ac_ct_CXX@
    +ac_ct_DUMPBIN = @ac_ct_DUMPBIN@
    +am__include = @am__include@
    +am__leading_dot = @am__leading_dot@
    +am__quote = @am__quote@
    +am__tar = @am__tar@
    +am__untar = @am__untar@
    +bindir = @bindir@
    +build = @build@
    +build_alias = @build_alias@
    +build_cpu = @build_cpu@
    +build_os = @build_os@
    +build_vendor = @build_vendor@
    +builddir = @builddir@
    +datadir = @datadir@
    +datarootdir = @datarootdir@
    +docdir = @docdir@
    +dvidir = @dvidir@
    +exec_prefix = @exec_prefix@
    +host = @host@
    +host_alias = @host_alias@
    +host_cpu = @host_cpu@
    +host_os = @host_os@
    +host_vendor = @host_vendor@
    +htmldir = @htmldir@
    +includedir = @includedir@
    +infodir = @infodir@
    +install_sh = @install_sh@
    +libdir = @libdir@
    +libexecdir = @libexecdir@
    +localedir = @localedir@
    +localstatedir = @localstatedir@
    +mandir = @mandir@
    +mkdir_p = @mkdir_p@
    +oldincludedir = @oldincludedir@
    +pdfdir = @pdfdir@
    +prefix = @prefix@
    +program_transform_name = @program_transform_name@
    +psdir = @psdir@
    +sbindir = @sbindir@
    +sharedstatedir = @sharedstatedir@
    +srcdir = @srcdir@
    +sysconfdir = @sysconfdir@
    +target_alias = @target_alias@
    +top_build_prefix = @top_build_prefix@
    +top_builddir = @top_builddir@
    +top_srcdir = @top_srcdir@
    +SUBDIRS = . benchmark
    +AM_CPPFLAGS = -I$(srcdir)/../lib
    +noinst_LIBRARIES = libruntests.a
    +
    +# To support MinGW and Non-MinGW at the same time:
    +LOG_DRIVER = $(srcdir)/../test-driver-wrapper.sh
    +libruntests_a_SOURCES = \
    +    chardata.c \
    +    memcheck.c \
    +    minicheck.c
    +
    +runtests_SOURCES = \
    +    runtests.c
    +
    +runtestspp_SOURCES = \
    +    runtestspp.cpp
    +
    +runtests_LDADD = libruntests.a ../lib/libexpat.la
    +runtestspp_LDADD = libruntests.a ../lib/libexpat.la
    +EXTRA_DIST = \
    +    chardata.h \
    +    minicheck.h \
    +    memcheck.h \
    +    README.txt \
    +    xmltest.log.expected \
    +    xmltest.sh
    +
    +all: all-recursive
    +
    +.SUFFIXES:
    +.SUFFIXES: .c .cpp .lo .log .o .obj .test .test$(EXEEXT) .trs
    +$(srcdir)/Makefile.in:  $(srcdir)/Makefile.am  $(am__configure_deps)
    +	@for dep in $?; do \
    +	  case '$(am__configure_deps)' in \
    +	    *$$dep*) \
    +	      ( cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh ) \
    +	        && { if test -f $@; then exit 0; else break; fi; }; \
    +	      exit 1;; \
    +	  esac; \
    +	done; \
    +	echo ' cd $(top_srcdir) && $(AUTOMAKE) --gnu tests/Makefile'; \
    +	$(am__cd) $(top_srcdir) && \
    +	  $(AUTOMAKE) --gnu tests/Makefile
    +Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status
    +	@case '$?' in \
    +	  *config.status*) \
    +	    cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh;; \
    +	  *) \
    +	    echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe)'; \
    +	    cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe);; \
    +	esac;
    +
    +$(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES)
    +	cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh
    +
    +$(top_srcdir)/configure:  $(am__configure_deps)
    +	cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh
    +$(ACLOCAL_M4):  $(am__aclocal_m4_deps)
    +	cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh
    +$(am__aclocal_m4_deps):
    +
    +clean-noinstLIBRARIES:
    +	-test -z "$(noinst_LIBRARIES)" || rm -f $(noinst_LIBRARIES)
    +
    +libruntests.a: $(libruntests_a_OBJECTS) $(libruntests_a_DEPENDENCIES) $(EXTRA_libruntests_a_DEPENDENCIES) 
    +	$(AM_V_at)-rm -f libruntests.a
    +	$(AM_V_AR)$(libruntests_a_AR) libruntests.a $(libruntests_a_OBJECTS) $(libruntests_a_LIBADD)
    +	$(AM_V_at)$(RANLIB) libruntests.a
    +
    +clean-checkPROGRAMS:
    +	@list='$(check_PROGRAMS)'; test -n "$$list" || exit 0; \
    +	echo " rm -f" $$list; \
    +	rm -f $$list || exit $$?; \
    +	test -n "$(EXEEXT)" || exit 0; \
    +	list=`for p in $$list; do echo "$$p"; done | sed 's/$(EXEEXT)$$//'`; \
    +	echo " rm -f" $$list; \
    +	rm -f $$list
    +
    +runtests$(EXEEXT): $(runtests_OBJECTS) $(runtests_DEPENDENCIES) $(EXTRA_runtests_DEPENDENCIES) 
    +	@rm -f runtests$(EXEEXT)
    +	$(AM_V_CCLD)$(LINK) $(runtests_OBJECTS) $(runtests_LDADD) $(LIBS)
    +
    +runtestspp$(EXEEXT): $(runtestspp_OBJECTS) $(runtestspp_DEPENDENCIES) $(EXTRA_runtestspp_DEPENDENCIES) 
    +	@rm -f runtestspp$(EXEEXT)
    +	$(AM_V_CXXLD)$(CXXLINK) $(runtestspp_OBJECTS) $(runtestspp_LDADD) $(LIBS)
    +
    +mostlyclean-compile:
    +	-rm -f *.$(OBJEXT)
    +
    +distclean-compile:
    +	-rm -f *.tab.c
    +
    +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/chardata.Po@am__quote@
    +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/memcheck.Po@am__quote@
    +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/minicheck.Po@am__quote@
    +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/runtests.Po@am__quote@
    +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/runtestspp.Po@am__quote@
    +
    +.c.o:
    +@am__fastdepCC_TRUE@	$(AM_V_CC)$(COMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ $<
    +@am__fastdepCC_TRUE@	$(AM_V_at)$(am__mv) $(DEPDIR)/$*.Tpo $(DEPDIR)/$*.Po
    +@AMDEP_TRUE@@am__fastdepCC_FALSE@	$(AM_V_CC)source='$<' object='$@' libtool=no @AMDEPBACKSLASH@
    +@AMDEP_TRUE@@am__fastdepCC_FALSE@	DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
    +@am__fastdepCC_FALSE@	$(AM_V_CC@am__nodep@)$(COMPILE) -c -o $@ $<
    +
    +.c.obj:
    +@am__fastdepCC_TRUE@	$(AM_V_CC)$(COMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ `$(CYGPATH_W) '$<'`
    +@am__fastdepCC_TRUE@	$(AM_V_at)$(am__mv) $(DEPDIR)/$*.Tpo $(DEPDIR)/$*.Po
    +@AMDEP_TRUE@@am__fastdepCC_FALSE@	$(AM_V_CC)source='$<' object='$@' libtool=no @AMDEPBACKSLASH@
    +@AMDEP_TRUE@@am__fastdepCC_FALSE@	DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
    +@am__fastdepCC_FALSE@	$(AM_V_CC@am__nodep@)$(COMPILE) -c -o $@ `$(CYGPATH_W) '$<'`
    +
    +.c.lo:
    +@am__fastdepCC_TRUE@	$(AM_V_CC)$(LTCOMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ $<
    +@am__fastdepCC_TRUE@	$(AM_V_at)$(am__mv) $(DEPDIR)/$*.Tpo $(DEPDIR)/$*.Plo
    +@AMDEP_TRUE@@am__fastdepCC_FALSE@	$(AM_V_CC)source='$<' object='$@' libtool=yes @AMDEPBACKSLASH@
    +@AMDEP_TRUE@@am__fastdepCC_FALSE@	DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
    +@am__fastdepCC_FALSE@	$(AM_V_CC@am__nodep@)$(LTCOMPILE) -c -o $@ $<
    +
    +.cpp.o:
    +@am__fastdepCXX_TRUE@	$(AM_V_CXX)$(CXXCOMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ $<
    +@am__fastdepCXX_TRUE@	$(AM_V_at)$(am__mv) $(DEPDIR)/$*.Tpo $(DEPDIR)/$*.Po
    +@AMDEP_TRUE@@am__fastdepCXX_FALSE@	$(AM_V_CXX)source='$<' object='$@' libtool=no @AMDEPBACKSLASH@
    +@AMDEP_TRUE@@am__fastdepCXX_FALSE@	DEPDIR=$(DEPDIR) $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@
    +@am__fastdepCXX_FALSE@	$(AM_V_CXX@am__nodep@)$(CXXCOMPILE) -c -o $@ $<
    +
    +.cpp.obj:
    +@am__fastdepCXX_TRUE@	$(AM_V_CXX)$(CXXCOMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ `$(CYGPATH_W) '$<'`
    +@am__fastdepCXX_TRUE@	$(AM_V_at)$(am__mv) $(DEPDIR)/$*.Tpo $(DEPDIR)/$*.Po
    +@AMDEP_TRUE@@am__fastdepCXX_FALSE@	$(AM_V_CXX)source='$<' object='$@' libtool=no @AMDEPBACKSLASH@
    +@AMDEP_TRUE@@am__fastdepCXX_FALSE@	DEPDIR=$(DEPDIR) $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@
    +@am__fastdepCXX_FALSE@	$(AM_V_CXX@am__nodep@)$(CXXCOMPILE) -c -o $@ `$(CYGPATH_W) '$<'`
    +
    +.cpp.lo:
    +@am__fastdepCXX_TRUE@	$(AM_V_CXX)$(LTCXXCOMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ $<
    +@am__fastdepCXX_TRUE@	$(AM_V_at)$(am__mv) $(DEPDIR)/$*.Tpo $(DEPDIR)/$*.Plo
    +@AMDEP_TRUE@@am__fastdepCXX_FALSE@	$(AM_V_CXX)source='$<' object='$@' libtool=yes @AMDEPBACKSLASH@
    +@AMDEP_TRUE@@am__fastdepCXX_FALSE@	DEPDIR=$(DEPDIR) $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@
    +@am__fastdepCXX_FALSE@	$(AM_V_CXX@am__nodep@)$(LTCXXCOMPILE) -c -o $@ $<
    +
    +mostlyclean-libtool:
    +	-rm -f *.lo
    +
    +clean-libtool:
    +	-rm -rf .libs _libs
    +
    +# This directory's subdirectories are mostly independent; you can cd
    +# into them and run 'make' without going through this Makefile.
    +# To change the values of 'make' variables: instead of editing Makefiles,
    +# (1) if the variable is set in 'config.status', edit 'config.status'
    +#     (which will cause the Makefiles to be regenerated when you run 'make');
    +# (2) otherwise, pass the desired values on the 'make' command line.
    +$(am__recursive_targets):
    +	@fail=; \
    +	if $(am__make_keepgoing); then \
    +	  failcom='fail=yes'; \
    +	else \
    +	  failcom='exit 1'; \
    +	fi; \
    +	dot_seen=no; \
    +	target=`echo $@ | sed s/-recursive//`; \
    +	case "$@" in \
    +	  distclean-* | maintainer-clean-*) list='$(DIST_SUBDIRS)' ;; \
    +	  *) list='$(SUBDIRS)' ;; \
    +	esac; \
    +	for subdir in $$list; do \
    +	  echo "Making $$target in $$subdir"; \
    +	  if test "$$subdir" = "."; then \
    +	    dot_seen=yes; \
    +	    local_target="$$target-am"; \
    +	  else \
    +	    local_target="$$target"; \
    +	  fi; \
    +	  ($(am__cd) $$subdir && $(MAKE) $(AM_MAKEFLAGS) $$local_target) \
    +	  || eval $$failcom; \
    +	done; \
    +	if test "$$dot_seen" = "no"; then \
    +	  $(MAKE) $(AM_MAKEFLAGS) "$$target-am" || exit 1; \
    +	fi; test -z "$$fail"
    +
    +ID: $(am__tagged_files)
    +	$(am__define_uniq_tagged_files); mkid -fID $$unique
    +tags: tags-recursive
    +TAGS: tags
    +
    +tags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files)
    +	set x; \
    +	here=`pwd`; \
    +	if ($(ETAGS) --etags-include --version) >/dev/null 2>&1; then \
    +	  include_option=--etags-include; \
    +	  empty_fix=.; \
    +	else \
    +	  include_option=--include; \
    +	  empty_fix=; \
    +	fi; \
    +	list='$(SUBDIRS)'; for subdir in $$list; do \
    +	  if test "$$subdir" = .; then :; else \
    +	    test ! -f $$subdir/TAGS || \
    +	      set "$$@" "$$include_option=$$here/$$subdir/TAGS"; \
    +	  fi; \
    +	done; \
    +	$(am__define_uniq_tagged_files); \
    +	shift; \
    +	if test -z "$(ETAGS_ARGS)$$*$$unique"; then :; else \
    +	  test -n "$$unique" || unique=$$empty_fix; \
    +	  if test $$# -gt 0; then \
    +	    $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \
    +	      "$$@" $$unique; \
    +	  else \
    +	    $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \
    +	      $$unique; \
    +	  fi; \
    +	fi
    +ctags: ctags-recursive
    +
    +CTAGS: ctags
    +ctags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files)
    +	$(am__define_uniq_tagged_files); \
    +	test -z "$(CTAGS_ARGS)$$unique" \
    +	  || $(CTAGS) $(CTAGSFLAGS) $(AM_CTAGSFLAGS) $(CTAGS_ARGS) \
    +	     $$unique
    +
    +GTAGS:
    +	here=`$(am__cd) $(top_builddir) && pwd` \
    +	  && $(am__cd) $(top_srcdir) \
    +	  && gtags -i $(GTAGS_ARGS) "$$here"
    +cscopelist: cscopelist-recursive
    +
    +cscopelist-am: $(am__tagged_files)
    +	list='$(am__tagged_files)'; \
    +	case "$(srcdir)" in \
    +	  [\\/]* | ?:[\\/]*) sdir="$(srcdir)" ;; \
    +	  *) sdir=$(subdir)/$(srcdir) ;; \
    +	esac; \
    +	for i in $$list; do \
    +	  if test -f "$$i"; then \
    +	    echo "$(subdir)/$$i"; \
    +	  else \
    +	    echo "$$sdir/$$i"; \
    +	  fi; \
    +	done >> $(top_builddir)/cscope.files
    +
    +distclean-tags:
    +	-rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH tags
    +
    +# Recover from deleted '.trs' file; this should ensure that
    +# "rm -f foo.log; make foo.trs" re-run 'foo.test', and re-create
    +# both 'foo.log' and 'foo.trs'.  Break the recipe in two subshells
    +# to avoid problems with "make -n".
    +.log.trs:
    +	rm -f $< $@
    +	$(MAKE) $(AM_MAKEFLAGS) $<
    +
    +# Leading 'am--fnord' is there to ensure the list of targets does not
    +# expand to empty, as could happen e.g. with make check TESTS=''.
    +am--fnord $(TEST_LOGS) $(TEST_LOGS:.log=.trs): $(am__force_recheck)
    +am--force-recheck:
    +	@:
    +
    +$(TEST_SUITE_LOG): $(TEST_LOGS)
    +	@$(am__set_TESTS_bases); \
    +	am__f_ok () { test -f "$$1" && test -r "$$1"; }; \
    +	redo_bases=`for i in $$bases; do \
    +	              am__f_ok $$i.trs && am__f_ok $$i.log || echo $$i; \
    +	            done`; \
    +	if test -n "$$redo_bases"; then \
    +	  redo_logs=`for i in $$redo_bases; do echo $$i.log; done`; \
    +	  redo_results=`for i in $$redo_bases; do echo $$i.trs; done`; \
    +	  if $(am__make_dryrun); then :; else \
    +	    rm -f $$redo_logs && rm -f $$redo_results || exit 1; \
    +	  fi; \
    +	fi; \
    +	if test -n "$$am__remaking_logs"; then \
    +	  echo "fatal: making $(TEST_SUITE_LOG): possible infinite" \
    +	       "recursion detected" >&2; \
    +	elif test -n "$$redo_logs"; then \
    +	  am__remaking_logs=yes $(MAKE) $(AM_MAKEFLAGS) $$redo_logs; \
    +	fi; \
    +	if $(am__make_dryrun); then :; else \
    +	  st=0;  \
    +	  errmsg="fatal: making $(TEST_SUITE_LOG): failed to create"; \
    +	  for i in $$redo_bases; do \
    +	    test -f $$i.trs && test -r $$i.trs \
    +	      || { echo "$$errmsg $$i.trs" >&2; st=1; }; \
    +	    test -f $$i.log && test -r $$i.log \
    +	      || { echo "$$errmsg $$i.log" >&2; st=1; }; \
    +	  done; \
    +	  test $$st -eq 0 || exit 1; \
    +	fi
    +	@$(am__sh_e_setup); $(am__tty_colors); $(am__set_TESTS_bases); \
    +	ws='[ 	]'; \
    +	results=`for b in $$bases; do echo $$b.trs; done`; \
    +	test -n "$$results" || results=/dev/null; \
    +	all=`  grep "^$$ws*:test-result:"           $$results | wc -l`; \
    +	pass=` grep "^$$ws*:test-result:$$ws*PASS"  $$results | wc -l`; \
    +	fail=` grep "^$$ws*:test-result:$$ws*FAIL"  $$results | wc -l`; \
    +	skip=` grep "^$$ws*:test-result:$$ws*SKIP"  $$results | wc -l`; \
    +	xfail=`grep "^$$ws*:test-result:$$ws*XFAIL" $$results | wc -l`; \
    +	xpass=`grep "^$$ws*:test-result:$$ws*XPASS" $$results | wc -l`; \
    +	error=`grep "^$$ws*:test-result:$$ws*ERROR" $$results | wc -l`; \
    +	if test `expr $$fail + $$xpass + $$error` -eq 0; then \
    +	  success=true; \
    +	else \
    +	  success=false; \
    +	fi; \
    +	br='==================='; br=$$br$$br$$br$$br; \
    +	result_count () \
    +	{ \
    +	    if test x"$$1" = x"--maybe-color"; then \
    +	      maybe_colorize=yes; \
    +	    elif test x"$$1" = x"--no-color"; then \
    +	      maybe_colorize=no; \
    +	    else \
    +	      echo "$@: invalid 'result_count' usage" >&2; exit 4; \
    +	    fi; \
    +	    shift; \
    +	    desc=$$1 count=$$2; \
    +	    if test $$maybe_colorize = yes && test $$count -gt 0; then \
    +	      color_start=$$3 color_end=$$std; \
    +	    else \
    +	      color_start= color_end=; \
    +	    fi; \
    +	    echo "$${color_start}# $$desc $$count$${color_end}"; \
    +	}; \
    +	create_testsuite_report () \
    +	{ \
    +	  result_count $$1 "TOTAL:" $$all   "$$brg"; \
    +	  result_count $$1 "PASS: " $$pass  "$$grn"; \
    +	  result_count $$1 "SKIP: " $$skip  "$$blu"; \
    +	  result_count $$1 "XFAIL:" $$xfail "$$lgn"; \
    +	  result_count $$1 "FAIL: " $$fail  "$$red"; \
    +	  result_count $$1 "XPASS:" $$xpass "$$red"; \
    +	  result_count $$1 "ERROR:" $$error "$$mgn"; \
    +	}; \
    +	{								\
    +	  echo "$(PACKAGE_STRING): $(subdir)/$(TEST_SUITE_LOG)" |	\
    +	    $(am__rst_title);						\
    +	  create_testsuite_report --no-color;				\
    +	  echo;								\
    +	  echo ".. contents:: :depth: 2";				\
    +	  echo;								\
    +	  for b in $$bases; do echo $$b; done				\
    +	    | $(am__create_global_log);					\
    +	} >$(TEST_SUITE_LOG).tmp || exit 1;				\
    +	mv $(TEST_SUITE_LOG).tmp $(TEST_SUITE_LOG);			\
    +	if $$success; then						\
    +	  col="$$grn";							\
    +	 else								\
    +	  col="$$red";							\
    +	  test x"$$VERBOSE" = x || cat $(TEST_SUITE_LOG);		\
    +	fi;								\
    +	echo "$${col}$$br$${std}"; 					\
    +	echo "$${col}Testsuite summary for $(PACKAGE_STRING)$${std}";	\
    +	echo "$${col}$$br$${std}"; 					\
    +	create_testsuite_report --maybe-color;				\
    +	echo "$$col$$br$$std";						\
    +	if $$success; then :; else					\
    +	  echo "$${col}See $(subdir)/$(TEST_SUITE_LOG)$${std}";		\
    +	  if test -n "$(PACKAGE_BUGREPORT)"; then			\
    +	    echo "$${col}Please report to $(PACKAGE_BUGREPORT)$${std}";	\
    +	  fi;								\
    +	  echo "$$col$$br$$std";					\
    +	fi;								\
    +	$$success || exit 1
    +
    +check-TESTS:
    +	@list='$(RECHECK_LOGS)';           test -z "$$list" || rm -f $$list
    +	@list='$(RECHECK_LOGS:.log=.trs)'; test -z "$$list" || rm -f $$list
    +	@test -z "$(TEST_SUITE_LOG)" || rm -f $(TEST_SUITE_LOG)
    +	@set +e; $(am__set_TESTS_bases); \
    +	log_list=`for i in $$bases; do echo $$i.log; done`; \
    +	trs_list=`for i in $$bases; do echo $$i.trs; done`; \
    +	log_list=`echo $$log_list`; trs_list=`echo $$trs_list`; \
    +	$(MAKE) $(AM_MAKEFLAGS) $(TEST_SUITE_LOG) TEST_LOGS="$$log_list"; \
    +	exit $$?;
    +recheck: all $(check_PROGRAMS)
    +	@test -z "$(TEST_SUITE_LOG)" || rm -f $(TEST_SUITE_LOG)
    +	@set +e; $(am__set_TESTS_bases); \
    +	bases=`for i in $$bases; do echo $$i; done \
    +	         | $(am__list_recheck_tests)` || exit 1; \
    +	log_list=`for i in $$bases; do echo $$i.log; done`; \
    +	log_list=`echo $$log_list`; \
    +	$(MAKE) $(AM_MAKEFLAGS) $(TEST_SUITE_LOG) \
    +	        am__force_recheck=am--force-recheck \
    +	        TEST_LOGS="$$log_list"; \
    +	exit $$?
    +runtests.log: runtests$(EXEEXT)
    +	@p='runtests$(EXEEXT)'; \
    +	b='runtests'; \
    +	$(am__check_pre) $(LOG_DRIVER) --test-name "$$f" \
    +	--log-file $$b.log --trs-file $$b.trs \
    +	$(am__common_driver_flags) $(AM_LOG_DRIVER_FLAGS) $(LOG_DRIVER_FLAGS) -- $(LOG_COMPILE) \
    +	"$$tst" $(AM_TESTS_FD_REDIRECT)
    +runtestspp.log: runtestspp$(EXEEXT)
    +	@p='runtestspp$(EXEEXT)'; \
    +	b='runtestspp'; \
    +	$(am__check_pre) $(LOG_DRIVER) --test-name "$$f" \
    +	--log-file $$b.log --trs-file $$b.trs \
    +	$(am__common_driver_flags) $(AM_LOG_DRIVER_FLAGS) $(LOG_DRIVER_FLAGS) -- $(LOG_COMPILE) \
    +	"$$tst" $(AM_TESTS_FD_REDIRECT)
    +.test.log:
    +	@p='$<'; \
    +	$(am__set_b); \
    +	$(am__check_pre) $(TEST_LOG_DRIVER) --test-name "$$f" \
    +	--log-file $$b.log --trs-file $$b.trs \
    +	$(am__common_driver_flags) $(AM_TEST_LOG_DRIVER_FLAGS) $(TEST_LOG_DRIVER_FLAGS) -- $(TEST_LOG_COMPILE) \
    +	"$$tst" $(AM_TESTS_FD_REDIRECT)
    +@am__EXEEXT_TRUE@.test$(EXEEXT).log:
    +@am__EXEEXT_TRUE@	@p='$<'; \
    +@am__EXEEXT_TRUE@	$(am__set_b); \
    +@am__EXEEXT_TRUE@	$(am__check_pre) $(TEST_LOG_DRIVER) --test-name "$$f" \
    +@am__EXEEXT_TRUE@	--log-file $$b.log --trs-file $$b.trs \
    +@am__EXEEXT_TRUE@	$(am__common_driver_flags) $(AM_TEST_LOG_DRIVER_FLAGS) $(TEST_LOG_DRIVER_FLAGS) -- $(TEST_LOG_COMPILE) \
    +@am__EXEEXT_TRUE@	"$$tst" $(AM_TESTS_FD_REDIRECT)
    +
    +distdir: $(DISTFILES)
    +	@srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \
    +	topsrcdirstrip=`echo "$(top_srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \
    +	list='$(DISTFILES)'; \
    +	  dist_files=`for file in $$list; do echo $$file; done | \
    +	  sed -e "s|^$$srcdirstrip/||;t" \
    +	      -e "s|^$$topsrcdirstrip/|$(top_builddir)/|;t"`; \
    +	case $$dist_files in \
    +	  */*) $(MKDIR_P) `echo "$$dist_files" | \
    +			   sed '/\//!d;s|^|$(distdir)/|;s,/[^/]*$$,,' | \
    +			   sort -u` ;; \
    +	esac; \
    +	for file in $$dist_files; do \
    +	  if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \
    +	  if test -d $$d/$$file; then \
    +	    dir=`echo "/$$file" | sed -e 's,/[^/]*$$,,'`; \
    +	    if test -d "$(distdir)/$$file"; then \
    +	      find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \
    +	    fi; \
    +	    if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \
    +	      cp -fpR $(srcdir)/$$file "$(distdir)$$dir" || exit 1; \
    +	      find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \
    +	    fi; \
    +	    cp -fpR $$d/$$file "$(distdir)$$dir" || exit 1; \
    +	  else \
    +	    test -f "$(distdir)/$$file" \
    +	    || cp -p $$d/$$file "$(distdir)/$$file" \
    +	    || exit 1; \
    +	  fi; \
    +	done
    +	@list='$(DIST_SUBDIRS)'; for subdir in $$list; do \
    +	  if test "$$subdir" = .; then :; else \
    +	    $(am__make_dryrun) \
    +	      || test -d "$(distdir)/$$subdir" \
    +	      || $(MKDIR_P) "$(distdir)/$$subdir" \
    +	      || exit 1; \
    +	    dir1=$$subdir; dir2="$(distdir)/$$subdir"; \
    +	    $(am__relativize); \
    +	    new_distdir=$$reldir; \
    +	    dir1=$$subdir; dir2="$(top_distdir)"; \
    +	    $(am__relativize); \
    +	    new_top_distdir=$$reldir; \
    +	    echo " (cd $$subdir && $(MAKE) $(AM_MAKEFLAGS) top_distdir="$$new_top_distdir" distdir="$$new_distdir" \\"; \
    +	    echo "     am__remove_distdir=: am__skip_length_check=: am__skip_mode_fix=: distdir)"; \
    +	    ($(am__cd) $$subdir && \
    +	      $(MAKE) $(AM_MAKEFLAGS) \
    +	        top_distdir="$$new_top_distdir" \
    +	        distdir="$$new_distdir" \
    +		am__remove_distdir=: \
    +		am__skip_length_check=: \
    +		am__skip_mode_fix=: \
    +	        distdir) \
    +	      || exit 1; \
    +	  fi; \
    +	done
    +check-am: all-am
    +	$(MAKE) $(AM_MAKEFLAGS) $(check_PROGRAMS)
    +	$(MAKE) $(AM_MAKEFLAGS) check-TESTS
    +check: check-recursive
    +all-am: Makefile $(LIBRARIES)
    +installdirs: installdirs-recursive
    +installdirs-am:
    +install: install-recursive
    +install-exec: install-exec-recursive
    +install-data: install-data-recursive
    +uninstall: uninstall-recursive
    +
    +install-am: all-am
    +	@$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am
    +
    +installcheck: installcheck-recursive
    +install-strip:
    +	if test -z '$(STRIP)'; then \
    +	  $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \
    +	    install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \
    +	      install; \
    +	else \
    +	  $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \
    +	    install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \
    +	    "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'" install; \
    +	fi
    +mostlyclean-generic:
    +	-test -z "$(TEST_LOGS)" || rm -f $(TEST_LOGS)
    +	-test -z "$(TEST_LOGS:.log=.trs)" || rm -f $(TEST_LOGS:.log=.trs)
    +	-test -z "$(TEST_SUITE_LOG)" || rm -f $(TEST_SUITE_LOG)
    +
    +clean-generic:
    +
    +distclean-generic:
    +	-test -z "$(CONFIG_CLEAN_FILES)" || rm -f $(CONFIG_CLEAN_FILES)
    +	-test . = "$(srcdir)" || test -z "$(CONFIG_CLEAN_VPATH_FILES)" || rm -f $(CONFIG_CLEAN_VPATH_FILES)
    +
    +maintainer-clean-generic:
    +	@echo "This command is intended for maintainers to use"
    +	@echo "it deletes files that may require special tools to rebuild."
    +clean: clean-recursive
    +
    +clean-am: clean-checkPROGRAMS clean-generic clean-libtool \
    +	clean-noinstLIBRARIES mostlyclean-am
    +
    +distclean: distclean-recursive
    +	-rm -rf ./$(DEPDIR)
    +	-rm -f Makefile
    +distclean-am: clean-am distclean-compile distclean-generic \
    +	distclean-tags
    +
    +dvi: dvi-recursive
    +
    +dvi-am:
    +
    +html: html-recursive
    +
    +html-am:
    +
    +info: info-recursive
    +
    +info-am:
    +
    +install-data-am:
    +
    +install-dvi: install-dvi-recursive
    +
    +install-dvi-am:
    +
    +install-exec-am:
    +
    +install-html: install-html-recursive
    +
    +install-html-am:
    +
    +install-info: install-info-recursive
    +
    +install-info-am:
    +
    +install-man:
    +
    +install-pdf: install-pdf-recursive
    +
    +install-pdf-am:
    +
    +install-ps: install-ps-recursive
    +
    +install-ps-am:
    +
    +installcheck-am:
    +
    +maintainer-clean: maintainer-clean-recursive
    +	-rm -rf ./$(DEPDIR)
    +	-rm -f Makefile
    +maintainer-clean-am: distclean-am maintainer-clean-generic
    +
    +mostlyclean: mostlyclean-recursive
    +
    +mostlyclean-am: mostlyclean-compile mostlyclean-generic \
    +	mostlyclean-libtool
    +
    +pdf: pdf-recursive
    +
    +pdf-am:
    +
    +ps: ps-recursive
    +
    +ps-am:
    +
    +uninstall-am:
    +
    +.MAKE: $(am__recursive_targets) check-am install-am install-strip
    +
    +.PHONY: $(am__recursive_targets) CTAGS GTAGS TAGS all all-am check \
    +	check-TESTS check-am clean clean-checkPROGRAMS clean-generic \
    +	clean-libtool clean-noinstLIBRARIES cscopelist-am ctags \
    +	ctags-am distclean distclean-compile distclean-generic \
    +	distclean-libtool distclean-tags distdir dvi dvi-am html \
    +	html-am info info-am install install-am install-data \
    +	install-data-am install-dvi install-dvi-am install-exec \
    +	install-exec-am install-html install-html-am install-info \
    +	install-info-am install-man install-pdf install-pdf-am \
    +	install-ps install-ps-am install-strip installcheck \
    +	installcheck-am installdirs installdirs-am maintainer-clean \
    +	maintainer-clean-generic mostlyclean mostlyclean-compile \
    +	mostlyclean-generic mostlyclean-libtool pdf pdf-am ps ps-am \
    +	recheck tags tags-am uninstall uninstall-am
    +
    +.PRECIOUS: Makefile
    +
    +
    +# Tell versions [3.59,3.63) of GNU make to not export all variables.
    +# Otherwise a system limit (for SysV at least) may be exceeded.
    +.NOEXPORT:
    diff --git a/tests/benchmark/Makefile.am b/tests/benchmark/Makefile.am
    new file mode 100644
    index 0000000..f4d7a8e
    --- /dev/null
    +++ b/tests/benchmark/Makefile.am
    @@ -0,0 +1,40 @@
    +#
    +#                          __  __            _
    +#                       ___\ \/ /_ __   __ _| |_
    +#                      / _ \\  /| '_ \ / _` | __|
    +#                     |  __//  \| |_) | (_| | |_
    +#                      \___/_/\_\ .__/ \__,_|\__|
    +#                               |_| XML parser
    +#
    +# Copyright (c) 2017 Expat development team
    +# Licensed under the MIT license:
    +#
    +# Permission is  hereby granted,  free of charge,  to any  person obtaining
    +# a  copy  of  this  software   and  associated  documentation  files  (the
    +# "Software"),  to  deal in  the  Software  without restriction,  including
    +# without  limitation the  rights  to use,  copy,  modify, merge,  publish,
    +# distribute, sublicense, and/or sell copies of the Software, and to permit
    +# persons  to whom  the Software  is  furnished to  do so,  subject to  the
    +# following conditions:
    +#
    +# The above copyright  notice and this permission notice  shall be included
    +# in all copies or substantial portions of the Software.
    +#
    +# THE  SOFTWARE  IS  PROVIDED  "AS  IS",  WITHOUT  WARRANTY  OF  ANY  KIND,
    +# EXPRESS  OR IMPLIED,  INCLUDING  BUT  NOT LIMITED  TO  THE WARRANTIES  OF
    +# MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN
    +# NO EVENT SHALL THE AUTHORS OR  COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
    +# DAMAGES OR  OTHER LIABILITY, WHETHER  IN AN  ACTION OF CONTRACT,  TORT OR
    +# OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE
    +# USE OR OTHER DEALINGS IN THE SOFTWARE.
    +
    +AM_CPPFLAGS = -I$(srcdir)/../../lib
    +
    +noinst_PROGRAMS = benchmark
    +
    +benchmark_SOURCES = benchmark.c
    +
    +benchmark_LDADD = ../../lib/libexpat.la
    +
    +EXTRA_DIST = \
    +    README.txt
    diff --git a/tests/benchmark/Makefile.in b/tests/benchmark/Makefile.in
    new file mode 100644
    index 0000000..90a012d
    --- /dev/null
    +++ b/tests/benchmark/Makefile.in
    @@ -0,0 +1,628 @@
    +# Makefile.in generated by automake 1.15.1 from Makefile.am.
    +# @configure_input@
    +
    +# Copyright (C) 1994-2017 Free Software Foundation, Inc.
    +
    +# This Makefile.in is free software; the Free Software Foundation
    +# gives unlimited permission to copy and/or distribute it,
    +# with or without modifications, as long as this notice is preserved.
    +
    +# This program is distributed in the hope that it will be useful,
    +# but WITHOUT ANY WARRANTY, to the extent permitted by law; without
    +# even the implied warranty of MERCHANTABILITY or FITNESS FOR A
    +# PARTICULAR PURPOSE.
    +
    +@SET_MAKE@
    +
    +#
    +#                          __  __            _
    +#                       ___\ \/ /_ __   __ _| |_
    +#                      / _ \\  /| '_ \ / _` | __|
    +#                     |  __//  \| |_) | (_| | |_
    +#                      \___/_/\_\ .__/ \__,_|\__|
    +#                               |_| XML parser
    +#
    +# Copyright (c) 2017 Expat development team
    +# Licensed under the MIT license:
    +#
    +# Permission is  hereby granted,  free of charge,  to any  person obtaining
    +# a  copy  of  this  software   and  associated  documentation  files  (the
    +# "Software"),  to  deal in  the  Software  without restriction,  including
    +# without  limitation the  rights  to use,  copy,  modify, merge,  publish,
    +# distribute, sublicense, and/or sell copies of the Software, and to permit
    +# persons  to whom  the Software  is  furnished to  do so,  subject to  the
    +# following conditions:
    +#
    +# The above copyright  notice and this permission notice  shall be included
    +# in all copies or substantial portions of the Software.
    +#
    +# THE  SOFTWARE  IS  PROVIDED  "AS  IS",  WITHOUT  WARRANTY  OF  ANY  KIND,
    +# EXPRESS  OR IMPLIED,  INCLUDING  BUT  NOT LIMITED  TO  THE WARRANTIES  OF
    +# MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN
    +# NO EVENT SHALL THE AUTHORS OR  COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
    +# DAMAGES OR  OTHER LIABILITY, WHETHER  IN AN  ACTION OF CONTRACT,  TORT OR
    +# OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE
    +# USE OR OTHER DEALINGS IN THE SOFTWARE.
    +
    +VPATH = @srcdir@
    +am__is_gnu_make = { \
    +  if test -z '$(MAKELEVEL)'; then \
    +    false; \
    +  elif test -n '$(MAKE_HOST)'; then \
    +    true; \
    +  elif test -n '$(MAKE_VERSION)' && test -n '$(CURDIR)'; then \
    +    true; \
    +  else \
    +    false; \
    +  fi; \
    +}
    +am__make_running_with_option = \
    +  case $${target_option-} in \
    +      ?) ;; \
    +      *) echo "am__make_running_with_option: internal error: invalid" \
    +              "target option '$${target_option-}' specified" >&2; \
    +         exit 1;; \
    +  esac; \
    +  has_opt=no; \
    +  sane_makeflags=$$MAKEFLAGS; \
    +  if $(am__is_gnu_make); then \
    +    sane_makeflags=$$MFLAGS; \
    +  else \
    +    case $$MAKEFLAGS in \
    +      *\\[\ \	]*) \
    +        bs=\\; \
    +        sane_makeflags=`printf '%s\n' "$$MAKEFLAGS" \
    +          | sed "s/$$bs$$bs[$$bs $$bs	]*//g"`;; \
    +    esac; \
    +  fi; \
    +  skip_next=no; \
    +  strip_trailopt () \
    +  { \
    +    flg=`printf '%s\n' "$$flg" | sed "s/$$1.*$$//"`; \
    +  }; \
    +  for flg in $$sane_makeflags; do \
    +    test $$skip_next = yes && { skip_next=no; continue; }; \
    +    case $$flg in \
    +      *=*|--*) continue;; \
    +        -*I) strip_trailopt 'I'; skip_next=yes;; \
    +      -*I?*) strip_trailopt 'I';; \
    +        -*O) strip_trailopt 'O'; skip_next=yes;; \
    +      -*O?*) strip_trailopt 'O';; \
    +        -*l) strip_trailopt 'l'; skip_next=yes;; \
    +      -*l?*) strip_trailopt 'l';; \
    +      -[dEDm]) skip_next=yes;; \
    +      -[JT]) skip_next=yes;; \
    +    esac; \
    +    case $$flg in \
    +      *$$target_option*) has_opt=yes; break;; \
    +    esac; \
    +  done; \
    +  test $$has_opt = yes
    +am__make_dryrun = (target_option=n; $(am__make_running_with_option))
    +am__make_keepgoing = (target_option=k; $(am__make_running_with_option))
    +pkgdatadir = $(datadir)/@PACKAGE@
    +pkgincludedir = $(includedir)/@PACKAGE@
    +pkglibdir = $(libdir)/@PACKAGE@
    +pkglibexecdir = $(libexecdir)/@PACKAGE@
    +am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd
    +install_sh_DATA = $(install_sh) -c -m 644
    +install_sh_PROGRAM = $(install_sh) -c
    +install_sh_SCRIPT = $(install_sh) -c
    +INSTALL_HEADER = $(INSTALL_DATA)
    +transform = $(program_transform_name)
    +NORMAL_INSTALL = :
    +PRE_INSTALL = :
    +POST_INSTALL = :
    +NORMAL_UNINSTALL = :
    +PRE_UNINSTALL = :
    +POST_UNINSTALL = :
    +build_triplet = @build@
    +host_triplet = @host@
    +noinst_PROGRAMS = benchmark$(EXEEXT)
    +subdir = tests/benchmark
    +ACLOCAL_M4 = $(top_srcdir)/aclocal.m4
    +am__aclocal_m4_deps = $(top_srcdir)/m4/libtool.m4 \
    +	$(top_srcdir)/m4/ltoptions.m4 $(top_srcdir)/m4/ltsugar.m4 \
    +	$(top_srcdir)/m4/ltversion.m4 $(top_srcdir)/m4/lt~obsolete.m4 \
    +	$(top_srcdir)/conftools/ac_c_bigendian_cross.m4 \
    +	$(top_srcdir)/configure.ac
    +am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \
    +	$(ACLOCAL_M4)
    +DIST_COMMON = $(srcdir)/Makefile.am $(am__DIST_COMMON)
    +mkinstalldirs = $(install_sh) -d
    +CONFIG_HEADER = $(top_builddir)/expat_config.h
    +CONFIG_CLEAN_FILES =
    +CONFIG_CLEAN_VPATH_FILES =
    +PROGRAMS = $(noinst_PROGRAMS)
    +am_benchmark_OBJECTS = benchmark.$(OBJEXT)
    +benchmark_OBJECTS = $(am_benchmark_OBJECTS)
    +benchmark_DEPENDENCIES = ../../lib/libexpat.la
    +AM_V_lt = $(am__v_lt_@AM_V@)
    +am__v_lt_ = $(am__v_lt_@AM_DEFAULT_V@)
    +am__v_lt_0 = --silent
    +am__v_lt_1 = 
    +AM_V_P = $(am__v_P_@AM_V@)
    +am__v_P_ = $(am__v_P_@AM_DEFAULT_V@)
    +am__v_P_0 = false
    +am__v_P_1 = :
    +AM_V_GEN = $(am__v_GEN_@AM_V@)
    +am__v_GEN_ = $(am__v_GEN_@AM_DEFAULT_V@)
    +am__v_GEN_0 = @echo "  GEN     " $@;
    +am__v_GEN_1 = 
    +AM_V_at = $(am__v_at_@AM_V@)
    +am__v_at_ = $(am__v_at_@AM_DEFAULT_V@)
    +am__v_at_0 = @
    +am__v_at_1 = 
    +DEFAULT_INCLUDES = -I.@am__isrc@ -I$(top_builddir)
    +depcomp = $(SHELL) $(top_srcdir)/conftools/depcomp
    +am__depfiles_maybe = depfiles
    +am__mv = mv -f
    +COMPILE = $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) \
    +	$(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS)
    +LTCOMPILE = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \
    +	$(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) \
    +	$(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) \
    +	$(AM_CFLAGS) $(CFLAGS)
    +AM_V_CC = $(am__v_CC_@AM_V@)
    +am__v_CC_ = $(am__v_CC_@AM_DEFAULT_V@)
    +am__v_CC_0 = @echo "  CC      " $@;
    +am__v_CC_1 = 
    +CCLD = $(CC)
    +LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \
    +	$(LIBTOOLFLAGS) --mode=link $(CCLD) $(AM_CFLAGS) $(CFLAGS) \
    +	$(AM_LDFLAGS) $(LDFLAGS) -o $@
    +AM_V_CCLD = $(am__v_CCLD_@AM_V@)
    +am__v_CCLD_ = $(am__v_CCLD_@AM_DEFAULT_V@)
    +am__v_CCLD_0 = @echo "  CCLD    " $@;
    +am__v_CCLD_1 = 
    +SOURCES = $(benchmark_SOURCES)
    +DIST_SOURCES = $(benchmark_SOURCES)
    +am__can_run_installinfo = \
    +  case $$AM_UPDATE_INFO_DIR in \
    +    n|no|NO) false;; \
    +    *) (install-info --version) >/dev/null 2>&1;; \
    +  esac
    +am__tagged_files = $(HEADERS) $(SOURCES) $(TAGS_FILES) $(LISP)
    +# Read a list of newline-separated strings from the standard input,
    +# and print each of them once, without duplicates.  Input order is
    +# *not* preserved.
    +am__uniquify_input = $(AWK) '\
    +  BEGIN { nonempty = 0; } \
    +  { items[$$0] = 1; nonempty = 1; } \
    +  END { if (nonempty) { for (i in items) print i; }; } \
    +'
    +# Make sure the list of sources is unique.  This is necessary because,
    +# e.g., the same source file might be shared among _SOURCES variables
    +# for different programs/libraries.
    +am__define_uniq_tagged_files = \
    +  list='$(am__tagged_files)'; \
    +  unique=`for i in $$list; do \
    +    if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \
    +  done | $(am__uniquify_input)`
    +ETAGS = etags
    +CTAGS = ctags
    +am__DIST_COMMON = $(srcdir)/Makefile.in \
    +	$(top_srcdir)/conftools/depcomp
    +DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST)
    +ACLOCAL = @ACLOCAL@
    +AMTAR = @AMTAR@
    +AM_DEFAULT_VERBOSITY = @AM_DEFAULT_VERBOSITY@
    +AR = @AR@
    +AS = @AS@
    +AUTOCONF = @AUTOCONF@
    +AUTOHEADER = @AUTOHEADER@
    +AUTOMAKE = @AUTOMAKE@
    +AWK = @AWK@
    +CC = @CC@
    +CCDEPMODE = @CCDEPMODE@
    +CFLAGS = @CFLAGS@
    +CPP = @CPP@
    +CPPFLAGS = @CPPFLAGS@
    +CXX = @CXX@
    +CXXCPP = @CXXCPP@
    +CXXDEPMODE = @CXXDEPMODE@
    +CXXFLAGS = @CXXFLAGS@
    +CYGPATH_W = @CYGPATH_W@
    +DEFS = @DEFS@
    +DEPDIR = @DEPDIR@
    +DLLTOOL = @DLLTOOL@
    +DSYMUTIL = @DSYMUTIL@
    +DUMPBIN = @DUMPBIN@
    +ECHO_C = @ECHO_C@
    +ECHO_N = @ECHO_N@
    +ECHO_T = @ECHO_T@
    +EGREP = @EGREP@
    +EXEEXT = @EXEEXT@
    +FGREP = @FGREP@
    +FILEMAP = @FILEMAP@
    +GREP = @GREP@
    +INSTALL = @INSTALL@
    +INSTALL_DATA = @INSTALL_DATA@
    +INSTALL_PROGRAM = @INSTALL_PROGRAM@
    +INSTALL_SCRIPT = @INSTALL_SCRIPT@
    +INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@
    +LD = @LD@
    +LDFLAGS = @LDFLAGS@
    +LIBAGE = @LIBAGE@
    +LIBCURRENT = @LIBCURRENT@
    +LIBOBJS = @LIBOBJS@
    +LIBREVISION = @LIBREVISION@
    +LIBS = @LIBS@
    +LIBTOOL = @LIBTOOL@
    +LIPO = @LIPO@
    +LN_S = @LN_S@
    +LTLIBOBJS = @LTLIBOBJS@
    +LT_SYS_LIBRARY_PATH = @LT_SYS_LIBRARY_PATH@
    +MAKEINFO = @MAKEINFO@
    +MANIFEST_TOOL = @MANIFEST_TOOL@
    +MKDIR_P = @MKDIR_P@
    +NM = @NM@
    +NMEDIT = @NMEDIT@
    +OBJDUMP = @OBJDUMP@
    +OBJEXT = @OBJEXT@
    +OTOOL = @OTOOL@
    +OTOOL64 = @OTOOL64@
    +PACKAGE = @PACKAGE@
    +PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@
    +PACKAGE_NAME = @PACKAGE_NAME@
    +PACKAGE_STRING = @PACKAGE_STRING@
    +PACKAGE_TARNAME = @PACKAGE_TARNAME@
    +PACKAGE_URL = @PACKAGE_URL@
    +PACKAGE_VERSION = @PACKAGE_VERSION@
    +PATH_SEPARATOR = @PATH_SEPARATOR@
    +RANLIB = @RANLIB@
    +SED = @SED@
    +SET_MAKE = @SET_MAKE@
    +SHELL = @SHELL@
    +STRIP = @STRIP@
    +VERSION = @VERSION@
    +abs_builddir = @abs_builddir@
    +abs_srcdir = @abs_srcdir@
    +abs_top_builddir = @abs_top_builddir@
    +abs_top_srcdir = @abs_top_srcdir@
    +ac_ct_AR = @ac_ct_AR@
    +ac_ct_CC = @ac_ct_CC@
    +ac_ct_CXX = @ac_ct_CXX@
    +ac_ct_DUMPBIN = @ac_ct_DUMPBIN@
    +am__include = @am__include@
    +am__leading_dot = @am__leading_dot@
    +am__quote = @am__quote@
    +am__tar = @am__tar@
    +am__untar = @am__untar@
    +bindir = @bindir@
    +build = @build@
    +build_alias = @build_alias@
    +build_cpu = @build_cpu@
    +build_os = @build_os@
    +build_vendor = @build_vendor@
    +builddir = @builddir@
    +datadir = @datadir@
    +datarootdir = @datarootdir@
    +docdir = @docdir@
    +dvidir = @dvidir@
    +exec_prefix = @exec_prefix@
    +host = @host@
    +host_alias = @host_alias@
    +host_cpu = @host_cpu@
    +host_os = @host_os@
    +host_vendor = @host_vendor@
    +htmldir = @htmldir@
    +includedir = @includedir@
    +infodir = @infodir@
    +install_sh = @install_sh@
    +libdir = @libdir@
    +libexecdir = @libexecdir@
    +localedir = @localedir@
    +localstatedir = @localstatedir@
    +mandir = @mandir@
    +mkdir_p = @mkdir_p@
    +oldincludedir = @oldincludedir@
    +pdfdir = @pdfdir@
    +prefix = @prefix@
    +program_transform_name = @program_transform_name@
    +psdir = @psdir@
    +sbindir = @sbindir@
    +sharedstatedir = @sharedstatedir@
    +srcdir = @srcdir@
    +sysconfdir = @sysconfdir@
    +target_alias = @target_alias@
    +top_build_prefix = @top_build_prefix@
    +top_builddir = @top_builddir@
    +top_srcdir = @top_srcdir@
    +AM_CPPFLAGS = -I$(srcdir)/../../lib
    +benchmark_SOURCES = benchmark.c
    +benchmark_LDADD = ../../lib/libexpat.la
    +EXTRA_DIST = \
    +    README.txt
    +
    +all: all-am
    +
    +.SUFFIXES:
    +.SUFFIXES: .c .lo .o .obj
    +$(srcdir)/Makefile.in:  $(srcdir)/Makefile.am  $(am__configure_deps)
    +	@for dep in $?; do \
    +	  case '$(am__configure_deps)' in \
    +	    *$$dep*) \
    +	      ( cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh ) \
    +	        && { if test -f $@; then exit 0; else break; fi; }; \
    +	      exit 1;; \
    +	  esac; \
    +	done; \
    +	echo ' cd $(top_srcdir) && $(AUTOMAKE) --gnu tests/benchmark/Makefile'; \
    +	$(am__cd) $(top_srcdir) && \
    +	  $(AUTOMAKE) --gnu tests/benchmark/Makefile
    +Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status
    +	@case '$?' in \
    +	  *config.status*) \
    +	    cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh;; \
    +	  *) \
    +	    echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe)'; \
    +	    cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe);; \
    +	esac;
    +
    +$(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES)
    +	cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh
    +
    +$(top_srcdir)/configure:  $(am__configure_deps)
    +	cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh
    +$(ACLOCAL_M4):  $(am__aclocal_m4_deps)
    +	cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh
    +$(am__aclocal_m4_deps):
    +
    +clean-noinstPROGRAMS:
    +	@list='$(noinst_PROGRAMS)'; test -n "$$list" || exit 0; \
    +	echo " rm -f" $$list; \
    +	rm -f $$list || exit $$?; \
    +	test -n "$(EXEEXT)" || exit 0; \
    +	list=`for p in $$list; do echo "$$p"; done | sed 's/$(EXEEXT)$$//'`; \
    +	echo " rm -f" $$list; \
    +	rm -f $$list
    +
    +benchmark$(EXEEXT): $(benchmark_OBJECTS) $(benchmark_DEPENDENCIES) $(EXTRA_benchmark_DEPENDENCIES) 
    +	@rm -f benchmark$(EXEEXT)
    +	$(AM_V_CCLD)$(LINK) $(benchmark_OBJECTS) $(benchmark_LDADD) $(LIBS)
    +
    +mostlyclean-compile:
    +	-rm -f *.$(OBJEXT)
    +
    +distclean-compile:
    +	-rm -f *.tab.c
    +
    +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/benchmark.Po@am__quote@
    +
    +.c.o:
    +@am__fastdepCC_TRUE@	$(AM_V_CC)$(COMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ $<
    +@am__fastdepCC_TRUE@	$(AM_V_at)$(am__mv) $(DEPDIR)/$*.Tpo $(DEPDIR)/$*.Po
    +@AMDEP_TRUE@@am__fastdepCC_FALSE@	$(AM_V_CC)source='$<' object='$@' libtool=no @AMDEPBACKSLASH@
    +@AMDEP_TRUE@@am__fastdepCC_FALSE@	DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
    +@am__fastdepCC_FALSE@	$(AM_V_CC@am__nodep@)$(COMPILE) -c -o $@ $<
    +
    +.c.obj:
    +@am__fastdepCC_TRUE@	$(AM_V_CC)$(COMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ `$(CYGPATH_W) '$<'`
    +@am__fastdepCC_TRUE@	$(AM_V_at)$(am__mv) $(DEPDIR)/$*.Tpo $(DEPDIR)/$*.Po
    +@AMDEP_TRUE@@am__fastdepCC_FALSE@	$(AM_V_CC)source='$<' object='$@' libtool=no @AMDEPBACKSLASH@
    +@AMDEP_TRUE@@am__fastdepCC_FALSE@	DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
    +@am__fastdepCC_FALSE@	$(AM_V_CC@am__nodep@)$(COMPILE) -c -o $@ `$(CYGPATH_W) '$<'`
    +
    +.c.lo:
    +@am__fastdepCC_TRUE@	$(AM_V_CC)$(LTCOMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ $<
    +@am__fastdepCC_TRUE@	$(AM_V_at)$(am__mv) $(DEPDIR)/$*.Tpo $(DEPDIR)/$*.Plo
    +@AMDEP_TRUE@@am__fastdepCC_FALSE@	$(AM_V_CC)source='$<' object='$@' libtool=yes @AMDEPBACKSLASH@
    +@AMDEP_TRUE@@am__fastdepCC_FALSE@	DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
    +@am__fastdepCC_FALSE@	$(AM_V_CC@am__nodep@)$(LTCOMPILE) -c -o $@ $<
    +
    +mostlyclean-libtool:
    +	-rm -f *.lo
    +
    +clean-libtool:
    +	-rm -rf .libs _libs
    +
    +ID: $(am__tagged_files)
    +	$(am__define_uniq_tagged_files); mkid -fID $$unique
    +tags: tags-am
    +TAGS: tags
    +
    +tags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files)
    +	set x; \
    +	here=`pwd`; \
    +	$(am__define_uniq_tagged_files); \
    +	shift; \
    +	if test -z "$(ETAGS_ARGS)$$*$$unique"; then :; else \
    +	  test -n "$$unique" || unique=$$empty_fix; \
    +	  if test $$# -gt 0; then \
    +	    $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \
    +	      "$$@" $$unique; \
    +	  else \
    +	    $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \
    +	      $$unique; \
    +	  fi; \
    +	fi
    +ctags: ctags-am
    +
    +CTAGS: ctags
    +ctags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files)
    +	$(am__define_uniq_tagged_files); \
    +	test -z "$(CTAGS_ARGS)$$unique" \
    +	  || $(CTAGS) $(CTAGSFLAGS) $(AM_CTAGSFLAGS) $(CTAGS_ARGS) \
    +	     $$unique
    +
    +GTAGS:
    +	here=`$(am__cd) $(top_builddir) && pwd` \
    +	  && $(am__cd) $(top_srcdir) \
    +	  && gtags -i $(GTAGS_ARGS) "$$here"
    +cscopelist: cscopelist-am
    +
    +cscopelist-am: $(am__tagged_files)
    +	list='$(am__tagged_files)'; \
    +	case "$(srcdir)" in \
    +	  [\\/]* | ?:[\\/]*) sdir="$(srcdir)" ;; \
    +	  *) sdir=$(subdir)/$(srcdir) ;; \
    +	esac; \
    +	for i in $$list; do \
    +	  if test -f "$$i"; then \
    +	    echo "$(subdir)/$$i"; \
    +	  else \
    +	    echo "$$sdir/$$i"; \
    +	  fi; \
    +	done >> $(top_builddir)/cscope.files
    +
    +distclean-tags:
    +	-rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH tags
    +
    +distdir: $(DISTFILES)
    +	@srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \
    +	topsrcdirstrip=`echo "$(top_srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \
    +	list='$(DISTFILES)'; \
    +	  dist_files=`for file in $$list; do echo $$file; done | \
    +	  sed -e "s|^$$srcdirstrip/||;t" \
    +	      -e "s|^$$topsrcdirstrip/|$(top_builddir)/|;t"`; \
    +	case $$dist_files in \
    +	  */*) $(MKDIR_P) `echo "$$dist_files" | \
    +			   sed '/\//!d;s|^|$(distdir)/|;s,/[^/]*$$,,' | \
    +			   sort -u` ;; \
    +	esac; \
    +	for file in $$dist_files; do \
    +	  if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \
    +	  if test -d $$d/$$file; then \
    +	    dir=`echo "/$$file" | sed -e 's,/[^/]*$$,,'`; \
    +	    if test -d "$(distdir)/$$file"; then \
    +	      find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \
    +	    fi; \
    +	    if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \
    +	      cp -fpR $(srcdir)/$$file "$(distdir)$$dir" || exit 1; \
    +	      find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \
    +	    fi; \
    +	    cp -fpR $$d/$$file "$(distdir)$$dir" || exit 1; \
    +	  else \
    +	    test -f "$(distdir)/$$file" \
    +	    || cp -p $$d/$$file "$(distdir)/$$file" \
    +	    || exit 1; \
    +	  fi; \
    +	done
    +check-am: all-am
    +check: check-am
    +all-am: Makefile $(PROGRAMS)
    +installdirs:
    +install: install-am
    +install-exec: install-exec-am
    +install-data: install-data-am
    +uninstall: uninstall-am
    +
    +install-am: all-am
    +	@$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am
    +
    +installcheck: installcheck-am
    +install-strip:
    +	if test -z '$(STRIP)'; then \
    +	  $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \
    +	    install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \
    +	      install; \
    +	else \
    +	  $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \
    +	    install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \
    +	    "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'" install; \
    +	fi
    +mostlyclean-generic:
    +
    +clean-generic:
    +
    +distclean-generic:
    +	-test -z "$(CONFIG_CLEAN_FILES)" || rm -f $(CONFIG_CLEAN_FILES)
    +	-test . = "$(srcdir)" || test -z "$(CONFIG_CLEAN_VPATH_FILES)" || rm -f $(CONFIG_CLEAN_VPATH_FILES)
    +
    +maintainer-clean-generic:
    +	@echo "This command is intended for maintainers to use"
    +	@echo "it deletes files that may require special tools to rebuild."
    +clean: clean-am
    +
    +clean-am: clean-generic clean-libtool clean-noinstPROGRAMS \
    +	mostlyclean-am
    +
    +distclean: distclean-am
    +	-rm -rf ./$(DEPDIR)
    +	-rm -f Makefile
    +distclean-am: clean-am distclean-compile distclean-generic \
    +	distclean-tags
    +
    +dvi: dvi-am
    +
    +dvi-am:
    +
    +html: html-am
    +
    +html-am:
    +
    +info: info-am
    +
    +info-am:
    +
    +install-data-am:
    +
    +install-dvi: install-dvi-am
    +
    +install-dvi-am:
    +
    +install-exec-am:
    +
    +install-html: install-html-am
    +
    +install-html-am:
    +
    +install-info: install-info-am
    +
    +install-info-am:
    +
    +install-man:
    +
    +install-pdf: install-pdf-am
    +
    +install-pdf-am:
    +
    +install-ps: install-ps-am
    +
    +install-ps-am:
    +
    +installcheck-am:
    +
    +maintainer-clean: maintainer-clean-am
    +	-rm -rf ./$(DEPDIR)
    +	-rm -f Makefile
    +maintainer-clean-am: distclean-am maintainer-clean-generic
    +
    +mostlyclean: mostlyclean-am
    +
    +mostlyclean-am: mostlyclean-compile mostlyclean-generic \
    +	mostlyclean-libtool
    +
    +pdf: pdf-am
    +
    +pdf-am:
    +
    +ps: ps-am
    +
    +ps-am:
    +
    +uninstall-am:
    +
    +.MAKE: install-am install-strip
    +
    +.PHONY: CTAGS GTAGS TAGS all all-am check check-am clean clean-generic \
    +	clean-libtool clean-noinstPROGRAMS cscopelist-am ctags \
    +	ctags-am distclean distclean-compile distclean-generic \
    +	distclean-libtool distclean-tags distdir dvi dvi-am html \
    +	html-am info info-am install install-am install-data \
    +	install-data-am install-dvi install-dvi-am install-exec \
    +	install-exec-am install-html install-html-am install-info \
    +	install-info-am install-man install-pdf install-pdf-am \
    +	install-ps install-ps-am install-strip installcheck \
    +	installcheck-am installdirs maintainer-clean \
    +	maintainer-clean-generic mostlyclean mostlyclean-compile \
    +	mostlyclean-generic mostlyclean-libtool pdf pdf-am ps ps-am \
    +	tags tags-am uninstall uninstall-am
    +
    +.PRECIOUS: Makefile
    +
    +
    +# Tell versions [3.59,3.63) of GNU make to not export all variables.
    +# Otherwise a system limit (for SysV at least) may be exceeded.
    +.NOEXPORT:
    diff --git a/tests/benchmark/benchmark.c b/tests/benchmark/benchmark.c
    index efa2858..8fa582f 100644
    --- a/tests/benchmark/benchmark.c
    +++ b/tests/benchmark/benchmark.c
    @@ -1,3 +1,35 @@
    +/*
    +                            __  __            _
    +                         ___\ \/ /_ __   __ _| |_
    +                        / _ \\  /| '_ \ / _` | __|
    +                       |  __//  \| |_) | (_| | |_
    +                        \___/_/\_\ .__/ \__,_|\__|
    +                                 |_| XML parser
    +
    +   Copyright (c) 1997-2000 Thai Open Source Software Center Ltd
    +   Copyright (c) 2000-2017 Expat development team
    +   Licensed under the MIT license:
    +
    +   Permission is  hereby granted,  free of charge,  to any  person obtaining
    +   a  copy  of  this  software   and  associated  documentation  files  (the
    +   "Software"),  to  deal in  the  Software  without restriction,  including
    +   without  limitation the  rights  to use,  copy,  modify, merge,  publish,
    +   distribute, sublicense, and/or sell copies of the Software, and to permit
    +   persons  to whom  the Software  is  furnished to  do so,  subject to  the
    +   following conditions:
    +
    +   The above copyright  notice and this permission notice  shall be included
    +   in all copies or substantial portions of the Software.
    +
    +   THE  SOFTWARE  IS  PROVIDED  "AS  IS",  WITHOUT  WARRANTY  OF  ANY  KIND,
    +   EXPRESS  OR IMPLIED,  INCLUDING  BUT  NOT LIMITED  TO  THE WARRANTIES  OF
    +   MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN
    +   NO EVENT SHALL THE AUTHORS OR  COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
    +   DAMAGES OR  OTHER LIABILITY, WHETHER  IN AN  ACTION OF CONTRACT,  TORT OR
    +   OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE
    +   USE OR OTHER DEALINGS IN THE SOFTWARE.
    +*/
    +
     #include 
     #include 
     #include 
    diff --git a/tests/benchmark/benchmark.sln b/tests/benchmark/benchmark.sln
    new file mode 100644
    index 0000000..bc790bc
    --- /dev/null
    +++ b/tests/benchmark/benchmark.sln
    @@ -0,0 +1,25 @@
    +
    +Microsoft Visual Studio Solution File, Format Version 12.00
    +# Visual Studio 2013
    +VisualStudioVersion = 12.0.40629.0
    +MinimumVisualStudioVersion = 10.0.40219.1
    +Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "benchmark", "benchmark.vcxproj", "{FF89BA66-62C4-49EC-9189-1E7B603A1FD6}"
    +EndProject
    +Global
    +	GlobalSection(SolutionConfigurationPlatforms) = preSolution
    +		Debug|Win32 = Debug|Win32
    +		Release|Win32 = Release|Win32
    +		Template|Win32 = Template|Win32
    +	EndGlobalSection
    +	GlobalSection(ProjectConfigurationPlatforms) = postSolution
    +		{FF89BA66-62C4-49EC-9189-1E7B603A1FD6}.Debug|Win32.ActiveCfg = Debug|Win32
    +		{FF89BA66-62C4-49EC-9189-1E7B603A1FD6}.Debug|Win32.Build.0 = Debug|Win32
    +		{FF89BA66-62C4-49EC-9189-1E7B603A1FD6}.Release|Win32.ActiveCfg = Release|Win32
    +		{FF89BA66-62C4-49EC-9189-1E7B603A1FD6}.Release|Win32.Build.0 = Release|Win32
    +		{FF89BA66-62C4-49EC-9189-1E7B603A1FD6}.Template|Win32.ActiveCfg = Template|Win32
    +		{FF89BA66-62C4-49EC-9189-1E7B603A1FD6}.Template|Win32.Build.0 = Template|Win32
    +	EndGlobalSection
    +	GlobalSection(SolutionProperties) = preSolution
    +		HideSolutionNode = FALSE
    +	EndGlobalSection
    +EndGlobal
    diff --git a/tests/benchmark/benchmark.vcxproj b/tests/benchmark/benchmark.vcxproj
    new file mode 100644
    index 0000000..0f46e88
    --- /dev/null
    +++ b/tests/benchmark/benchmark.vcxproj
    @@ -0,0 +1,143 @@
    +
    +
    +  
    +    
    +      Debug
    +      Win32
    +    
    +    
    +      Release
    +      Win32
    +    
    +    
    +      Template
    +      Win32
    +    
    +  
    +  
    +    
    +    
    +    {FF89BA66-62C4-49EC-9189-1E7B603A1FD6}
    +  
    +  
    +  
    +    Application
    +    v120
    +  
    +  
    +    Application
    +    v120
    +    false
    +    MultiByte
    +  
    +  
    +    Application
    +    v120
    +    false
    +    MultiByte
    +  
    +  
    +  
    +  
    +  
    +    
    +  
    +  
    +    
    +    
    +  
    +  
    +    
    +    
    +  
    +  
    +  
    +    .\Release\
    +    .\Release\
    +    false
    +  
    +  
    +    .\Debug\
    +    .\Debug\
    +    true
    +  
    +  
    +    
    +      MultiThreaded
    +      Default
    +      true
    +      true
    +      MaxSpeed
    +      true
    +      Level3
    +      ..\..\lib;%(AdditionalIncludeDirectories)
    +      NDEBUG;_CONSOLE;%(PreprocessorDefinitions)
    +      .\Release\
    +      .\Release\benchmark.pch
    +      .\Release\
    +      .\Release\
    +    
    +    
    +      .\Release\benchmark.tlb
    +    
    +    
    +      0x1009
    +      NDEBUG;%(PreprocessorDefinitions)
    +    
    +    
    +      true
    +      .\Release\benchmark.bsc
    +    
    +    
    +      true
    +      Console
    +      .\Release\benchmark.exe
    +      ..\..\win32\bin\Release;%(AdditionalLibraryDirectories)
    +      libexpat.lib;%(AdditionalDependencies)
    +    
    +  
    +  
    +    
    +      MultiThreadedDebug
    +      Default
    +      true
    +      Disabled
    +      true
    +      Level3
    +      true
    +      EditAndContinue
    +      ..\..\lib;%(AdditionalIncludeDirectories)
    +      _DEBUG;_CONSOLE;%(PreprocessorDefinitions)
    +      .\Debug\
    +      .\Debug\benchmark.pch
    +      .\Debug\
    +      .\Debug\
    +      EnableFastChecks
    +    
    +    
    +      .\Debug\benchmark.tlb
    +    
    +    
    +      0x1009
    +      _DEBUG;%(PreprocessorDefinitions)
    +    
    +    
    +      true
    +      .\Debug\benchmark.bsc
    +    
    +    
    +      true
    +      true
    +      Console
    +      .\Debug\benchmark.exe
    +      ..\..\win32\bin\Debug;%(AdditionalLibraryDirectories)
    +      libexpat.lib;%(AdditionalDependencies)
    +    
    +  
    +  
    +    
    +  
    +  
    +  
    +  
    +
    \ No newline at end of file
    diff --git a/tests/chardata.c b/tests/chardata.c
    index 8e4e97a..9a93f59 100644
    --- a/tests/chardata.c
    +++ b/tests/chardata.c
    @@ -1,7 +1,33 @@
    -/* Copyright (c) 1998-2003 Thai Open Source Software Center Ltd
    -   See the file COPYING for copying permission.
    -
    -   chardata.c
    +/*
    +                            __  __            _
    +                         ___\ \/ /_ __   __ _| |_
    +                        / _ \\  /| '_ \ / _` | __|
    +                       |  __//  \| |_) | (_| | |_
    +                        \___/_/\_\ .__/ \__,_|\__|
    +                                 |_| XML parser
    +
    +   Copyright (c) 1997-2000 Thai Open Source Software Center Ltd
    +   Copyright (c) 2000-2017 Expat development team
    +   Licensed under the MIT license:
    +
    +   Permission is  hereby granted,  free of charge,  to any  person obtaining
    +   a  copy  of  this  software   and  associated  documentation  files  (the
    +   "Software"),  to  deal in  the  Software  without restriction,  including
    +   without  limitation the  rights  to use,  copy,  modify, merge,  publish,
    +   distribute, sublicense, and/or sell copies of the Software, and to permit
    +   persons  to whom  the Software  is  furnished to  do so,  subject to  the
    +   following conditions:
    +
    +   The above copyright  notice and this permission notice  shall be included
    +   in all copies or substantial portions of the Software.
    +
    +   THE  SOFTWARE  IS  PROVIDED  "AS  IS",  WITHOUT  WARRANTY  OF  ANY  KIND,
    +   EXPRESS  OR IMPLIED,  INCLUDING  BUT  NOT LIMITED  TO  THE WARRANTIES  OF
    +   MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN
    +   NO EVENT SHALL THE AUTHORS OR  COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
    +   DAMAGES OR  OTHER LIABILITY, WHETHER  IN AN  ACTION OF CONTRACT,  TORT OR
    +   OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE
    +   USE OR OTHER DEALINGS IN THE SOFTWARE.
     */
     
     #ifdef HAVE_EXPAT_CONFIG_H
    diff --git a/tests/chardata.h b/tests/chardata.h
    index 0db4b99..193edc7 100644
    --- a/tests/chardata.h
    +++ b/tests/chardata.h
    @@ -1,7 +1,34 @@
    -/* chardata.h
    -
    -   Interface to some helper routines used to accumulate and check text
    +/* Interface to some helper routines used to accumulate and check text
        and attribute content.
    +                            __  __            _
    +                         ___\ \/ /_ __   __ _| |_
    +                        / _ \\  /| '_ \ / _` | __|
    +                       |  __//  \| |_) | (_| | |_
    +                        \___/_/\_\ .__/ \__,_|\__|
    +                                 |_| XML parser
    +
    +   Copyright (c) 1997-2000 Thai Open Source Software Center Ltd
    +   Copyright (c) 2000-2017 Expat development team
    +   Licensed under the MIT license:
    +
    +   Permission is  hereby granted,  free of charge,  to any  person obtaining
    +   a  copy  of  this  software   and  associated  documentation  files  (the
    +   "Software"),  to  deal in  the  Software  without restriction,  including
    +   without  limitation the  rights  to use,  copy,  modify, merge,  publish,
    +   distribute, sublicense, and/or sell copies of the Software, and to permit
    +   persons  to whom  the Software  is  furnished to  do so,  subject to  the
    +   following conditions:
    +
    +   The above copyright  notice and this permission notice  shall be included
    +   in all copies or substantial portions of the Software.
    +
    +   THE  SOFTWARE  IS  PROVIDED  "AS  IS",  WITHOUT  WARRANTY  OF  ANY  KIND,
    +   EXPRESS  OR IMPLIED,  INCLUDING  BUT  NOT LIMITED  TO  THE WARRANTIES  OF
    +   MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN
    +   NO EVENT SHALL THE AUTHORS OR  COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
    +   DAMAGES OR  OTHER LIABILITY, WHETHER  IN AN  ACTION OF CONTRACT,  TORT OR
    +   OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE
    +   USE OR OTHER DEALINGS IN THE SOFTWARE.
     */
     
     #ifdef __cplusplus
    diff --git a/tests/memcheck.c b/tests/memcheck.c
    index 4a24ddc..23e9fdf 100644
    --- a/tests/memcheck.c
    +++ b/tests/memcheck.c
    @@ -1,9 +1,34 @@
    -/* Copyright (c) 2017 The Expat Maintainers
    - * Copying is permitted under the MIT license.  See the file COPYING
    - * for details.
    - *
    - * memcheck.c : debug allocators for the Expat test suite
    - */
    +/* Debug allocators for the Expat test suite
    +                            __  __            _
    +                         ___\ \/ /_ __   __ _| |_
    +                        / _ \\  /| '_ \ / _` | __|
    +                       |  __//  \| |_) | (_| | |_
    +                        \___/_/\_\ .__/ \__,_|\__|
    +                                 |_| XML parser
    +
    +   Copyright (c) 1997-2000 Thai Open Source Software Center Ltd
    +   Copyright (c) 2000-2017 Expat development team
    +   Licensed under the MIT license:
    +
    +   Permission is  hereby granted,  free of charge,  to any  person obtaining
    +   a  copy  of  this  software   and  associated  documentation  files  (the
    +   "Software"),  to  deal in  the  Software  without restriction,  including
    +   without  limitation the  rights  to use,  copy,  modify, merge,  publish,
    +   distribute, sublicense, and/or sell copies of the Software, and to permit
    +   persons  to whom  the Software  is  furnished to  do so,  subject to  the
    +   following conditions:
    +
    +   The above copyright  notice and this permission notice  shall be included
    +   in all copies or substantial portions of the Software.
    +
    +   THE  SOFTWARE  IS  PROVIDED  "AS  IS",  WITHOUT  WARRANTY  OF  ANY  KIND,
    +   EXPRESS  OR IMPLIED,  INCLUDING  BUT  NOT LIMITED  TO  THE WARRANTIES  OF
    +   MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN
    +   NO EVENT SHALL THE AUTHORS OR  COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
    +   DAMAGES OR  OTHER LIABILITY, WHETHER  IN AN  ACTION OF CONTRACT,  TORT OR
    +   OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE
    +   USE OR OTHER DEALINGS IN THE SOFTWARE.
    +*/
     
     #include 
     #include 
    diff --git a/tests/memcheck.h b/tests/memcheck.h
    index 2c92724..1cc4848 100644
    --- a/tests/memcheck.h
    +++ b/tests/memcheck.h
    @@ -1,11 +1,34 @@
    -/* Copyright (c) 2017 The Expat Maintainers
    - * Copying is permitted under the MIT license.  See the file COPYING
    - * for details.
    - *
    - * memcheck.h
    - *
    - * Interface to allocation functions that will track what has or has
    - * not been freed.
    +/* Interface to allocation functions that will track what has or has
    +   not been freed.
    +                            __  __            _
    +                         ___\ \/ /_ __   __ _| |_
    +                        / _ \\  /| '_ \ / _` | __|
    +                       |  __//  \| |_) | (_| | |_
    +                        \___/_/\_\ .__/ \__,_|\__|
    +                                 |_| XML parser
    +
    +   Copyright (c) 1997-2000 Thai Open Source Software Center Ltd
    +   Copyright (c) 2000-2017 Expat development team
    +   Licensed under the MIT license:
    +
    +   Permission is  hereby granted,  free of charge,  to any  person obtaining
    +   a  copy  of  this  software   and  associated  documentation  files  (the
    +   "Software"),  to  deal in  the  Software  without restriction,  including
    +   without  limitation the  rights  to use,  copy,  modify, merge,  publish,
    +   distribute, sublicense, and/or sell copies of the Software, and to permit
    +   persons  to whom  the Software  is  furnished to  do so,  subject to  the
    +   following conditions:
    +
    +   The above copyright  notice and this permission notice  shall be included
    +   in all copies or substantial portions of the Software.
    +
    +   THE  SOFTWARE  IS  PROVIDED  "AS  IS",  WITHOUT  WARRANTY  OF  ANY  KIND,
    +   EXPRESS  OR IMPLIED,  INCLUDING  BUT  NOT LIMITED  TO  THE WARRANTIES  OF
    +   MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN
    +   NO EVENT SHALL THE AUTHORS OR  COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
    +   DAMAGES OR  OTHER LIABILITY, WHETHER  IN AN  ACTION OF CONTRACT,  TORT OR
    +   OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE
    +   USE OR OTHER DEALINGS IN THE SOFTWARE.
     */
     
     #ifdef __cplusplus
    diff --git a/tests/minicheck.c b/tests/minicheck.c
    index a6cae23..be1e37e 100644
    --- a/tests/minicheck.c
    +++ b/tests/minicheck.c
    @@ -1,14 +1,44 @@
     /* Miniature re-implementation of the "check" library.
    - *
    - * This is intended to support just enough of check to run the Expat
    - * tests.  This interface is based entirely on the portion of the
    - * check library being used.
    - */
    +
    +   This is intended to support just enough of check to run the Expat
    +   tests.  This interface is based entirely on the portion of the
    +   check library being used.
    +                            __  __            _
    +                         ___\ \/ /_ __   __ _| |_
    +                        / _ \\  /| '_ \ / _` | __|
    +                       |  __//  \| |_) | (_| | |_
    +                        \___/_/\_\ .__/ \__,_|\__|
    +                                 |_| XML parser
    +
    +   Copyright (c) 1997-2000 Thai Open Source Software Center Ltd
    +   Copyright (c) 2000-2017 Expat development team
    +   Licensed under the MIT license:
    +
    +   Permission is  hereby granted,  free of charge,  to any  person obtaining
    +   a  copy  of  this  software   and  associated  documentation  files  (the
    +   "Software"),  to  deal in  the  Software  without restriction,  including
    +   without  limitation the  rights  to use,  copy,  modify, merge,  publish,
    +   distribute, sublicense, and/or sell copies of the Software, and to permit
    +   persons  to whom  the Software  is  furnished to  do so,  subject to  the
    +   following conditions:
    +
    +   The above copyright  notice and this permission notice  shall be included
    +   in all copies or substantial portions of the Software.
    +
    +   THE  SOFTWARE  IS  PROVIDED  "AS  IS",  WITHOUT  WARRANTY  OF  ANY  KIND,
    +   EXPRESS  OR IMPLIED,  INCLUDING  BUT  NOT LIMITED  TO  THE WARRANTIES  OF
    +   MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN
    +   NO EVENT SHALL THE AUTHORS OR  COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
    +   DAMAGES OR  OTHER LIABILITY, WHETHER  IN AN  ACTION OF CONTRACT,  TORT OR
    +   OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE
    +   USE OR OTHER DEALINGS IN THE SOFTWARE.
    +*/
     
     #include 
     #include 
     #include 
     #include 
    +#include 
     
     #include "internal.h"  /* for UNUSED_P only */
     #include "minicheck.h"
    @@ -186,8 +216,10 @@ _fail_unless(int UNUSED_P(condition), const char *UNUSED_P(file), int UNUSED_P(l
            we have a failure, so there's no reason to be quiet about what
            it is.
         */
    -    if (msg != NULL)
    -        printf("%s", msg);
    +    if (msg != NULL) {
    +        const int has_newline = (msg[strlen(msg) - 1] == '\n');
    +        fprintf(stderr, "ERROR: %s%s", msg, has_newline ? "" : "\n");
    +    }
         longjmp(env, 1);
     }
     
    diff --git a/tests/minicheck.h b/tests/minicheck.h
    index 3702cf8..a2f57dd 100644
    --- a/tests/minicheck.h
    +++ b/tests/minicheck.h
    @@ -1,11 +1,40 @@
     /* Miniature re-implementation of the "check" library.
    - *
    - * This is intended to support just enough of check to run the Expat
    - * tests.  This interface is based entirely on the portion of the
    - * check library being used.
    - *
    - * This is *source* compatible, but not necessary *link* compatible.
    - */
    +
    +   This is intended to support just enough of check to run the Expat
    +   tests.  This interface is based entirely on the portion of the
    +   check library being used.
    +
    +   This is *source* compatible, but not necessary *link* compatible.
    +                            __  __            _
    +                         ___\ \/ /_ __   __ _| |_
    +                        / _ \\  /| '_ \ / _` | __|
    +                       |  __//  \| |_) | (_| | |_
    +                        \___/_/\_\ .__/ \__,_|\__|
    +                                 |_| XML parser
    +
    +   Copyright (c) 1997-2000 Thai Open Source Software Center Ltd
    +   Copyright (c) 2000-2017 Expat development team
    +   Licensed under the MIT license:
    +
    +   Permission is  hereby granted,  free of charge,  to any  person obtaining
    +   a  copy  of  this  software   and  associated  documentation  files  (the
    +   "Software"),  to  deal in  the  Software  without restriction,  including
    +   without  limitation the  rights  to use,  copy,  modify, merge,  publish,
    +   distribute, sublicense, and/or sell copies of the Software, and to permit
    +   persons  to whom  the Software  is  furnished to  do so,  subject to  the
    +   following conditions:
    +
    +   The above copyright  notice and this permission notice  shall be included
    +   in all copies or substantial portions of the Software.
    +
    +   THE  SOFTWARE  IS  PROVIDED  "AS  IS",  WITHOUT  WARRANTY  OF  ANY  KIND,
    +   EXPRESS  OR IMPLIED,  INCLUDING  BUT  NOT LIMITED  TO  THE WARRANTIES  OF
    +   MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN
    +   NO EVENT SHALL THE AUTHORS OR  COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
    +   DAMAGES OR  OTHER LIABILITY, WHETHER  IN AN  ACTION OF CONTRACT,  TORT OR
    +   OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE
    +   USE OR OTHER DEALINGS IN THE SOFTWARE.
    +*/
     
     #ifdef __cplusplus
     extern "C" {
    diff --git a/tests/runtests.c b/tests/runtests.c
    index aa95fd3..4ad5c8b 100644
    --- a/tests/runtests.c
    +++ b/tests/runtests.c
    @@ -1,7 +1,33 @@
    -/* Copyright (c) 1998, 1999, 2000 Thai Open Source Software Center Ltd
    -   See the file COPYING for copying permission.
    -
    -   runtest.c : run the Expat test suite
    +/* Run the Expat test suite
    +                            __  __            _
    +                         ___\ \/ /_ __   __ _| |_
    +                        / _ \\  /| '_ \ / _` | __|
    +                       |  __//  \| |_) | (_| | |_
    +                        \___/_/\_\ .__/ \__,_|\__|
    +                                 |_| XML parser
    +
    +   Copyright (c) 1997-2000 Thai Open Source Software Center Ltd
    +   Copyright (c) 2000-2017 Expat development team
    +   Licensed under the MIT license:
    +
    +   Permission is  hereby granted,  free of charge,  to any  person obtaining
    +   a  copy  of  this  software   and  associated  documentation  files  (the
    +   "Software"),  to  deal in  the  Software  without restriction,  including
    +   without  limitation the  rights  to use,  copy,  modify, merge,  publish,
    +   distribute, sublicense, and/or sell copies of the Software, and to permit
    +   persons  to whom  the Software  is  furnished to  do so,  subject to  the
    +   following conditions:
    +
    +   The above copyright  notice and this permission notice  shall be included
    +   in all copies or substantial portions of the Software.
    +
    +   THE  SOFTWARE  IS  PROVIDED  "AS  IS",  WITHOUT  WARRANTY  OF  ANY  KIND,
    +   EXPRESS  OR IMPLIED,  INCLUDING  BUT  NOT LIMITED  TO  THE WARRANTIES  OF
    +   MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN
    +   NO EVENT SHALL THE AUTHORS OR  COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
    +   DAMAGES OR  OTHER LIABILITY, WHETHER  IN AN  ACTION OF CONTRACT,  TORT OR
    +   OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE
    +   USE OR OTHER DEALINGS IN THE SOFTWARE.
     */
     
     #ifdef HAVE_EXPAT_CONFIG_H
    @@ -5671,7 +5697,7 @@ static int XMLCALL
     prefix_converter(void *UNUSED_P(data), const char *s)
     {
         /* If the first byte is 0xff, raise an error */
    -    if (s[0] == -1)
    +    if (s[0] == (char)-1)
             return -1;
         /* Just add the low bits of the first byte to the second */
         return (s[1] + (s[0] & 0x7f)) & 0x01ff;
    @@ -7738,7 +7764,7 @@ START_TEST(test_misc_version)
             fail("Version mismatch");
     
     #if ! defined(XML_UNICODE)
    -    if (strcmp(version_text, "expat_2.2.3"))  /* needs bump on releases */
    +    if (strcmp(version_text, "expat_2.2.4"))  /* needs bump on releases */
             fail("XML_*_VERSION in expat.h out of sync?\n");
     #endif  /* ! defined(XML_UNICODE) */
     }
    diff --git a/tests/runtests.sln b/tests/runtests.sln
    new file mode 100644
    index 0000000..6e07293
    --- /dev/null
    +++ b/tests/runtests.sln
    @@ -0,0 +1,24 @@
    +
    +Microsoft Visual Studio Solution File, Format Version 12.00
    +# Visual Studio 2013
    +VisualStudioVersion = 12.0.40629.0
    +MinimumVisualStudioVersion = 10.0.40219.1
    +Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "runtests", "runtests.vcxproj", "{63D6D820-B526-4A5F-9605-9B8551FAC591}"
    +EndProject
    +Global
    +	GlobalSection(SolutionConfigurationPlatforms) = preSolution
    +		Debug|Win32 = Debug|Win32
    +		Release|Win32 = Release|Win32
    +		Template|Win32 = Template|Win32
    +	EndGlobalSection
    +	GlobalSection(ProjectConfigurationPlatforms) = postSolution
    +		{63D6D820-B526-4A5F-9605-9B8551FAC591}.Debug|Win32.ActiveCfg = Debug|Win32
    +		{63D6D820-B526-4A5F-9605-9B8551FAC591}.Debug|Win32.Build.0 = Debug|Win32
    +		{63D6D820-B526-4A5F-9605-9B8551FAC591}.Release|Win32.ActiveCfg = Release|Win32
    +		{63D6D820-B526-4A5F-9605-9B8551FAC591}.Release|Win32.Build.0 = Release|Win32
    +		{63D6D820-B526-4A5F-9605-9B8551FAC591}.Template|Win32.ActiveCfg = Release|Win32
    +	EndGlobalSection
    +	GlobalSection(SolutionProperties) = preSolution
    +		HideSolutionNode = FALSE
    +	EndGlobalSection
    +EndGlobal
    diff --git a/tests/runtests.vcxproj b/tests/runtests.vcxproj
    new file mode 100644
    index 0000000..ff8f549
    --- /dev/null
    +++ b/tests/runtests.vcxproj
    @@ -0,0 +1,140 @@
    +
    +
    +  
    +    
    +      Debug
    +      Win32
    +    
    +    
    +      Release
    +      Win32
    +    
    +  
    +  
    +    
    +    
    +    {63D6D820-B526-4A5F-9605-9B8551FAC591}
    +  
    +  
    +  
    +    Application
    +    v120
    +    false
    +    MultiByte
    +  
    +  
    +    Application
    +    v120
    +    false
    +    MultiByte
    +  
    +  
    +  
    +  
    +  
    +    
    +    
    +  
    +  
    +    
    +    
    +  
    +  
    +  
    +    .\Release\
    +    .\Release\
    +    false
    +  
    +  
    +    .\Debug\
    +    .\Debug\
    +    true
    +  
    +  
    +    
    +      MultiThreaded
    +      Default
    +      true
    +      true
    +      MaxSpeed
    +      true
    +      Level3
    +      ..\lib;%(AdditionalIncludeDirectories)
    +      NDEBUG;_CONSOLE;%(PreprocessorDefinitions)
    +      .\Release\
    +      .\Release\runtests.pch
    +      .\Release\
    +      .\Release\
    +    
    +    
    +      .\Release\runtests.tlb
    +    
    +    
    +      0x1009
    +      NDEBUG;%(PreprocessorDefinitions)
    +    
    +    
    +      true
    +      .\Release\runtests.bsc
    +    
    +    
    +      true
    +      Console
    +      .\Release\runtests.exe
    +      ..\win32\bin\Release;%(AdditionalLibraryDirectories)
    +      libexpatMT.lib;libexpat.exp;%(AdditionalDependencies)
    +    
    +  
    +  
    +    
    +      MultiThreadedDebug
    +      Default
    +      true
    +      Disabled
    +      true
    +      Level3
    +      true
    +      EditAndContinue
    +      ..\lib;%(AdditionalIncludeDirectories)
    +      _DEBUG;_CONSOLE;%(PreprocessorDefinitions)
    +      .\Debug\
    +      .\Debug\runtests.pch
    +      .\Debug\
    +      .\Debug\
    +      EnableFastChecks
    +    
    +    
    +      .\Debug\runtests.tlb
    +    
    +    
    +      0x1009
    +      _DEBUG;%(PreprocessorDefinitions)
    +    
    +    
    +      true
    +      .\Debug\runtests.bsc
    +    
    +    
    +      true
    +      true
    +      Console
    +      .\Debug\runtests.exe
    +      ..\win32\bin\Debug;%(AdditionalLibraryDirectories)
    +      libexpatMT.lib;libexpat.exp;%(AdditionalDependencies)
    +    
    +  
    +  
    +    
    +    
    +    
    +    
    +  
    +  
    +    
    +    
    +    
    +  
    +  
    +  
    +  
    +
    \ No newline at end of file
    diff --git a/tests/runtests.vcxproj.filters b/tests/runtests.vcxproj.filters
    new file mode 100644
    index 0000000..ca66cb5
    --- /dev/null
    +++ b/tests/runtests.vcxproj.filters
    @@ -0,0 +1,42 @@
    +
    +
    +  
    +    
    +      {a3e83144-e1b8-4d37-853a-793ce2b17b31}
    +      cpp;c;cxx;rc;def;r;odl;idl;hpj;bat
    +    
    +    
    +      {6a1287d5-359d-4ecb-a1a8-79aec14ad46d}
    +      h;hpp;hxx;hm;inl
    +    
    +    
    +      {75f72e18-16a8-453e-84bc-fe9301b8d5b2}
    +      ico;cur;bmp;dlg;rc2;rct;bin;rgs;gif;jpg;jpeg;jpe
    +    
    +  
    +  
    +    
    +      Source Files
    +    
    +    
    +      Source Files
    +    
    +    
    +      Source Files
    +    
    +    
    +      Source Files
    +    
    +  
    +  
    +    
    +      Header Files
    +    
    +    
    +      Header Files
    +    
    +    
    +      Header Files
    +    
    +  
    +
    \ No newline at end of file
    diff --git a/tests/runtestspp.cpp b/tests/runtestspp.cpp
    index c35dc58..fd3ceaa 100644
    --- a/tests/runtestspp.cpp
    +++ b/tests/runtestspp.cpp
    @@ -1,6 +1,36 @@
    -// C++ compilation harness for the test suite.
    -//
    -// This is used to ensure the Expat headers can be included from C++
    -// and have everything work as expected.
    -//
    +/* C++ compilation harness for the test suite.
    +
    +   This is used to ensure the Expat headers can be included from C++
    +   and have everything work as expected.
    +                            __  __            _
    +                         ___\ \/ /_ __   __ _| |_
    +                        / _ \\  /| '_ \ / _` | __|
    +                       |  __//  \| |_) | (_| | |_
    +                        \___/_/\_\ .__/ \__,_|\__|
    +                                 |_| XML parser
    +
    +   Copyright (c) 1997-2000 Thai Open Source Software Center Ltd
    +   Copyright (c) 2000-2017 Expat development team
    +   Licensed under the MIT license:
    +
    +   Permission is  hereby granted,  free of charge,  to any  person obtaining
    +   a  copy  of  this  software   and  associated  documentation  files  (the
    +   "Software"),  to  deal in  the  Software  without restriction,  including
    +   without  limitation the  rights  to use,  copy,  modify, merge,  publish,
    +   distribute, sublicense, and/or sell copies of the Software, and to permit
    +   persons  to whom  the Software  is  furnished to  do so,  subject to  the
    +   following conditions:
    +
    +   The above copyright  notice and this permission notice  shall be included
    +   in all copies or substantial portions of the Software.
    +
    +   THE  SOFTWARE  IS  PROVIDED  "AS  IS",  WITHOUT  WARRANTY  OF  ANY  KIND,
    +   EXPRESS  OR IMPLIED,  INCLUDING  BUT  NOT LIMITED  TO  THE WARRANTIES  OF
    +   MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN
    +   NO EVENT SHALL THE AUTHORS OR  COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
    +   DAMAGES OR  OTHER LIABILITY, WHETHER  IN AN  ACTION OF CONTRACT,  TORT OR
    +   OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE
    +   USE OR OTHER DEALINGS IN THE SOFTWARE.
    +*/
    +
     #include "runtests.c"
    diff --git a/tests/xmltest.log.expected b/tests/xmltest.log.expected
    new file mode 100644
    index 0000000..7c92c1d
    --- /dev/null
    +++ b/tests/xmltest.log.expected
    @@ -0,0 +1,35 @@
    +Output differs: ibm/valid/P02/ibm02v01.xml
    +Output differs: ibm/valid/P28/ibm28v02.xml
    +Output differs: ibm/valid/P29/ibm29v01.xml
    +Output differs: ibm/valid/P29/ibm29v02.xml
    +Output differs: ibm/valid/P54/ibm54v01.xml
    +Output differs: ibm/valid/P56/ibm56v08.xml
    +Output differs: ibm/valid/P57/ibm57v01.xml
    +Output differs: ibm/valid/P58/ibm58v01.xml
    +Output differs: ibm/valid/P58/ibm58v02.xml
    +Output differs: ibm/valid/P70/ibm70v01.xml
    +Output differs: ibm/valid/P82/ibm82v01.xml
    +ibm49i02.dtd: No such file or directory
    +Output differs: ibm/invalid/P58/ibm58i01.xml
    +Output differs: ibm/invalid/P58/ibm58i02.xml
    +Output differs: xmltest/valid/sa/069.xml
    +Output differs: xmltest/valid/sa/076.xml
    +Output differs: xmltest/valid/sa/090.xml
    +Output differs: xmltest/valid/sa/091.xml
    +Output differs: sun/valid/notation01.xml
    +Output differs: sun/valid/not-sa01.xml
    +Output differs: sun/valid/not-sa02.xml
    +Output differs: sun/valid/not-sa03.xml
    +Output differs: sun/valid/not-sa04.xml
    +Output differs: sun/valid/sa02.xml
    +Output differs: sun/valid/sa03.xml
    +Output differs: sun/valid/sa04.xml
    +Output differs: sun/valid/sa05.xml
    +Expected not well-formed: ibm/not-wf/misc/432gewf.xml
    +Expected not well-formed: xmltest/not-wf/not-sa/005.xml
    +Expected not well-formed: sun/not-wf/uri01.xml
    +Expected not well-formed: oasis/p06fail1.xml
    +Expected not well-formed: oasis/p08fail1.xml
    +Expected not well-formed: oasis/p08fail2.xml
    +Passed: 1776
    +Failed: 33
    diff --git a/win32/expat.iss b/win32/expat.iss
    index 04968e7..73f3080 100644
    --- a/win32/expat.iss
    +++ b/win32/expat.iss
    @@ -7,17 +7,17 @@
     [Setup]
     AppName=Expat
     AppId=expat
    -AppVersion=2.2.3
    -AppVerName=Expat 2.2.3
    +AppVersion=2.2.4
    +AppVerName=Expat 2.2.4
     AppCopyright=Copyright � 1998-2017 Thai Open Source Software Center, Clark Cooper, and the Expat maintainers
     AppPublisher=The Expat Developers
     AppPublisherURL=http://www.libexpat.org/
     AppSupportURL=http://www.libexpat.org/
     AppUpdatesURL=http://www.libexpat.org/
    -UninstallDisplayName=Expat XML Parser 2.2.3
    -VersionInfoVersion=2.2.3
    +UninstallDisplayName=Expat XML Parser 2.2.4
    +VersionInfoVersion=2.2.4
     
    -DefaultDirName={pf}\Expat 2.2.3
    +DefaultDirName={pf}\Expat 2.2.4
     UninstallFilesDir={app}\Uninstall
     
     Compression=lzma
    diff --git a/xmlwf/Makefile.am b/xmlwf/Makefile.am
    new file mode 100644
    index 0000000..0ef113c
    --- /dev/null
    +++ b/xmlwf/Makefile.am
    @@ -0,0 +1,54 @@
    +#
    +#                          __  __            _
    +#                       ___\ \/ /_ __   __ _| |_
    +#                      / _ \\  /| '_ \ / _` | __|
    +#                     |  __//  \| |_) | (_| | |_
    +#                      \___/_/\_\ .__/ \__,_|\__|
    +#                               |_| XML parser
    +#
    +# Copyright (c) 2017 Expat development team
    +# Licensed under the MIT license:
    +#
    +# Permission is  hereby granted,  free of charge,  to any  person obtaining
    +# a  copy  of  this  software   and  associated  documentation  files  (the
    +# "Software"),  to  deal in  the  Software  without restriction,  including
    +# without  limitation the  rights  to use,  copy,  modify, merge,  publish,
    +# distribute, sublicense, and/or sell copies of the Software, and to permit
    +# persons  to whom  the Software  is  furnished to  do so,  subject to  the
    +# following conditions:
    +#
    +# The above copyright  notice and this permission notice  shall be included
    +# in all copies or substantial portions of the Software.
    +#
    +# THE  SOFTWARE  IS  PROVIDED  "AS  IS",  WITHOUT  WARRANTY  OF  ANY  KIND,
    +# EXPRESS  OR IMPLIED,  INCLUDING  BUT  NOT LIMITED  TO  THE WARRANTIES  OF
    +# MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN
    +# NO EVENT SHALL THE AUTHORS OR  COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
    +# DAMAGES OR  OTHER LIABILITY, WHETHER  IN AN  ACTION OF CONTRACT,  TORT OR
    +# OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE
    +# USE OR OTHER DEALINGS IN THE SOFTWARE.
    +
    +AM_CPPFLAGS = -I$(srcdir)/../lib
    +
    +bin_PROGRAMS = xmlwf
    +
    +xmlwf_LDADD = ../lib/libexpat.la
    +xmlwf_SOURCES = \
    +    xmlwf.c \
    +    xmlfile.c \
    +    codepage.c \
    +    @FILEMAP@.c
    +
    +EXTRA_DIST = \
    +    codepage.h \
    +    ct.c \
    +    filemap.h \
    +    readfilemap.c \
    +    unixfilemap.c \
    +    win32filemap.c \
    +    xmlfile.h \
    +    xmlmime.c \
    +    xmlmime.h \
    +    xmltchar.h \
    +    xmlurl.h \
    +    xmlwin32url.cxx
    diff --git a/xmlwf/Makefile.in b/xmlwf/Makefile.in
    new file mode 100644
    index 0000000..8d3b6c0
    --- /dev/null
    +++ b/xmlwf/Makefile.in
    @@ -0,0 +1,691 @@
    +# Makefile.in generated by automake 1.15.1 from Makefile.am.
    +# @configure_input@
    +
    +# Copyright (C) 1994-2017 Free Software Foundation, Inc.
    +
    +# This Makefile.in is free software; the Free Software Foundation
    +# gives unlimited permission to copy and/or distribute it,
    +# with or without modifications, as long as this notice is preserved.
    +
    +# This program is distributed in the hope that it will be useful,
    +# but WITHOUT ANY WARRANTY, to the extent permitted by law; without
    +# even the implied warranty of MERCHANTABILITY or FITNESS FOR A
    +# PARTICULAR PURPOSE.
    +
    +@SET_MAKE@
    +
    +#
    +#                          __  __            _
    +#                       ___\ \/ /_ __   __ _| |_
    +#                      / _ \\  /| '_ \ / _` | __|
    +#                     |  __//  \| |_) | (_| | |_
    +#                      \___/_/\_\ .__/ \__,_|\__|
    +#                               |_| XML parser
    +#
    +# Copyright (c) 2017 Expat development team
    +# Licensed under the MIT license:
    +#
    +# Permission is  hereby granted,  free of charge,  to any  person obtaining
    +# a  copy  of  this  software   and  associated  documentation  files  (the
    +# "Software"),  to  deal in  the  Software  without restriction,  including
    +# without  limitation the  rights  to use,  copy,  modify, merge,  publish,
    +# distribute, sublicense, and/or sell copies of the Software, and to permit
    +# persons  to whom  the Software  is  furnished to  do so,  subject to  the
    +# following conditions:
    +#
    +# The above copyright  notice and this permission notice  shall be included
    +# in all copies or substantial portions of the Software.
    +#
    +# THE  SOFTWARE  IS  PROVIDED  "AS  IS",  WITHOUT  WARRANTY  OF  ANY  KIND,
    +# EXPRESS  OR IMPLIED,  INCLUDING  BUT  NOT LIMITED  TO  THE WARRANTIES  OF
    +# MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN
    +# NO EVENT SHALL THE AUTHORS OR  COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
    +# DAMAGES OR  OTHER LIABILITY, WHETHER  IN AN  ACTION OF CONTRACT,  TORT OR
    +# OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE
    +# USE OR OTHER DEALINGS IN THE SOFTWARE.
    +
    +VPATH = @srcdir@
    +am__is_gnu_make = { \
    +  if test -z '$(MAKELEVEL)'; then \
    +    false; \
    +  elif test -n '$(MAKE_HOST)'; then \
    +    true; \
    +  elif test -n '$(MAKE_VERSION)' && test -n '$(CURDIR)'; then \
    +    true; \
    +  else \
    +    false; \
    +  fi; \
    +}
    +am__make_running_with_option = \
    +  case $${target_option-} in \
    +      ?) ;; \
    +      *) echo "am__make_running_with_option: internal error: invalid" \
    +              "target option '$${target_option-}' specified" >&2; \
    +         exit 1;; \
    +  esac; \
    +  has_opt=no; \
    +  sane_makeflags=$$MAKEFLAGS; \
    +  if $(am__is_gnu_make); then \
    +    sane_makeflags=$$MFLAGS; \
    +  else \
    +    case $$MAKEFLAGS in \
    +      *\\[\ \	]*) \
    +        bs=\\; \
    +        sane_makeflags=`printf '%s\n' "$$MAKEFLAGS" \
    +          | sed "s/$$bs$$bs[$$bs $$bs	]*//g"`;; \
    +    esac; \
    +  fi; \
    +  skip_next=no; \
    +  strip_trailopt () \
    +  { \
    +    flg=`printf '%s\n' "$$flg" | sed "s/$$1.*$$//"`; \
    +  }; \
    +  for flg in $$sane_makeflags; do \
    +    test $$skip_next = yes && { skip_next=no; continue; }; \
    +    case $$flg in \
    +      *=*|--*) continue;; \
    +        -*I) strip_trailopt 'I'; skip_next=yes;; \
    +      -*I?*) strip_trailopt 'I';; \
    +        -*O) strip_trailopt 'O'; skip_next=yes;; \
    +      -*O?*) strip_trailopt 'O';; \
    +        -*l) strip_trailopt 'l'; skip_next=yes;; \
    +      -*l?*) strip_trailopt 'l';; \
    +      -[dEDm]) skip_next=yes;; \
    +      -[JT]) skip_next=yes;; \
    +    esac; \
    +    case $$flg in \
    +      *$$target_option*) has_opt=yes; break;; \
    +    esac; \
    +  done; \
    +  test $$has_opt = yes
    +am__make_dryrun = (target_option=n; $(am__make_running_with_option))
    +am__make_keepgoing = (target_option=k; $(am__make_running_with_option))
    +pkgdatadir = $(datadir)/@PACKAGE@
    +pkgincludedir = $(includedir)/@PACKAGE@
    +pkglibdir = $(libdir)/@PACKAGE@
    +pkglibexecdir = $(libexecdir)/@PACKAGE@
    +am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd
    +install_sh_DATA = $(install_sh) -c -m 644
    +install_sh_PROGRAM = $(install_sh) -c
    +install_sh_SCRIPT = $(install_sh) -c
    +INSTALL_HEADER = $(INSTALL_DATA)
    +transform = $(program_transform_name)
    +NORMAL_INSTALL = :
    +PRE_INSTALL = :
    +POST_INSTALL = :
    +NORMAL_UNINSTALL = :
    +PRE_UNINSTALL = :
    +POST_UNINSTALL = :
    +build_triplet = @build@
    +host_triplet = @host@
    +bin_PROGRAMS = xmlwf$(EXEEXT)
    +subdir = xmlwf
    +ACLOCAL_M4 = $(top_srcdir)/aclocal.m4
    +am__aclocal_m4_deps = $(top_srcdir)/m4/libtool.m4 \
    +	$(top_srcdir)/m4/ltoptions.m4 $(top_srcdir)/m4/ltsugar.m4 \
    +	$(top_srcdir)/m4/ltversion.m4 $(top_srcdir)/m4/lt~obsolete.m4 \
    +	$(top_srcdir)/conftools/ac_c_bigendian_cross.m4 \
    +	$(top_srcdir)/configure.ac
    +am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \
    +	$(ACLOCAL_M4)
    +DIST_COMMON = $(srcdir)/Makefile.am $(am__DIST_COMMON)
    +mkinstalldirs = $(install_sh) -d
    +CONFIG_HEADER = $(top_builddir)/expat_config.h
    +CONFIG_CLEAN_FILES =
    +CONFIG_CLEAN_VPATH_FILES =
    +am__installdirs = "$(DESTDIR)$(bindir)"
    +PROGRAMS = $(bin_PROGRAMS)
    +am_xmlwf_OBJECTS = xmlwf.$(OBJEXT) xmlfile.$(OBJEXT) \
    +	codepage.$(OBJEXT) @FILEMAP@.$(OBJEXT)
    +xmlwf_OBJECTS = $(am_xmlwf_OBJECTS)
    +xmlwf_DEPENDENCIES = ../lib/libexpat.la
    +AM_V_lt = $(am__v_lt_@AM_V@)
    +am__v_lt_ = $(am__v_lt_@AM_DEFAULT_V@)
    +am__v_lt_0 = --silent
    +am__v_lt_1 = 
    +AM_V_P = $(am__v_P_@AM_V@)
    +am__v_P_ = $(am__v_P_@AM_DEFAULT_V@)
    +am__v_P_0 = false
    +am__v_P_1 = :
    +AM_V_GEN = $(am__v_GEN_@AM_V@)
    +am__v_GEN_ = $(am__v_GEN_@AM_DEFAULT_V@)
    +am__v_GEN_0 = @echo "  GEN     " $@;
    +am__v_GEN_1 = 
    +AM_V_at = $(am__v_at_@AM_V@)
    +am__v_at_ = $(am__v_at_@AM_DEFAULT_V@)
    +am__v_at_0 = @
    +am__v_at_1 = 
    +DEFAULT_INCLUDES = -I.@am__isrc@ -I$(top_builddir)
    +depcomp = $(SHELL) $(top_srcdir)/conftools/depcomp
    +am__depfiles_maybe = depfiles
    +am__mv = mv -f
    +COMPILE = $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) \
    +	$(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS)
    +LTCOMPILE = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \
    +	$(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) \
    +	$(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) \
    +	$(AM_CFLAGS) $(CFLAGS)
    +AM_V_CC = $(am__v_CC_@AM_V@)
    +am__v_CC_ = $(am__v_CC_@AM_DEFAULT_V@)
    +am__v_CC_0 = @echo "  CC      " $@;
    +am__v_CC_1 = 
    +CCLD = $(CC)
    +LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \
    +	$(LIBTOOLFLAGS) --mode=link $(CCLD) $(AM_CFLAGS) $(CFLAGS) \
    +	$(AM_LDFLAGS) $(LDFLAGS) -o $@
    +AM_V_CCLD = $(am__v_CCLD_@AM_V@)
    +am__v_CCLD_ = $(am__v_CCLD_@AM_DEFAULT_V@)
    +am__v_CCLD_0 = @echo "  CCLD    " $@;
    +am__v_CCLD_1 = 
    +SOURCES = $(xmlwf_SOURCES)
    +DIST_SOURCES = $(xmlwf_SOURCES)
    +am__can_run_installinfo = \
    +  case $$AM_UPDATE_INFO_DIR in \
    +    n|no|NO) false;; \
    +    *) (install-info --version) >/dev/null 2>&1;; \
    +  esac
    +am__tagged_files = $(HEADERS) $(SOURCES) $(TAGS_FILES) $(LISP)
    +# Read a list of newline-separated strings from the standard input,
    +# and print each of them once, without duplicates.  Input order is
    +# *not* preserved.
    +am__uniquify_input = $(AWK) '\
    +  BEGIN { nonempty = 0; } \
    +  { items[$$0] = 1; nonempty = 1; } \
    +  END { if (nonempty) { for (i in items) print i; }; } \
    +'
    +# Make sure the list of sources is unique.  This is necessary because,
    +# e.g., the same source file might be shared among _SOURCES variables
    +# for different programs/libraries.
    +am__define_uniq_tagged_files = \
    +  list='$(am__tagged_files)'; \
    +  unique=`for i in $$list; do \
    +    if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \
    +  done | $(am__uniquify_input)`
    +ETAGS = etags
    +CTAGS = ctags
    +am__DIST_COMMON = $(srcdir)/Makefile.in \
    +	$(top_srcdir)/conftools/depcomp
    +DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST)
    +ACLOCAL = @ACLOCAL@
    +AMTAR = @AMTAR@
    +AM_DEFAULT_VERBOSITY = @AM_DEFAULT_VERBOSITY@
    +AR = @AR@
    +AS = @AS@
    +AUTOCONF = @AUTOCONF@
    +AUTOHEADER = @AUTOHEADER@
    +AUTOMAKE = @AUTOMAKE@
    +AWK = @AWK@
    +CC = @CC@
    +CCDEPMODE = @CCDEPMODE@
    +CFLAGS = @CFLAGS@
    +CPP = @CPP@
    +CPPFLAGS = @CPPFLAGS@
    +CXX = @CXX@
    +CXXCPP = @CXXCPP@
    +CXXDEPMODE = @CXXDEPMODE@
    +CXXFLAGS = @CXXFLAGS@
    +CYGPATH_W = @CYGPATH_W@
    +DEFS = @DEFS@
    +DEPDIR = @DEPDIR@
    +DLLTOOL = @DLLTOOL@
    +DSYMUTIL = @DSYMUTIL@
    +DUMPBIN = @DUMPBIN@
    +ECHO_C = @ECHO_C@
    +ECHO_N = @ECHO_N@
    +ECHO_T = @ECHO_T@
    +EGREP = @EGREP@
    +EXEEXT = @EXEEXT@
    +FGREP = @FGREP@
    +FILEMAP = @FILEMAP@
    +GREP = @GREP@
    +INSTALL = @INSTALL@
    +INSTALL_DATA = @INSTALL_DATA@
    +INSTALL_PROGRAM = @INSTALL_PROGRAM@
    +INSTALL_SCRIPT = @INSTALL_SCRIPT@
    +INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@
    +LD = @LD@
    +LDFLAGS = @LDFLAGS@
    +LIBAGE = @LIBAGE@
    +LIBCURRENT = @LIBCURRENT@
    +LIBOBJS = @LIBOBJS@
    +LIBREVISION = @LIBREVISION@
    +LIBS = @LIBS@
    +LIBTOOL = @LIBTOOL@
    +LIPO = @LIPO@
    +LN_S = @LN_S@
    +LTLIBOBJS = @LTLIBOBJS@
    +LT_SYS_LIBRARY_PATH = @LT_SYS_LIBRARY_PATH@
    +MAKEINFO = @MAKEINFO@
    +MANIFEST_TOOL = @MANIFEST_TOOL@
    +MKDIR_P = @MKDIR_P@
    +NM = @NM@
    +NMEDIT = @NMEDIT@
    +OBJDUMP = @OBJDUMP@
    +OBJEXT = @OBJEXT@
    +OTOOL = @OTOOL@
    +OTOOL64 = @OTOOL64@
    +PACKAGE = @PACKAGE@
    +PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@
    +PACKAGE_NAME = @PACKAGE_NAME@
    +PACKAGE_STRING = @PACKAGE_STRING@
    +PACKAGE_TARNAME = @PACKAGE_TARNAME@
    +PACKAGE_URL = @PACKAGE_URL@
    +PACKAGE_VERSION = @PACKAGE_VERSION@
    +PATH_SEPARATOR = @PATH_SEPARATOR@
    +RANLIB = @RANLIB@
    +SED = @SED@
    +SET_MAKE = @SET_MAKE@
    +SHELL = @SHELL@
    +STRIP = @STRIP@
    +VERSION = @VERSION@
    +abs_builddir = @abs_builddir@
    +abs_srcdir = @abs_srcdir@
    +abs_top_builddir = @abs_top_builddir@
    +abs_top_srcdir = @abs_top_srcdir@
    +ac_ct_AR = @ac_ct_AR@
    +ac_ct_CC = @ac_ct_CC@
    +ac_ct_CXX = @ac_ct_CXX@
    +ac_ct_DUMPBIN = @ac_ct_DUMPBIN@
    +am__include = @am__include@
    +am__leading_dot = @am__leading_dot@
    +am__quote = @am__quote@
    +am__tar = @am__tar@
    +am__untar = @am__untar@
    +bindir = @bindir@
    +build = @build@
    +build_alias = @build_alias@
    +build_cpu = @build_cpu@
    +build_os = @build_os@
    +build_vendor = @build_vendor@
    +builddir = @builddir@
    +datadir = @datadir@
    +datarootdir = @datarootdir@
    +docdir = @docdir@
    +dvidir = @dvidir@
    +exec_prefix = @exec_prefix@
    +host = @host@
    +host_alias = @host_alias@
    +host_cpu = @host_cpu@
    +host_os = @host_os@
    +host_vendor = @host_vendor@
    +htmldir = @htmldir@
    +includedir = @includedir@
    +infodir = @infodir@
    +install_sh = @install_sh@
    +libdir = @libdir@
    +libexecdir = @libexecdir@
    +localedir = @localedir@
    +localstatedir = @localstatedir@
    +mandir = @mandir@
    +mkdir_p = @mkdir_p@
    +oldincludedir = @oldincludedir@
    +pdfdir = @pdfdir@
    +prefix = @prefix@
    +program_transform_name = @program_transform_name@
    +psdir = @psdir@
    +sbindir = @sbindir@
    +sharedstatedir = @sharedstatedir@
    +srcdir = @srcdir@
    +sysconfdir = @sysconfdir@
    +target_alias = @target_alias@
    +top_build_prefix = @top_build_prefix@
    +top_builddir = @top_builddir@
    +top_srcdir = @top_srcdir@
    +AM_CPPFLAGS = -I$(srcdir)/../lib
    +xmlwf_LDADD = ../lib/libexpat.la
    +xmlwf_SOURCES = \
    +    xmlwf.c \
    +    xmlfile.c \
    +    codepage.c \
    +    @FILEMAP@.c
    +
    +EXTRA_DIST = \
    +    codepage.h \
    +    ct.c \
    +    filemap.h \
    +    readfilemap.c \
    +    unixfilemap.c \
    +    win32filemap.c \
    +    xmlfile.h \
    +    xmlmime.c \
    +    xmlmime.h \
    +    xmltchar.h \
    +    xmlurl.h \
    +    xmlwin32url.cxx
    +
    +all: all-am
    +
    +.SUFFIXES:
    +.SUFFIXES: .c .lo .o .obj
    +$(srcdir)/Makefile.in:  $(srcdir)/Makefile.am  $(am__configure_deps)
    +	@for dep in $?; do \
    +	  case '$(am__configure_deps)' in \
    +	    *$$dep*) \
    +	      ( cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh ) \
    +	        && { if test -f $@; then exit 0; else break; fi; }; \
    +	      exit 1;; \
    +	  esac; \
    +	done; \
    +	echo ' cd $(top_srcdir) && $(AUTOMAKE) --gnu xmlwf/Makefile'; \
    +	$(am__cd) $(top_srcdir) && \
    +	  $(AUTOMAKE) --gnu xmlwf/Makefile
    +Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status
    +	@case '$?' in \
    +	  *config.status*) \
    +	    cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh;; \
    +	  *) \
    +	    echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe)'; \
    +	    cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe);; \
    +	esac;
    +
    +$(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES)
    +	cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh
    +
    +$(top_srcdir)/configure:  $(am__configure_deps)
    +	cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh
    +$(ACLOCAL_M4):  $(am__aclocal_m4_deps)
    +	cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh
    +$(am__aclocal_m4_deps):
    +install-binPROGRAMS: $(bin_PROGRAMS)
    +	@$(NORMAL_INSTALL)
    +	@list='$(bin_PROGRAMS)'; test -n "$(bindir)" || list=; \
    +	if test -n "$$list"; then \
    +	  echo " $(MKDIR_P) '$(DESTDIR)$(bindir)'"; \
    +	  $(MKDIR_P) "$(DESTDIR)$(bindir)" || exit 1; \
    +	fi; \
    +	for p in $$list; do echo "$$p $$p"; done | \
    +	sed 's/$(EXEEXT)$$//' | \
    +	while read p p1; do if test -f $$p \
    +	 || test -f $$p1 \
    +	  ; then echo "$$p"; echo "$$p"; else :; fi; \
    +	done | \
    +	sed -e 'p;s,.*/,,;n;h' \
    +	    -e 's|.*|.|' \
    +	    -e 'p;x;s,.*/,,;s/$(EXEEXT)$$//;$(transform);s/$$/$(EXEEXT)/' | \
    +	sed 'N;N;N;s,\n, ,g' | \
    +	$(AWK) 'BEGIN { files["."] = ""; dirs["."] = 1 } \
    +	  { d=$$3; if (dirs[d] != 1) { print "d", d; dirs[d] = 1 } \
    +	    if ($$2 == $$4) files[d] = files[d] " " $$1; \
    +	    else { print "f", $$3 "/" $$4, $$1; } } \
    +	  END { for (d in files) print "f", d, files[d] }' | \
    +	while read type dir files; do \
    +	    if test "$$dir" = .; then dir=; else dir=/$$dir; fi; \
    +	    test -z "$$files" || { \
    +	    echo " $(INSTALL_PROGRAM_ENV) $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=install $(INSTALL_PROGRAM) $$files '$(DESTDIR)$(bindir)$$dir'"; \
    +	    $(INSTALL_PROGRAM_ENV) $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=install $(INSTALL_PROGRAM) $$files "$(DESTDIR)$(bindir)$$dir" || exit $$?; \
    +	    } \
    +	; done
    +
    +uninstall-binPROGRAMS:
    +	@$(NORMAL_UNINSTALL)
    +	@list='$(bin_PROGRAMS)'; test -n "$(bindir)" || list=; \
    +	files=`for p in $$list; do echo "$$p"; done | \
    +	  sed -e 'h;s,^.*/,,;s/$(EXEEXT)$$//;$(transform)' \
    +	      -e 's/$$/$(EXEEXT)/' \
    +	`; \
    +	test -n "$$list" || exit 0; \
    +	echo " ( cd '$(DESTDIR)$(bindir)' && rm -f" $$files ")"; \
    +	cd "$(DESTDIR)$(bindir)" && rm -f $$files
    +
    +clean-binPROGRAMS:
    +	@list='$(bin_PROGRAMS)'; test -n "$$list" || exit 0; \
    +	echo " rm -f" $$list; \
    +	rm -f $$list || exit $$?; \
    +	test -n "$(EXEEXT)" || exit 0; \
    +	list=`for p in $$list; do echo "$$p"; done | sed 's/$(EXEEXT)$$//'`; \
    +	echo " rm -f" $$list; \
    +	rm -f $$list
    +
    +xmlwf$(EXEEXT): $(xmlwf_OBJECTS) $(xmlwf_DEPENDENCIES) $(EXTRA_xmlwf_DEPENDENCIES) 
    +	@rm -f xmlwf$(EXEEXT)
    +	$(AM_V_CCLD)$(LINK) $(xmlwf_OBJECTS) $(xmlwf_LDADD) $(LIBS)
    +
    +mostlyclean-compile:
    +	-rm -f *.$(OBJEXT)
    +
    +distclean-compile:
    +	-rm -f *.tab.c
    +
    +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/@FILEMAP@.Po@am__quote@
    +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/codepage.Po@am__quote@
    +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/xmlfile.Po@am__quote@
    +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/xmlwf.Po@am__quote@
    +
    +.c.o:
    +@am__fastdepCC_TRUE@	$(AM_V_CC)$(COMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ $<
    +@am__fastdepCC_TRUE@	$(AM_V_at)$(am__mv) $(DEPDIR)/$*.Tpo $(DEPDIR)/$*.Po
    +@AMDEP_TRUE@@am__fastdepCC_FALSE@	$(AM_V_CC)source='$<' object='$@' libtool=no @AMDEPBACKSLASH@
    +@AMDEP_TRUE@@am__fastdepCC_FALSE@	DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
    +@am__fastdepCC_FALSE@	$(AM_V_CC@am__nodep@)$(COMPILE) -c -o $@ $<
    +
    +.c.obj:
    +@am__fastdepCC_TRUE@	$(AM_V_CC)$(COMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ `$(CYGPATH_W) '$<'`
    +@am__fastdepCC_TRUE@	$(AM_V_at)$(am__mv) $(DEPDIR)/$*.Tpo $(DEPDIR)/$*.Po
    +@AMDEP_TRUE@@am__fastdepCC_FALSE@	$(AM_V_CC)source='$<' object='$@' libtool=no @AMDEPBACKSLASH@
    +@AMDEP_TRUE@@am__fastdepCC_FALSE@	DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
    +@am__fastdepCC_FALSE@	$(AM_V_CC@am__nodep@)$(COMPILE) -c -o $@ `$(CYGPATH_W) '$<'`
    +
    +.c.lo:
    +@am__fastdepCC_TRUE@	$(AM_V_CC)$(LTCOMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ $<
    +@am__fastdepCC_TRUE@	$(AM_V_at)$(am__mv) $(DEPDIR)/$*.Tpo $(DEPDIR)/$*.Plo
    +@AMDEP_TRUE@@am__fastdepCC_FALSE@	$(AM_V_CC)source='$<' object='$@' libtool=yes @AMDEPBACKSLASH@
    +@AMDEP_TRUE@@am__fastdepCC_FALSE@	DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
    +@am__fastdepCC_FALSE@	$(AM_V_CC@am__nodep@)$(LTCOMPILE) -c -o $@ $<
    +
    +mostlyclean-libtool:
    +	-rm -f *.lo
    +
    +clean-libtool:
    +	-rm -rf .libs _libs
    +
    +ID: $(am__tagged_files)
    +	$(am__define_uniq_tagged_files); mkid -fID $$unique
    +tags: tags-am
    +TAGS: tags
    +
    +tags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files)
    +	set x; \
    +	here=`pwd`; \
    +	$(am__define_uniq_tagged_files); \
    +	shift; \
    +	if test -z "$(ETAGS_ARGS)$$*$$unique"; then :; else \
    +	  test -n "$$unique" || unique=$$empty_fix; \
    +	  if test $$# -gt 0; then \
    +	    $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \
    +	      "$$@" $$unique; \
    +	  else \
    +	    $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \
    +	      $$unique; \
    +	  fi; \
    +	fi
    +ctags: ctags-am
    +
    +CTAGS: ctags
    +ctags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files)
    +	$(am__define_uniq_tagged_files); \
    +	test -z "$(CTAGS_ARGS)$$unique" \
    +	  || $(CTAGS) $(CTAGSFLAGS) $(AM_CTAGSFLAGS) $(CTAGS_ARGS) \
    +	     $$unique
    +
    +GTAGS:
    +	here=`$(am__cd) $(top_builddir) && pwd` \
    +	  && $(am__cd) $(top_srcdir) \
    +	  && gtags -i $(GTAGS_ARGS) "$$here"
    +cscopelist: cscopelist-am
    +
    +cscopelist-am: $(am__tagged_files)
    +	list='$(am__tagged_files)'; \
    +	case "$(srcdir)" in \
    +	  [\\/]* | ?:[\\/]*) sdir="$(srcdir)" ;; \
    +	  *) sdir=$(subdir)/$(srcdir) ;; \
    +	esac; \
    +	for i in $$list; do \
    +	  if test -f "$$i"; then \
    +	    echo "$(subdir)/$$i"; \
    +	  else \
    +	    echo "$$sdir/$$i"; \
    +	  fi; \
    +	done >> $(top_builddir)/cscope.files
    +
    +distclean-tags:
    +	-rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH tags
    +
    +distdir: $(DISTFILES)
    +	@srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \
    +	topsrcdirstrip=`echo "$(top_srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \
    +	list='$(DISTFILES)'; \
    +	  dist_files=`for file in $$list; do echo $$file; done | \
    +	  sed -e "s|^$$srcdirstrip/||;t" \
    +	      -e "s|^$$topsrcdirstrip/|$(top_builddir)/|;t"`; \
    +	case $$dist_files in \
    +	  */*) $(MKDIR_P) `echo "$$dist_files" | \
    +			   sed '/\//!d;s|^|$(distdir)/|;s,/[^/]*$$,,' | \
    +			   sort -u` ;; \
    +	esac; \
    +	for file in $$dist_files; do \
    +	  if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \
    +	  if test -d $$d/$$file; then \
    +	    dir=`echo "/$$file" | sed -e 's,/[^/]*$$,,'`; \
    +	    if test -d "$(distdir)/$$file"; then \
    +	      find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \
    +	    fi; \
    +	    if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \
    +	      cp -fpR $(srcdir)/$$file "$(distdir)$$dir" || exit 1; \
    +	      find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \
    +	    fi; \
    +	    cp -fpR $$d/$$file "$(distdir)$$dir" || exit 1; \
    +	  else \
    +	    test -f "$(distdir)/$$file" \
    +	    || cp -p $$d/$$file "$(distdir)/$$file" \
    +	    || exit 1; \
    +	  fi; \
    +	done
    +check-am: all-am
    +check: check-am
    +all-am: Makefile $(PROGRAMS)
    +installdirs:
    +	for dir in "$(DESTDIR)$(bindir)"; do \
    +	  test -z "$$dir" || $(MKDIR_P) "$$dir"; \
    +	done
    +install: install-am
    +install-exec: install-exec-am
    +install-data: install-data-am
    +uninstall: uninstall-am
    +
    +install-am: all-am
    +	@$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am
    +
    +installcheck: installcheck-am
    +install-strip:
    +	if test -z '$(STRIP)'; then \
    +	  $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \
    +	    install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \
    +	      install; \
    +	else \
    +	  $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \
    +	    install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \
    +	    "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'" install; \
    +	fi
    +mostlyclean-generic:
    +
    +clean-generic:
    +
    +distclean-generic:
    +	-test -z "$(CONFIG_CLEAN_FILES)" || rm -f $(CONFIG_CLEAN_FILES)
    +	-test . = "$(srcdir)" || test -z "$(CONFIG_CLEAN_VPATH_FILES)" || rm -f $(CONFIG_CLEAN_VPATH_FILES)
    +
    +maintainer-clean-generic:
    +	@echo "This command is intended for maintainers to use"
    +	@echo "it deletes files that may require special tools to rebuild."
    +clean: clean-am
    +
    +clean-am: clean-binPROGRAMS clean-generic clean-libtool mostlyclean-am
    +
    +distclean: distclean-am
    +	-rm -rf ./$(DEPDIR)
    +	-rm -f Makefile
    +distclean-am: clean-am distclean-compile distclean-generic \
    +	distclean-tags
    +
    +dvi: dvi-am
    +
    +dvi-am:
    +
    +html: html-am
    +
    +html-am:
    +
    +info: info-am
    +
    +info-am:
    +
    +install-data-am:
    +
    +install-dvi: install-dvi-am
    +
    +install-dvi-am:
    +
    +install-exec-am: install-binPROGRAMS
    +
    +install-html: install-html-am
    +
    +install-html-am:
    +
    +install-info: install-info-am
    +
    +install-info-am:
    +
    +install-man:
    +
    +install-pdf: install-pdf-am
    +
    +install-pdf-am:
    +
    +install-ps: install-ps-am
    +
    +install-ps-am:
    +
    +installcheck-am:
    +
    +maintainer-clean: maintainer-clean-am
    +	-rm -rf ./$(DEPDIR)
    +	-rm -f Makefile
    +maintainer-clean-am: distclean-am maintainer-clean-generic
    +
    +mostlyclean: mostlyclean-am
    +
    +mostlyclean-am: mostlyclean-compile mostlyclean-generic \
    +	mostlyclean-libtool
    +
    +pdf: pdf-am
    +
    +pdf-am:
    +
    +ps: ps-am
    +
    +ps-am:
    +
    +uninstall-am: uninstall-binPROGRAMS
    +
    +.MAKE: install-am install-strip
    +
    +.PHONY: CTAGS GTAGS TAGS all all-am check check-am clean \
    +	clean-binPROGRAMS clean-generic clean-libtool cscopelist-am \
    +	ctags ctags-am distclean distclean-compile distclean-generic \
    +	distclean-libtool distclean-tags distdir dvi dvi-am html \
    +	html-am info info-am install install-am install-binPROGRAMS \
    +	install-data install-data-am install-dvi install-dvi-am \
    +	install-exec install-exec-am install-html install-html-am \
    +	install-info install-info-am install-man install-pdf \
    +	install-pdf-am install-ps install-ps-am install-strip \
    +	installcheck installcheck-am installdirs maintainer-clean \
    +	maintainer-clean-generic mostlyclean mostlyclean-compile \
    +	mostlyclean-generic mostlyclean-libtool pdf pdf-am ps ps-am \
    +	tags tags-am uninstall uninstall-am uninstall-binPROGRAMS
    +
    +.PRECIOUS: Makefile
    +
    +
    +# Tell versions [3.59,3.63) of GNU make to not export all variables.
    +# Otherwise a system limit (for SysV at least) may be exceeded.
    +.NOEXPORT:
    diff --git a/xmlwf/codepage.c b/xmlwf/codepage.c
    index 7d78f21..1a0487f 100644
    --- a/xmlwf/codepage.c
    +++ b/xmlwf/codepage.c
    @@ -1,5 +1,33 @@
    -/* Copyright (c) 1998, 1999 Thai Open Source Software Center Ltd
    -   See the file COPYING for copying permission.
    +/*
    +                            __  __            _
    +                         ___\ \/ /_ __   __ _| |_
    +                        / _ \\  /| '_ \ / _` | __|
    +                       |  __//  \| |_) | (_| | |_
    +                        \___/_/\_\ .__/ \__,_|\__|
    +                                 |_| XML parser
    +
    +   Copyright (c) 1997-2000 Thai Open Source Software Center Ltd
    +   Copyright (c) 2000-2017 Expat development team
    +   Licensed under the MIT license:
    +
    +   Permission is  hereby granted,  free of charge,  to any  person obtaining
    +   a  copy  of  this  software   and  associated  documentation  files  (the
    +   "Software"),  to  deal in  the  Software  without restriction,  including
    +   without  limitation the  rights  to use,  copy,  modify, merge,  publish,
    +   distribute, sublicense, and/or sell copies of the Software, and to permit
    +   persons  to whom  the Software  is  furnished to  do so,  subject to  the
    +   following conditions:
    +
    +   The above copyright  notice and this permission notice  shall be included
    +   in all copies or substantial portions of the Software.
    +
    +   THE  SOFTWARE  IS  PROVIDED  "AS  IS",  WITHOUT  WARRANTY  OF  ANY  KIND,
    +   EXPRESS  OR IMPLIED,  INCLUDING  BUT  NOT LIMITED  TO  THE WARRANTIES  OF
    +   MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN
    +   NO EVENT SHALL THE AUTHORS OR  COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
    +   DAMAGES OR  OTHER LIABILITY, WHETHER  IN AN  ACTION OF CONTRACT,  TORT OR
    +   OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE
    +   USE OR OTHER DEALINGS IN THE SOFTWARE.
     */
     
     #include "codepage.h"
    diff --git a/xmlwf/codepage.h b/xmlwf/codepage.h
    index 6a4df68..1b75d58 100644
    --- a/xmlwf/codepage.h
    +++ b/xmlwf/codepage.h
    @@ -1,5 +1,33 @@
    -/* Copyright (c) 1998, 1999 Thai Open Source Software Center Ltd
    -   See the file COPYING for copying permission.
    +/*
    +                            __  __            _
    +                         ___\ \/ /_ __   __ _| |_
    +                        / _ \\  /| '_ \ / _` | __|
    +                       |  __//  \| |_) | (_| | |_
    +                        \___/_/\_\ .__/ \__,_|\__|
    +                                 |_| XML parser
    +
    +   Copyright (c) 1997-2000 Thai Open Source Software Center Ltd
    +   Copyright (c) 2000-2017 Expat development team
    +   Licensed under the MIT license:
    +
    +   Permission is  hereby granted,  free of charge,  to any  person obtaining
    +   a  copy  of  this  software   and  associated  documentation  files  (the
    +   "Software"),  to  deal in  the  Software  without restriction,  including
    +   without  limitation the  rights  to use,  copy,  modify, merge,  publish,
    +   distribute, sublicense, and/or sell copies of the Software, and to permit
    +   persons  to whom  the Software  is  furnished to  do so,  subject to  the
    +   following conditions:
    +
    +   The above copyright  notice and this permission notice  shall be included
    +   in all copies or substantial portions of the Software.
    +
    +   THE  SOFTWARE  IS  PROVIDED  "AS  IS",  WITHOUT  WARRANTY  OF  ANY  KIND,
    +   EXPRESS  OR IMPLIED,  INCLUDING  BUT  NOT LIMITED  TO  THE WARRANTIES  OF
    +   MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN
    +   NO EVENT SHALL THE AUTHORS OR  COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
    +   DAMAGES OR  OTHER LIABILITY, WHETHER  IN AN  ACTION OF CONTRACT,  TORT OR
    +   OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE
    +   USE OR OTHER DEALINGS IN THE SOFTWARE.
     */
     
     int codepageMap(int cp, int *map);
    diff --git a/xmlwf/ct.c b/xmlwf/ct.c
    index 95903a3..dd42f5e 100644
    --- a/xmlwf/ct.c
    +++ b/xmlwf/ct.c
    @@ -1,3 +1,35 @@
    +/*
    +                            __  __            _
    +                         ___\ \/ /_ __   __ _| |_
    +                        / _ \\  /| '_ \ / _` | __|
    +                       |  __//  \| |_) | (_| | |_
    +                        \___/_/\_\ .__/ \__,_|\__|
    +                                 |_| XML parser
    +
    +   Copyright (c) 1997-2000 Thai Open Source Software Center Ltd
    +   Copyright (c) 2000-2017 Expat development team
    +   Licensed under the MIT license:
    +
    +   Permission is  hereby granted,  free of charge,  to any  person obtaining
    +   a  copy  of  this  software   and  associated  documentation  files  (the
    +   "Software"),  to  deal in  the  Software  without restriction,  including
    +   without  limitation the  rights  to use,  copy,  modify, merge,  publish,
    +   distribute, sublicense, and/or sell copies of the Software, and to permit
    +   persons  to whom  the Software  is  furnished to  do so,  subject to  the
    +   following conditions:
    +
    +   The above copyright  notice and this permission notice  shall be included
    +   in all copies or substantial portions of the Software.
    +
    +   THE  SOFTWARE  IS  PROVIDED  "AS  IS",  WITHOUT  WARRANTY  OF  ANY  KIND,
    +   EXPRESS  OR IMPLIED,  INCLUDING  BUT  NOT LIMITED  TO  THE WARRANTIES  OF
    +   MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN
    +   NO EVENT SHALL THE AUTHORS OR  COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
    +   DAMAGES OR  OTHER LIABILITY, WHETHER  IN AN  ACTION OF CONTRACT,  TORT OR
    +   OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE
    +   USE OR OTHER DEALINGS IN THE SOFTWARE.
    +*/
    +
     #define CHARSET_MAX 41
     
     static const char *
    diff --git a/xmlwf/filemap.h b/xmlwf/filemap.h
    index db83d1a..5487a4e 100644
    --- a/xmlwf/filemap.h
    +++ b/xmlwf/filemap.h
    @@ -1,5 +1,33 @@
    -/* Copyright (c) 1998, 1999 Thai Open Source Software Center Ltd
    -   See the file COPYING for copying permission.
    +/*
    +                            __  __            _
    +                         ___\ \/ /_ __   __ _| |_
    +                        / _ \\  /| '_ \ / _` | __|
    +                       |  __//  \| |_) | (_| | |_
    +                        \___/_/\_\ .__/ \__,_|\__|
    +                                 |_| XML parser
    +
    +   Copyright (c) 1997-2000 Thai Open Source Software Center Ltd
    +   Copyright (c) 2000-2017 Expat development team
    +   Licensed under the MIT license:
    +
    +   Permission is  hereby granted,  free of charge,  to any  person obtaining
    +   a  copy  of  this  software   and  associated  documentation  files  (the
    +   "Software"),  to  deal in  the  Software  without restriction,  including
    +   without  limitation the  rights  to use,  copy,  modify, merge,  publish,
    +   distribute, sublicense, and/or sell copies of the Software, and to permit
    +   persons  to whom  the Software  is  furnished to  do so,  subject to  the
    +   following conditions:
    +
    +   The above copyright  notice and this permission notice  shall be included
    +   in all copies or substantial portions of the Software.
    +
    +   THE  SOFTWARE  IS  PROVIDED  "AS  IS",  WITHOUT  WARRANTY  OF  ANY  KIND,
    +   EXPRESS  OR IMPLIED,  INCLUDING  BUT  NOT LIMITED  TO  THE WARRANTIES  OF
    +   MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN
    +   NO EVENT SHALL THE AUTHORS OR  COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
    +   DAMAGES OR  OTHER LIABILITY, WHETHER  IN AN  ACTION OF CONTRACT,  TORT OR
    +   OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE
    +   USE OR OTHER DEALINGS IN THE SOFTWARE.
     */
     
     #include   /* INT_MAX */
    diff --git a/xmlwf/readfilemap.c b/xmlwf/readfilemap.c
    index fc540e5..dd71847 100644
    --- a/xmlwf/readfilemap.c
    +++ b/xmlwf/readfilemap.c
    @@ -1,5 +1,33 @@
    -/* Copyright (c) 1998, 1999 Thai Open Source Software Center Ltd
    -   See the file COPYING for copying permission.
    +/*
    +                            __  __            _
    +                         ___\ \/ /_ __   __ _| |_
    +                        / _ \\  /| '_ \ / _` | __|
    +                       |  __//  \| |_) | (_| | |_
    +                        \___/_/\_\ .__/ \__,_|\__|
    +                                 |_| XML parser
    +
    +   Copyright (c) 1997-2000 Thai Open Source Software Center Ltd
    +   Copyright (c) 2000-2017 Expat development team
    +   Licensed under the MIT license:
    +
    +   Permission is  hereby granted,  free of charge,  to any  person obtaining
    +   a  copy  of  this  software   and  associated  documentation  files  (the
    +   "Software"),  to  deal in  the  Software  without restriction,  including
    +   without  limitation the  rights  to use,  copy,  modify, merge,  publish,
    +   distribute, sublicense, and/or sell copies of the Software, and to permit
    +   persons  to whom  the Software  is  furnished to  do so,  subject to  the
    +   following conditions:
    +
    +   The above copyright  notice and this permission notice  shall be included
    +   in all copies or substantial portions of the Software.
    +
    +   THE  SOFTWARE  IS  PROVIDED  "AS  IS",  WITHOUT  WARRANTY  OF  ANY  KIND,
    +   EXPRESS  OR IMPLIED,  INCLUDING  BUT  NOT LIMITED  TO  THE WARRANTIES  OF
    +   MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN
    +   NO EVENT SHALL THE AUTHORS OR  COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
    +   DAMAGES OR  OTHER LIABILITY, WHETHER  IN AN  ACTION OF CONTRACT,  TORT OR
    +   OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE
    +   USE OR OTHER DEALINGS IN THE SOFTWARE.
     */
     
     #include 
    diff --git a/xmlwf/unixfilemap.c b/xmlwf/unixfilemap.c
    index 8783134..a829ab3 100644
    --- a/xmlwf/unixfilemap.c
    +++ b/xmlwf/unixfilemap.c
    @@ -1,5 +1,33 @@
    -/* Copyright (c) 1998, 1999 Thai Open Source Software Center Ltd
    -   See the file COPYING for copying permission.
    +/*
    +                            __  __            _
    +                         ___\ \/ /_ __   __ _| |_
    +                        / _ \\  /| '_ \ / _` | __|
    +                       |  __//  \| |_) | (_| | |_
    +                        \___/_/\_\ .__/ \__,_|\__|
    +                                 |_| XML parser
    +
    +   Copyright (c) 1997-2000 Thai Open Source Software Center Ltd
    +   Copyright (c) 2000-2017 Expat development team
    +   Licensed under the MIT license:
    +
    +   Permission is  hereby granted,  free of charge,  to any  person obtaining
    +   a  copy  of  this  software   and  associated  documentation  files  (the
    +   "Software"),  to  deal in  the  Software  without restriction,  including
    +   without  limitation the  rights  to use,  copy,  modify, merge,  publish,
    +   distribute, sublicense, and/or sell copies of the Software, and to permit
    +   persons  to whom  the Software  is  furnished to  do so,  subject to  the
    +   following conditions:
    +
    +   The above copyright  notice and this permission notice  shall be included
    +   in all copies or substantial portions of the Software.
    +
    +   THE  SOFTWARE  IS  PROVIDED  "AS  IS",  WITHOUT  WARRANTY  OF  ANY  KIND,
    +   EXPRESS  OR IMPLIED,  INCLUDING  BUT  NOT LIMITED  TO  THE WARRANTIES  OF
    +   MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN
    +   NO EVENT SHALL THE AUTHORS OR  COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
    +   DAMAGES OR  OTHER LIABILITY, WHETHER  IN AN  ACTION OF CONTRACT,  TORT OR
    +   OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE
    +   USE OR OTHER DEALINGS IN THE SOFTWARE.
     */
     
     #include 
    diff --git a/xmlwf/win32filemap.c b/xmlwf/win32filemap.c
    index 6be4596..ed8453a 100644
    --- a/xmlwf/win32filemap.c
    +++ b/xmlwf/win32filemap.c
    @@ -1,5 +1,33 @@
    -/* Copyright (c) 1998, 1999 Thai Open Source Software Center Ltd
    -   See the file COPYING for copying permission.
    +/*
    +                            __  __            _
    +                         ___\ \/ /_ __   __ _| |_
    +                        / _ \\  /| '_ \ / _` | __|
    +                       |  __//  \| |_) | (_| | |_
    +                        \___/_/\_\ .__/ \__,_|\__|
    +                                 |_| XML parser
    +
    +   Copyright (c) 1997-2000 Thai Open Source Software Center Ltd
    +   Copyright (c) 2000-2017 Expat development team
    +   Licensed under the MIT license:
    +
    +   Permission is  hereby granted,  free of charge,  to any  person obtaining
    +   a  copy  of  this  software   and  associated  documentation  files  (the
    +   "Software"),  to  deal in  the  Software  without restriction,  including
    +   without  limitation the  rights  to use,  copy,  modify, merge,  publish,
    +   distribute, sublicense, and/or sell copies of the Software, and to permit
    +   persons  to whom  the Software  is  furnished to  do so,  subject to  the
    +   following conditions:
    +
    +   The above copyright  notice and this permission notice  shall be included
    +   in all copies or substantial portions of the Software.
    +
    +   THE  SOFTWARE  IS  PROVIDED  "AS  IS",  WITHOUT  WARRANTY  OF  ANY  KIND,
    +   EXPRESS  OR IMPLIED,  INCLUDING  BUT  NOT LIMITED  TO  THE WARRANTIES  OF
    +   MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN
    +   NO EVENT SHALL THE AUTHORS OR  COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
    +   DAMAGES OR  OTHER LIABILITY, WHETHER  IN AN  ACTION OF CONTRACT,  TORT OR
    +   OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE
    +   USE OR OTHER DEALINGS IN THE SOFTWARE.
     */
     
     #define STRICT 1
    diff --git a/xmlwf/xmlfile.c b/xmlwf/xmlfile.c
    index 6473c6e..7799a59 100644
    --- a/xmlwf/xmlfile.c
    +++ b/xmlwf/xmlfile.c
    @@ -1,5 +1,33 @@
    -/* Copyright (c) 1998, 1999 Thai Open Source Software Center Ltd
    -   See the file COPYING for copying permission.
    +/*
    +                            __  __            _
    +                         ___\ \/ /_ __   __ _| |_
    +                        / _ \\  /| '_ \ / _` | __|
    +                       |  __//  \| |_) | (_| | |_
    +                        \___/_/\_\ .__/ \__,_|\__|
    +                                 |_| XML parser
    +
    +   Copyright (c) 1997-2000 Thai Open Source Software Center Ltd
    +   Copyright (c) 2000-2017 Expat development team
    +   Licensed under the MIT license:
    +
    +   Permission is  hereby granted,  free of charge,  to any  person obtaining
    +   a  copy  of  this  software   and  associated  documentation  files  (the
    +   "Software"),  to  deal in  the  Software  without restriction,  including
    +   without  limitation the  rights  to use,  copy,  modify, merge,  publish,
    +   distribute, sublicense, and/or sell copies of the Software, and to permit
    +   persons  to whom  the Software  is  furnished to  do so,  subject to  the
    +   following conditions:
    +
    +   The above copyright  notice and this permission notice  shall be included
    +   in all copies or substantial portions of the Software.
    +
    +   THE  SOFTWARE  IS  PROVIDED  "AS  IS",  WITHOUT  WARRANTY  OF  ANY  KIND,
    +   EXPRESS  OR IMPLIED,  INCLUDING  BUT  NOT LIMITED  TO  THE WARRANTIES  OF
    +   MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN
    +   NO EVENT SHALL THE AUTHORS OR  COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
    +   DAMAGES OR  OTHER LIABILITY, WHETHER  IN AN  ACTION OF CONTRACT,  TORT OR
    +   OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE
    +   USE OR OTHER DEALINGS IN THE SOFTWARE.
     */
     
     #include 
    diff --git a/xmlwf/xmlfile.h b/xmlwf/xmlfile.h
    index d093ecc..c47ea2c 100644
    --- a/xmlwf/xmlfile.h
    +++ b/xmlwf/xmlfile.h
    @@ -1,5 +1,33 @@
    -/* Copyright (c) 1998, 1999 Thai Open Source Software Center Ltd
    -   See the file COPYING for copying permission.
    +/*
    +                            __  __            _
    +                         ___\ \/ /_ __   __ _| |_
    +                        / _ \\  /| '_ \ / _` | __|
    +                       |  __//  \| |_) | (_| | |_
    +                        \___/_/\_\ .__/ \__,_|\__|
    +                                 |_| XML parser
    +
    +   Copyright (c) 1997-2000 Thai Open Source Software Center Ltd
    +   Copyright (c) 2000-2017 Expat development team
    +   Licensed under the MIT license:
    +
    +   Permission is  hereby granted,  free of charge,  to any  person obtaining
    +   a  copy  of  this  software   and  associated  documentation  files  (the
    +   "Software"),  to  deal in  the  Software  without restriction,  including
    +   without  limitation the  rights  to use,  copy,  modify, merge,  publish,
    +   distribute, sublicense, and/or sell copies of the Software, and to permit
    +   persons  to whom  the Software  is  furnished to  do so,  subject to  the
    +   following conditions:
    +
    +   The above copyright  notice and this permission notice  shall be included
    +   in all copies or substantial portions of the Software.
    +
    +   THE  SOFTWARE  IS  PROVIDED  "AS  IS",  WITHOUT  WARRANTY  OF  ANY  KIND,
    +   EXPRESS  OR IMPLIED,  INCLUDING  BUT  NOT LIMITED  TO  THE WARRANTIES  OF
    +   MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN
    +   NO EVENT SHALL THE AUTHORS OR  COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
    +   DAMAGES OR  OTHER LIABILITY, WHETHER  IN AN  ACTION OF CONTRACT,  TORT OR
    +   OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE
    +   USE OR OTHER DEALINGS IN THE SOFTWARE.
     */
     
     #define XML_MAP_FILE 01
    diff --git a/xmlwf/xmlmime.c b/xmlwf/xmlmime.c
    index 56a0e7f..c530979 100644
    --- a/xmlwf/xmlmime.c
    +++ b/xmlwf/xmlmime.c
    @@ -1,3 +1,35 @@
    +/*
    +                            __  __            _
    +                         ___\ \/ /_ __   __ _| |_
    +                        / _ \\  /| '_ \ / _` | __|
    +                       |  __//  \| |_) | (_| | |_
    +                        \___/_/\_\ .__/ \__,_|\__|
    +                                 |_| XML parser
    +
    +   Copyright (c) 1997-2000 Thai Open Source Software Center Ltd
    +   Copyright (c) 2000-2017 Expat development team
    +   Licensed under the MIT license:
    +
    +   Permission is  hereby granted,  free of charge,  to any  person obtaining
    +   a  copy  of  this  software   and  associated  documentation  files  (the
    +   "Software"),  to  deal in  the  Software  without restriction,  including
    +   without  limitation the  rights  to use,  copy,  modify, merge,  publish,
    +   distribute, sublicense, and/or sell copies of the Software, and to permit
    +   persons  to whom  the Software  is  furnished to  do so,  subject to  the
    +   following conditions:
    +
    +   The above copyright  notice and this permission notice  shall be included
    +   in all copies or substantial portions of the Software.
    +
    +   THE  SOFTWARE  IS  PROVIDED  "AS  IS",  WITHOUT  WARRANTY  OF  ANY  KIND,
    +   EXPRESS  OR IMPLIED,  INCLUDING  BUT  NOT LIMITED  TO  THE WARRANTIES  OF
    +   MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN
    +   NO EVENT SHALL THE AUTHORS OR  COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
    +   DAMAGES OR  OTHER LIABILITY, WHETHER  IN AN  ACTION OF CONTRACT,  TORT OR
    +   OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE
    +   USE OR OTHER DEALINGS IN THE SOFTWARE.
    +*/
    +
     #include 
     #include "xmlmime.h"
     
    diff --git a/xmlwf/xmlmime.h b/xmlwf/xmlmime.h
    index bf0356d..0471286 100644
    --- a/xmlwf/xmlmime.h
    +++ b/xmlwf/xmlmime.h
    @@ -1,3 +1,35 @@
    +/*
    +                            __  __            _
    +                         ___\ \/ /_ __   __ _| |_
    +                        / _ \\  /| '_ \ / _` | __|
    +                       |  __//  \| |_) | (_| | |_
    +                        \___/_/\_\ .__/ \__,_|\__|
    +                                 |_| XML parser
    +
    +   Copyright (c) 1997-2000 Thai Open Source Software Center Ltd
    +   Copyright (c) 2000-2017 Expat development team
    +   Licensed under the MIT license:
    +
    +   Permission is  hereby granted,  free of charge,  to any  person obtaining
    +   a  copy  of  this  software   and  associated  documentation  files  (the
    +   "Software"),  to  deal in  the  Software  without restriction,  including
    +   without  limitation the  rights  to use,  copy,  modify, merge,  publish,
    +   distribute, sublicense, and/or sell copies of the Software, and to permit
    +   persons  to whom  the Software  is  furnished to  do so,  subject to  the
    +   following conditions:
    +
    +   The above copyright  notice and this permission notice  shall be included
    +   in all copies or substantial portions of the Software.
    +
    +   THE  SOFTWARE  IS  PROVIDED  "AS  IS",  WITHOUT  WARRANTY  OF  ANY  KIND,
    +   EXPRESS  OR IMPLIED,  INCLUDING  BUT  NOT LIMITED  TO  THE WARRANTIES  OF
    +   MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN
    +   NO EVENT SHALL THE AUTHORS OR  COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
    +   DAMAGES OR  OTHER LIABILITY, WHETHER  IN AN  ACTION OF CONTRACT,  TORT OR
    +   OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE
    +   USE OR OTHER DEALINGS IN THE SOFTWARE.
    +*/
    +
     #ifdef __cplusplus
     extern "C" {
     #endif
    diff --git a/xmlwf/xmltchar.h b/xmlwf/xmltchar.h
    index 1088575..92477e0 100644
    --- a/xmlwf/xmltchar.h
    +++ b/xmlwf/xmltchar.h
    @@ -1,3 +1,35 @@
    +/*
    +                            __  __            _
    +                         ___\ \/ /_ __   __ _| |_
    +                        / _ \\  /| '_ \ / _` | __|
    +                       |  __//  \| |_) | (_| | |_
    +                        \___/_/\_\ .__/ \__,_|\__|
    +                                 |_| XML parser
    +
    +   Copyright (c) 1997-2000 Thai Open Source Software Center Ltd
    +   Copyright (c) 2000-2017 Expat development team
    +   Licensed under the MIT license:
    +
    +   Permission is  hereby granted,  free of charge,  to any  person obtaining
    +   a  copy  of  this  software   and  associated  documentation  files  (the
    +   "Software"),  to  deal in  the  Software  without restriction,  including
    +   without  limitation the  rights  to use,  copy,  modify, merge,  publish,
    +   distribute, sublicense, and/or sell copies of the Software, and to permit
    +   persons  to whom  the Software  is  furnished to  do so,  subject to  the
    +   following conditions:
    +
    +   The above copyright  notice and this permission notice  shall be included
    +   in all copies or substantial portions of the Software.
    +
    +   THE  SOFTWARE  IS  PROVIDED  "AS  IS",  WITHOUT  WARRANTY  OF  ANY  KIND,
    +   EXPRESS  OR IMPLIED,  INCLUDING  BUT  NOT LIMITED  TO  THE WARRANTIES  OF
    +   MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN
    +   NO EVENT SHALL THE AUTHORS OR  COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
    +   DAMAGES OR  OTHER LIABILITY, WHETHER  IN AN  ACTION OF CONTRACT,  TORT OR
    +   OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE
    +   USE OR OTHER DEALINGS IN THE SOFTWARE.
    +*/
    +
     #ifdef XML_UNICODE
     #ifndef XML_UNICODE_WCHAR_T
     #error xmlwf requires a 16-bit Unicode-compatible wchar_t 
    diff --git a/xmlwf/xmlurl.h b/xmlwf/xmlurl.h
    index d329913..f2cff09 100644
    --- a/xmlwf/xmlurl.h
    +++ b/xmlwf/xmlurl.h
    @@ -1,3 +1,35 @@
    +/*
    +                            __  __            _
    +                         ___\ \/ /_ __   __ _| |_
    +                        / _ \\  /| '_ \ / _` | __|
    +                       |  __//  \| |_) | (_| | |_
    +                        \___/_/\_\ .__/ \__,_|\__|
    +                                 |_| XML parser
    +
    +   Copyright (c) 1997-2000 Thai Open Source Software Center Ltd
    +   Copyright (c) 2000-2017 Expat development team
    +   Licensed under the MIT license:
    +
    +   Permission is  hereby granted,  free of charge,  to any  person obtaining
    +   a  copy  of  this  software   and  associated  documentation  files  (the
    +   "Software"),  to  deal in  the  Software  without restriction,  including
    +   without  limitation the  rights  to use,  copy,  modify, merge,  publish,
    +   distribute, sublicense, and/or sell copies of the Software, and to permit
    +   persons  to whom  the Software  is  furnished to  do so,  subject to  the
    +   following conditions:
    +
    +   The above copyright  notice and this permission notice  shall be included
    +   in all copies or substantial portions of the Software.
    +
    +   THE  SOFTWARE  IS  PROVIDED  "AS  IS",  WITHOUT  WARRANTY  OF  ANY  KIND,
    +   EXPRESS  OR IMPLIED,  INCLUDING  BUT  NOT LIMITED  TO  THE WARRANTIES  OF
    +   MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN
    +   NO EVENT SHALL THE AUTHORS OR  COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
    +   DAMAGES OR  OTHER LIABILITY, WHETHER  IN AN  ACTION OF CONTRACT,  TORT OR
    +   OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE
    +   USE OR OTHER DEALINGS IN THE SOFTWARE.
    +*/
    +
     #ifdef __cplusplus
     extern "C" {
     #endif
    diff --git a/xmlwf/xmlwf.c b/xmlwf/xmlwf.c
    index 7581c07..6801e37 100644
    --- a/xmlwf/xmlwf.c
    +++ b/xmlwf/xmlwf.c
    @@ -1,5 +1,33 @@
    -/* Copyright (c) 1998, 1999 Thai Open Source Software Center Ltd
    -   See the file COPYING for copying permission.
    +/*
    +                            __  __            _
    +                         ___\ \/ /_ __   __ _| |_
    +                        / _ \\  /| '_ \ / _` | __|
    +                       |  __//  \| |_) | (_| | |_
    +                        \___/_/\_\ .__/ \__,_|\__|
    +                                 |_| XML parser
    +
    +   Copyright (c) 1997-2000 Thai Open Source Software Center Ltd
    +   Copyright (c) 2000-2017 Expat development team
    +   Licensed under the MIT license:
    +
    +   Permission is  hereby granted,  free of charge,  to any  person obtaining
    +   a  copy  of  this  software   and  associated  documentation  files  (the
    +   "Software"),  to  deal in  the  Software  without restriction,  including
    +   without  limitation the  rights  to use,  copy,  modify, merge,  publish,
    +   distribute, sublicense, and/or sell copies of the Software, and to permit
    +   persons  to whom  the Software  is  furnished to  do so,  subject to  the
    +   following conditions:
    +
    +   The above copyright  notice and this permission notice  shall be included
    +   in all copies or substantial portions of the Software.
    +
    +   THE  SOFTWARE  IS  PROVIDED  "AS  IS",  WITHOUT  WARRANTY  OF  ANY  KIND,
    +   EXPRESS  OR IMPLIED,  INCLUDING  BUT  NOT LIMITED  TO  THE WARRANTIES  OF
    +   MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN
    +   NO EVENT SHALL THE AUTHORS OR  COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
    +   DAMAGES OR  OTHER LIABILITY, WHETHER  IN AN  ACTION OF CONTRACT,  TORT OR
    +   OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE
    +   USE OR OTHER DEALINGS IN THE SOFTWARE.
     */
     
     #include 
    diff --git a/xmlwf/xmlwf.vcxproj b/xmlwf/xmlwf.vcxproj
    new file mode 100644
    index 0000000..0a511c6
    --- /dev/null
    +++ b/xmlwf/xmlwf.vcxproj
    @@ -0,0 +1,163 @@
    +
    +
    +  
    +    
    +      Debug
    +      Win32
    +    
    +    
    +      Release
    +      Win32
    +    
    +    
    +      Template
    +      Win32
    +    
    +  
    +  
    +    
    +    
    +    {E3C5991F-5238-4168-A179-275D1AC98D7E}
    +  
    +  
    +  
    +    Application
    +    v120
    +  
    +  
    +    Application
    +    v120
    +    false
    +  
    +  
    +    Application
    +    v120
    +    false
    +  
    +  
    +  
    +  
    +  
    +    
    +  
    +  
    +    
    +    
    +  
    +  
    +    
    +    
    +  
    +  
    +  
    +    .\..\win32\bin\Release\
    +    .\..\win32\tmp\Release-xmlwf\
    +    false
    +  
    +  
    +    .\..\win32\bin\Debug\
    +    .\..\win32\tmp\Debug-xmlwf\
    +    true
    +  
    +  
    +    
    +      MultiThreaded
    +      Default
    +      true
    +      true
    +      MaxSpeed
    +      true
    +      Level3
    +      ..\lib;%(AdditionalIncludeDirectories)
    +      NDEBUG;_CONSOLE;%(PreprocessorDefinitions)
    +      .\..\win32\tmp\Release-xmlwf\
    +      .\..\win32\tmp\Release-xmlwf\xmlwf.pch
    +      
    +      .\..\win32\tmp\Release-xmlwf\
    +      .\..\win32\tmp\Release-xmlwf\
    +    
    +    
    +      .\..\win32\bin\Release\xmlwf.tlb
    +    
    +    
    +      0x0409
    +      NDEBUG;%(PreprocessorDefinitions)
    +    
    +    
    +      true
    +      .\..\win32\bin\Release\xmlwf.bsc
    +    
    +    
    +      true
    +      Console
    +      false
    +      ..\win32\bin\Release\xmlwf.exe
    +      ..\win32\bin\Release;%(AdditionalLibraryDirectories)
    +      libexpat.lib;setargv.obj;%(AdditionalDependencies)
    +    
    +  
    +  
    +    
    +      MultiThreadedDebug
    +      Default
    +      true
    +      Disabled
    +      true
    +      Level3
    +      EditAndContinue
    +      ..\lib;%(AdditionalIncludeDirectories)
    +      _DEBUG;_CONSOLE;%(PreprocessorDefinitions)
    +      .\..\win32\tmp\Debug-xmlwf\
    +      .\..\win32\tmp\Debug-xmlwf\xmlwf.pch
    +      .\..\win32\tmp\Debug-xmlwf\
    +      .\..\win32\tmp\Debug-xmlwf\
    +    
    +    
    +      .\..\win32\bin\Debug\xmlwf.tlb
    +    
    +    
    +      0x0409
    +      _DEBUG;%(PreprocessorDefinitions)
    +    
    +    
    +      true
    +      .\..\win32\bin\Debug\xmlwf.bsc
    +    
    +    
    +      true
    +      true
    +      Console
    +      ..\win32\bin\Debug\xmlwf.exe
    +      ..\win32\bin\Debug;%(AdditionalLibraryDirectories)
    +      libexpat.lib;setargv.obj;%(AdditionalDependencies)
    +    
    +  
    +  
    +    
    +    
    +      true
    +      true
    +    
    +    
    +      true
    +      true
    +    
    +    
    +    
    +    
    +  
    +  
    +    
    +    
    +    
    +  
    +  
    +    
    +      {45a5074d-66e8-44a4-a03f-018027b528d6}
    +      false
    +    
    +  
    +  
    +  
    +  
    +
    \ No newline at end of file
    diff --git a/xmlwf/xmlwf.vcxproj.filters b/xmlwf/xmlwf.vcxproj.filters
    new file mode 100644
    index 0000000..890b9ef
    --- /dev/null
    +++ b/xmlwf/xmlwf.vcxproj.filters
    @@ -0,0 +1,48 @@
    +
    +
    +  
    +    
    +      {843deb01-ec59-4070-9fb7-4de851940fbd}
    +      cpp;c;cxx;rc;def;r;odl;idl;hpj;bat;for;f90
    +    
    +    
    +      {41225059-d26f-42fd-9d1b-fda760b7e45d}
    +      h;hpp;hxx;hm;inl;fi;fd
    +    
    +    
    +      {a722469e-558e-4d77-b8ea-88c9f136e29a}
    +      ico;cur;bmp;dlg;rc2;rct;bin;cnt;rtf;gif;jpg;jpeg;jpe
    +    
    +  
    +  
    +    
    +      Source Files
    +    
    +    
    +      Source Files
    +    
    +    
    +      Source Files
    +    
    +    
    +      Source Files
    +    
    +    
    +      Source Files
    +    
    +    
    +      Source Files
    +    
    +  
    +  
    +    
    +      Header Files
    +    
    +    
    +      Header Files
    +    
    +    
    +      Header Files
    +    
    +  
    +
    \ No newline at end of file
    diff --git a/xmlwf/xmlwin32url.cxx b/xmlwf/xmlwin32url.cxx
    index bbfcce2..ef2a137 100644
    --- a/xmlwf/xmlwin32url.cxx
    +++ b/xmlwf/xmlwin32url.cxx
    @@ -1,3 +1,35 @@
    +/*
    +                            __  __            _
    +                         ___\ \/ /_ __   __ _| |_
    +                        / _ \\  /| '_ \ / _` | __|
    +                       |  __//  \| |_) | (_| | |_
    +                        \___/_/\_\ .__/ \__,_|\__|
    +                                 |_| XML parser
    +
    +   Copyright (c) 1997-2000 Thai Open Source Software Center Ltd
    +   Copyright (c) 2000-2017 Expat development team
    +   Licensed under the MIT license:
    +
    +   Permission is  hereby granted,  free of charge,  to any  person obtaining
    +   a  copy  of  this  software   and  associated  documentation  files  (the
    +   "Software"),  to  deal in  the  Software  without restriction,  including
    +   without  limitation the  rights  to use,  copy,  modify, merge,  publish,
    +   distribute, sublicense, and/or sell copies of the Software, and to permit
    +   persons  to whom  the Software  is  furnished to  do so,  subject to  the
    +   following conditions:
    +
    +   The above copyright  notice and this permission notice  shall be included
    +   in all copies or substantial portions of the Software.
    +
    +   THE  SOFTWARE  IS  PROVIDED  "AS  IS",  WITHOUT  WARRANTY  OF  ANY  KIND,
    +   EXPRESS  OR IMPLIED,  INCLUDING  BUT  NOT LIMITED  TO  THE WARRANTIES  OF
    +   MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN
    +   NO EVENT SHALL THE AUTHORS OR  COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
    +   DAMAGES OR  OTHER LIABILITY, WHETHER  IN AN  ACTION OF CONTRACT,  TORT OR
    +   OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE
    +   USE OR OTHER DEALINGS IN THE SOFTWARE.
    +*/
    +
     #include "expat.h"
     #ifdef XML_UNICODE
     #define UNICODE