mirror of
https://github.com/reactos/reactos.git
synced 2025-05-25 20:18:22 +00:00
update libxslt to version 1.1.26
svn path=/trunk/; revision=43620
This commit is contained in:
parent
3d8e1d4e02
commit
5923afe8fe
31 changed files with 1744 additions and 735 deletions
110
reactos/dll/3rdparty/libxslt/ChangeLog
vendored
110
reactos/dll/3rdparty/libxslt/ChangeLog
vendored
|
@ -1,3 +1,113 @@
|
||||||
|
Fri Jul 24 10:16:24 CEST 2009 Daniel Veillard <veillard@redhat.com>
|
||||||
|
|
||||||
|
* libxslt/attributes.c: fix an IDness issue when building the tree
|
||||||
|
|
||||||
|
Tue May 12 09:03:46 CEST 2009 Daniel Veillard <veillard@redhat.com>
|
||||||
|
|
||||||
|
* configure.in: adapt the extra version detection code to git
|
||||||
|
* libxslt.doap: adding RDF dope file
|
||||||
|
|
||||||
|
Fri Jan 23 19:02:28 PST 2009 William Brack <wbrack@mmm.com.hk>
|
||||||
|
|
||||||
|
* libexslt/strings.c: Fixed indexing error reported by
|
||||||
|
Ron Burk on the mailing list.
|
||||||
|
|
||||||
|
Fri Nov 14 15:06:55 CET 2008 Daniel Veillard <veillard@redhat.com>
|
||||||
|
|
||||||
|
* python/Makefile.am libxslt/Makefile.am configure.in
|
||||||
|
libexslt/Makefile.am: applied patch from Roumen Petrov for
|
||||||
|
mingw cross compilation problems raised by Rich Jones
|
||||||
|
|
||||||
|
Tue Oct 28 11:55:27 CET 2008 Daniel Veillard <veillard@redhat.com>
|
||||||
|
|
||||||
|
* configure.in Makefile.am: patch from Richard Jones to build
|
||||||
|
shared libs with MinGW cross-compiler
|
||||||
|
|
||||||
|
Tue Oct 7 18:16:08 CEST 2008 Daniel Veillard <veillard@redhat.com>
|
||||||
|
|
||||||
|
* libxslt/pattern.c: prevent some unchecked pointer accesses, patch
|
||||||
|
by Jake Goulding
|
||||||
|
|
||||||
|
Wed Aug 6 20:10:08 HKT 2008 William Brack <wbrack@mmm.com.hk>
|
||||||
|
|
||||||
|
* Minor cleanup of "typo" and some compilation warnings:
|
||||||
|
tests/namespaces/tst7.xsl: fixed typo detected by new libxml2 code
|
||||||
|
libxslt/keys.c, libxslt/xsltlocale.c, libexslt/date.c: trivial
|
||||||
|
changes for gcc warnings.
|
||||||
|
|
||||||
|
Fri Aug 1 10:16:48 CEST 2008 Daniel Veillard <veillard@redhat.com>
|
||||||
|
|
||||||
|
* libxslt/xsltconfig.h.in libxslt/xslt.c libxslt/extensions.c
|
||||||
|
libxslt/xsltlocale.c libxslt/preproc.c libxslt/xsltutils.c
|
||||||
|
libxslt/xsltlocale.h libxslt/win32config.h configure.in
|
||||||
|
config.h.in win32/configure.js: big patch from Roumen Petrov
|
||||||
|
finishing xsl:sort lang support with many portability issues
|
||||||
|
fixed and feedback from Nick Wellnhofer and Rob Richards
|
||||||
|
|
||||||
|
Fri Aug 1 07:54:02 CEST 2008 Daniel Veillard <veillard@redhat.com>
|
||||||
|
|
||||||
|
* libexslt/crypto.c: fix for CVE-2008-2935 libexslt RC4
|
||||||
|
encryption/decryption functions
|
||||||
|
|
||||||
|
Mon Jul 28 14:46:27 CEST 2008 Daniel Veillard <veillard@redhat.com>
|
||||||
|
|
||||||
|
* configure.in: fix my static linking setup on x86_64
|
||||||
|
|
||||||
|
Sun Jul 27 13:52:10 CEST 2008 Daniel Veillard <veillard@redhat.com>
|
||||||
|
|
||||||
|
* libxslt/xslt.c: avoid a quadratic behaviour when hitting duplicates
|
||||||
|
exclude-result-prefixes declarations, should fix #544906
|
||||||
|
|
||||||
|
Sat Jul 26 12:43:18 PST 2008 William Brack <wbrack@mmm.com.hk>
|
||||||
|
|
||||||
|
*configure.in: fixed option --with-debugger with patch from
|
||||||
|
Arun Ragnavan #544829
|
||||||
|
|
||||||
|
Sat Jul 12 16:36:58 PST 2008 William Brack <wbrack@mmm.com.hk>
|
||||||
|
|
||||||
|
* libexslt/math.c: fixed incorrect argument popping in
|
||||||
|
exsltMathAtan2Function #541965
|
||||||
|
|
||||||
|
Thu Jul 10 10:04:28 PST 2008 William Brack <wbrack@mmm.com.hk>
|
||||||
|
|
||||||
|
* libxslt/functions.c: patch from Ron Burk to fix problem
|
||||||
|
with string check for element-available and
|
||||||
|
function-available #530891.
|
||||||
|
|
||||||
|
Tue Jun 24 23:55:48 PST 2008 William Brack <wbrack@mmm.com.hk>
|
||||||
|
|
||||||
|
* libxslt/attrvt.c: added code to handle literal within an
|
||||||
|
AVT #539741.
|
||||||
|
* tests/docs/Makefile.am tests/docs/bug-168.xsl
|
||||||
|
* tests/general/Makefile.am tests/general/bug-168.* add a
|
||||||
|
test for this bug to the regression suite.
|
||||||
|
|
||||||
|
Fri Jun 13 10:58:52 CEST 2008 Daniel Veillard <daniel@veillard.com>
|
||||||
|
|
||||||
|
* libxslt/libxslt.h libexslt/libexslt.h libexslt/exslt.h: patch
|
||||||
|
from Roumen Petrov fixing include path when compiling outside
|
||||||
|
source tree
|
||||||
|
|
||||||
|
Thu Jun 12 11:23:23 CEST 2008 Daniel Veillard <daniel@veillard.com>
|
||||||
|
|
||||||
|
* libxslt/xsltconfig.h.in libxslt/xsltlocale.h configure.in
|
||||||
|
config.h.in win32/configure.js: patch from Nick Wellnhofer and
|
||||||
|
Roumen Petrov to fix some portability problems on the previous
|
||||||
|
xsl:sort locale patch
|
||||||
|
|
||||||
|
Tue Jun 3 18:26:26 CEST 2008 Daniel Veillard <daniel@veillard.com>
|
||||||
|
|
||||||
|
* configure.in libxslt/extra.c libxslt/Makefile.am libxslt/preproc.c
|
||||||
|
libxslt/xsltInternals.h libxslt/xsltlocale.c libxslt/xsltlocale.h
|
||||||
|
libxslt/xsltutils.c win32/Makefile.mingw win32/Makefile.msvc: patch
|
||||||
|
from Nick Wellnhofer adding xsl:sort lang support using the locale
|
||||||
|
support from the C library.
|
||||||
|
|
||||||
|
Tue Jun 3 18:14:55 CEST 2008 Daniel Veillard <daniel@veillard.com>
|
||||||
|
|
||||||
|
* libxslt/extensions.h: as Ralf Junker pointed out
|
||||||
|
xsltExtFunctionLookup was defined but never implemented, removing it
|
||||||
|
|
||||||
Tue May 13 17:51:05 CEST 2008 Daniel Veillard <daniel@veillard.com>
|
Tue May 13 17:51:05 CEST 2008 Daniel Veillard <daniel@veillard.com>
|
||||||
|
|
||||||
* configure.in doc/*: release of 1.1.24
|
* configure.in doc/*: release of 1.1.24
|
||||||
|
|
17
reactos/dll/3rdparty/libxslt/Makefile.am
vendored
17
reactos/dll/3rdparty/libxslt/Makefile.am
vendored
|
@ -24,11 +24,13 @@ xsltinc_HEADERS = \
|
||||||
security.h \
|
security.h \
|
||||||
xsltInternals.h \
|
xsltInternals.h \
|
||||||
xsltconfig.h \
|
xsltconfig.h \
|
||||||
xsltexports.h
|
xsltexports.h \
|
||||||
|
xsltlocale.h
|
||||||
|
|
||||||
libxslt_la_SOURCES = \
|
libxslt_la_SOURCES = \
|
||||||
attrvt.c \
|
attrvt.c \
|
||||||
xslt.c \
|
xslt.c \
|
||||||
|
xsltlocale.c \
|
||||||
xsltutils.c \
|
xsltutils.c \
|
||||||
pattern.c \
|
pattern.c \
|
||||||
templates.c \
|
templates.c \
|
||||||
|
@ -50,12 +52,21 @@ libxslt_la_SOURCES = \
|
||||||
xsltwin32config.h.in \
|
xsltwin32config.h.in \
|
||||||
libxslt.h
|
libxslt.h
|
||||||
|
|
||||||
|
if USE_VERSION_SCRIPT
|
||||||
|
LIBXSLT_VERSION_SCRIPT = $(VERSION_SCRIPT_FLAGS)$(srcdir)/libxslt.syms
|
||||||
|
else
|
||||||
|
LIBXSLT_VERSION_SCRIPT =
|
||||||
|
endif
|
||||||
|
|
||||||
libxslt_la_LIBADD = $(EXTRA_LIBS)
|
libxslt_la_LIBADD = $(EXTRA_LIBS)
|
||||||
libxslt_la_LDFLAGS = -version-info @LIBXSLT_VERSION_INFO@
|
libxslt_la_LDFLAGS = \
|
||||||
|
$(WIN32_EXTRA_LDFLAGS) \
|
||||||
|
$(LIBXSLT_VERSION_SCRIPT) \
|
||||||
|
-version-info @LIBXSLT_VERSION_INFO@
|
||||||
|
|
||||||
man_MANS = libxslt.3
|
man_MANS = libxslt.3
|
||||||
|
|
||||||
EXTRA_DIST = $(man_MANS) trio.h triodef.h
|
EXTRA_DIST = $(man_MANS) trio.h triodef.h libxslt.syms
|
||||||
|
|
||||||
xsltproc: all
|
xsltproc: all
|
||||||
@(cd ../xsltproc ; $(MAKE))
|
@(cd ../xsltproc ; $(MAKE))
|
||||||
|
|
295
reactos/dll/3rdparty/libxslt/Makefile.in
vendored
295
reactos/dll/3rdparty/libxslt/Makefile.in
vendored
|
@ -1,8 +1,9 @@
|
||||||
# Makefile.in generated by automake 1.10 from Makefile.am.
|
# Makefile.in generated by automake 1.11 from Makefile.am.
|
||||||
# @configure_input@
|
# @configure_input@
|
||||||
|
|
||||||
# Copyright (C) 1994, 1995, 1996, 1997, 1998, 1999, 2000, 2001, 2002,
|
# Copyright (C) 1994, 1995, 1996, 1997, 1998, 1999, 2000, 2001, 2002,
|
||||||
# 2003, 2004, 2005, 2006 Free Software Foundation, Inc.
|
# 2003, 2004, 2005, 2006, 2007, 2008, 2009 Free Software Foundation,
|
||||||
|
# Inc.
|
||||||
# This Makefile.in is free software; the Free Software Foundation
|
# This Makefile.in is free software; the Free Software Foundation
|
||||||
# gives unlimited permission to copy and/or distribute it,
|
# gives unlimited permission to copy and/or distribute it,
|
||||||
# with or without modifications, as long as this notice is preserved.
|
# with or without modifications, as long as this notice is preserved.
|
||||||
|
@ -17,8 +18,9 @@
|
||||||
|
|
||||||
VPATH = @srcdir@
|
VPATH = @srcdir@
|
||||||
pkgdatadir = $(datadir)/@PACKAGE@
|
pkgdatadir = $(datadir)/@PACKAGE@
|
||||||
pkglibdir = $(libdir)/@PACKAGE@
|
|
||||||
pkgincludedir = $(includedir)/@PACKAGE@
|
pkgincludedir = $(includedir)/@PACKAGE@
|
||||||
|
pkglibdir = $(libdir)/@PACKAGE@
|
||||||
|
pkglibexecdir = $(libexecdir)/@PACKAGE@
|
||||||
am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd
|
am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd
|
||||||
install_sh_DATA = $(install_sh) -c -m 644
|
install_sh_DATA = $(install_sh) -c -m 644
|
||||||
install_sh_PROGRAM = $(install_sh) -c
|
install_sh_PROGRAM = $(install_sh) -c
|
||||||
|
@ -44,29 +46,45 @@ am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \
|
||||||
mkinstalldirs = $(install_sh) -d
|
mkinstalldirs = $(install_sh) -d
|
||||||
CONFIG_HEADER = $(top_builddir)/config.h
|
CONFIG_HEADER = $(top_builddir)/config.h
|
||||||
CONFIG_CLEAN_FILES = xsltconfig.h xsltwin32config.h
|
CONFIG_CLEAN_FILES = xsltconfig.h xsltwin32config.h
|
||||||
|
CONFIG_CLEAN_VPATH_FILES =
|
||||||
am__vpath_adj_setup = srcdirstrip=`echo "$(srcdir)" | sed 's|.|.|g'`;
|
am__vpath_adj_setup = srcdirstrip=`echo "$(srcdir)" | sed 's|.|.|g'`;
|
||||||
am__vpath_adj = case $$p in \
|
am__vpath_adj = case $$p in \
|
||||||
$(srcdir)/*) f=`echo "$$p" | sed "s|^$$srcdirstrip/||"`;; \
|
$(srcdir)/*) f=`echo "$$p" | sed "s|^$$srcdirstrip/||"`;; \
|
||||||
*) f=$$p;; \
|
*) f=$$p;; \
|
||||||
esac;
|
esac;
|
||||||
am__strip_dir = `echo $$p | sed -e 's|^.*/||'`;
|
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__installdirs = "$(DESTDIR)$(libdir)" "$(DESTDIR)$(man3dir)" \
|
am__installdirs = "$(DESTDIR)$(libdir)" "$(DESTDIR)$(man3dir)" \
|
||||||
"$(DESTDIR)$(xsltincdir)"
|
"$(DESTDIR)$(xsltincdir)"
|
||||||
libLTLIBRARIES_INSTALL = $(INSTALL)
|
|
||||||
LTLIBRARIES = $(lib_LTLIBRARIES)
|
LTLIBRARIES = $(lib_LTLIBRARIES)
|
||||||
am__DEPENDENCIES_1 =
|
am__DEPENDENCIES_1 =
|
||||||
libxslt_la_DEPENDENCIES = $(am__DEPENDENCIES_1)
|
libxslt_la_DEPENDENCIES = $(am__DEPENDENCIES_1)
|
||||||
am_libxslt_la_OBJECTS = attrvt.lo xslt.lo xsltutils.lo pattern.lo \
|
am_libxslt_la_OBJECTS = attrvt.lo xslt.lo xsltlocale.lo xsltutils.lo \
|
||||||
templates.lo variables.lo keys.lo numbers.lo extensions.lo \
|
pattern.lo templates.lo variables.lo keys.lo numbers.lo \
|
||||||
extra.lo functions.lo namespaces.lo imports.lo attributes.lo \
|
extensions.lo extra.lo functions.lo namespaces.lo imports.lo \
|
||||||
documents.lo preproc.lo transform.lo security.lo
|
attributes.lo documents.lo preproc.lo transform.lo security.lo
|
||||||
libxslt_la_OBJECTS = $(am_libxslt_la_OBJECTS)
|
libxslt_la_OBJECTS = $(am_libxslt_la_OBJECTS)
|
||||||
libxslt_la_LINK = $(LIBTOOL) --tag=CC $(AM_LIBTOOLFLAGS) \
|
libxslt_la_LINK = $(LIBTOOL) --tag=CC $(AM_LIBTOOLFLAGS) \
|
||||||
$(LIBTOOLFLAGS) --mode=link $(CCLD) $(AM_CFLAGS) $(CFLAGS) \
|
$(LIBTOOLFLAGS) --mode=link $(CCLD) $(AM_CFLAGS) $(CFLAGS) \
|
||||||
$(libxslt_la_LDFLAGS) $(LDFLAGS) -o $@
|
$(libxslt_la_LDFLAGS) $(LDFLAGS) -o $@
|
||||||
DEFAULT_INCLUDES = -I. -I$(top_builddir)@am__isrc@
|
DEFAULT_INCLUDES = -I.@am__isrc@ -I$(top_builddir)
|
||||||
depcomp = $(SHELL) $(top_srcdir)/depcomp
|
depcomp = $(SHELL) $(top_srcdir)/depcomp
|
||||||
am__depfiles_maybe = depfiles
|
am__depfiles_maybe = depfiles
|
||||||
|
am__mv = mv -f
|
||||||
COMPILE = $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) \
|
COMPILE = $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) \
|
||||||
$(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS)
|
$(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS)
|
||||||
LTCOMPILE = $(LIBTOOL) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) \
|
LTCOMPILE = $(LIBTOOL) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) \
|
||||||
|
@ -81,7 +99,6 @@ DIST_SOURCES = $(libxslt_la_SOURCES)
|
||||||
man3dir = $(mandir)/man3
|
man3dir = $(mandir)/man3
|
||||||
NROFF = nroff
|
NROFF = nroff
|
||||||
MANS = $(man_MANS)
|
MANS = $(man_MANS)
|
||||||
xsltincHEADERS_INSTALL = $(INSTALL_HEADER)
|
|
||||||
HEADERS = $(xsltinc_HEADERS)
|
HEADERS = $(xsltinc_HEADERS)
|
||||||
ETAGS = etags
|
ETAGS = etags
|
||||||
CTAGS = ctags
|
CTAGS = ctags
|
||||||
|
@ -89,6 +106,7 @@ DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST)
|
||||||
ACLOCAL = @ACLOCAL@
|
ACLOCAL = @ACLOCAL@
|
||||||
AMTAR = @AMTAR@
|
AMTAR = @AMTAR@
|
||||||
AR = @AR@
|
AR = @AR@
|
||||||
|
AS = @AS@
|
||||||
AUTOCONF = @AUTOCONF@
|
AUTOCONF = @AUTOCONF@
|
||||||
AUTOHEADER = @AUTOHEADER@
|
AUTOHEADER = @AUTOHEADER@
|
||||||
AUTOMAKE = @AUTOMAKE@
|
AUTOMAKE = @AUTOMAKE@
|
||||||
|
@ -98,14 +116,12 @@ CCDEPMODE = @CCDEPMODE@
|
||||||
CFLAGS = @CFLAGS@
|
CFLAGS = @CFLAGS@
|
||||||
CPP = @CPP@
|
CPP = @CPP@
|
||||||
CPPFLAGS = @CPPFLAGS@
|
CPPFLAGS = @CPPFLAGS@
|
||||||
CXX = @CXX@
|
|
||||||
CXXCPP = @CXXCPP@
|
|
||||||
CXXDEPMODE = @CXXDEPMODE@
|
|
||||||
CXXFLAGS = @CXXFLAGS@
|
|
||||||
CYGPATH_W = @CYGPATH_W@
|
CYGPATH_W = @CYGPATH_W@
|
||||||
DEFS = @DEFS@
|
DEFS = @DEFS@
|
||||||
DEPDIR = @DEPDIR@
|
DEPDIR = @DEPDIR@
|
||||||
ECHO = @ECHO@
|
DLLTOOL = @DLLTOOL@
|
||||||
|
DSYMUTIL = @DSYMUTIL@
|
||||||
|
DUMPBIN = @DUMPBIN@
|
||||||
ECHO_C = @ECHO_C@
|
ECHO_C = @ECHO_C@
|
||||||
ECHO_N = @ECHO_N@
|
ECHO_N = @ECHO_N@
|
||||||
ECHO_T = @ECHO_T@
|
ECHO_T = @ECHO_T@
|
||||||
|
@ -115,8 +131,7 @@ EXSLT_INCLUDEDIR = @EXSLT_INCLUDEDIR@
|
||||||
EXSLT_LIBDIR = @EXSLT_LIBDIR@
|
EXSLT_LIBDIR = @EXSLT_LIBDIR@
|
||||||
EXSLT_LIBS = @EXSLT_LIBS@
|
EXSLT_LIBS = @EXSLT_LIBS@
|
||||||
EXTRA_LIBS = @EXTRA_LIBS@
|
EXTRA_LIBS = @EXTRA_LIBS@
|
||||||
F77 = @F77@
|
FGREP = @FGREP@
|
||||||
FFLAGS = @FFLAGS@
|
|
||||||
GREP = @GREP@
|
GREP = @GREP@
|
||||||
HTML_DIR = @HTML_DIR@
|
HTML_DIR = @HTML_DIR@
|
||||||
INSTALL = @INSTALL@
|
INSTALL = @INSTALL@
|
||||||
|
@ -124,6 +139,7 @@ INSTALL_DATA = @INSTALL_DATA@
|
||||||
INSTALL_PROGRAM = @INSTALL_PROGRAM@
|
INSTALL_PROGRAM = @INSTALL_PROGRAM@
|
||||||
INSTALL_SCRIPT = @INSTALL_SCRIPT@
|
INSTALL_SCRIPT = @INSTALL_SCRIPT@
|
||||||
INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@
|
INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@
|
||||||
|
LD = @LD@
|
||||||
LDFLAGS = @LDFLAGS@
|
LDFLAGS = @LDFLAGS@
|
||||||
LIBEXSLT_MAJOR_VERSION = @LIBEXSLT_MAJOR_VERSION@
|
LIBEXSLT_MAJOR_VERSION = @LIBEXSLT_MAJOR_VERSION@
|
||||||
LIBEXSLT_MICRO_VERSION = @LIBEXSLT_MICRO_VERSION@
|
LIBEXSLT_MICRO_VERSION = @LIBEXSLT_MICRO_VERSION@
|
||||||
|
@ -151,13 +167,19 @@ LIBXSLT_VERSION = @LIBXSLT_VERSION@
|
||||||
LIBXSLT_VERSION_EXTRA = @LIBXSLT_VERSION_EXTRA@
|
LIBXSLT_VERSION_EXTRA = @LIBXSLT_VERSION_EXTRA@
|
||||||
LIBXSLT_VERSION_INFO = @LIBXSLT_VERSION_INFO@
|
LIBXSLT_VERSION_INFO = @LIBXSLT_VERSION_INFO@
|
||||||
LIBXSLT_VERSION_NUMBER = @LIBXSLT_VERSION_NUMBER@
|
LIBXSLT_VERSION_NUMBER = @LIBXSLT_VERSION_NUMBER@
|
||||||
|
LIPO = @LIPO@
|
||||||
LN_S = @LN_S@
|
LN_S = @LN_S@
|
||||||
LTLIBOBJS = @LTLIBOBJS@
|
LTLIBOBJS = @LTLIBOBJS@
|
||||||
MAKEINFO = @MAKEINFO@
|
MAKEINFO = @MAKEINFO@
|
||||||
MKDIR_P = @MKDIR_P@
|
MKDIR_P = @MKDIR_P@
|
||||||
MV = @MV@
|
MV = @MV@
|
||||||
M_LIBS = @M_LIBS@
|
M_LIBS = @M_LIBS@
|
||||||
|
NM = @NM@
|
||||||
|
NMEDIT = @NMEDIT@
|
||||||
|
OBJDUMP = @OBJDUMP@
|
||||||
OBJEXT = @OBJEXT@
|
OBJEXT = @OBJEXT@
|
||||||
|
OTOOL = @OTOOL@
|
||||||
|
OTOOL64 = @OTOOL64@
|
||||||
PACKAGE = @PACKAGE@
|
PACKAGE = @PACKAGE@
|
||||||
PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@
|
PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@
|
||||||
PACKAGE_NAME = @PACKAGE_NAME@
|
PACKAGE_NAME = @PACKAGE_NAME@
|
||||||
|
@ -181,7 +203,9 @@ SHELL = @SHELL@
|
||||||
STATIC_BINARIES = @STATIC_BINARIES@
|
STATIC_BINARIES = @STATIC_BINARIES@
|
||||||
STRIP = @STRIP@
|
STRIP = @STRIP@
|
||||||
TAR = @TAR@
|
TAR = @TAR@
|
||||||
|
THREAD_LIBS = @THREAD_LIBS@
|
||||||
VERSION = @VERSION@
|
VERSION = @VERSION@
|
||||||
|
VERSION_SCRIPT_FLAGS = @VERSION_SCRIPT_FLAGS@
|
||||||
WIN32_EXTRA_LDFLAGS = @WIN32_EXTRA_LDFLAGS@
|
WIN32_EXTRA_LDFLAGS = @WIN32_EXTRA_LDFLAGS@
|
||||||
WIN32_EXTRA_LIBADD = @WIN32_EXTRA_LIBADD@
|
WIN32_EXTRA_LIBADD = @WIN32_EXTRA_LIBADD@
|
||||||
WITH_CRYPTO = @WITH_CRYPTO@
|
WITH_CRYPTO = @WITH_CRYPTO@
|
||||||
|
@ -190,18 +214,21 @@ WITH_MEM_DEBUG = @WITH_MEM_DEBUG@
|
||||||
WITH_MODULES = @WITH_MODULES@
|
WITH_MODULES = @WITH_MODULES@
|
||||||
WITH_TRIO = @WITH_TRIO@
|
WITH_TRIO = @WITH_TRIO@
|
||||||
WITH_XSLT_DEBUG = @WITH_XSLT_DEBUG@
|
WITH_XSLT_DEBUG = @WITH_XSLT_DEBUG@
|
||||||
|
XMLLINT = @XMLLINT@
|
||||||
XML_CONFIG = @XML_CONFIG@
|
XML_CONFIG = @XML_CONFIG@
|
||||||
|
XSLTPROC = @XSLTPROC@
|
||||||
XSLTPROCDV = @XSLTPROCDV@
|
XSLTPROCDV = @XSLTPROCDV@
|
||||||
XSLT_INCLUDEDIR = @XSLT_INCLUDEDIR@
|
XSLT_INCLUDEDIR = @XSLT_INCLUDEDIR@
|
||||||
XSLT_LIBDIR = @XSLT_LIBDIR@
|
XSLT_LIBDIR = @XSLT_LIBDIR@
|
||||||
XSLT_LIBS = @XSLT_LIBS@
|
XSLT_LIBS = @XSLT_LIBS@
|
||||||
|
XSLT_LOCALE_WINAPI = @XSLT_LOCALE_WINAPI@
|
||||||
|
XSLT_LOCALE_XLOCALE = @XSLT_LOCALE_XLOCALE@
|
||||||
abs_builddir = @abs_builddir@
|
abs_builddir = @abs_builddir@
|
||||||
abs_srcdir = @abs_srcdir@
|
abs_srcdir = @abs_srcdir@
|
||||||
abs_top_builddir = @abs_top_builddir@
|
abs_top_builddir = @abs_top_builddir@
|
||||||
abs_top_srcdir = @abs_top_srcdir@
|
abs_top_srcdir = @abs_top_srcdir@
|
||||||
ac_ct_CC = @ac_ct_CC@
|
ac_ct_CC = @ac_ct_CC@
|
||||||
ac_ct_CXX = @ac_ct_CXX@
|
ac_ct_DUMPBIN = @ac_ct_DUMPBIN@
|
||||||
ac_ct_F77 = @ac_ct_F77@
|
|
||||||
am__include = @am__include@
|
am__include = @am__include@
|
||||||
am__leading_dot = @am__leading_dot@
|
am__leading_dot = @am__leading_dot@
|
||||||
am__quote = @am__quote@
|
am__quote = @am__quote@
|
||||||
|
@ -232,6 +259,7 @@ libdir = @libdir@
|
||||||
libexecdir = @libexecdir@
|
libexecdir = @libexecdir@
|
||||||
localedir = @localedir@
|
localedir = @localedir@
|
||||||
localstatedir = @localstatedir@
|
localstatedir = @localstatedir@
|
||||||
|
lt_ECHO = @lt_ECHO@
|
||||||
mandir = @mandir@
|
mandir = @mandir@
|
||||||
mkdir_p = @mkdir_p@
|
mkdir_p = @mkdir_p@
|
||||||
oldincludedir = @oldincludedir@
|
oldincludedir = @oldincludedir@
|
||||||
|
@ -245,6 +273,7 @@ sharedstatedir = @sharedstatedir@
|
||||||
srcdir = @srcdir@
|
srcdir = @srcdir@
|
||||||
sysconfdir = @sysconfdir@
|
sysconfdir = @sysconfdir@
|
||||||
target_alias = @target_alias@
|
target_alias = @target_alias@
|
||||||
|
top_build_prefix = @top_build_prefix@
|
||||||
top_builddir = @top_builddir@
|
top_builddir = @top_builddir@
|
||||||
top_srcdir = @top_srcdir@
|
top_srcdir = @top_srcdir@
|
||||||
INCLUDES = -I$(top_srcdir) -I$(top_srcdir)/libxslt $(LIBXML_CFLAGS)
|
INCLUDES = -I$(top_srcdir) -I$(top_srcdir)/libxslt $(LIBXML_CFLAGS)
|
||||||
|
@ -270,11 +299,13 @@ xsltinc_HEADERS = \
|
||||||
security.h \
|
security.h \
|
||||||
xsltInternals.h \
|
xsltInternals.h \
|
||||||
xsltconfig.h \
|
xsltconfig.h \
|
||||||
xsltexports.h
|
xsltexports.h \
|
||||||
|
xsltlocale.h
|
||||||
|
|
||||||
libxslt_la_SOURCES = \
|
libxslt_la_SOURCES = \
|
||||||
attrvt.c \
|
attrvt.c \
|
||||||
xslt.c \
|
xslt.c \
|
||||||
|
xsltlocale.c \
|
||||||
xsltutils.c \
|
xsltutils.c \
|
||||||
pattern.c \
|
pattern.c \
|
||||||
templates.c \
|
templates.c \
|
||||||
|
@ -296,10 +327,16 @@ libxslt_la_SOURCES = \
|
||||||
xsltwin32config.h.in \
|
xsltwin32config.h.in \
|
||||||
libxslt.h
|
libxslt.h
|
||||||
|
|
||||||
|
@USE_VERSION_SCRIPT_FALSE@LIBXSLT_VERSION_SCRIPT =
|
||||||
|
@USE_VERSION_SCRIPT_TRUE@LIBXSLT_VERSION_SCRIPT = $(VERSION_SCRIPT_FLAGS)$(srcdir)/libxslt.syms
|
||||||
libxslt_la_LIBADD = $(EXTRA_LIBS)
|
libxslt_la_LIBADD = $(EXTRA_LIBS)
|
||||||
libxslt_la_LDFLAGS = -version-info @LIBXSLT_VERSION_INFO@
|
libxslt_la_LDFLAGS = \
|
||||||
|
$(WIN32_EXTRA_LDFLAGS) \
|
||||||
|
$(LIBXSLT_VERSION_SCRIPT) \
|
||||||
|
-version-info @LIBXSLT_VERSION_INFO@
|
||||||
|
|
||||||
man_MANS = libxslt.3
|
man_MANS = libxslt.3
|
||||||
EXTRA_DIST = $(man_MANS) trio.h triodef.h
|
EXTRA_DIST = $(man_MANS) trio.h triodef.h libxslt.syms
|
||||||
all: all-am
|
all: all-am
|
||||||
|
|
||||||
.SUFFIXES:
|
.SUFFIXES:
|
||||||
|
@ -308,14 +345,14 @@ $(srcdir)/Makefile.in: $(srcdir)/Makefile.am $(am__configure_deps)
|
||||||
@for dep in $?; do \
|
@for dep in $?; do \
|
||||||
case '$(am__configure_deps)' in \
|
case '$(am__configure_deps)' in \
|
||||||
*$$dep*) \
|
*$$dep*) \
|
||||||
cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh \
|
( cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh ) \
|
||||||
&& exit 0; \
|
&& { if test -f $@; then exit 0; else break; fi; }; \
|
||||||
exit 1;; \
|
exit 1;; \
|
||||||
esac; \
|
esac; \
|
||||||
done; \
|
done; \
|
||||||
echo ' cd $(top_srcdir) && $(AUTOMAKE) --gnu libxslt/Makefile'; \
|
echo ' cd $(top_srcdir) && $(AUTOMAKE) --gnu libxslt/Makefile'; \
|
||||||
cd $(top_srcdir) && \
|
$(am__cd) $(top_srcdir) && \
|
||||||
$(AUTOMAKE) --gnu libxslt/Makefile
|
$(AUTOMAKE) --gnu libxslt/Makefile
|
||||||
.PRECIOUS: Makefile
|
.PRECIOUS: Makefile
|
||||||
Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status
|
Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status
|
||||||
@case '$?' in \
|
@case '$?' in \
|
||||||
|
@ -333,6 +370,7 @@ $(top_srcdir)/configure: $(am__configure_deps)
|
||||||
cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh
|
cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh
|
||||||
$(ACLOCAL_M4): $(am__aclocal_m4_deps)
|
$(ACLOCAL_M4): $(am__aclocal_m4_deps)
|
||||||
cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh
|
cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh
|
||||||
|
$(am__aclocal_m4_deps):
|
||||||
xsltconfig.h: $(top_builddir)/config.status $(srcdir)/xsltconfig.h.in
|
xsltconfig.h: $(top_builddir)/config.status $(srcdir)/xsltconfig.h.in
|
||||||
cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@
|
cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@
|
||||||
xsltwin32config.h: $(top_builddir)/config.status $(srcdir)/xsltwin32config.h.in
|
xsltwin32config.h: $(top_builddir)/config.status $(srcdir)/xsltwin32config.h.in
|
||||||
|
@ -340,20 +378,24 @@ xsltwin32config.h: $(top_builddir)/config.status $(srcdir)/xsltwin32config.h.in
|
||||||
install-libLTLIBRARIES: $(lib_LTLIBRARIES)
|
install-libLTLIBRARIES: $(lib_LTLIBRARIES)
|
||||||
@$(NORMAL_INSTALL)
|
@$(NORMAL_INSTALL)
|
||||||
test -z "$(libdir)" || $(MKDIR_P) "$(DESTDIR)$(libdir)"
|
test -z "$(libdir)" || $(MKDIR_P) "$(DESTDIR)$(libdir)"
|
||||||
@list='$(lib_LTLIBRARIES)'; for p in $$list; do \
|
@list='$(lib_LTLIBRARIES)'; test -n "$(libdir)" || list=; \
|
||||||
|
list2=; for p in $$list; do \
|
||||||
if test -f $$p; then \
|
if test -f $$p; then \
|
||||||
f=$(am__strip_dir) \
|
list2="$$list2 $$p"; \
|
||||||
echo " $(LIBTOOL) --mode=install $(libLTLIBRARIES_INSTALL) $(INSTALL_STRIP_FLAG) '$$p' '$(DESTDIR)$(libdir)/$$f'"; \
|
|
||||||
$(LIBTOOL) --mode=install $(libLTLIBRARIES_INSTALL) $(INSTALL_STRIP_FLAG) "$$p" "$(DESTDIR)$(libdir)/$$f"; \
|
|
||||||
else :; fi; \
|
else :; fi; \
|
||||||
done
|
done; \
|
||||||
|
test -z "$$list2" || { \
|
||||||
|
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:
|
uninstall-libLTLIBRARIES:
|
||||||
@$(NORMAL_UNINSTALL)
|
@$(NORMAL_UNINSTALL)
|
||||||
@list='$(lib_LTLIBRARIES)'; for p in $$list; do \
|
@list='$(lib_LTLIBRARIES)'; test -n "$(libdir)" || list=; \
|
||||||
p=$(am__strip_dir) \
|
for p in $$list; do \
|
||||||
echo " $(LIBTOOL) --mode=uninstall rm -f '$(DESTDIR)$(libdir)/$$p'"; \
|
$(am__strip_dir) \
|
||||||
$(LIBTOOL) --mode=uninstall rm -f "$(DESTDIR)$(libdir)/$$p"; \
|
echo " $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=uninstall rm -f '$(DESTDIR)$(libdir)/$$f'"; \
|
||||||
|
$(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=uninstall rm -f "$(DESTDIR)$(libdir)/$$f"; \
|
||||||
done
|
done
|
||||||
|
|
||||||
clean-libLTLIBRARIES:
|
clean-libLTLIBRARIES:
|
||||||
|
@ -390,25 +432,26 @@ distclean-compile:
|
||||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/transform.Plo@am__quote@
|
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/transform.Plo@am__quote@
|
||||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/variables.Plo@am__quote@
|
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/variables.Plo@am__quote@
|
||||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/xslt.Plo@am__quote@
|
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/xslt.Plo@am__quote@
|
||||||
|
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/xsltlocale.Plo@am__quote@
|
||||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/xsltutils.Plo@am__quote@
|
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/xsltutils.Plo@am__quote@
|
||||||
|
|
||||||
.c.o:
|
.c.o:
|
||||||
@am__fastdepCC_TRUE@ $(COMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ $<
|
@am__fastdepCC_TRUE@ $(COMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ $<
|
||||||
@am__fastdepCC_TRUE@ mv -f $(DEPDIR)/$*.Tpo $(DEPDIR)/$*.Po
|
@am__fastdepCC_TRUE@ $(am__mv) $(DEPDIR)/$*.Tpo $(DEPDIR)/$*.Po
|
||||||
@AMDEP_TRUE@@am__fastdepCC_FALSE@ source='$<' object='$@' libtool=no @AMDEPBACKSLASH@
|
@AMDEP_TRUE@@am__fastdepCC_FALSE@ source='$<' object='$@' libtool=no @AMDEPBACKSLASH@
|
||||||
@AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
|
@AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
|
||||||
@am__fastdepCC_FALSE@ $(COMPILE) -c $<
|
@am__fastdepCC_FALSE@ $(COMPILE) -c $<
|
||||||
|
|
||||||
.c.obj:
|
.c.obj:
|
||||||
@am__fastdepCC_TRUE@ $(COMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ `$(CYGPATH_W) '$<'`
|
@am__fastdepCC_TRUE@ $(COMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ `$(CYGPATH_W) '$<'`
|
||||||
@am__fastdepCC_TRUE@ mv -f $(DEPDIR)/$*.Tpo $(DEPDIR)/$*.Po
|
@am__fastdepCC_TRUE@ $(am__mv) $(DEPDIR)/$*.Tpo $(DEPDIR)/$*.Po
|
||||||
@AMDEP_TRUE@@am__fastdepCC_FALSE@ source='$<' object='$@' libtool=no @AMDEPBACKSLASH@
|
@AMDEP_TRUE@@am__fastdepCC_FALSE@ source='$<' object='$@' libtool=no @AMDEPBACKSLASH@
|
||||||
@AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
|
@AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
|
||||||
@am__fastdepCC_FALSE@ $(COMPILE) -c `$(CYGPATH_W) '$<'`
|
@am__fastdepCC_FALSE@ $(COMPILE) -c `$(CYGPATH_W) '$<'`
|
||||||
|
|
||||||
.c.lo:
|
.c.lo:
|
||||||
@am__fastdepCC_TRUE@ $(LTCOMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ $<
|
@am__fastdepCC_TRUE@ $(LTCOMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ $<
|
||||||
@am__fastdepCC_TRUE@ mv -f $(DEPDIR)/$*.Tpo $(DEPDIR)/$*.Plo
|
@am__fastdepCC_TRUE@ $(am__mv) $(DEPDIR)/$*.Tpo $(DEPDIR)/$*.Plo
|
||||||
@AMDEP_TRUE@@am__fastdepCC_FALSE@ source='$<' object='$@' libtool=yes @AMDEPBACKSLASH@
|
@AMDEP_TRUE@@am__fastdepCC_FALSE@ source='$<' object='$@' libtool=yes @AMDEPBACKSLASH@
|
||||||
@AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
|
@AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
|
||||||
@am__fastdepCC_FALSE@ $(LTCOMPILE) -c -o $@ $<
|
@am__fastdepCC_FALSE@ $(LTCOMPILE) -c -o $@ $<
|
||||||
|
@ -418,118 +461,131 @@ mostlyclean-libtool:
|
||||||
|
|
||||||
clean-libtool:
|
clean-libtool:
|
||||||
-rm -rf .libs _libs
|
-rm -rf .libs _libs
|
||||||
install-man3: $(man3_MANS) $(man_MANS)
|
install-man3: $(man_MANS)
|
||||||
@$(NORMAL_INSTALL)
|
@$(NORMAL_INSTALL)
|
||||||
test -z "$(man3dir)" || $(MKDIR_P) "$(DESTDIR)$(man3dir)"
|
test -z "$(man3dir)" || $(MKDIR_P) "$(DESTDIR)$(man3dir)"
|
||||||
@list='$(man3_MANS) $(dist_man3_MANS) $(nodist_man3_MANS)'; \
|
@list=''; test -n "$(man3dir)" || exit 0; \
|
||||||
l2='$(man_MANS) $(dist_man_MANS) $(nodist_man_MANS)'; \
|
{ for i in $$list; do echo "$$i"; done; \
|
||||||
for i in $$l2; do \
|
l2='$(man_MANS)'; for i in $$l2; do echo "$$i"; done | \
|
||||||
case "$$i" in \
|
sed -n '/\.3[a-z]*$$/p'; \
|
||||||
*.3*) list="$$list $$i" ;; \
|
} | while read p; do \
|
||||||
esac; \
|
if test -f $$p; then d=; else d="$(srcdir)/"; fi; \
|
||||||
|
echo "$$d$$p"; echo "$$p"; \
|
||||||
|
done | \
|
||||||
|
sed -e 'n;s,.*/,,;p;h;s,.*\.,,;s,^[^3][0-9a-z]*$$,3,;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)$(man3dir)/$$inst'"; \
|
||||||
|
$(INSTALL_DATA) "$$file" "$(DESTDIR)$(man3dir)/$$inst" || exit $$?; \
|
||||||
|
fi; \
|
||||||
done; \
|
done; \
|
||||||
for i in $$list; do \
|
for i in $$list; do echo "$$i"; done | $(am__base_list) | \
|
||||||
if test -f $(srcdir)/$$i; then file=$(srcdir)/$$i; \
|
while read files; do \
|
||||||
else file=$$i; fi; \
|
test -z "$$files" || { \
|
||||||
ext=`echo $$i | sed -e 's/^.*\\.//'`; \
|
echo " $(INSTALL_DATA) $$files '$(DESTDIR)$(man3dir)'"; \
|
||||||
case "$$ext" in \
|
$(INSTALL_DATA) $$files "$(DESTDIR)$(man3dir)" || exit $$?; }; \
|
||||||
3*) ;; \
|
done; }
|
||||||
*) ext='3' ;; \
|
|
||||||
esac; \
|
|
||||||
inst=`echo $$i | sed -e 's/\\.[0-9a-z]*$$//'`; \
|
|
||||||
inst=`echo $$inst | sed -e 's/^.*\///'`; \
|
|
||||||
inst=`echo $$inst | sed '$(transform)'`.$$ext; \
|
|
||||||
echo " $(INSTALL_DATA) '$$file' '$(DESTDIR)$(man3dir)/$$inst'"; \
|
|
||||||
$(INSTALL_DATA) "$$file" "$(DESTDIR)$(man3dir)/$$inst"; \
|
|
||||||
done
|
|
||||||
uninstall-man3:
|
uninstall-man3:
|
||||||
@$(NORMAL_UNINSTALL)
|
@$(NORMAL_UNINSTALL)
|
||||||
@list='$(man3_MANS) $(dist_man3_MANS) $(nodist_man3_MANS)'; \
|
@list=''; test -n "$(man3dir)" || exit 0; \
|
||||||
l2='$(man_MANS) $(dist_man_MANS) $(nodist_man_MANS)'; \
|
files=`{ for i in $$list; do echo "$$i"; done; \
|
||||||
for i in $$l2; do \
|
l2='$(man_MANS)'; for i in $$l2; do echo "$$i"; done | \
|
||||||
case "$$i" in \
|
sed -n '/\.3[a-z]*$$/p'; \
|
||||||
*.3*) list="$$list $$i" ;; \
|
} | sed -e 's,.*/,,;h;s,.*\.,,;s,^[^3][0-9a-z]*$$,3,;x' \
|
||||||
esac; \
|
-e 's,\.[0-9a-z]*$$,,;$(transform);G;s,\n,.,'`; \
|
||||||
done; \
|
test -z "$$files" || { \
|
||||||
for i in $$list; do \
|
echo " ( cd '$(DESTDIR)$(man3dir)' && rm -f" $$files ")"; \
|
||||||
ext=`echo $$i | sed -e 's/^.*\\.//'`; \
|
cd "$(DESTDIR)$(man3dir)" && rm -f $$files; }
|
||||||
case "$$ext" in \
|
|
||||||
3*) ;; \
|
|
||||||
*) ext='3' ;; \
|
|
||||||
esac; \
|
|
||||||
inst=`echo $$i | sed -e 's/\\.[0-9a-z]*$$//'`; \
|
|
||||||
inst=`echo $$inst | sed -e 's/^.*\///'`; \
|
|
||||||
inst=`echo $$inst | sed '$(transform)'`.$$ext; \
|
|
||||||
echo " rm -f '$(DESTDIR)$(man3dir)/$$inst'"; \
|
|
||||||
rm -f "$(DESTDIR)$(man3dir)/$$inst"; \
|
|
||||||
done
|
|
||||||
install-xsltincHEADERS: $(xsltinc_HEADERS)
|
install-xsltincHEADERS: $(xsltinc_HEADERS)
|
||||||
@$(NORMAL_INSTALL)
|
@$(NORMAL_INSTALL)
|
||||||
test -z "$(xsltincdir)" || $(MKDIR_P) "$(DESTDIR)$(xsltincdir)"
|
test -z "$(xsltincdir)" || $(MKDIR_P) "$(DESTDIR)$(xsltincdir)"
|
||||||
@list='$(xsltinc_HEADERS)'; for p in $$list; do \
|
@list='$(xsltinc_HEADERS)'; test -n "$(xsltincdir)" || list=; \
|
||||||
|
for p in $$list; do \
|
||||||
if test -f "$$p"; then d=; else d="$(srcdir)/"; fi; \
|
if test -f "$$p"; then d=; else d="$(srcdir)/"; fi; \
|
||||||
f=$(am__strip_dir) \
|
echo "$$d$$p"; \
|
||||||
echo " $(xsltincHEADERS_INSTALL) '$$d$$p' '$(DESTDIR)$(xsltincdir)/$$f'"; \
|
done | $(am__base_list) | \
|
||||||
$(xsltincHEADERS_INSTALL) "$$d$$p" "$(DESTDIR)$(xsltincdir)/$$f"; \
|
while read files; do \
|
||||||
|
echo " $(INSTALL_HEADER) $$files '$(DESTDIR)$(xsltincdir)'"; \
|
||||||
|
$(INSTALL_HEADER) $$files "$(DESTDIR)$(xsltincdir)" || exit $$?; \
|
||||||
done
|
done
|
||||||
|
|
||||||
uninstall-xsltincHEADERS:
|
uninstall-xsltincHEADERS:
|
||||||
@$(NORMAL_UNINSTALL)
|
@$(NORMAL_UNINSTALL)
|
||||||
@list='$(xsltinc_HEADERS)'; for p in $$list; do \
|
@list='$(xsltinc_HEADERS)'; test -n "$(xsltincdir)" || list=; \
|
||||||
f=$(am__strip_dir) \
|
files=`for p in $$list; do echo $$p; done | sed -e 's|^.*/||'`; \
|
||||||
echo " rm -f '$(DESTDIR)$(xsltincdir)/$$f'"; \
|
test -n "$$files" || exit 0; \
|
||||||
rm -f "$(DESTDIR)$(xsltincdir)/$$f"; \
|
echo " ( cd '$(DESTDIR)$(xsltincdir)' && rm -f" $$files ")"; \
|
||||||
done
|
cd "$(DESTDIR)$(xsltincdir)" && rm -f $$files
|
||||||
|
|
||||||
ID: $(HEADERS) $(SOURCES) $(LISP) $(TAGS_FILES)
|
ID: $(HEADERS) $(SOURCES) $(LISP) $(TAGS_FILES)
|
||||||
list='$(SOURCES) $(HEADERS) $(LISP) $(TAGS_FILES)'; \
|
list='$(SOURCES) $(HEADERS) $(LISP) $(TAGS_FILES)'; \
|
||||||
unique=`for i in $$list; do \
|
unique=`for i in $$list; do \
|
||||||
if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \
|
if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \
|
||||||
done | \
|
done | \
|
||||||
$(AWK) ' { files[$$0] = 1; } \
|
$(AWK) '{ files[$$0] = 1; nonempty = 1; } \
|
||||||
END { for (i in files) print i; }'`; \
|
END { if (nonempty) { for (i in files) print i; }; }'`; \
|
||||||
mkid -fID $$unique
|
mkid -fID $$unique
|
||||||
tags: TAGS
|
tags: TAGS
|
||||||
|
|
||||||
TAGS: $(HEADERS) $(SOURCES) $(TAGS_DEPENDENCIES) \
|
TAGS: $(HEADERS) $(SOURCES) $(TAGS_DEPENDENCIES) \
|
||||||
$(TAGS_FILES) $(LISP)
|
$(TAGS_FILES) $(LISP)
|
||||||
tags=; \
|
set x; \
|
||||||
here=`pwd`; \
|
here=`pwd`; \
|
||||||
list='$(SOURCES) $(HEADERS) $(LISP) $(TAGS_FILES)'; \
|
list='$(SOURCES) $(HEADERS) $(LISP) $(TAGS_FILES)'; \
|
||||||
unique=`for i in $$list; do \
|
unique=`for i in $$list; do \
|
||||||
if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \
|
if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \
|
||||||
done | \
|
done | \
|
||||||
$(AWK) ' { files[$$0] = 1; } \
|
$(AWK) '{ files[$$0] = 1; nonempty = 1; } \
|
||||||
END { for (i in files) print i; }'`; \
|
END { if (nonempty) { for (i in files) print i; }; }'`; \
|
||||||
if test -z "$(ETAGS_ARGS)$$tags$$unique"; then :; else \
|
shift; \
|
||||||
|
if test -z "$(ETAGS_ARGS)$$*$$unique"; then :; else \
|
||||||
test -n "$$unique" || unique=$$empty_fix; \
|
test -n "$$unique" || unique=$$empty_fix; \
|
||||||
$(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \
|
if test $$# -gt 0; then \
|
||||||
$$tags $$unique; \
|
$(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \
|
||||||
|
"$$@" $$unique; \
|
||||||
|
else \
|
||||||
|
$(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \
|
||||||
|
$$unique; \
|
||||||
|
fi; \
|
||||||
fi
|
fi
|
||||||
ctags: CTAGS
|
ctags: CTAGS
|
||||||
CTAGS: $(HEADERS) $(SOURCES) $(TAGS_DEPENDENCIES) \
|
CTAGS: $(HEADERS) $(SOURCES) $(TAGS_DEPENDENCIES) \
|
||||||
$(TAGS_FILES) $(LISP)
|
$(TAGS_FILES) $(LISP)
|
||||||
tags=; \
|
|
||||||
here=`pwd`; \
|
|
||||||
list='$(SOURCES) $(HEADERS) $(LISP) $(TAGS_FILES)'; \
|
list='$(SOURCES) $(HEADERS) $(LISP) $(TAGS_FILES)'; \
|
||||||
unique=`for i in $$list; do \
|
unique=`for i in $$list; do \
|
||||||
if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \
|
if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \
|
||||||
done | \
|
done | \
|
||||||
$(AWK) ' { files[$$0] = 1; } \
|
$(AWK) '{ files[$$0] = 1; nonempty = 1; } \
|
||||||
END { for (i in files) print i; }'`; \
|
END { if (nonempty) { for (i in files) print i; }; }'`; \
|
||||||
test -z "$(CTAGS_ARGS)$$tags$$unique" \
|
test -z "$(CTAGS_ARGS)$$unique" \
|
||||||
|| $(CTAGS) $(CTAGSFLAGS) $(AM_CTAGSFLAGS) $(CTAGS_ARGS) \
|
|| $(CTAGS) $(CTAGSFLAGS) $(AM_CTAGSFLAGS) $(CTAGS_ARGS) \
|
||||||
$$tags $$unique
|
$$unique
|
||||||
|
|
||||||
GTAGS:
|
GTAGS:
|
||||||
here=`$(am__cd) $(top_builddir) && pwd` \
|
here=`$(am__cd) $(top_builddir) && pwd` \
|
||||||
&& cd $(top_srcdir) \
|
&& $(am__cd) $(top_srcdir) \
|
||||||
&& gtags -i $(GTAGS_ARGS) $$here
|
&& gtags -i $(GTAGS_ARGS) "$$here"
|
||||||
|
|
||||||
distclean-tags:
|
distclean-tags:
|
||||||
-rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH tags
|
-rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH tags
|
||||||
|
|
||||||
distdir: $(DISTFILES)
|
distdir: $(DISTFILES)
|
||||||
|
@list='$(MANS)'; if test -n "$$list"; then \
|
||||||
|
list=`for p in $$list; do \
|
||||||
|
if test -f $$p; then d=; else d="$(srcdir)/"; fi; \
|
||||||
|
if test -f "$$d$$p"; then echo "$$d$$p"; else :; fi; done`; \
|
||||||
|
if test -n "$$list" && \
|
||||||
|
grep 'ab help2man is required to generate this page' $$list >/dev/null; then \
|
||||||
|
echo "error: found man pages containing the \`missing help2man' replacement text:" >&2; \
|
||||||
|
grep -l 'ab help2man is required to generate this page' $$list | sed 's/^/ /' >&2; \
|
||||||
|
echo " to fix them, install help2man, remove and regenerate the man pages;" >&2; \
|
||||||
|
echo " typically \`make maintainer-clean' will remove them" >&2; \
|
||||||
|
exit 1; \
|
||||||
|
else :; fi; \
|
||||||
|
else :; fi
|
||||||
@srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \
|
@srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \
|
||||||
topsrcdirstrip=`echo "$(top_srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \
|
topsrcdirstrip=`echo "$(top_srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \
|
||||||
list='$(DISTFILES)'; \
|
list='$(DISTFILES)'; \
|
||||||
|
@ -545,13 +601,17 @@ distdir: $(DISTFILES)
|
||||||
if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \
|
if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \
|
||||||
if test -d $$d/$$file; then \
|
if test -d $$d/$$file; then \
|
||||||
dir=`echo "/$$file" | sed -e 's,/[^/]*$$,,'`; \
|
dir=`echo "/$$file" | sed -e 's,/[^/]*$$,,'`; \
|
||||||
if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \
|
if test -d "$(distdir)/$$file"; then \
|
||||||
cp -pR $(srcdir)/$$file $(distdir)$$dir || exit 1; \
|
find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \
|
||||||
fi; \
|
fi; \
|
||||||
cp -pR $$d/$$file $(distdir)$$dir || exit 1; \
|
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 \
|
else \
|
||||||
test -f $(distdir)/$$file \
|
test -f "$(distdir)/$$file" \
|
||||||
|| cp -p $$d/$$file $(distdir)/$$file \
|
|| cp -p $$d/$$file "$(distdir)/$$file" \
|
||||||
|| exit 1; \
|
|| exit 1; \
|
||||||
fi; \
|
fi; \
|
||||||
done
|
done
|
||||||
|
@ -582,6 +642,7 @@ clean-generic:
|
||||||
|
|
||||||
distclean-generic:
|
distclean-generic:
|
||||||
-test -z "$(CONFIG_CLEAN_FILES)" || rm -f $(CONFIG_CLEAN_FILES)
|
-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:
|
maintainer-clean-generic:
|
||||||
@echo "This command is intended for maintainers to use"
|
@echo "This command is intended for maintainers to use"
|
||||||
|
@ -603,6 +664,8 @@ dvi-am:
|
||||||
|
|
||||||
html: html-am
|
html: html-am
|
||||||
|
|
||||||
|
html-am:
|
||||||
|
|
||||||
info: info-am
|
info: info-am
|
||||||
|
|
||||||
info-am:
|
info-am:
|
||||||
|
@ -611,20 +674,29 @@ install-data-am: install-man install-xsltincHEADERS
|
||||||
|
|
||||||
install-dvi: install-dvi-am
|
install-dvi: install-dvi-am
|
||||||
|
|
||||||
|
install-dvi-am:
|
||||||
|
|
||||||
install-exec-am: install-libLTLIBRARIES
|
install-exec-am: install-libLTLIBRARIES
|
||||||
@$(NORMAL_INSTALL)
|
@$(NORMAL_INSTALL)
|
||||||
$(MAKE) $(AM_MAKEFLAGS) install-exec-hook
|
$(MAKE) $(AM_MAKEFLAGS) install-exec-hook
|
||||||
|
|
||||||
install-html: install-html-am
|
install-html: install-html-am
|
||||||
|
|
||||||
|
install-html-am:
|
||||||
|
|
||||||
install-info: install-info-am
|
install-info: install-info-am
|
||||||
|
|
||||||
|
install-info-am:
|
||||||
|
|
||||||
install-man: install-man3
|
install-man: install-man3
|
||||||
|
|
||||||
install-pdf: install-pdf-am
|
install-pdf: install-pdf-am
|
||||||
|
|
||||||
|
install-pdf-am:
|
||||||
|
|
||||||
install-ps: install-ps-am
|
install-ps: install-ps-am
|
||||||
|
|
||||||
|
install-ps-am:
|
||||||
|
|
||||||
installcheck-am:
|
installcheck-am:
|
||||||
|
|
||||||
maintainer-clean: maintainer-clean-am
|
maintainer-clean: maintainer-clean-am
|
||||||
|
@ -674,6 +746,7 @@ xsltproc: all
|
||||||
|
|
||||||
install-exec-hook:
|
install-exec-hook:
|
||||||
$(mkinstalldirs) "$(DESTDIR)$(libdir)/libxslt-plugins"
|
$(mkinstalldirs) "$(DESTDIR)$(libdir)/libxslt-plugins"
|
||||||
|
|
||||||
# Tell versions [3.59,3.63) of GNU make to not export all variables.
|
# 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.
|
# Otherwise a system limit (for SysV at least) may be exceeded.
|
||||||
.NOEXPORT:
|
.NOEXPORT:
|
||||||
|
|
7
reactos/dll/3rdparty/libxslt/attributes.c
vendored
7
reactos/dll/3rdparty/libxslt/attributes.c
vendored
|
@ -978,6 +978,13 @@ xsltAttributeInternal(xsltTransformContextPtr ctxt,
|
||||||
if (inst->children->name == xmlStringTextNoenc)
|
if (inst->children->name == xmlStringTextNoenc)
|
||||||
copyTxt->name = xmlStringTextNoenc;
|
copyTxt->name = xmlStringTextNoenc;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* since we create the attribute without content IDness must be
|
||||||
|
* asserted as a second step
|
||||||
|
*/
|
||||||
|
if ((copyTxt->content != NULL) &&
|
||||||
|
(xmlIsID(attr->doc, attr->parent, attr)))
|
||||||
|
xmlAddID(NULL, attr->doc, copyTxt->content, attr);
|
||||||
} else {
|
} else {
|
||||||
/*
|
/*
|
||||||
* The sequence constructor might be complex, so instantiate it.
|
* The sequence constructor might be complex, so instantiate it.
|
||||||
|
|
12
reactos/dll/3rdparty/libxslt/attrvt.c
vendored
12
reactos/dll/3rdparty/libxslt/attrvt.c
vendored
|
@ -244,7 +244,17 @@ xsltCompileAttr(xsltStylesheetPtr style, xmlAttrPtr attr) {
|
||||||
}
|
}
|
||||||
|
|
||||||
cur++;
|
cur++;
|
||||||
while ((*cur != 0) && (*cur != '}')) cur++;
|
while ((*cur != 0) && (*cur != '}')) {
|
||||||
|
/* Need to check for literal (bug539741) */
|
||||||
|
if ((*cur == '\'') || (*cur == '"')) {
|
||||||
|
char delim = *(cur++);
|
||||||
|
while ((*cur != 0) && (*cur != delim))
|
||||||
|
cur++;
|
||||||
|
if (*cur != 0)
|
||||||
|
cur++; /* skip the ending delimiter */
|
||||||
|
} else
|
||||||
|
cur++;
|
||||||
|
}
|
||||||
if (*cur == 0) {
|
if (*cur == 0) {
|
||||||
xsltTransformError(NULL, style, attr->parent,
|
xsltTransformError(NULL, style, attr->parent,
|
||||||
"Attribute '%s': The AVT has an unmatched '{'.\n",
|
"Attribute '%s': The AVT has an unmatched '{'.\n",
|
||||||
|
|
225
reactos/dll/3rdparty/libxslt/extensions.c
vendored
225
reactos/dll/3rdparty/libxslt/extensions.c
vendored
|
@ -86,6 +86,7 @@ static xmlHashTablePtr xsltFunctionsHash = NULL;
|
||||||
static xmlHashTablePtr xsltElementsHash = NULL;
|
static xmlHashTablePtr xsltElementsHash = NULL;
|
||||||
static xmlHashTablePtr xsltTopLevelsHash = NULL;
|
static xmlHashTablePtr xsltTopLevelsHash = NULL;
|
||||||
static xmlHashTablePtr xsltModuleHash = NULL;
|
static xmlHashTablePtr xsltModuleHash = NULL;
|
||||||
|
static xmlMutexPtr xsltExtMutex = NULL;
|
||||||
|
|
||||||
/************************************************************************
|
/************************************************************************
|
||||||
* *
|
* *
|
||||||
|
@ -339,10 +340,14 @@ xsltExtModuleRegisterDynamic(const xmlChar * URI)
|
||||||
return (-1);
|
return (-1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
xmlMutexLock(xsltExtMutex);
|
||||||
|
|
||||||
/* have we attempted to register this module already? */
|
/* have we attempted to register this module already? */
|
||||||
if (xmlHashLookup(xsltModuleHash, URI) != NULL) {
|
if (xmlHashLookup(xsltModuleHash, URI) != NULL) {
|
||||||
|
xmlMutexUnlock(xsltExtMutex);
|
||||||
return (-1);
|
return (-1);
|
||||||
}
|
}
|
||||||
|
xmlMutexUnlock(xsltExtMutex);
|
||||||
|
|
||||||
/* transform extension namespace into a module name */
|
/* transform extension namespace into a module name */
|
||||||
protocol = xmlStrstr(URI, BAD_CAST "://");
|
protocol = xmlStrstr(URI, BAD_CAST "://");
|
||||||
|
@ -368,15 +373,16 @@ xsltExtModuleRegisterDynamic(const xmlChar * URI)
|
||||||
/* determine module directory */
|
/* determine module directory */
|
||||||
ext_directory = (xmlChar *) getenv("LIBXSLT_PLUGINS_PATH");
|
ext_directory = (xmlChar *) getenv("LIBXSLT_PLUGINS_PATH");
|
||||||
|
|
||||||
#ifdef WITH_XSLT_DEBUG_EXTENSIONS
|
if (NULL == ext_directory) {
|
||||||
xsltGenericDebug(xsltGenericDebugContext,
|
|
||||||
"LIBXSLT_PLUGINS_PATH is %s\n", ext_directory);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
if (NULL == ext_directory)
|
|
||||||
ext_directory = BAD_CAST LIBXSLT_DEFAULT_PLUGINS_PATH();
|
ext_directory = BAD_CAST LIBXSLT_DEFAULT_PLUGINS_PATH();
|
||||||
if (NULL == ext_directory)
|
if (NULL == ext_directory)
|
||||||
return (-1);
|
return (-1);
|
||||||
|
}
|
||||||
|
#ifdef WITH_XSLT_DEBUG_EXTENSIONS
|
||||||
|
else
|
||||||
|
xsltGenericDebug(xsltGenericDebugContext,
|
||||||
|
"LIBXSLT_PLUGINS_PATH is %s\n", ext_directory);
|
||||||
|
#endif
|
||||||
|
|
||||||
/* build the module filename, and confirm the module exists */
|
/* build the module filename, and confirm the module exists */
|
||||||
xmlStrPrintf((xmlChar *) module_filename, sizeof(module_filename),
|
xmlStrPrintf((xmlChar *) module_filename, sizeof(module_filename),
|
||||||
|
@ -429,7 +435,9 @@ xsltExtModuleRegisterDynamic(const xmlChar * URI)
|
||||||
(*regfunc) ();
|
(*regfunc) ();
|
||||||
|
|
||||||
/* register this module in our hash */
|
/* register this module in our hash */
|
||||||
|
xmlMutexLock(xsltExtMutex);
|
||||||
xmlHashAddEntry(xsltModuleHash, URI, (void *) m);
|
xmlHashAddEntry(xsltModuleHash, URI, (void *) m);
|
||||||
|
xmlMutexUnlock(xsltExtMutex);
|
||||||
} else {
|
} else {
|
||||||
|
|
||||||
#ifdef WITH_XSLT_DEBUG_EXTENSIONS
|
#ifdef WITH_XSLT_DEBUG_EXTENSIONS
|
||||||
|
@ -448,7 +456,7 @@ xsltExtModuleRegisterDynamic(const xmlChar * URI)
|
||||||
}
|
}
|
||||||
#else
|
#else
|
||||||
static int
|
static int
|
||||||
xsltExtModuleRegisterDynamic(const xmlChar * ATTRIBUTE_UNUSED URI)
|
xsltExtModuleRegisterDynamic(const xmlChar * URI ATTRIBUTE_UNUSED)
|
||||||
{
|
{
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
@ -540,10 +548,14 @@ xsltRegisterExtPrefix(xsltStylesheetPtr style,
|
||||||
if (xsltExtensionsHash != NULL) {
|
if (xsltExtensionsHash != NULL) {
|
||||||
xsltExtModulePtr module;
|
xsltExtModulePtr module;
|
||||||
|
|
||||||
|
xmlMutexLock(xsltExtMutex);
|
||||||
module = xmlHashLookup(xsltExtensionsHash, URI);
|
module = xmlHashLookup(xsltExtensionsHash, URI);
|
||||||
|
xmlMutexUnlock(xsltExtMutex);
|
||||||
if (NULL == module) {
|
if (NULL == module) {
|
||||||
if (!xsltExtModuleRegisterDynamic(URI)) {
|
if (!xsltExtModuleRegisterDynamic(URI)) {
|
||||||
|
xmlMutexLock(xsltExtMutex);
|
||||||
module = xmlHashLookup(xsltExtensionsHash, URI);
|
module = xmlHashLookup(xsltExtensionsHash, URI);
|
||||||
|
xmlMutexUnlock(xsltExtMutex);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (module != NULL) {
|
if (module != NULL) {
|
||||||
|
@ -575,6 +587,8 @@ int
|
||||||
xsltRegisterExtFunction(xsltTransformContextPtr ctxt, const xmlChar * name,
|
xsltRegisterExtFunction(xsltTransformContextPtr ctxt, const xmlChar * name,
|
||||||
const xmlChar * URI, xmlXPathFunction function)
|
const xmlChar * URI, xmlXPathFunction function)
|
||||||
{
|
{
|
||||||
|
int ret;
|
||||||
|
|
||||||
if ((ctxt == NULL) || (name == NULL) ||
|
if ((ctxt == NULL) || (name == NULL) ||
|
||||||
(URI == NULL) || (function == NULL))
|
(URI == NULL) || (function == NULL))
|
||||||
return (-1);
|
return (-1);
|
||||||
|
@ -585,8 +599,11 @@ xsltRegisterExtFunction(xsltTransformContextPtr ctxt, const xmlChar * name,
|
||||||
ctxt->extFunctions = xmlHashCreate(10);
|
ctxt->extFunctions = xmlHashCreate(10);
|
||||||
if (ctxt->extFunctions == NULL)
|
if (ctxt->extFunctions == NULL)
|
||||||
return (-1);
|
return (-1);
|
||||||
return (xmlHashAddEntry2
|
|
||||||
(ctxt->extFunctions, name, URI, XML_CAST_FPTR(function)));
|
ret = xmlHashAddEntry2(ctxt->extFunctions, name, URI,
|
||||||
|
XML_CAST_FPTR(function));
|
||||||
|
|
||||||
|
return(ret);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -661,7 +678,12 @@ xsltStyleInitializeStylesheetModule(xsltStylesheetPtr style,
|
||||||
return(NULL);
|
return(NULL);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
xmlMutexLock(xsltExtMutex);
|
||||||
|
|
||||||
module = xmlHashLookup(xsltExtensionsHash, URI);
|
module = xmlHashLookup(xsltExtensionsHash, URI);
|
||||||
|
|
||||||
|
xmlMutexUnlock(xsltExtMutex);
|
||||||
|
|
||||||
if (module == NULL) {
|
if (module == NULL) {
|
||||||
#ifdef WITH_XSLT_DEBUG_EXTENSIONS
|
#ifdef WITH_XSLT_DEBUG_EXTENSIONS
|
||||||
xsltGenericDebug(xsltGenericDebugContext,
|
xsltGenericDebug(xsltGenericDebugContext,
|
||||||
|
@ -855,7 +877,12 @@ xsltGetExtData(xsltTransformContextPtr ctxt, const xmlChar * URI)
|
||||||
void *extData;
|
void *extData;
|
||||||
xsltExtModulePtr module;
|
xsltExtModulePtr module;
|
||||||
|
|
||||||
|
xmlMutexLock(xsltExtMutex);
|
||||||
|
|
||||||
module = xmlHashLookup(xsltExtensionsHash, URI);
|
module = xmlHashLookup(xsltExtensionsHash, URI);
|
||||||
|
|
||||||
|
xmlMutexUnlock(xsltExtMutex);
|
||||||
|
|
||||||
if (module == NULL) {
|
if (module == NULL) {
|
||||||
#ifdef WITH_XSLT_DEBUG_EXTENSIONS
|
#ifdef WITH_XSLT_DEBUG_EXTENSIONS
|
||||||
xsltGenericDebug(xsltGenericDebugContext,
|
xsltGenericDebug(xsltGenericDebugContext,
|
||||||
|
@ -1235,18 +1262,27 @@ xsltRegisterExtModuleFull(const xmlChar * URI,
|
||||||
if (xsltExtensionsHash == NULL)
|
if (xsltExtensionsHash == NULL)
|
||||||
return (-1);
|
return (-1);
|
||||||
|
|
||||||
|
xmlMutexLock(xsltExtMutex);
|
||||||
|
|
||||||
module = xmlHashLookup(xsltExtensionsHash, URI);
|
module = xmlHashLookup(xsltExtensionsHash, URI);
|
||||||
if (module != NULL) {
|
if (module != NULL) {
|
||||||
if ((module->initFunc == initFunc) &&
|
if ((module->initFunc == initFunc) &&
|
||||||
(module->shutdownFunc == shutdownFunc))
|
(module->shutdownFunc == shutdownFunc))
|
||||||
return (0);
|
ret = 0;
|
||||||
return (-1);
|
else
|
||||||
|
ret = -1;
|
||||||
|
goto done;
|
||||||
}
|
}
|
||||||
module = xsltNewExtModule(initFunc, shutdownFunc,
|
module = xsltNewExtModule(initFunc, shutdownFunc,
|
||||||
styleInitFunc, styleShutdownFunc);
|
styleInitFunc, styleShutdownFunc);
|
||||||
if (module == NULL)
|
if (module == NULL) {
|
||||||
return (-1);
|
ret = -1;
|
||||||
|
goto done;
|
||||||
|
}
|
||||||
ret = xmlHashAddEntry(xsltExtensionsHash, URI, (void *) module);
|
ret = xmlHashAddEntry(xsltExtensionsHash, URI, (void *) module);
|
||||||
|
|
||||||
|
done:
|
||||||
|
xmlMutexUnlock(xsltExtMutex);
|
||||||
return (ret);
|
return (ret);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1287,9 +1323,13 @@ xsltUnregisterExtModule(const xmlChar * URI)
|
||||||
if (xsltExtensionsHash == NULL)
|
if (xsltExtensionsHash == NULL)
|
||||||
return (-1);
|
return (-1);
|
||||||
|
|
||||||
ret =
|
xmlMutexLock(xsltExtMutex);
|
||||||
xmlHashRemoveEntry(xsltExtensionsHash, URI,
|
|
||||||
(xmlHashDeallocator) xsltFreeExtModule);
|
ret = xmlHashRemoveEntry(xsltExtensionsHash, URI,
|
||||||
|
(xmlHashDeallocator) xsltFreeExtModule);
|
||||||
|
|
||||||
|
xmlMutexUnlock(xsltExtMutex);
|
||||||
|
|
||||||
return (ret);
|
return (ret);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1304,9 +1344,13 @@ xsltUnregisterAllExtModules(void)
|
||||||
if (xsltExtensionsHash == NULL)
|
if (xsltExtensionsHash == NULL)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
|
xmlMutexLock(xsltExtMutex);
|
||||||
|
|
||||||
xmlHashFree(xsltExtensionsHash,
|
xmlHashFree(xsltExtensionsHash,
|
||||||
(xmlHashDeallocator) xsltFreeExtModule);
|
(xmlHashDeallocator) xsltFreeExtModule);
|
||||||
xsltExtensionsHash = NULL;
|
xsltExtensionsHash = NULL;
|
||||||
|
|
||||||
|
xmlMutexUnlock(xsltExtMutex);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -1351,9 +1395,13 @@ xsltRegisterExtModuleFunction(const xmlChar * name, const xmlChar * URI,
|
||||||
if (xsltFunctionsHash == NULL)
|
if (xsltFunctionsHash == NULL)
|
||||||
return (-1);
|
return (-1);
|
||||||
|
|
||||||
|
xmlMutexLock(xsltExtMutex);
|
||||||
|
|
||||||
xmlHashUpdateEntry2(xsltFunctionsHash, name, URI,
|
xmlHashUpdateEntry2(xsltFunctionsHash, name, URI,
|
||||||
XML_CAST_FPTR(function), NULL);
|
XML_CAST_FPTR(function), NULL);
|
||||||
|
|
||||||
|
xmlMutexUnlock(xsltExtMutex);
|
||||||
|
|
||||||
return (0);
|
return (0);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1374,13 +1422,21 @@ xsltExtModuleFunctionLookup(const xmlChar * name, const xmlChar * URI)
|
||||||
if ((xsltFunctionsHash == NULL) || (name == NULL) || (URI == NULL))
|
if ((xsltFunctionsHash == NULL) || (name == NULL) || (URI == NULL))
|
||||||
return (NULL);
|
return (NULL);
|
||||||
|
|
||||||
|
xmlMutexLock(xsltExtMutex);
|
||||||
|
|
||||||
XML_CAST_FPTR(ret) = xmlHashLookup2(xsltFunctionsHash, name, URI);
|
XML_CAST_FPTR(ret) = xmlHashLookup2(xsltFunctionsHash, name, URI);
|
||||||
|
|
||||||
|
xmlMutexUnlock(xsltExtMutex);
|
||||||
|
|
||||||
/* if lookup fails, attempt a dynamic load on supported platforms */
|
/* if lookup fails, attempt a dynamic load on supported platforms */
|
||||||
if (NULL == ret) {
|
if (NULL == ret) {
|
||||||
if (!xsltExtModuleRegisterDynamic(URI)) {
|
if (!xsltExtModuleRegisterDynamic(URI)) {
|
||||||
|
xmlMutexLock(xsltExtMutex);
|
||||||
|
|
||||||
XML_CAST_FPTR(ret) =
|
XML_CAST_FPTR(ret) =
|
||||||
xmlHashLookup2(xsltFunctionsHash, name, URI);
|
xmlHashLookup2(xsltFunctionsHash, name, URI);
|
||||||
|
|
||||||
|
xmlMutexUnlock(xsltExtMutex);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1399,10 +1455,18 @@ xsltExtModuleFunctionLookup(const xmlChar * name, const xmlChar * URI)
|
||||||
int
|
int
|
||||||
xsltUnregisterExtModuleFunction(const xmlChar * name, const xmlChar * URI)
|
xsltUnregisterExtModuleFunction(const xmlChar * name, const xmlChar * URI)
|
||||||
{
|
{
|
||||||
|
int ret;
|
||||||
|
|
||||||
if ((xsltFunctionsHash == NULL) || (name == NULL) || (URI == NULL))
|
if ((xsltFunctionsHash == NULL) || (name == NULL) || (URI == NULL))
|
||||||
return (-1);
|
return (-1);
|
||||||
|
|
||||||
return xmlHashRemoveEntry2(xsltFunctionsHash, name, URI, NULL);
|
xmlMutexLock(xsltExtMutex);
|
||||||
|
|
||||||
|
ret = xmlHashRemoveEntry2(xsltFunctionsHash, name, URI, NULL);
|
||||||
|
|
||||||
|
xmlMutexUnlock(xsltExtMutex);
|
||||||
|
|
||||||
|
return(ret);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -1413,8 +1477,12 @@ xsltUnregisterExtModuleFunction(const xmlChar * name, const xmlChar * URI)
|
||||||
static void
|
static void
|
||||||
xsltUnregisterAllExtModuleFunction(void)
|
xsltUnregisterAllExtModuleFunction(void)
|
||||||
{
|
{
|
||||||
|
xmlMutexLock(xsltExtMutex);
|
||||||
|
|
||||||
xmlHashFree(xsltFunctionsHash, NULL);
|
xmlHashFree(xsltFunctionsHash, NULL);
|
||||||
xsltFunctionsHash = NULL;
|
xsltFunctionsHash = NULL;
|
||||||
|
|
||||||
|
xmlMutexUnlock(xsltExtMutex);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -1494,8 +1562,13 @@ xsltPreComputeExtModuleElement(xsltStylesheetPtr style, xmlNodePtr inst)
|
||||||
(inst->type != XML_ELEMENT_NODE) || (inst->ns == NULL))
|
(inst->type != XML_ELEMENT_NODE) || (inst->ns == NULL))
|
||||||
return (NULL);
|
return (NULL);
|
||||||
|
|
||||||
|
xmlMutexLock(xsltExtMutex);
|
||||||
|
|
||||||
ext = (xsltExtElementPtr)
|
ext = (xsltExtElementPtr)
|
||||||
xmlHashLookup2(xsltElementsHash, inst->name, inst->ns->href);
|
xmlHashLookup2(xsltElementsHash, inst->name, inst->ns->href);
|
||||||
|
|
||||||
|
xmlMutexUnlock(xsltExtMutex);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* EXT TODO: Now what?
|
* EXT TODO: Now what?
|
||||||
*/
|
*/
|
||||||
|
@ -1549,6 +1622,8 @@ xsltRegisterExtModuleElement(const xmlChar * name, const xmlChar * URI,
|
||||||
xsltPreComputeFunction precomp,
|
xsltPreComputeFunction precomp,
|
||||||
xsltTransformFunction transform)
|
xsltTransformFunction transform)
|
||||||
{
|
{
|
||||||
|
int ret;
|
||||||
|
|
||||||
xsltExtElementPtr ext;
|
xsltExtElementPtr ext;
|
||||||
|
|
||||||
if ((name == NULL) || (URI == NULL) || (transform == NULL))
|
if ((name == NULL) || (URI == NULL) || (transform == NULL))
|
||||||
|
@ -1559,13 +1634,20 @@ xsltRegisterExtModuleElement(const xmlChar * name, const xmlChar * URI,
|
||||||
if (xsltElementsHash == NULL)
|
if (xsltElementsHash == NULL)
|
||||||
return (-1);
|
return (-1);
|
||||||
|
|
||||||
|
xmlMutexLock(xsltExtMutex);
|
||||||
|
|
||||||
ext = xsltNewExtElement(precomp, transform);
|
ext = xsltNewExtElement(precomp, transform);
|
||||||
if (ext == NULL)
|
if (ext == NULL) {
|
||||||
return (-1);
|
ret = -1;
|
||||||
|
goto done;
|
||||||
|
}
|
||||||
|
|
||||||
xmlHashUpdateEntry2(xsltElementsHash, name, URI, (void *) ext,
|
xmlHashUpdateEntry2(xsltElementsHash, name, URI, (void *) ext,
|
||||||
(xmlHashDeallocator) xsltFreeExtElement);
|
(xmlHashDeallocator) xsltFreeExtElement);
|
||||||
|
|
||||||
|
done:
|
||||||
|
xmlMutexUnlock(xsltExtMutex);
|
||||||
|
|
||||||
return (0);
|
return (0);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1591,10 +1673,14 @@ xsltExtElementLookup(xsltTransformContextPtr ctxt,
|
||||||
|
|
||||||
if ((ctxt != NULL) && (ctxt->extElements != NULL)) {
|
if ((ctxt != NULL) && (ctxt->extElements != NULL)) {
|
||||||
XML_CAST_FPTR(ret) = xmlHashLookup2(ctxt->extElements, name, URI);
|
XML_CAST_FPTR(ret) = xmlHashLookup2(ctxt->extElements, name, URI);
|
||||||
if (ret != NULL)
|
if (ret != NULL) {
|
||||||
return (ret);
|
return(ret);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
return xsltExtModuleElementLookup(name, URI);
|
|
||||||
|
ret = xsltExtModuleElementLookup(name, URI);
|
||||||
|
|
||||||
|
return (ret);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -1614,14 +1700,24 @@ xsltExtModuleElementLookup(const xmlChar * name, const xmlChar * URI)
|
||||||
if ((xsltElementsHash == NULL) || (name == NULL) || (URI == NULL))
|
if ((xsltElementsHash == NULL) || (name == NULL) || (URI == NULL))
|
||||||
return (NULL);
|
return (NULL);
|
||||||
|
|
||||||
|
xmlMutexLock(xsltExtMutex);
|
||||||
|
|
||||||
ext = (xsltExtElementPtr) xmlHashLookup2(xsltElementsHash, name, URI);
|
ext = (xsltExtElementPtr) xmlHashLookup2(xsltElementsHash, name, URI);
|
||||||
|
|
||||||
/* if function lookup fails, attempt a dynamic load on supported platforms */
|
xmlMutexUnlock(xsltExtMutex);
|
||||||
ext = (xsltExtElementPtr) xmlHashLookup2(xsltElementsHash, name, URI);
|
|
||||||
|
/*
|
||||||
|
* if function lookup fails, attempt a dynamic load on
|
||||||
|
* supported platforms
|
||||||
|
*/
|
||||||
if (NULL == ext) {
|
if (NULL == ext) {
|
||||||
if (!xsltExtModuleRegisterDynamic(URI)) {
|
if (!xsltExtModuleRegisterDynamic(URI)) {
|
||||||
|
xmlMutexLock(xsltExtMutex);
|
||||||
|
|
||||||
ext = (xsltExtElementPtr)
|
ext = (xsltExtElementPtr)
|
||||||
xmlHashLookup2(xsltElementsHash, name, URI);
|
xmlHashLookup2(xsltElementsHash, name, URI);
|
||||||
|
|
||||||
|
xmlMutexUnlock(xsltExtMutex);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1648,12 +1744,20 @@ xsltExtModuleElementPreComputeLookup(const xmlChar * name,
|
||||||
if ((xsltElementsHash == NULL) || (name == NULL) || (URI == NULL))
|
if ((xsltElementsHash == NULL) || (name == NULL) || (URI == NULL))
|
||||||
return (NULL);
|
return (NULL);
|
||||||
|
|
||||||
|
xmlMutexLock(xsltExtMutex);
|
||||||
|
|
||||||
ext = (xsltExtElementPtr) xmlHashLookup2(xsltElementsHash, name, URI);
|
ext = (xsltExtElementPtr) xmlHashLookup2(xsltElementsHash, name, URI);
|
||||||
|
|
||||||
|
xmlMutexUnlock(xsltExtMutex);
|
||||||
|
|
||||||
if (ext == NULL) {
|
if (ext == NULL) {
|
||||||
if (!xsltExtModuleRegisterDynamic(URI)) {
|
if (!xsltExtModuleRegisterDynamic(URI)) {
|
||||||
|
xmlMutexLock(xsltExtMutex);
|
||||||
|
|
||||||
ext = (xsltExtElementPtr)
|
ext = (xsltExtElementPtr)
|
||||||
xmlHashLookup2(xsltElementsHash, name, URI);
|
xmlHashLookup2(xsltElementsHash, name, URI);
|
||||||
|
|
||||||
|
xmlMutexUnlock(xsltExtMutex);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1674,11 +1778,19 @@ xsltExtModuleElementPreComputeLookup(const xmlChar * name,
|
||||||
int
|
int
|
||||||
xsltUnregisterExtModuleElement(const xmlChar * name, const xmlChar * URI)
|
xsltUnregisterExtModuleElement(const xmlChar * name, const xmlChar * URI)
|
||||||
{
|
{
|
||||||
|
int ret;
|
||||||
|
|
||||||
if ((xsltElementsHash == NULL) || (name == NULL) || (URI == NULL))
|
if ((xsltElementsHash == NULL) || (name == NULL) || (URI == NULL))
|
||||||
return (-1);
|
return (-1);
|
||||||
|
|
||||||
return xmlHashRemoveEntry2(xsltElementsHash, name, URI,
|
xmlMutexLock(xsltExtMutex);
|
||||||
(xmlHashDeallocator) xsltFreeExtElement);
|
|
||||||
|
ret = xmlHashRemoveEntry2(xsltElementsHash, name, URI,
|
||||||
|
(xmlHashDeallocator) xsltFreeExtElement);
|
||||||
|
|
||||||
|
xmlMutexUnlock(xsltExtMutex);
|
||||||
|
|
||||||
|
return(ret);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -1689,8 +1801,12 @@ xsltUnregisterExtModuleElement(const xmlChar * name, const xmlChar * URI)
|
||||||
static void
|
static void
|
||||||
xsltUnregisterAllExtModuleElement(void)
|
xsltUnregisterAllExtModuleElement(void)
|
||||||
{
|
{
|
||||||
|
xmlMutexLock(xsltExtMutex);
|
||||||
|
|
||||||
xmlHashFree(xsltElementsHash, (xmlHashDeallocator) xsltFreeExtElement);
|
xmlHashFree(xsltElementsHash, (xmlHashDeallocator) xsltFreeExtElement);
|
||||||
xsltElementsHash = NULL;
|
xsltElementsHash = NULL;
|
||||||
|
|
||||||
|
xmlMutexUnlock(xsltExtMutex);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -1715,9 +1831,13 @@ xsltRegisterExtModuleTopLevel(const xmlChar * name, const xmlChar * URI,
|
||||||
if (xsltTopLevelsHash == NULL)
|
if (xsltTopLevelsHash == NULL)
|
||||||
return (-1);
|
return (-1);
|
||||||
|
|
||||||
|
xmlMutexLock(xsltExtMutex);
|
||||||
|
|
||||||
xmlHashUpdateEntry2(xsltTopLevelsHash, name, URI,
|
xmlHashUpdateEntry2(xsltTopLevelsHash, name, URI,
|
||||||
XML_CAST_FPTR(function), NULL);
|
XML_CAST_FPTR(function), NULL);
|
||||||
|
|
||||||
|
xmlMutexUnlock(xsltExtMutex);
|
||||||
|
|
||||||
return (0);
|
return (0);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1738,12 +1858,20 @@ xsltExtModuleTopLevelLookup(const xmlChar * name, const xmlChar * URI)
|
||||||
if ((xsltTopLevelsHash == NULL) || (name == NULL) || (URI == NULL))
|
if ((xsltTopLevelsHash == NULL) || (name == NULL) || (URI == NULL))
|
||||||
return (NULL);
|
return (NULL);
|
||||||
|
|
||||||
|
xmlMutexLock(xsltExtMutex);
|
||||||
|
|
||||||
XML_CAST_FPTR(ret) = xmlHashLookup2(xsltTopLevelsHash, name, URI);
|
XML_CAST_FPTR(ret) = xmlHashLookup2(xsltTopLevelsHash, name, URI);
|
||||||
|
|
||||||
|
xmlMutexUnlock(xsltExtMutex);
|
||||||
|
|
||||||
/* if lookup fails, attempt a dynamic load on supported platforms */
|
/* if lookup fails, attempt a dynamic load on supported platforms */
|
||||||
if (NULL == ret) {
|
if (NULL == ret) {
|
||||||
if (!xsltExtModuleRegisterDynamic(URI)) {
|
if (!xsltExtModuleRegisterDynamic(URI)) {
|
||||||
|
xmlMutexLock(xsltExtMutex);
|
||||||
|
|
||||||
XML_CAST_FPTR(ret) = xmlHashLookup2(xsltTopLevelsHash, name, URI);
|
XML_CAST_FPTR(ret) = xmlHashLookup2(xsltTopLevelsHash, name, URI);
|
||||||
|
|
||||||
|
xmlMutexUnlock(xsltExtMutex);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1762,10 +1890,18 @@ xsltExtModuleTopLevelLookup(const xmlChar * name, const xmlChar * URI)
|
||||||
int
|
int
|
||||||
xsltUnregisterExtModuleTopLevel(const xmlChar * name, const xmlChar * URI)
|
xsltUnregisterExtModuleTopLevel(const xmlChar * name, const xmlChar * URI)
|
||||||
{
|
{
|
||||||
|
int ret;
|
||||||
|
|
||||||
if ((xsltTopLevelsHash == NULL) || (name == NULL) || (URI == NULL))
|
if ((xsltTopLevelsHash == NULL) || (name == NULL) || (URI == NULL))
|
||||||
return (-1);
|
return (-1);
|
||||||
|
|
||||||
return xmlHashRemoveEntry2(xsltTopLevelsHash, name, URI, NULL);
|
xmlMutexLock(xsltExtMutex);
|
||||||
|
|
||||||
|
ret = xmlHashRemoveEntry2(xsltTopLevelsHash, name, URI, NULL);
|
||||||
|
|
||||||
|
xmlMutexUnlock(xsltExtMutex);
|
||||||
|
|
||||||
|
return(ret);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -1776,8 +1912,12 @@ xsltUnregisterExtModuleTopLevel(const xmlChar * name, const xmlChar * URI)
|
||||||
static void
|
static void
|
||||||
xsltUnregisterAllExtModuleTopLevel(void)
|
xsltUnregisterAllExtModuleTopLevel(void)
|
||||||
{
|
{
|
||||||
|
xmlMutexLock(xsltExtMutex);
|
||||||
|
|
||||||
xmlHashFree(xsltTopLevelsHash, NULL);
|
xmlHashFree(xsltTopLevelsHash, NULL);
|
||||||
xsltTopLevelsHash = NULL;
|
xsltTopLevelsHash = NULL;
|
||||||
|
|
||||||
|
xmlMutexUnlock(xsltExtMutex);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -2088,6 +2228,7 @@ xsltExtStyleShutdownTest(xsltStylesheetPtr style ATTRIBUTE_UNUSED,
|
||||||
void
|
void
|
||||||
xsltRegisterTestModule(void)
|
xsltRegisterTestModule(void)
|
||||||
{
|
{
|
||||||
|
xsltInitGlobals();
|
||||||
xsltRegisterExtModuleFull((const xmlChar *) XSLT_DEFAULT_URL,
|
xsltRegisterExtModuleFull((const xmlChar *) XSLT_DEFAULT_URL,
|
||||||
xsltExtInitTest, xsltExtShutdownTest,
|
xsltExtInitTest, xsltExtShutdownTest,
|
||||||
xsltExtStyleInitTest,
|
xsltExtStyleInitTest,
|
||||||
|
@ -2102,7 +2243,8 @@ xsltRegisterTestModule(void)
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
xsltHashScannerModuleFree(void *payload, void *data ATTRIBUTE_UNUSED,
|
xsltHashScannerModuleFree(void *payload ATTRIBUTE_UNUSED,
|
||||||
|
void *data ATTRIBUTE_UNUSED,
|
||||||
xmlChar * name ATTRIBUTE_UNUSED)
|
xmlChar * name ATTRIBUTE_UNUSED)
|
||||||
{
|
{
|
||||||
#ifdef WITH_MODULES
|
#ifdef WITH_MODULES
|
||||||
|
@ -2110,6 +2252,19 @@ xsltHashScannerModuleFree(void *payload, void *data ATTRIBUTE_UNUSED,
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* xsltInitGlobals:
|
||||||
|
*
|
||||||
|
* Initialize the global variables for extensions
|
||||||
|
*/
|
||||||
|
void
|
||||||
|
xsltInitGlobals(void)
|
||||||
|
{
|
||||||
|
if (xsltExtMutex == NULL) {
|
||||||
|
xsltExtMutex = xmlNewMutex();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* xsltCleanupGlobals:
|
* xsltCleanupGlobals:
|
||||||
*
|
*
|
||||||
|
@ -2123,13 +2278,17 @@ xsltCleanupGlobals(void)
|
||||||
xsltUnregisterAllExtModuleElement();
|
xsltUnregisterAllExtModuleElement();
|
||||||
xsltUnregisterAllExtModuleTopLevel();
|
xsltUnregisterAllExtModuleTopLevel();
|
||||||
|
|
||||||
|
xmlMutexLock(xsltExtMutex);
|
||||||
/* cleanup dynamic module hash */
|
/* cleanup dynamic module hash */
|
||||||
if (NULL != xsltModuleHash) {
|
if (NULL != xsltModuleHash) {
|
||||||
xmlHashScan(xsltModuleHash, xsltHashScannerModuleFree, 0);
|
xmlHashScan(xsltModuleHash, xsltHashScannerModuleFree, 0);
|
||||||
xmlHashFree(xsltModuleHash, NULL);
|
xmlHashFree(xsltModuleHash, NULL);
|
||||||
xsltModuleHash = NULL;
|
xsltModuleHash = NULL;
|
||||||
}
|
}
|
||||||
|
xmlMutexUnlock(xsltExtMutex);
|
||||||
|
|
||||||
|
xmlFreeMutex(xsltExtMutex);
|
||||||
|
xsltExtMutex = NULL;
|
||||||
xsltUninit();
|
xsltUninit();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2172,25 +2331,31 @@ xsltDebugDumpExtensions(FILE * output)
|
||||||
fprintf(output, "No registered extension functions\n");
|
fprintf(output, "No registered extension functions\n");
|
||||||
else {
|
else {
|
||||||
fprintf(output, "Registered Extension Functions:\n");
|
fprintf(output, "Registered Extension Functions:\n");
|
||||||
|
xmlMutexLock(xsltExtMutex);
|
||||||
xmlHashScanFull(xsltFunctionsHash,
|
xmlHashScanFull(xsltFunctionsHash,
|
||||||
(xmlHashScannerFull)
|
(xmlHashScannerFull)
|
||||||
xsltDebugDumpExtensionsCallback, output);
|
xsltDebugDumpExtensionsCallback, output);
|
||||||
|
xmlMutexUnlock(xsltExtMutex);
|
||||||
}
|
}
|
||||||
if (!xsltElementsHash)
|
if (!xsltElementsHash)
|
||||||
fprintf(output, "\nNo registered extension elements\n");
|
fprintf(output, "\nNo registered extension elements\n");
|
||||||
else {
|
else {
|
||||||
fprintf(output, "\nRegistered Extension Elements:\n");
|
fprintf(output, "\nRegistered Extension Elements:\n");
|
||||||
|
xmlMutexLock(xsltExtMutex);
|
||||||
xmlHashScanFull(xsltElementsHash,
|
xmlHashScanFull(xsltElementsHash,
|
||||||
(xmlHashScannerFull)
|
(xmlHashScannerFull)
|
||||||
xsltDebugDumpExtensionsCallback, output);
|
xsltDebugDumpExtensionsCallback, output);
|
||||||
|
xmlMutexUnlock(xsltExtMutex);
|
||||||
}
|
}
|
||||||
if (!xsltExtensionsHash)
|
if (!xsltExtensionsHash)
|
||||||
fprintf(output, "\nNo registered extension modules\n");
|
fprintf(output, "\nNo registered extension modules\n");
|
||||||
else {
|
else {
|
||||||
fprintf(output, "\nRegistered Extension Modules:\n");
|
fprintf(output, "\nRegistered Extension Modules:\n");
|
||||||
|
xmlMutexLock(xsltExtMutex);
|
||||||
xmlHashScanFull(xsltExtensionsHash,
|
xmlHashScanFull(xsltExtensionsHash,
|
||||||
(xmlHashScannerFull)
|
(xmlHashScannerFull)
|
||||||
xsltDebugDumpExtModulesCallback, output);
|
xsltDebugDumpExtModulesCallback, output);
|
||||||
|
xmlMutexUnlock(xsltExtMutex);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
92
reactos/dll/3rdparty/libxslt/extensions.h
vendored
92
reactos/dll/3rdparty/libxslt/extensions.h
vendored
|
@ -23,6 +23,16 @@ extern "C" {
|
||||||
* Extension Modules API.
|
* Extension Modules API.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* xsltInitGlobals:
|
||||||
|
*
|
||||||
|
* Initialize the global variables for extensions
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
XSLTPUBFUN void XSLTCALL
|
||||||
|
xsltInitGlobals (void);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* xsltStyleExtInitFunction:
|
* xsltStyleExtInitFunction:
|
||||||
* @ctxt: an XSLT stylesheet
|
* @ctxt: an XSLT stylesheet
|
||||||
|
@ -86,11 +96,11 @@ XSLTPUBFUN int XSLTCALL
|
||||||
XSLTPUBFUN int XSLTCALL
|
XSLTPUBFUN int XSLTCALL
|
||||||
xsltUnregisterExtModule (const xmlChar * URI);
|
xsltUnregisterExtModule (const xmlChar * URI);
|
||||||
|
|
||||||
XSLTPUBFUN void * XSLTCALL
|
XSLTPUBFUN void * XSLTCALL
|
||||||
xsltGetExtData (xsltTransformContextPtr ctxt,
|
xsltGetExtData (xsltTransformContextPtr ctxt,
|
||||||
const xmlChar *URI);
|
const xmlChar *URI);
|
||||||
|
|
||||||
XSLTPUBFUN void * XSLTCALL
|
XSLTPUBFUN void * XSLTCALL
|
||||||
xsltStyleGetExtData (xsltStylesheetPtr style,
|
xsltStyleGetExtData (xsltStylesheetPtr style,
|
||||||
const xmlChar *URI);
|
const xmlChar *URI);
|
||||||
#ifdef XSLT_REFACTORED
|
#ifdef XSLT_REFACTORED
|
||||||
|
@ -99,33 +109,29 @@ XSLTPUBFUN void * XSLTCALL
|
||||||
xsltStylesheetPtr style,
|
xsltStylesheetPtr style,
|
||||||
const xmlChar * URI);
|
const xmlChar * URI);
|
||||||
#endif
|
#endif
|
||||||
XSLTPUBFUN void XSLTCALL
|
XSLTPUBFUN void XSLTCALL
|
||||||
xsltShutdownCtxtExts (xsltTransformContextPtr ctxt);
|
xsltShutdownCtxtExts (xsltTransformContextPtr ctxt);
|
||||||
|
|
||||||
XSLTPUBFUN void XSLTCALL
|
XSLTPUBFUN void XSLTCALL
|
||||||
xsltShutdownExts (xsltStylesheetPtr style);
|
xsltShutdownExts (xsltStylesheetPtr style);
|
||||||
|
|
||||||
XSLTPUBFUN xsltTransformContextPtr XSLTCALL
|
XSLTPUBFUN xsltTransformContextPtr XSLTCALL
|
||||||
xsltXPathGetTransformContext
|
xsltXPathGetTransformContext
|
||||||
(xmlXPathParserContextPtr ctxt);
|
(xmlXPathParserContextPtr ctxt);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* extension functions
|
* extension functions
|
||||||
*/
|
*/
|
||||||
XSLTPUBFUN int XSLTCALL
|
XSLTPUBFUN int XSLTCALL
|
||||||
xsltRegisterExtModuleFunction
|
xsltRegisterExtModuleFunction
|
||||||
(const xmlChar *name,
|
(const xmlChar *name,
|
||||||
const xmlChar *URI,
|
const xmlChar *URI,
|
||||||
xmlXPathFunction function);
|
xmlXPathFunction function);
|
||||||
XSLTPUBFUN xmlXPathFunction XSLTCALL
|
|
||||||
xsltExtFunctionLookup (xsltTransformContextPtr ctxt,
|
|
||||||
const xmlChar *name,
|
|
||||||
const xmlChar *URI);
|
|
||||||
XSLTPUBFUN xmlXPathFunction XSLTCALL
|
XSLTPUBFUN xmlXPathFunction XSLTCALL
|
||||||
xsltExtModuleFunctionLookup (const xmlChar *name,
|
xsltExtModuleFunctionLookup (const xmlChar *name,
|
||||||
const xmlChar *URI);
|
const xmlChar *URI);
|
||||||
XSLTPUBFUN int XSLTCALL
|
XSLTPUBFUN int XSLTCALL
|
||||||
xsltUnregisterExtModuleFunction
|
xsltUnregisterExtModuleFunction
|
||||||
(const xmlChar *name,
|
(const xmlChar *name,
|
||||||
const xmlChar *URI);
|
const xmlChar *URI);
|
||||||
|
|
||||||
|
@ -133,7 +139,7 @@ XSLTPUBFUN int XSLTCALL
|
||||||
* extension elements
|
* extension elements
|
||||||
*/
|
*/
|
||||||
typedef xsltElemPreCompPtr (*xsltPreComputeFunction)
|
typedef xsltElemPreCompPtr (*xsltPreComputeFunction)
|
||||||
(xsltStylesheetPtr style,
|
(xsltStylesheetPtr style,
|
||||||
xmlNodePtr inst,
|
xmlNodePtr inst,
|
||||||
xsltTransformFunction function);
|
xsltTransformFunction function);
|
||||||
|
|
||||||
|
@ -141,33 +147,33 @@ XSLTPUBFUN xsltElemPreCompPtr XSLTCALL
|
||||||
xsltNewElemPreComp (xsltStylesheetPtr style,
|
xsltNewElemPreComp (xsltStylesheetPtr style,
|
||||||
xmlNodePtr inst,
|
xmlNodePtr inst,
|
||||||
xsltTransformFunction function);
|
xsltTransformFunction function);
|
||||||
XSLTPUBFUN void XSLTCALL
|
XSLTPUBFUN void XSLTCALL
|
||||||
xsltInitElemPreComp (xsltElemPreCompPtr comp,
|
xsltInitElemPreComp (xsltElemPreCompPtr comp,
|
||||||
xsltStylesheetPtr style,
|
xsltStylesheetPtr style,
|
||||||
xmlNodePtr inst,
|
xmlNodePtr inst,
|
||||||
xsltTransformFunction function,
|
xsltTransformFunction function,
|
||||||
xsltElemPreCompDeallocator freeFunc);
|
xsltElemPreCompDeallocator freeFunc);
|
||||||
|
|
||||||
XSLTPUBFUN int XSLTCALL
|
XSLTPUBFUN int XSLTCALL
|
||||||
xsltRegisterExtModuleElement
|
xsltRegisterExtModuleElement
|
||||||
(const xmlChar *name,
|
(const xmlChar *name,
|
||||||
const xmlChar *URI,
|
const xmlChar *URI,
|
||||||
xsltPreComputeFunction precomp,
|
xsltPreComputeFunction precomp,
|
||||||
xsltTransformFunction transform);
|
xsltTransformFunction transform);
|
||||||
XSLTPUBFUN xsltTransformFunction XSLTCALL
|
XSLTPUBFUN xsltTransformFunction XSLTCALL
|
||||||
xsltExtElementLookup (xsltTransformContextPtr ctxt,
|
xsltExtElementLookup (xsltTransformContextPtr ctxt,
|
||||||
const xmlChar *name,
|
const xmlChar *name,
|
||||||
const xmlChar *URI);
|
const xmlChar *URI);
|
||||||
XSLTPUBFUN xsltTransformFunction XSLTCALL
|
XSLTPUBFUN xsltTransformFunction XSLTCALL
|
||||||
xsltExtModuleElementLookup
|
xsltExtModuleElementLookup
|
||||||
(const xmlChar *name,
|
(const xmlChar *name,
|
||||||
const xmlChar *URI);
|
const xmlChar *URI);
|
||||||
XSLTPUBFUN xsltPreComputeFunction XSLTCALL
|
XSLTPUBFUN xsltPreComputeFunction XSLTCALL
|
||||||
xsltExtModuleElementPreComputeLookup
|
xsltExtModuleElementPreComputeLookup
|
||||||
(const xmlChar *name,
|
(const xmlChar *name,
|
||||||
const xmlChar *URI);
|
const xmlChar *URI);
|
||||||
XSLTPUBFUN int XSLTCALL
|
XSLTPUBFUN int XSLTCALL
|
||||||
xsltUnregisterExtModuleElement
|
xsltUnregisterExtModuleElement
|
||||||
(const xmlChar *name,
|
(const xmlChar *name,
|
||||||
const xmlChar *URI);
|
const xmlChar *URI);
|
||||||
|
|
||||||
|
@ -177,28 +183,28 @@ XSLTPUBFUN int XSLTCALL
|
||||||
typedef void (*xsltTopLevelFunction) (xsltStylesheetPtr style,
|
typedef void (*xsltTopLevelFunction) (xsltStylesheetPtr style,
|
||||||
xmlNodePtr inst);
|
xmlNodePtr inst);
|
||||||
|
|
||||||
XSLTPUBFUN int XSLTCALL
|
XSLTPUBFUN int XSLTCALL
|
||||||
xsltRegisterExtModuleTopLevel
|
xsltRegisterExtModuleTopLevel
|
||||||
(const xmlChar *name,
|
(const xmlChar *name,
|
||||||
const xmlChar *URI,
|
const xmlChar *URI,
|
||||||
xsltTopLevelFunction function);
|
xsltTopLevelFunction function);
|
||||||
XSLTPUBFUN xsltTopLevelFunction XSLTCALL
|
XSLTPUBFUN xsltTopLevelFunction XSLTCALL
|
||||||
xsltExtModuleTopLevelLookup
|
xsltExtModuleTopLevelLookup
|
||||||
(const xmlChar *name,
|
(const xmlChar *name,
|
||||||
const xmlChar *URI);
|
const xmlChar *URI);
|
||||||
XSLTPUBFUN int XSLTCALL
|
XSLTPUBFUN int XSLTCALL
|
||||||
xsltUnregisterExtModuleTopLevel
|
xsltUnregisterExtModuleTopLevel
|
||||||
(const xmlChar *name,
|
(const xmlChar *name,
|
||||||
const xmlChar *URI);
|
const xmlChar *URI);
|
||||||
|
|
||||||
|
|
||||||
/* These 2 functions are deprecated for use within modules. */
|
/* These 2 functions are deprecated for use within modules. */
|
||||||
XSLTPUBFUN int XSLTCALL
|
XSLTPUBFUN int XSLTCALL
|
||||||
xsltRegisterExtFunction (xsltTransformContextPtr ctxt,
|
xsltRegisterExtFunction (xsltTransformContextPtr ctxt,
|
||||||
const xmlChar *name,
|
const xmlChar *name,
|
||||||
const xmlChar *URI,
|
const xmlChar *URI,
|
||||||
xmlXPathFunction function);
|
xmlXPathFunction function);
|
||||||
XSLTPUBFUN int XSLTCALL
|
XSLTPUBFUN int XSLTCALL
|
||||||
xsltRegisterExtElement (xsltTransformContextPtr ctxt,
|
xsltRegisterExtElement (xsltTransformContextPtr ctxt,
|
||||||
const xmlChar *name,
|
const xmlChar *name,
|
||||||
const xmlChar *URI,
|
const xmlChar *URI,
|
||||||
|
@ -209,24 +215,24 @@ XSLTPUBFUN int XSLTCALL
|
||||||
* Those are used by the XSLT (pre)processor.
|
* Those are used by the XSLT (pre)processor.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
XSLTPUBFUN int XSLTCALL
|
XSLTPUBFUN int XSLTCALL
|
||||||
xsltRegisterExtPrefix (xsltStylesheetPtr style,
|
xsltRegisterExtPrefix (xsltStylesheetPtr style,
|
||||||
const xmlChar *prefix,
|
const xmlChar *prefix,
|
||||||
const xmlChar *URI);
|
const xmlChar *URI);
|
||||||
XSLTPUBFUN int XSLTCALL
|
XSLTPUBFUN int XSLTCALL
|
||||||
xsltCheckExtPrefix (xsltStylesheetPtr style,
|
xsltCheckExtPrefix (xsltStylesheetPtr style,
|
||||||
const xmlChar *URI);
|
const xmlChar *URI);
|
||||||
XSLTPUBFUN int XSLTCALL
|
XSLTPUBFUN int XSLTCALL
|
||||||
xsltCheckExtURI (xsltStylesheetPtr style,
|
xsltCheckExtURI (xsltStylesheetPtr style,
|
||||||
const xmlChar *URI);
|
const xmlChar *URI);
|
||||||
XSLTPUBFUN int XSLTCALL
|
XSLTPUBFUN int XSLTCALL
|
||||||
xsltInitCtxtExts (xsltTransformContextPtr ctxt);
|
xsltInitCtxtExts (xsltTransformContextPtr ctxt);
|
||||||
XSLTPUBFUN void XSLTCALL
|
XSLTPUBFUN void XSLTCALL
|
||||||
xsltFreeCtxtExts (xsltTransformContextPtr ctxt);
|
xsltFreeCtxtExts (xsltTransformContextPtr ctxt);
|
||||||
XSLTPUBFUN void XSLTCALL
|
XSLTPUBFUN void XSLTCALL
|
||||||
xsltFreeExts (xsltStylesheetPtr style);
|
xsltFreeExts (xsltStylesheetPtr style);
|
||||||
|
|
||||||
XSLTPUBFUN xsltElemPreCompPtr XSLTCALL
|
XSLTPUBFUN xsltElemPreCompPtr XSLTCALL
|
||||||
xsltPreComputeExtModuleElement
|
xsltPreComputeExtModuleElement
|
||||||
(xsltStylesheetPtr style,
|
(xsltStylesheetPtr style,
|
||||||
xmlNodePtr inst);
|
xmlNodePtr inst);
|
||||||
|
@ -235,16 +241,16 @@ XSLTPUBFUN xsltElemPreCompPtr XSLTCALL
|
||||||
* Used by exslt initialisation
|
* Used by exslt initialisation
|
||||||
*/
|
*/
|
||||||
|
|
||||||
XSLTPUBFUN xmlHashTablePtr XSLTCALL
|
XSLTPUBFUN xmlHashTablePtr XSLTCALL
|
||||||
xsltGetExtInfo (xsltStylesheetPtr style,
|
xsltGetExtInfo (xsltStylesheetPtr style,
|
||||||
const xmlChar *URI);
|
const xmlChar *URI);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Test module http://xmlsoft.org/XSLT/
|
* Test module http://xmlsoft.org/XSLT/
|
||||||
*/
|
*/
|
||||||
XSLTPUBFUN void XSLTCALL
|
XSLTPUBFUN void XSLTCALL
|
||||||
xsltRegisterTestModule (void);
|
xsltRegisterTestModule (void);
|
||||||
XSLTPUBFUN void XSLTCALL
|
XSLTPUBFUN void XSLTCALL
|
||||||
xsltDebugDumpExtensions (FILE * output);
|
xsltDebugDumpExtensions (FILE * output);
|
||||||
|
|
||||||
|
|
||||||
|
|
3
reactos/dll/3rdparty/libxslt/extra.c
vendored
3
reactos/dll/3rdparty/libxslt/extra.c
vendored
|
@ -15,7 +15,6 @@
|
||||||
|
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#ifdef HAVE_TIME_H
|
#ifdef HAVE_TIME_H
|
||||||
#define __USE_XOPEN
|
|
||||||
#include <time.h>
|
#include <time.h>
|
||||||
#endif
|
#endif
|
||||||
#ifdef HAVE_STDLIB_H
|
#ifdef HAVE_STDLIB_H
|
||||||
|
@ -199,7 +198,7 @@ xsltFunctionLocalTime(xmlXPathParserContextPtr ctxt, int nargs) {
|
||||||
|
|
||||||
str = (char *) obj->stringval;
|
str = (char *) obj->stringval;
|
||||||
|
|
||||||
/* str = "$Date: 2002-10-15 18:06:47 +0200 (Tue, 15 Oct 2002) $" */
|
/* str = "$Date$" */
|
||||||
memset(digits, 0, sizeof(digits));
|
memset(digits, 0, sizeof(digits));
|
||||||
strncpy(digits, str+7, 4);
|
strncpy(digits, str+7, 4);
|
||||||
field = strtol(digits, NULL, 10);
|
field = strtol(digits, NULL, 10);
|
||||||
|
|
2
reactos/dll/3rdparty/libxslt/functions.c
vendored
2
reactos/dll/3rdparty/libxslt/functions.c
vendored
|
@ -813,6 +813,7 @@ xsltElementAvailableFunction(xmlXPathParserContextPtr ctxt, int nargs){
|
||||||
ctxt->error = XPATH_INVALID_ARITY;
|
ctxt->error = XPATH_INVALID_ARITY;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
xmlXPathStringFunction(ctxt, 1);
|
||||||
if ((ctxt->value == NULL) || (ctxt->value->type != XPATH_STRING)) {
|
if ((ctxt->value == NULL) || (ctxt->value->type != XPATH_STRING)) {
|
||||||
xsltTransformError(xsltXPathGetTransformContext(ctxt), NULL, NULL,
|
xsltTransformError(xsltXPathGetTransformContext(ctxt), NULL, NULL,
|
||||||
"element-available() : invalid arg expecting a string\n");
|
"element-available() : invalid arg expecting a string\n");
|
||||||
|
@ -878,6 +879,7 @@ xsltFunctionAvailableFunction(xmlXPathParserContextPtr ctxt, int nargs){
|
||||||
ctxt->error = XPATH_INVALID_ARITY;
|
ctxt->error = XPATH_INVALID_ARITY;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
xmlXPathStringFunction(ctxt, 1);
|
||||||
if ((ctxt->value == NULL) || (ctxt->value->type != XPATH_STRING)) {
|
if ((ctxt->value == NULL) || (ctxt->value->type != XPATH_STRING)) {
|
||||||
xsltTransformError(xsltXPathGetTransformContext(ctxt), NULL, NULL,
|
xsltTransformError(xsltXPathGetTransformContext(ctxt), NULL, NULL,
|
||||||
"function-available() : invalid arg expecting a string\n");
|
"function-available() : invalid arg expecting a string\n");
|
||||||
|
|
7
reactos/dll/3rdparty/libxslt/imports.c
vendored
7
reactos/dll/3rdparty/libxslt/imports.c
vendored
|
@ -348,6 +348,11 @@ xsltFindElemSpaceHandling(xsltTransformContextPtr ctxt, xmlNodePtr node) {
|
||||||
if (node->ns != NULL) {
|
if (node->ns != NULL) {
|
||||||
val = (const xmlChar *)
|
val = (const xmlChar *)
|
||||||
xmlHashLookup2(style->stripSpaces, node->name, node->ns->href);
|
xmlHashLookup2(style->stripSpaces, node->name, node->ns->href);
|
||||||
|
if (val == NULL) {
|
||||||
|
val = (const xmlChar *)
|
||||||
|
xmlHashLookup2(style->stripSpaces, BAD_CAST "*",
|
||||||
|
node->ns->href);
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
val = (const xmlChar *)
|
val = (const xmlChar *)
|
||||||
xmlHashLookup2(style->stripSpaces, node->name, NULL);
|
xmlHashLookup2(style->stripSpaces, node->name, NULL);
|
||||||
|
@ -357,7 +362,7 @@ xsltFindElemSpaceHandling(xsltTransformContextPtr ctxt, xmlNodePtr node) {
|
||||||
return(1);
|
return(1);
|
||||||
if (xmlStrEqual(val, (xmlChar *) "preserve"))
|
if (xmlStrEqual(val, (xmlChar *) "preserve"))
|
||||||
return(0);
|
return(0);
|
||||||
}
|
}
|
||||||
if (style->stripAll == 1)
|
if (style->stripAll == 1)
|
||||||
return(1);
|
return(1);
|
||||||
if (style->stripAll == -1)
|
if (style->stripAll == -1)
|
||||||
|
|
5
reactos/dll/3rdparty/libxslt/keys.c
vendored
5
reactos/dll/3rdparty/libxslt/keys.c
vendored
|
@ -504,7 +504,7 @@ fprintf(stderr, "xsltInitDocKeyTable %s\n", name);
|
||||||
XSLT_TRACE(ctxt,XSLT_TRACE_KEYS,xsltGenericDebug(xsltGenericDebugContext,
|
XSLT_TRACE(ctxt,XSLT_TRACE_KEYS,xsltGenericDebug(xsltGenericDebugContext,
|
||||||
"xsltInitDocKeyTable: did not found %s\n", name));
|
"xsltInitDocKeyTable: did not found %s\n", name));
|
||||||
#endif
|
#endif
|
||||||
xsltTransformError(ctxt, NULL, keyd->inst,
|
xsltTransformError(ctxt, NULL, keyd? keyd->inst : NULL,
|
||||||
"Failed to find key definition for %s\n", name);
|
"Failed to find key definition for %s\n", name);
|
||||||
ctxt->state = XSLT_STATE_STOPPED;
|
ctxt->state = XSLT_STATE_STOPPED;
|
||||||
return(-1);
|
return(-1);
|
||||||
|
@ -517,10 +517,13 @@ fprintf(stderr, "xsltInitDocKeyTable %s done\n", name);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* xsltInitAllDocKeys:
|
* xsltInitAllDocKeys:
|
||||||
|
* @ctxt: transformation context
|
||||||
*
|
*
|
||||||
* INTERNAL ROUTINE ONLY
|
* INTERNAL ROUTINE ONLY
|
||||||
*
|
*
|
||||||
* Check if any keys on the current document need to be computed
|
* Check if any keys on the current document need to be computed
|
||||||
|
*
|
||||||
|
* Returns 0 in case of success, -1 in case of failure
|
||||||
*/
|
*/
|
||||||
int
|
int
|
||||||
xsltInitAllDocKeys(xsltTransformContextPtr ctxt)
|
xsltInitAllDocKeys(xsltTransformContextPtr ctxt)
|
||||||
|
|
2
reactos/dll/3rdparty/libxslt/libxslt.h
vendored
2
reactos/dll/3rdparty/libxslt/libxslt.h
vendored
|
@ -16,7 +16,7 @@
|
||||||
#include "config.h"
|
#include "config.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#include "xsltconfig.h"
|
#include <libxslt/xsltconfig.h>
|
||||||
#include <libxml/xmlversion.h>
|
#include <libxml/xmlversion.h>
|
||||||
|
|
||||||
#if !defined LIBXSLT_PUBLIC
|
#if !defined LIBXSLT_PUBLIC
|
||||||
|
|
1
reactos/dll/3rdparty/libxslt/libxslt.rbuild
vendored
1
reactos/dll/3rdparty/libxslt/libxslt.rbuild
vendored
|
@ -30,5 +30,6 @@
|
||||||
<file>transform.c</file>
|
<file>transform.c</file>
|
||||||
<file>variables.c</file>
|
<file>variables.c</file>
|
||||||
<file>xslt.c</file>
|
<file>xslt.c</file>
|
||||||
|
<file>xsltlocale.c</file>
|
||||||
<file>xsltutils.c</file>
|
<file>xsltutils.c</file>
|
||||||
</module>
|
</module>
|
||||||
|
|
4
reactos/dll/3rdparty/libxslt/namespaces.c
vendored
4
reactos/dll/3rdparty/libxslt/namespaces.c
vendored
|
@ -584,6 +584,10 @@ declare_new_prefix:
|
||||||
xmlChar pref[30];
|
xmlChar pref[30];
|
||||||
int counter = 1;
|
int counter = 1;
|
||||||
|
|
||||||
|
if (nsPrefix == NULL) {
|
||||||
|
nsPrefix = "ns";
|
||||||
|
}
|
||||||
|
|
||||||
do {
|
do {
|
||||||
snprintf((char *) pref, 30, "%s_%d", nsPrefix, counter++);
|
snprintf((char *) pref, 30, "%s_%d", nsPrefix, counter++);
|
||||||
ns = xmlSearchNs(target->doc, target, BAD_CAST pref);
|
ns = xmlSearchNs(target->doc, target, BAD_CAST pref);
|
||||||
|
|
258
reactos/dll/3rdparty/libxslt/pattern.c
vendored
258
reactos/dll/3rdparty/libxslt/pattern.c
vendored
|
@ -46,7 +46,6 @@ typedef enum {
|
||||||
XSLT_OP_END=0,
|
XSLT_OP_END=0,
|
||||||
XSLT_OP_ROOT,
|
XSLT_OP_ROOT,
|
||||||
XSLT_OP_ELEM,
|
XSLT_OP_ELEM,
|
||||||
XSLT_OP_CHILD,
|
|
||||||
XSLT_OP_ATTR,
|
XSLT_OP_ATTR,
|
||||||
XSLT_OP_PARENT,
|
XSLT_OP_PARENT,
|
||||||
XSLT_OP_ANCESTOR,
|
XSLT_OP_ANCESTOR,
|
||||||
|
@ -61,6 +60,11 @@ typedef enum {
|
||||||
XSLT_OP_PREDICATE
|
XSLT_OP_PREDICATE
|
||||||
} xsltOp;
|
} xsltOp;
|
||||||
|
|
||||||
|
typedef enum {
|
||||||
|
AXIS_CHILD=1,
|
||||||
|
AXIS_ATTRIBUTE
|
||||||
|
} xsltAxis;
|
||||||
|
|
||||||
typedef struct _xsltStepState xsltStepState;
|
typedef struct _xsltStepState xsltStepState;
|
||||||
typedef xsltStepState *xsltStepStatePtr;
|
typedef xsltStepState *xsltStepStatePtr;
|
||||||
struct _xsltStepState {
|
struct _xsltStepState {
|
||||||
|
@ -697,32 +701,6 @@ restart:
|
||||||
goto rollback;
|
goto rollback;
|
||||||
}
|
}
|
||||||
continue;
|
continue;
|
||||||
case XSLT_OP_CHILD: {
|
|
||||||
xmlNodePtr lst;
|
|
||||||
|
|
||||||
if ((node->type != XML_ELEMENT_NODE) &&
|
|
||||||
(node->type != XML_DOCUMENT_NODE) &&
|
|
||||||
#ifdef LIBXML_DOCB_ENABLED
|
|
||||||
(node->type != XML_DOCB_DOCUMENT_NODE) &&
|
|
||||||
#endif
|
|
||||||
(node->type != XML_HTML_DOCUMENT_NODE))
|
|
||||||
goto rollback;
|
|
||||||
|
|
||||||
lst = node->children;
|
|
||||||
|
|
||||||
if (step->value != NULL) {
|
|
||||||
while (lst != NULL) {
|
|
||||||
if ((lst->type == XML_ELEMENT_NODE) &&
|
|
||||||
(step->value[0] == lst->name[0]) &&
|
|
||||||
(xmlStrEqual(step->value, lst->name)))
|
|
||||||
break;
|
|
||||||
lst = lst->next;
|
|
||||||
}
|
|
||||||
if (lst != NULL)
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
goto rollback;
|
|
||||||
}
|
|
||||||
case XSLT_OP_ATTR:
|
case XSLT_OP_ATTR:
|
||||||
if (node->type != XML_ATTRIBUTE_NODE)
|
if (node->type != XML_ATTRIBUTE_NODE)
|
||||||
goto rollback;
|
goto rollback;
|
||||||
|
@ -984,8 +962,10 @@ restart:
|
||||||
/*
|
/*
|
||||||
* recompute the index
|
* recompute the index
|
||||||
*/
|
*/
|
||||||
xmlNodePtr siblings = node->parent->children;
|
|
||||||
xmlNodePtr parent = node->parent;
|
xmlNodePtr parent = node->parent;
|
||||||
|
xmlNodePtr siblings = NULL;
|
||||||
|
|
||||||
|
if (parent) siblings = parent->children;
|
||||||
|
|
||||||
while (siblings != NULL) {
|
while (siblings != NULL) {
|
||||||
if (siblings->type == XML_ELEMENT_NODE) {
|
if (siblings->type == XML_ELEMENT_NODE) {
|
||||||
|
@ -1088,8 +1068,10 @@ restart:
|
||||||
/*
|
/*
|
||||||
* recompute the index
|
* recompute the index
|
||||||
*/
|
*/
|
||||||
xmlNodePtr siblings = node->parent->children;
|
|
||||||
xmlNodePtr parent = node->parent;
|
xmlNodePtr parent = node->parent;
|
||||||
|
xmlNodePtr siblings = NULL;
|
||||||
|
|
||||||
|
if (parent) siblings = parent->children;
|
||||||
|
|
||||||
while (siblings != NULL) {
|
while (siblings != NULL) {
|
||||||
if (siblings->type == XML_ELEMENT_NODE) {
|
if (siblings->type == XML_ELEMENT_NODE) {
|
||||||
|
@ -1325,46 +1307,6 @@ xsltScanLiteral(xsltParserContextPtr ctxt) {
|
||||||
return(ret);
|
return(ret);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* xsltScanName:
|
|
||||||
* @ctxt: the XPath Parser context
|
|
||||||
*
|
|
||||||
* [4] NameChar ::= Letter | Digit | '.' | '-' | '_' |
|
|
||||||
* CombiningChar | Extender
|
|
||||||
*
|
|
||||||
* [5] Name ::= (Letter | '_' | ':') (NameChar)*
|
|
||||||
*
|
|
||||||
* [6] Names ::= Name (S Name)*
|
|
||||||
*
|
|
||||||
* Returns the Name parsed or NULL
|
|
||||||
*/
|
|
||||||
|
|
||||||
static xmlChar *
|
|
||||||
xsltScanName(xsltParserContextPtr ctxt) {
|
|
||||||
const xmlChar *q, *cur;
|
|
||||||
xmlChar *ret = NULL;
|
|
||||||
int val, len;
|
|
||||||
|
|
||||||
SKIP_BLANKS;
|
|
||||||
|
|
||||||
cur = q = CUR_PTR;
|
|
||||||
val = xmlStringCurrentChar(NULL, cur, &len);
|
|
||||||
if (!IS_LETTER(val) && (val != '_') && (val != ':'))
|
|
||||||
return(NULL);
|
|
||||||
|
|
||||||
while ((IS_LETTER(val)) || (IS_DIGIT(val)) ||
|
|
||||||
(val == '.') || (val == '-') ||
|
|
||||||
(val == '_') ||
|
|
||||||
(IS_COMBINING(val)) ||
|
|
||||||
(IS_EXTENDER(val))) {
|
|
||||||
cur += len;
|
|
||||||
val = xmlStringCurrentChar(NULL, cur, &len);
|
|
||||||
}
|
|
||||||
ret = xmlStrndup(q, cur - q);
|
|
||||||
CUR_PTR = cur;
|
|
||||||
return(ret);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* xsltScanNCName:
|
* xsltScanNCName:
|
||||||
* @ctxt: the XPath Parser context
|
* @ctxt: the XPath Parser context
|
||||||
|
@ -1400,30 +1342,6 @@ xsltScanNCName(xsltParserContextPtr ctxt) {
|
||||||
return(ret);
|
return(ret);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* xsltScanQName:
|
|
||||||
* @ctxt: the XPath Parser context
|
|
||||||
* @prefix: the place to store the prefix
|
|
||||||
*
|
|
||||||
* Parse a qualified name
|
|
||||||
*
|
|
||||||
* Returns the Name parsed or NULL
|
|
||||||
*/
|
|
||||||
|
|
||||||
static xmlChar *
|
|
||||||
xsltScanQName(xsltParserContextPtr ctxt, xmlChar **prefix) {
|
|
||||||
xmlChar *ret = NULL;
|
|
||||||
|
|
||||||
*prefix = NULL;
|
|
||||||
ret = xsltScanNCName(ctxt);
|
|
||||||
if (CUR == ':') {
|
|
||||||
*prefix = ret;
|
|
||||||
NEXT;
|
|
||||||
ret = xsltScanNCName(ctxt);
|
|
||||||
}
|
|
||||||
return(ret);
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* xsltCompileIdKeyPattern:
|
* xsltCompileIdKeyPattern:
|
||||||
* @ctxt: the compilation context
|
* @ctxt: the compilation context
|
||||||
|
@ -1443,7 +1361,7 @@ xsltScanQName(xsltParserContextPtr ctxt, xmlChar **prefix) {
|
||||||
*/
|
*/
|
||||||
static void
|
static void
|
||||||
xsltCompileIdKeyPattern(xsltParserContextPtr ctxt, xmlChar *name,
|
xsltCompileIdKeyPattern(xsltParserContextPtr ctxt, xmlChar *name,
|
||||||
int aid, int novar) {
|
int aid, int novar, xsltAxis axis) {
|
||||||
xmlChar *lit = NULL;
|
xmlChar *lit = NULL;
|
||||||
xmlChar *lit2 = NULL;
|
xmlChar *lit2 = NULL;
|
||||||
|
|
||||||
|
@ -1454,6 +1372,12 @@ xsltCompileIdKeyPattern(xsltParserContextPtr ctxt, xmlChar *name,
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if ((aid) && (xmlStrEqual(name, (const xmlChar *)"id"))) {
|
if ((aid) && (xmlStrEqual(name, (const xmlChar *)"id"))) {
|
||||||
|
if (axis != 0) {
|
||||||
|
xsltTransformError(NULL, NULL, NULL,
|
||||||
|
"xsltCompileIdKeyPattern : NodeTest expected\n");
|
||||||
|
ctxt->error = 1;
|
||||||
|
return;
|
||||||
|
}
|
||||||
NEXT;
|
NEXT;
|
||||||
SKIP_BLANKS;
|
SKIP_BLANKS;
|
||||||
lit = xsltScanLiteral(ctxt);
|
lit = xsltScanLiteral(ctxt);
|
||||||
|
@ -1469,6 +1393,12 @@ xsltCompileIdKeyPattern(xsltParserContextPtr ctxt, xmlChar *name,
|
||||||
NEXT;
|
NEXT;
|
||||||
PUSH(XSLT_OP_ID, lit, NULL, novar);
|
PUSH(XSLT_OP_ID, lit, NULL, novar);
|
||||||
} else if ((aid) && (xmlStrEqual(name, (const xmlChar *)"key"))) {
|
} else if ((aid) && (xmlStrEqual(name, (const xmlChar *)"key"))) {
|
||||||
|
if (axis != 0) {
|
||||||
|
xsltTransformError(NULL, NULL, NULL,
|
||||||
|
"xsltCompileIdKeyPattern : NodeTest expected\n");
|
||||||
|
ctxt->error = 1;
|
||||||
|
return;
|
||||||
|
}
|
||||||
NEXT;
|
NEXT;
|
||||||
SKIP_BLANKS;
|
SKIP_BLANKS;
|
||||||
lit = xsltScanLiteral(ctxt);
|
lit = xsltScanLiteral(ctxt);
|
||||||
|
@ -1545,7 +1475,12 @@ xsltCompileIdKeyPattern(xsltParserContextPtr ctxt, xmlChar *name,
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
NEXT;
|
NEXT;
|
||||||
PUSH(XSLT_OP_NODE, NULL, NULL, novar);
|
if (axis == AXIS_ATTRIBUTE) {
|
||||||
|
PUSH(XSLT_OP_ATTR, NULL, NULL, novar);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
PUSH(XSLT_OP_NODE, NULL, NULL, novar);
|
||||||
|
}
|
||||||
} else if (aid) {
|
} else if (aid) {
|
||||||
xsltTransformError(NULL, NULL, NULL,
|
xsltTransformError(NULL, NULL, NULL,
|
||||||
"xsltCompileIdKeyPattern : expecting 'key' or 'id' or node type\n");
|
"xsltCompileIdKeyPattern : expecting 'key' or 'id' or node type\n");
|
||||||
|
@ -1590,51 +1525,25 @@ xsltCompileStepPattern(xsltParserContextPtr ctxt, xmlChar *token, int novar) {
|
||||||
const xmlChar *URI = NULL;
|
const xmlChar *URI = NULL;
|
||||||
xmlChar *URL = NULL;
|
xmlChar *URL = NULL;
|
||||||
int level;
|
int level;
|
||||||
|
xsltAxis axis = 0;
|
||||||
|
|
||||||
SKIP_BLANKS;
|
SKIP_BLANKS;
|
||||||
if ((token == NULL) && (CUR == '@')) {
|
if ((token == NULL) && (CUR == '@')) {
|
||||||
xmlChar *prefix = NULL;
|
|
||||||
|
|
||||||
NEXT;
|
NEXT;
|
||||||
if (CUR == '*') {
|
axis = AXIS_ATTRIBUTE;
|
||||||
NEXT;
|
|
||||||
PUSH(XSLT_OP_ATTR, NULL, NULL, novar);
|
|
||||||
goto parse_predicate;
|
|
||||||
}
|
|
||||||
token = xsltScanQName(ctxt, &prefix);
|
|
||||||
if (prefix != NULL) {
|
|
||||||
xmlNsPtr ns;
|
|
||||||
|
|
||||||
ns = xmlSearchNs(ctxt->doc, ctxt->elem, prefix);
|
|
||||||
if (ns == NULL) {
|
|
||||||
xsltTransformError(NULL, NULL, NULL,
|
|
||||||
"xsltCompileStepPattern : no namespace bound to prefix %s\n",
|
|
||||||
prefix);
|
|
||||||
} else {
|
|
||||||
URL = xmlStrdup(ns->href);
|
|
||||||
}
|
|
||||||
xmlFree(prefix);
|
|
||||||
}
|
|
||||||
if (token == NULL) {
|
|
||||||
if (CUR == '*') {
|
|
||||||
NEXT;
|
|
||||||
PUSH(XSLT_OP_ATTR, NULL, URL, novar);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
xsltTransformError(NULL, NULL, NULL,
|
|
||||||
"xsltCompileStepPattern : Name expected\n");
|
|
||||||
ctxt->error = 1;
|
|
||||||
goto error;
|
|
||||||
}
|
|
||||||
PUSH(XSLT_OP_ATTR, token, URL, novar);
|
|
||||||
goto parse_predicate;
|
|
||||||
}
|
}
|
||||||
|
parse_node_test:
|
||||||
if (token == NULL)
|
if (token == NULL)
|
||||||
token = xsltScanName(ctxt);
|
token = xsltScanNCName(ctxt);
|
||||||
if (token == NULL) {
|
if (token == NULL) {
|
||||||
if (CUR == '*') {
|
if (CUR == '*') {
|
||||||
NEXT;
|
NEXT;
|
||||||
PUSH(XSLT_OP_ALL, token, NULL, novar);
|
if (axis == AXIS_ATTRIBUTE) {
|
||||||
|
PUSH(XSLT_OP_ATTR, NULL, NULL, novar);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
PUSH(XSLT_OP_ALL, NULL, NULL, novar);
|
||||||
|
}
|
||||||
goto parse_predicate;
|
goto parse_predicate;
|
||||||
} else {
|
} else {
|
||||||
xsltTransformError(NULL, NULL, NULL,
|
xsltTransformError(NULL, NULL, NULL,
|
||||||
|
@ -1647,7 +1556,7 @@ xsltCompileStepPattern(xsltParserContextPtr ctxt, xmlChar *token, int novar) {
|
||||||
|
|
||||||
SKIP_BLANKS;
|
SKIP_BLANKS;
|
||||||
if (CUR == '(') {
|
if (CUR == '(') {
|
||||||
xsltCompileIdKeyPattern(ctxt, token, 0, novar);
|
xsltCompileIdKeyPattern(ctxt, token, 0, novar, axis);
|
||||||
if (ctxt->error)
|
if (ctxt->error)
|
||||||
goto error;
|
goto error;
|
||||||
} else if (CUR == ':') {
|
} else if (CUR == ':') {
|
||||||
|
@ -1659,12 +1568,13 @@ xsltCompileStepPattern(xsltParserContextPtr ctxt, xmlChar *token, int novar) {
|
||||||
/*
|
/*
|
||||||
* This is a namespace match
|
* This is a namespace match
|
||||||
*/
|
*/
|
||||||
token = xsltScanName(ctxt);
|
token = xsltScanNCName(ctxt);
|
||||||
ns = xmlSearchNs(ctxt->doc, ctxt->elem, prefix);
|
ns = xmlSearchNs(ctxt->doc, ctxt->elem, prefix);
|
||||||
if (ns == NULL) {
|
if (ns == NULL) {
|
||||||
xsltTransformError(NULL, NULL, NULL,
|
xsltTransformError(NULL, NULL, NULL,
|
||||||
"xsltCompileStepPattern : no namespace bound to prefix %s\n",
|
"xsltCompileStepPattern : no namespace bound to prefix %s\n",
|
||||||
prefix);
|
prefix);
|
||||||
|
xmlFree(prefix);
|
||||||
ctxt->error = 1;
|
ctxt->error = 1;
|
||||||
goto error;
|
goto error;
|
||||||
} else {
|
} else {
|
||||||
|
@ -1674,7 +1584,12 @@ xsltCompileStepPattern(xsltParserContextPtr ctxt, xmlChar *token, int novar) {
|
||||||
if (token == NULL) {
|
if (token == NULL) {
|
||||||
if (CUR == '*') {
|
if (CUR == '*') {
|
||||||
NEXT;
|
NEXT;
|
||||||
PUSH(XSLT_OP_NS, URL, NULL, novar);
|
if (axis == AXIS_ATTRIBUTE) {
|
||||||
|
PUSH(XSLT_OP_ATTR, NULL, URL, novar);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
PUSH(XSLT_OP_NS, URL, NULL, novar);
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
xsltTransformError(NULL, NULL, NULL,
|
xsltTransformError(NULL, NULL, NULL,
|
||||||
"xsltCompileStepPattern : Name expected\n");
|
"xsltCompileStepPattern : Name expected\n");
|
||||||
|
@ -1682,54 +1597,25 @@ xsltCompileStepPattern(xsltParserContextPtr ctxt, xmlChar *token, int novar) {
|
||||||
goto error;
|
goto error;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
PUSH(XSLT_OP_ELEM, token, URL, novar);
|
if (axis == AXIS_ATTRIBUTE) {
|
||||||
|
PUSH(XSLT_OP_ATTR, token, URL, novar);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
PUSH(XSLT_OP_ELEM, token, URL, novar);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
|
if (axis != 0) {
|
||||||
|
xsltTransformError(NULL, NULL, NULL,
|
||||||
|
"xsltCompileStepPattern : NodeTest expected\n");
|
||||||
|
ctxt->error = 1;
|
||||||
|
goto error;
|
||||||
|
}
|
||||||
NEXT;
|
NEXT;
|
||||||
if (xmlStrEqual(token, (const xmlChar *) "child")) {
|
if (xmlStrEqual(token, (const xmlChar *) "child")) {
|
||||||
xmlFree(token);
|
axis = AXIS_CHILD;
|
||||||
token = xsltScanName(ctxt);
|
|
||||||
if (token == NULL) {
|
|
||||||
if (CUR == '*') {
|
|
||||||
NEXT;
|
|
||||||
PUSH(XSLT_OP_ALL, token, NULL, novar);
|
|
||||||
goto parse_predicate;
|
|
||||||
} else {
|
|
||||||
xsltTransformError(NULL, NULL, NULL,
|
|
||||||
"xsltCompileStepPattern : QName expected\n");
|
|
||||||
ctxt->error = 1;
|
|
||||||
goto error;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
URI = xsltGetQNameURI(ctxt->elem, &token);
|
|
||||||
if (token == NULL) {
|
|
||||||
ctxt->error = 1;
|
|
||||||
goto error;
|
|
||||||
} else {
|
|
||||||
name = xmlStrdup(token);
|
|
||||||
if (URI != NULL)
|
|
||||||
URL = xmlStrdup(URI);
|
|
||||||
}
|
|
||||||
PUSH(XSLT_OP_CHILD, name, URL, novar);
|
|
||||||
} else if (xmlStrEqual(token, (const xmlChar *) "attribute")) {
|
} else if (xmlStrEqual(token, (const xmlChar *) "attribute")) {
|
||||||
xmlFree(token);
|
axis = AXIS_ATTRIBUTE;
|
||||||
token = xsltScanName(ctxt);
|
|
||||||
if (token == NULL) {
|
|
||||||
xsltTransformError(NULL, NULL, NULL,
|
|
||||||
"xsltCompileStepPattern : QName expected\n");
|
|
||||||
ctxt->error = 1;
|
|
||||||
goto error;
|
|
||||||
}
|
|
||||||
URI = xsltGetQNameURI(ctxt->elem, &token);
|
|
||||||
if (token == NULL) {
|
|
||||||
ctxt->error = 1;
|
|
||||||
goto error;
|
|
||||||
} else {
|
|
||||||
name = xmlStrdup(token);
|
|
||||||
if (URI != NULL)
|
|
||||||
URL = xmlStrdup(URI);
|
|
||||||
}
|
|
||||||
PUSH(XSLT_OP_ATTR, name, URL, novar);
|
|
||||||
} else {
|
} else {
|
||||||
xsltTransformError(NULL, NULL, NULL,
|
xsltTransformError(NULL, NULL, NULL,
|
||||||
"xsltCompileStepPattern : 'child' or 'attribute' expected\n");
|
"xsltCompileStepPattern : 'child' or 'attribute' expected\n");
|
||||||
|
@ -1737,10 +1623,10 @@ xsltCompileStepPattern(xsltParserContextPtr ctxt, xmlChar *token, int novar) {
|
||||||
goto error;
|
goto error;
|
||||||
}
|
}
|
||||||
xmlFree(token);
|
xmlFree(token);
|
||||||
|
SKIP_BLANKS;
|
||||||
|
token = xsltScanNCName(ctxt);
|
||||||
|
goto parse_node_test;
|
||||||
}
|
}
|
||||||
} else if (CUR == '*') {
|
|
||||||
NEXT;
|
|
||||||
PUSH(XSLT_OP_ALL, token, NULL, novar);
|
|
||||||
} else {
|
} else {
|
||||||
URI = xsltGetQNameURI(ctxt->elem, &token);
|
URI = xsltGetQNameURI(ctxt->elem, &token);
|
||||||
if (token == NULL) {
|
if (token == NULL) {
|
||||||
|
@ -1749,7 +1635,12 @@ xsltCompileStepPattern(xsltParserContextPtr ctxt, xmlChar *token, int novar) {
|
||||||
}
|
}
|
||||||
if (URI != NULL)
|
if (URI != NULL)
|
||||||
URL = xmlStrdup(URI);
|
URL = xmlStrdup(URI);
|
||||||
PUSH(XSLT_OP_ELEM, token, URL, novar);
|
if (axis == AXIS_ATTRIBUTE) {
|
||||||
|
PUSH(XSLT_OP_ATTR, token, URL, novar);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
PUSH(XSLT_OP_ELEM, token, URL, novar);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
parse_predicate:
|
parse_predicate:
|
||||||
SKIP_BLANKS;
|
SKIP_BLANKS;
|
||||||
|
@ -1886,7 +1777,7 @@ xsltCompileLocationPathPattern(xsltParserContextPtr ctxt, int novar) {
|
||||||
xsltCompileRelativePathPattern(ctxt, NULL, novar);
|
xsltCompileRelativePathPattern(ctxt, NULL, novar);
|
||||||
} else {
|
} else {
|
||||||
xmlChar *name;
|
xmlChar *name;
|
||||||
name = xsltScanName(ctxt);
|
name = xsltScanNCName(ctxt);
|
||||||
if (name == NULL) {
|
if (name == NULL) {
|
||||||
xsltTransformError(NULL, NULL, NULL,
|
xsltTransformError(NULL, NULL, NULL,
|
||||||
"xsltCompileLocationPathPattern : Name expected\n");
|
"xsltCompileLocationPathPattern : Name expected\n");
|
||||||
|
@ -1895,7 +1786,7 @@ xsltCompileLocationPathPattern(xsltParserContextPtr ctxt, int novar) {
|
||||||
}
|
}
|
||||||
SKIP_BLANKS;
|
SKIP_BLANKS;
|
||||||
if ((CUR == '(') && !xmlXPathIsNodeType(name)) {
|
if ((CUR == '(') && !xmlXPathIsNodeType(name)) {
|
||||||
xsltCompileIdKeyPattern(ctxt, name, 1, novar);
|
xsltCompileIdKeyPattern(ctxt, name, 1, novar, 0);
|
||||||
if ((CUR == '/') && (NXT(1) == '/')) {
|
if ((CUR == '/') && (NXT(1) == '/')) {
|
||||||
PUSH(XSLT_OP_ANCESTOR, NULL, NULL, novar);
|
PUSH(XSLT_OP_ANCESTOR, NULL, NULL, novar);
|
||||||
NEXT;
|
NEXT;
|
||||||
|
@ -2173,7 +2064,6 @@ xsltAddTemplate(xsltStylesheetPtr style, xsltTemplatePtr cur,
|
||||||
else
|
else
|
||||||
top = &(style->attrMatch);
|
top = &(style->attrMatch);
|
||||||
break;
|
break;
|
||||||
case XSLT_OP_CHILD:
|
|
||||||
case XSLT_OP_PARENT:
|
case XSLT_OP_PARENT:
|
||||||
case XSLT_OP_ANCESTOR:
|
case XSLT_OP_ANCESTOR:
|
||||||
top = &(style->elemMatch);
|
top = &(style->elemMatch);
|
||||||
|
|
12
reactos/dll/3rdparty/libxslt/preproc.c
vendored
12
reactos/dll/3rdparty/libxslt/preproc.c
vendored
|
@ -82,7 +82,7 @@ xsltCheckTopLevelElement(xsltStylesheetPtr style, xmlNodePtr inst, int err) {
|
||||||
}
|
}
|
||||||
return(0);
|
return(0);
|
||||||
}
|
}
|
||||||
if ((parent->ns == NULL) ||
|
if ((parent->ns == NULL) || (parent->type != XML_ELEMENT_NODE) ||
|
||||||
((parent->ns != inst->ns) &&
|
((parent->ns != inst->ns) &&
|
||||||
(!xmlStrEqual(parent->ns->href, inst->ns->href))) ||
|
(!xmlStrEqual(parent->ns->href, inst->ns->href))) ||
|
||||||
((!xmlStrEqual(parent->name, BAD_CAST "stylesheet")) &&
|
((!xmlStrEqual(parent->name, BAD_CAST "stylesheet")) &&
|
||||||
|
@ -391,6 +391,8 @@ xsltFreeStylePreComp(xsltStylePreCompPtr comp) {
|
||||||
break;
|
break;
|
||||||
case XSLT_FUNC_SORT: {
|
case XSLT_FUNC_SORT: {
|
||||||
xsltStyleItemSortPtr item = (xsltStyleItemSortPtr) comp;
|
xsltStyleItemSortPtr item = (xsltStyleItemSortPtr) comp;
|
||||||
|
if (item->locale != (xsltLocale)0)
|
||||||
|
xsltFreeLocale(item->locale);
|
||||||
if (item->comp != NULL)
|
if (item->comp != NULL)
|
||||||
xmlXPathFreeCompExpr(item->comp);
|
xmlXPathFreeCompExpr(item->comp);
|
||||||
}
|
}
|
||||||
|
@ -487,6 +489,8 @@ xsltFreeStylePreComp(xsltStylePreCompPtr comp) {
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
#else
|
#else
|
||||||
|
if (comp->locale != (xsltLocale)0)
|
||||||
|
xsltFreeLocale(comp->locale);
|
||||||
if (comp->comp != NULL)
|
if (comp->comp != NULL)
|
||||||
xmlXPathFreeCompExpr(comp->comp);
|
xmlXPathFreeCompExpr(comp->comp);
|
||||||
if (comp->nsList != NULL)
|
if (comp->nsList != NULL)
|
||||||
|
@ -728,6 +732,12 @@ xsltSortComp(xsltStylesheetPtr style, xmlNodePtr inst) {
|
||||||
comp->lang = xsltEvalStaticAttrValueTemplate(style, inst,
|
comp->lang = xsltEvalStaticAttrValueTemplate(style, inst,
|
||||||
(const xmlChar *)"lang",
|
(const xmlChar *)"lang",
|
||||||
NULL, &comp->has_lang);
|
NULL, &comp->has_lang);
|
||||||
|
if (comp->lang != NULL) {
|
||||||
|
comp->locale = xsltNewLocale(comp->lang);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
comp->locale = (xsltLocale)0;
|
||||||
|
}
|
||||||
|
|
||||||
comp->select = xsltGetCNsProp(style, inst,(const xmlChar *)"select", XSLT_NAMESPACE);
|
comp->select = xsltGetCNsProp(style, inst,(const xmlChar *)"select", XSLT_NAMESPACE);
|
||||||
if (comp->select == NULL) {
|
if (comp->select == NULL) {
|
||||||
|
|
5
reactos/dll/3rdparty/libxslt/security.c
vendored
5
reactos/dll/3rdparty/libxslt/security.c
vendored
|
@ -58,6 +58,7 @@
|
||||||
#include "xslt.h"
|
#include "xslt.h"
|
||||||
#include "xsltInternals.h"
|
#include "xsltInternals.h"
|
||||||
#include "xsltutils.h"
|
#include "xsltutils.h"
|
||||||
|
#include "extensions.h"
|
||||||
#include "security.h"
|
#include "security.h"
|
||||||
|
|
||||||
|
|
||||||
|
@ -88,6 +89,8 @@ xsltSecurityPrefsPtr
|
||||||
xsltNewSecurityPrefs(void) {
|
xsltNewSecurityPrefs(void) {
|
||||||
xsltSecurityPrefsPtr ret;
|
xsltSecurityPrefsPtr ret;
|
||||||
|
|
||||||
|
xsltInitGlobals();
|
||||||
|
|
||||||
ret = (xsltSecurityPrefsPtr) xmlMalloc(sizeof(xsltSecurityPrefs));
|
ret = (xsltSecurityPrefsPtr) xmlMalloc(sizeof(xsltSecurityPrefs));
|
||||||
if (ret == NULL) {
|
if (ret == NULL) {
|
||||||
xsltTransformError(NULL, NULL, NULL,
|
xsltTransformError(NULL, NULL, NULL,
|
||||||
|
@ -124,6 +127,7 @@ xsltFreeSecurityPrefs(xsltSecurityPrefsPtr sec) {
|
||||||
int
|
int
|
||||||
xsltSetSecurityPrefs(xsltSecurityPrefsPtr sec, xsltSecurityOption option,
|
xsltSetSecurityPrefs(xsltSecurityPrefsPtr sec, xsltSecurityOption option,
|
||||||
xsltSecurityCheck func) {
|
xsltSecurityCheck func) {
|
||||||
|
xsltInitGlobals();
|
||||||
if (sec == NULL)
|
if (sec == NULL)
|
||||||
return(-1);
|
return(-1);
|
||||||
switch (option) {
|
switch (option) {
|
||||||
|
@ -177,6 +181,7 @@ xsltGetSecurityPrefs(xsltSecurityPrefsPtr sec, xsltSecurityOption option) {
|
||||||
*/
|
*/
|
||||||
void
|
void
|
||||||
xsltSetDefaultSecurityPrefs(xsltSecurityPrefsPtr sec) {
|
xsltSetDefaultSecurityPrefs(xsltSecurityPrefsPtr sec) {
|
||||||
|
|
||||||
xsltDefaultSecurityPrefs = sec;
|
xsltDefaultSecurityPrefs = sec;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
15
reactos/dll/3rdparty/libxslt/templates.c
vendored
15
reactos/dll/3rdparty/libxslt/templates.c
vendored
|
@ -637,7 +637,7 @@ xsltAttrListTemplateProcess(xsltTransformContextPtr ctxt,
|
||||||
last = last->next;
|
last = last->next;
|
||||||
} else {
|
} else {
|
||||||
last = NULL;
|
last = NULL;
|
||||||
}
|
}
|
||||||
attr = attrs;
|
attr = attrs;
|
||||||
do {
|
do {
|
||||||
/*
|
/*
|
||||||
|
@ -719,20 +719,20 @@ xsltAttrListTemplateProcess(xsltTransformContextPtr ctxt,
|
||||||
copyNs = NULL;
|
copyNs = NULL;
|
||||||
}
|
}
|
||||||
copy->ns = copyNs;
|
copy->ns = copyNs;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Set the value.
|
* Set the value.
|
||||||
*/
|
*/
|
||||||
text = xmlNewText(NULL);
|
text = xmlNewText(NULL);
|
||||||
if (text != NULL) {
|
if (text != NULL) {
|
||||||
copy->last = copy->children = text;
|
copy->last = copy->children = text;
|
||||||
text->parent = (xmlNodePtr) copy;
|
text->parent = (xmlNodePtr) copy;
|
||||||
text->doc = copy->doc;
|
text->doc = copy->doc;
|
||||||
|
|
||||||
if (attr->psvi != NULL) {
|
if (attr->psvi != NULL) {
|
||||||
/*
|
/*
|
||||||
* Evaluate the Attribute Value Template.
|
* Evaluate the Attribute Value Template.
|
||||||
*/
|
*/
|
||||||
valueAVT = xsltEvalAVT(ctxt, attr->psvi, attr->parent);
|
valueAVT = xsltEvalAVT(ctxt, attr->psvi, attr->parent);
|
||||||
if (valueAVT == NULL) {
|
if (valueAVT == NULL) {
|
||||||
/*
|
/*
|
||||||
|
@ -743,7 +743,7 @@ xsltAttrListTemplateProcess(xsltTransformContextPtr ctxt,
|
||||||
xsltTransformError(ctxt, NULL, attr->parent,
|
xsltTransformError(ctxt, NULL, attr->parent,
|
||||||
"Internal error: Failed to evaluate the AVT "
|
"Internal error: Failed to evaluate the AVT "
|
||||||
"of attribute '{%s}%s'.\n",
|
"of attribute '{%s}%s'.\n",
|
||||||
attr->ns->href, attr->name);
|
attr->ns->href, attr->name);
|
||||||
} else {
|
} else {
|
||||||
xsltTransformError(ctxt, NULL, attr->parent,
|
xsltTransformError(ctxt, NULL, attr->parent,
|
||||||
"Internal error: Failed to evaluate the AVT "
|
"Internal error: Failed to evaluate the AVT "
|
||||||
|
@ -763,6 +763,9 @@ xsltAttrListTemplateProcess(xsltTransformContextPtr ctxt,
|
||||||
} else {
|
} else {
|
||||||
text->content = xmlStrdup(value);
|
text->content = xmlStrdup(value);
|
||||||
}
|
}
|
||||||
|
if ((copy != NULL) && (text != NULL) &&
|
||||||
|
(xmlIsID(copy->doc, copy->parent, copy)))
|
||||||
|
xmlAddID(NULL, copy->doc, text->content, copy);
|
||||||
}
|
}
|
||||||
|
|
||||||
next_attribute:
|
next_attribute:
|
||||||
|
|
586
reactos/dll/3rdparty/libxslt/transform.c
vendored
586
reactos/dll/3rdparty/libxslt/transform.c
vendored
File diff suppressed because it is too large
Load diff
66
reactos/dll/3rdparty/libxslt/transform.h
vendored
66
reactos/dll/3rdparty/libxslt/transform.h
vendored
|
@ -24,51 +24,55 @@ extern "C" {
|
||||||
/**
|
/**
|
||||||
* XInclude default processing.
|
* XInclude default processing.
|
||||||
*/
|
*/
|
||||||
XSLTPUBFUN void XSLTCALL
|
XSLTPUBFUN void XSLTCALL
|
||||||
xsltSetXIncludeDefault (int xinclude);
|
xsltSetXIncludeDefault (int xinclude);
|
||||||
XSLTPUBFUN int XSLTCALL
|
XSLTPUBFUN int XSLTCALL
|
||||||
xsltGetXIncludeDefault (void);
|
xsltGetXIncludeDefault (void);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Export context to users.
|
* Export context to users.
|
||||||
*/
|
*/
|
||||||
XSLTPUBFUN xsltTransformContextPtr XSLTCALL
|
XSLTPUBFUN xsltTransformContextPtr XSLTCALL
|
||||||
xsltNewTransformContext (xsltStylesheetPtr style,
|
xsltNewTransformContext (xsltStylesheetPtr style,
|
||||||
xmlDocPtr doc);
|
xmlDocPtr doc);
|
||||||
|
|
||||||
XSLTPUBFUN void XSLTCALL
|
XSLTPUBFUN void XSLTCALL
|
||||||
xsltFreeTransformContext(xsltTransformContextPtr ctxt);
|
xsltFreeTransformContext(xsltTransformContextPtr ctxt);
|
||||||
|
|
||||||
XSLTPUBFUN xmlDocPtr XSLTCALL
|
XSLTPUBFUN xmlDocPtr XSLTCALL
|
||||||
xsltApplyStylesheetUser (xsltStylesheetPtr style,
|
xsltApplyStylesheetUser (xsltStylesheetPtr style,
|
||||||
xmlDocPtr doc,
|
xmlDocPtr doc,
|
||||||
const char **params,
|
const char **params,
|
||||||
const char *output,
|
const char *output,
|
||||||
FILE * profile,
|
FILE * profile,
|
||||||
xsltTransformContextPtr userCtxt);
|
xsltTransformContextPtr userCtxt);
|
||||||
|
XSLTPUBFUN void XSLTCALL
|
||||||
|
xsltProcessOneNode (xsltTransformContextPtr ctxt,
|
||||||
|
xmlNodePtr node,
|
||||||
|
xsltStackElemPtr params);
|
||||||
/**
|
/**
|
||||||
* Private Interfaces.
|
* Private Interfaces.
|
||||||
*/
|
*/
|
||||||
XSLTPUBFUN void XSLTCALL
|
XSLTPUBFUN void XSLTCALL
|
||||||
xsltApplyStripSpaces (xsltTransformContextPtr ctxt,
|
xsltApplyStripSpaces (xsltTransformContextPtr ctxt,
|
||||||
xmlNodePtr node);
|
xmlNodePtr node);
|
||||||
XSLTPUBFUN xmlDocPtr XSLTCALL
|
XSLTPUBFUN xmlDocPtr XSLTCALL
|
||||||
xsltApplyStylesheet (xsltStylesheetPtr style,
|
xsltApplyStylesheet (xsltStylesheetPtr style,
|
||||||
xmlDocPtr doc,
|
xmlDocPtr doc,
|
||||||
const char **params);
|
const char **params);
|
||||||
XSLTPUBFUN xmlDocPtr XSLTCALL
|
XSLTPUBFUN xmlDocPtr XSLTCALL
|
||||||
xsltProfileStylesheet (xsltStylesheetPtr style,
|
xsltProfileStylesheet (xsltStylesheetPtr style,
|
||||||
xmlDocPtr doc,
|
xmlDocPtr doc,
|
||||||
const char **params,
|
const char **params,
|
||||||
FILE * output);
|
FILE * output);
|
||||||
XSLTPUBFUN int XSLTCALL
|
XSLTPUBFUN int XSLTCALL
|
||||||
xsltRunStylesheet (xsltStylesheetPtr style,
|
xsltRunStylesheet (xsltStylesheetPtr style,
|
||||||
xmlDocPtr doc,
|
xmlDocPtr doc,
|
||||||
const char **params,
|
const char **params,
|
||||||
const char *output,
|
const char *output,
|
||||||
xmlSAXHandlerPtr SAX,
|
xmlSAXHandlerPtr SAX,
|
||||||
xmlOutputBufferPtr IObuf);
|
xmlOutputBufferPtr IObuf);
|
||||||
XSLTPUBFUN int XSLTCALL
|
XSLTPUBFUN int XSLTCALL
|
||||||
xsltRunStylesheetUser (xsltStylesheetPtr style,
|
xsltRunStylesheetUser (xsltStylesheetPtr style,
|
||||||
xmlDocPtr doc,
|
xmlDocPtr doc,
|
||||||
const char **params,
|
const char **params,
|
||||||
|
@ -77,101 +81,101 @@ XSLTPUBFUN int XSLTCALL
|
||||||
xmlOutputBufferPtr IObuf,
|
xmlOutputBufferPtr IObuf,
|
||||||
FILE * profile,
|
FILE * profile,
|
||||||
xsltTransformContextPtr userCtxt);
|
xsltTransformContextPtr userCtxt);
|
||||||
XSLTPUBFUN void XSLTCALL
|
XSLTPUBFUN void XSLTCALL
|
||||||
xsltApplyOneTemplate (xsltTransformContextPtr ctxt,
|
xsltApplyOneTemplate (xsltTransformContextPtr ctxt,
|
||||||
xmlNodePtr node,
|
xmlNodePtr node,
|
||||||
xmlNodePtr list,
|
xmlNodePtr list,
|
||||||
xsltTemplatePtr templ,
|
xsltTemplatePtr templ,
|
||||||
xsltStackElemPtr params);
|
xsltStackElemPtr params);
|
||||||
XSLTPUBFUN void XSLTCALL
|
XSLTPUBFUN void XSLTCALL
|
||||||
xsltDocumentElem (xsltTransformContextPtr ctxt,
|
xsltDocumentElem (xsltTransformContextPtr ctxt,
|
||||||
xmlNodePtr node,
|
xmlNodePtr node,
|
||||||
xmlNodePtr inst,
|
xmlNodePtr inst,
|
||||||
xsltStylePreCompPtr comp);
|
xsltStylePreCompPtr comp);
|
||||||
XSLTPUBFUN void XSLTCALL
|
XSLTPUBFUN void XSLTCALL
|
||||||
xsltSort (xsltTransformContextPtr ctxt,
|
xsltSort (xsltTransformContextPtr ctxt,
|
||||||
xmlNodePtr node,
|
xmlNodePtr node,
|
||||||
xmlNodePtr inst,
|
xmlNodePtr inst,
|
||||||
xsltStylePreCompPtr comp);
|
xsltStylePreCompPtr comp);
|
||||||
XSLTPUBFUN void XSLTCALL
|
XSLTPUBFUN void XSLTCALL
|
||||||
xsltCopy (xsltTransformContextPtr ctxt,
|
xsltCopy (xsltTransformContextPtr ctxt,
|
||||||
xmlNodePtr node,
|
xmlNodePtr node,
|
||||||
xmlNodePtr inst,
|
xmlNodePtr inst,
|
||||||
xsltStylePreCompPtr comp);
|
xsltStylePreCompPtr comp);
|
||||||
XSLTPUBFUN void XSLTCALL
|
XSLTPUBFUN void XSLTCALL
|
||||||
xsltText (xsltTransformContextPtr ctxt,
|
xsltText (xsltTransformContextPtr ctxt,
|
||||||
xmlNodePtr node,
|
xmlNodePtr node,
|
||||||
xmlNodePtr inst,
|
xmlNodePtr inst,
|
||||||
xsltStylePreCompPtr comp);
|
xsltStylePreCompPtr comp);
|
||||||
XSLTPUBFUN void XSLTCALL
|
XSLTPUBFUN void XSLTCALL
|
||||||
xsltElement (xsltTransformContextPtr ctxt,
|
xsltElement (xsltTransformContextPtr ctxt,
|
||||||
xmlNodePtr node,
|
xmlNodePtr node,
|
||||||
xmlNodePtr inst,
|
xmlNodePtr inst,
|
||||||
xsltStylePreCompPtr comp);
|
xsltStylePreCompPtr comp);
|
||||||
XSLTPUBFUN void XSLTCALL
|
XSLTPUBFUN void XSLTCALL
|
||||||
xsltComment (xsltTransformContextPtr ctxt,
|
xsltComment (xsltTransformContextPtr ctxt,
|
||||||
xmlNodePtr node,
|
xmlNodePtr node,
|
||||||
xmlNodePtr inst,
|
xmlNodePtr inst,
|
||||||
xsltStylePreCompPtr comp);
|
xsltStylePreCompPtr comp);
|
||||||
XSLTPUBFUN void XSLTCALL
|
XSLTPUBFUN void XSLTCALL
|
||||||
xsltAttribute (xsltTransformContextPtr ctxt,
|
xsltAttribute (xsltTransformContextPtr ctxt,
|
||||||
xmlNodePtr node,
|
xmlNodePtr node,
|
||||||
xmlNodePtr inst,
|
xmlNodePtr inst,
|
||||||
xsltStylePreCompPtr comp);
|
xsltStylePreCompPtr comp);
|
||||||
XSLTPUBFUN void XSLTCALL
|
XSLTPUBFUN void XSLTCALL
|
||||||
xsltProcessingInstruction(xsltTransformContextPtr ctxt,
|
xsltProcessingInstruction(xsltTransformContextPtr ctxt,
|
||||||
xmlNodePtr node,
|
xmlNodePtr node,
|
||||||
xmlNodePtr inst,
|
xmlNodePtr inst,
|
||||||
xsltStylePreCompPtr comp);
|
xsltStylePreCompPtr comp);
|
||||||
XSLTPUBFUN void XSLTCALL
|
XSLTPUBFUN void XSLTCALL
|
||||||
xsltCopyOf (xsltTransformContextPtr ctxt,
|
xsltCopyOf (xsltTransformContextPtr ctxt,
|
||||||
xmlNodePtr node,
|
xmlNodePtr node,
|
||||||
xmlNodePtr inst,
|
xmlNodePtr inst,
|
||||||
xsltStylePreCompPtr comp);
|
xsltStylePreCompPtr comp);
|
||||||
XSLTPUBFUN void XSLTCALL
|
XSLTPUBFUN void XSLTCALL
|
||||||
xsltValueOf (xsltTransformContextPtr ctxt,
|
xsltValueOf (xsltTransformContextPtr ctxt,
|
||||||
xmlNodePtr node,
|
xmlNodePtr node,
|
||||||
xmlNodePtr inst,
|
xmlNodePtr inst,
|
||||||
xsltStylePreCompPtr comp);
|
xsltStylePreCompPtr comp);
|
||||||
XSLTPUBFUN void XSLTCALL
|
XSLTPUBFUN void XSLTCALL
|
||||||
xsltNumber (xsltTransformContextPtr ctxt,
|
xsltNumber (xsltTransformContextPtr ctxt,
|
||||||
xmlNodePtr node,
|
xmlNodePtr node,
|
||||||
xmlNodePtr inst,
|
xmlNodePtr inst,
|
||||||
xsltStylePreCompPtr comp);
|
xsltStylePreCompPtr comp);
|
||||||
XSLTPUBFUN void XSLTCALL
|
XSLTPUBFUN void XSLTCALL
|
||||||
xsltApplyImports (xsltTransformContextPtr ctxt,
|
xsltApplyImports (xsltTransformContextPtr ctxt,
|
||||||
xmlNodePtr node,
|
xmlNodePtr node,
|
||||||
xmlNodePtr inst,
|
xmlNodePtr inst,
|
||||||
xsltStylePreCompPtr comp);
|
xsltStylePreCompPtr comp);
|
||||||
XSLTPUBFUN void XSLTCALL
|
XSLTPUBFUN void XSLTCALL
|
||||||
xsltCallTemplate (xsltTransformContextPtr ctxt,
|
xsltCallTemplate (xsltTransformContextPtr ctxt,
|
||||||
xmlNodePtr node,
|
xmlNodePtr node,
|
||||||
xmlNodePtr inst,
|
xmlNodePtr inst,
|
||||||
xsltStylePreCompPtr comp);
|
xsltStylePreCompPtr comp);
|
||||||
XSLTPUBFUN void XSLTCALL
|
XSLTPUBFUN void XSLTCALL
|
||||||
xsltApplyTemplates (xsltTransformContextPtr ctxt,
|
xsltApplyTemplates (xsltTransformContextPtr ctxt,
|
||||||
xmlNodePtr node,
|
xmlNodePtr node,
|
||||||
xmlNodePtr inst,
|
xmlNodePtr inst,
|
||||||
xsltStylePreCompPtr comp);
|
xsltStylePreCompPtr comp);
|
||||||
XSLTPUBFUN void XSLTCALL
|
XSLTPUBFUN void XSLTCALL
|
||||||
xsltChoose (xsltTransformContextPtr ctxt,
|
xsltChoose (xsltTransformContextPtr ctxt,
|
||||||
xmlNodePtr node,
|
xmlNodePtr node,
|
||||||
xmlNodePtr inst,
|
xmlNodePtr inst,
|
||||||
xsltStylePreCompPtr comp);
|
xsltStylePreCompPtr comp);
|
||||||
XSLTPUBFUN void XSLTCALL
|
XSLTPUBFUN void XSLTCALL
|
||||||
xsltIf (xsltTransformContextPtr ctxt,
|
xsltIf (xsltTransformContextPtr ctxt,
|
||||||
xmlNodePtr node,
|
xmlNodePtr node,
|
||||||
xmlNodePtr inst,
|
xmlNodePtr inst,
|
||||||
xsltStylePreCompPtr comp);
|
xsltStylePreCompPtr comp);
|
||||||
XSLTPUBFUN void XSLTCALL
|
XSLTPUBFUN void XSLTCALL
|
||||||
xsltForEach (xsltTransformContextPtr ctxt,
|
xsltForEach (xsltTransformContextPtr ctxt,
|
||||||
xmlNodePtr node,
|
xmlNodePtr node,
|
||||||
xmlNodePtr inst,
|
xmlNodePtr inst,
|
||||||
xsltStylePreCompPtr comp);
|
xsltStylePreCompPtr comp);
|
||||||
XSLTPUBFUN void XSLTCALL
|
XSLTPUBFUN void XSLTCALL
|
||||||
xsltRegisterAllElement (xsltTransformContextPtr ctxt);
|
xsltRegisterAllElement (xsltTransformContextPtr ctxt);
|
||||||
|
|
||||||
XSLTPUBFUN xmlNodePtr XSLTCALL
|
XSLTPUBFUN xmlNodePtr XSLTCALL
|
||||||
xsltCopyTextString (xsltTransformContextPtr ctxt,
|
xsltCopyTextString (xsltTransformContextPtr ctxt,
|
||||||
xmlNodePtr target,
|
xmlNodePtr target,
|
||||||
const xmlChar *string,
|
const xmlChar *string,
|
||||||
|
@ -189,7 +193,7 @@ XSLTPUBFUN int XSLTCALL
|
||||||
/*
|
/*
|
||||||
* Hook for the debugger if activated.
|
* Hook for the debugger if activated.
|
||||||
*/
|
*/
|
||||||
XSLTPUBFUN void XSLTCALL
|
XSLTPUBFUN void XSLTCALL
|
||||||
xslHandleDebugger (xmlNodePtr cur,
|
xslHandleDebugger (xmlNodePtr cur,
|
||||||
xmlNodePtr node,
|
xmlNodePtr node,
|
||||||
xsltTemplatePtr templ,
|
xsltTemplatePtr templ,
|
||||||
|
|
2
reactos/dll/3rdparty/libxslt/trio.h
vendored
2
reactos/dll/3rdparty/libxslt/trio.h
vendored
|
@ -1,6 +1,6 @@
|
||||||
/*************************************************************************
|
/*************************************************************************
|
||||||
*
|
*
|
||||||
* $Id: trio.h 897 2003-04-07 12:41:56Z veillard $
|
* $Id$
|
||||||
*
|
*
|
||||||
* Copyright (C) 1998 Bjorn Reese and Daniel Stenberg.
|
* Copyright (C) 1998 Bjorn Reese and Daniel Stenberg.
|
||||||
*
|
*
|
||||||
|
|
2
reactos/dll/3rdparty/libxslt/triodef.h
vendored
2
reactos/dll/3rdparty/libxslt/triodef.h
vendored
|
@ -1,6 +1,6 @@
|
||||||
/*************************************************************************
|
/*************************************************************************
|
||||||
*
|
*
|
||||||
* $Id: triodef.h 912 2003-04-26 12:06:36Z veillard $
|
* $Id$
|
||||||
*
|
*
|
||||||
* Copyright (C) 2001 Bjorn Reese <breese@users.sourceforge.net>
|
* Copyright (C) 2001 Bjorn Reese <breese@users.sourceforge.net>
|
||||||
*
|
*
|
||||||
|
|
4
reactos/dll/3rdparty/libxslt/variables.c
vendored
4
reactos/dll/3rdparty/libxslt/variables.c
vendored
|
@ -43,6 +43,10 @@ const xmlChar *xsltDocFragFake = (const xmlChar *) " fake node libxslt";
|
||||||
const xmlChar *xsltComputingGlobalVarMarker =
|
const xmlChar *xsltComputingGlobalVarMarker =
|
||||||
(const xmlChar *) " var/param being computed";
|
(const xmlChar *) " var/param being computed";
|
||||||
|
|
||||||
|
#define XSLT_VAR_GLOBAL 1<<0
|
||||||
|
#define XSLT_VAR_IN_SELECT 1<<1
|
||||||
|
#define XSLT_TCTXT_VARIABLE(c) ((xsltStackElemPtr) (c)->contextVariable)
|
||||||
|
|
||||||
/************************************************************************
|
/************************************************************************
|
||||||
* *
|
* *
|
||||||
* Result Value Tree (Result Tree Fragment) interfaces *
|
* Result Value Tree (Result Tree Fragment) interfaces *
|
||||||
|
|
112
reactos/dll/3rdparty/libxslt/xslt.c
vendored
112
reactos/dll/3rdparty/libxslt/xslt.c
vendored
|
@ -56,6 +56,10 @@ const int xsltLibxmlVersion = LIBXML_VERSION;
|
||||||
|
|
||||||
const xmlChar *xsltConstNamespaceNameXSLT = (const xmlChar *) XSLT_NAMESPACE;
|
const xmlChar *xsltConstNamespaceNameXSLT = (const xmlChar *) XSLT_NAMESPACE;
|
||||||
|
|
||||||
|
#define XSLT_ELEMENT_CATEGORY_XSLT 0
|
||||||
|
#define XSLT_ELEMENT_CATEGORY_EXTENSION 1
|
||||||
|
#define XSLT_ELEMENT_CATEGORY_LRE 2
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* xsltLiteralResultMarker:
|
* xsltLiteralResultMarker:
|
||||||
* Marker for Literal result elements, in order to avoid multiple attempts
|
* Marker for Literal result elements, in order to avoid multiple attempts
|
||||||
|
@ -83,6 +87,9 @@ const xmlChar *xsltXSLTAttrMarker = (const xmlChar *) "LRE XSLT Attr";
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#ifdef XSLT_LOCALE_WINAPI
|
||||||
|
extern xmlRMutexPtr xsltLocaleMutex;
|
||||||
|
#endif
|
||||||
/*
|
/*
|
||||||
* Harmless but avoiding a problem when compiling against a
|
* Harmless but avoiding a problem when compiling against a
|
||||||
* libxml <= 2.3.11 without LIBXML_DEBUG_ENABLED
|
* libxml <= 2.3.11 without LIBXML_DEBUG_ENABLED
|
||||||
|
@ -141,11 +148,14 @@ xsltParseContentError(xsltStylesheetPtr style,
|
||||||
*
|
*
|
||||||
* Push an excluded namespace name on the stack
|
* Push an excluded namespace name on the stack
|
||||||
*
|
*
|
||||||
* Returns the new index in the stack or 0 in case of error
|
* Returns the new index in the stack or -1 if already present or
|
||||||
|
* in case of error
|
||||||
*/
|
*/
|
||||||
static int
|
static int
|
||||||
exclPrefixPush(xsltStylesheetPtr style, xmlChar * value)
|
exclPrefixPush(xsltStylesheetPtr style, xmlChar * value)
|
||||||
{
|
{
|
||||||
|
int i;
|
||||||
|
|
||||||
if (style->exclPrefixMax == 0) {
|
if (style->exclPrefixMax == 0) {
|
||||||
style->exclPrefixMax = 4;
|
style->exclPrefixMax = 4;
|
||||||
style->exclPrefixTab =
|
style->exclPrefixTab =
|
||||||
|
@ -153,9 +163,14 @@ exclPrefixPush(xsltStylesheetPtr style, xmlChar * value)
|
||||||
sizeof(style->exclPrefixTab[0]));
|
sizeof(style->exclPrefixTab[0]));
|
||||||
if (style->exclPrefixTab == NULL) {
|
if (style->exclPrefixTab == NULL) {
|
||||||
xmlGenericError(xmlGenericErrorContext, "malloc failed !\n");
|
xmlGenericError(xmlGenericErrorContext, "malloc failed !\n");
|
||||||
return (0);
|
return (-1);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
/* do not push duplicates */
|
||||||
|
for (i = 0;i < style->exclPrefixNr;i++) {
|
||||||
|
if (xmlStrEqual(style->exclPrefixTab[i], value))
|
||||||
|
return(-1);
|
||||||
|
}
|
||||||
if (style->exclPrefixNr >= style->exclPrefixMax) {
|
if (style->exclPrefixNr >= style->exclPrefixMax) {
|
||||||
style->exclPrefixMax *= 2;
|
style->exclPrefixMax *= 2;
|
||||||
style->exclPrefixTab =
|
style->exclPrefixTab =
|
||||||
|
@ -164,7 +179,7 @@ exclPrefixPush(xsltStylesheetPtr style, xmlChar * value)
|
||||||
sizeof(style->exclPrefixTab[0]));
|
sizeof(style->exclPrefixTab[0]));
|
||||||
if (style->exclPrefixTab == NULL) {
|
if (style->exclPrefixTab == NULL) {
|
||||||
xmlGenericError(xmlGenericErrorContext, "realloc failed !\n");
|
xmlGenericError(xmlGenericErrorContext, "realloc failed !\n");
|
||||||
return (0);
|
return (-1);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
style->exclPrefixTab[style->exclPrefixNr] = value;
|
style->exclPrefixTab[style->exclPrefixNr] = value;
|
||||||
|
@ -214,6 +229,9 @@ void
|
||||||
xsltInit (void) {
|
xsltInit (void) {
|
||||||
if (initialized == 0) {
|
if (initialized == 0) {
|
||||||
initialized = 1;
|
initialized = 1;
|
||||||
|
#ifdef XSLT_LOCALE_WINAPI
|
||||||
|
xsltLocaleMutex = xmlNewRMutex();
|
||||||
|
#endif
|
||||||
xsltRegisterAllExtras();
|
xsltRegisterAllExtras();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1704,12 +1722,13 @@ xsltParseStylesheetExcludePrefix(xsltStylesheetPtr style, xmlNodePtr cur,
|
||||||
prefix);
|
prefix);
|
||||||
if (style != NULL) style->warnings++;
|
if (style != NULL) style->warnings++;
|
||||||
} else {
|
} else {
|
||||||
|
if (exclPrefixPush(style, (xmlChar *) ns->href) >= 0) {
|
||||||
#ifdef WITH_XSLT_DEBUG_PARSING
|
#ifdef WITH_XSLT_DEBUG_PARSING
|
||||||
xsltGenericDebug(xsltGenericDebugContext,
|
xsltGenericDebug(xsltGenericDebugContext,
|
||||||
"exclude result prefix %s\n", prefix);
|
"exclude result prefix %s\n", prefix);
|
||||||
#endif
|
#endif
|
||||||
exclPrefixPush(style, (xmlChar *) ns->href);
|
nb++;
|
||||||
nb++;
|
}
|
||||||
}
|
}
|
||||||
xmlFree(prefix);
|
xmlFree(prefix);
|
||||||
}
|
}
|
||||||
|
@ -4921,13 +4940,14 @@ xsltParseTemplateContent(xsltStylesheetPtr style, xmlNodePtr templ) {
|
||||||
* okay this is an extension element compile it too
|
* okay this is an extension element compile it too
|
||||||
*/
|
*/
|
||||||
xsltStylePreCompute(style, cur);
|
xsltStylePreCompute(style, cur);
|
||||||
} else {
|
}
|
||||||
|
else if (cur->type == XML_ELEMENT_NODE)
|
||||||
|
{
|
||||||
/*
|
/*
|
||||||
* This is an element which will be output as part of the
|
* This is an element which will be output as part of the
|
||||||
* template exectution, precompile AVT if found.
|
* template exectution, precompile AVT if found.
|
||||||
*/
|
*/
|
||||||
if ((cur->ns == NULL) && (style->defaultAlias != NULL) &&
|
if ((cur->ns == NULL) && (style->defaultAlias != NULL)) {
|
||||||
(cur->type == XML_ELEMENT_NODE)) {
|
|
||||||
cur->ns = xmlSearchNsByHref(cur->doc, cur,
|
cur->ns = xmlSearchNsByHref(cur->doc, cur,
|
||||||
style->defaultAlias);
|
style->defaultAlias);
|
||||||
}
|
}
|
||||||
|
@ -6233,6 +6253,15 @@ xsltParseSimplifiedStylesheetTree(xsltCompilerCtxtPtr cctxt,
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef XSLT_REFACTORED_XSLT_NSCOMP
|
#ifdef XSLT_REFACTORED_XSLT_NSCOMP
|
||||||
|
/**
|
||||||
|
* xsltRestoreDocumentNamespaces:
|
||||||
|
* @ns: map of namespaces
|
||||||
|
* @doc: the document
|
||||||
|
*
|
||||||
|
* Restore the namespaces for the document
|
||||||
|
*
|
||||||
|
* Returns 0 in case of success, -1 in case of failure
|
||||||
|
*/
|
||||||
int
|
int
|
||||||
xsltRestoreDocumentNamespaces(xsltNsMapPtr ns, xmlDocPtr doc)
|
xsltRestoreDocumentNamespaces(xsltNsMapPtr ns, xmlDocPtr doc)
|
||||||
{
|
{
|
||||||
|
@ -6274,6 +6303,7 @@ xsltParseStylesheetProcess(xsltStylesheetPtr style, xmlDocPtr doc)
|
||||||
xmlNodePtr cur;
|
xmlNodePtr cur;
|
||||||
int oldIsSimplifiedStylesheet;
|
int oldIsSimplifiedStylesheet;
|
||||||
|
|
||||||
|
xsltInitGlobals();
|
||||||
|
|
||||||
if ((style == NULL) || (doc == NULL))
|
if ((style == NULL) || (doc == NULL))
|
||||||
return(NULL);
|
return(NULL);
|
||||||
|
@ -6326,10 +6356,25 @@ xsltParseStylesheetProcess(xsltStylesheetPtr style, xmlDocPtr doc)
|
||||||
|
|
||||||
#else /* XSLT_REFACTORED */
|
#else /* XSLT_REFACTORED */
|
||||||
|
|
||||||
|
/**
|
||||||
|
* xsltParseStylesheetProcess:
|
||||||
|
* @ret: the XSLT stylesheet (the current stylesheet-level)
|
||||||
|
* @doc: and xmlDoc parsed XML
|
||||||
|
*
|
||||||
|
* Parses an XSLT stylesheet, adding the associated structures.
|
||||||
|
* Called by:
|
||||||
|
* xsltParseStylesheetImportedDoc() (xslt.c)
|
||||||
|
* xsltParseStylesheetInclude() (imports.c)
|
||||||
|
*
|
||||||
|
* Returns the value of the @style parameter if everything
|
||||||
|
* went right, NULL if something went amiss.
|
||||||
|
*/
|
||||||
xsltStylesheetPtr
|
xsltStylesheetPtr
|
||||||
xsltParseStylesheetProcess(xsltStylesheetPtr ret, xmlDocPtr doc) {
|
xsltParseStylesheetProcess(xsltStylesheetPtr ret, xmlDocPtr doc) {
|
||||||
xmlNodePtr cur;
|
xmlNodePtr cur;
|
||||||
|
|
||||||
|
xsltInitGlobals();
|
||||||
|
|
||||||
if (doc == NULL)
|
if (doc == NULL)
|
||||||
return(NULL);
|
return(NULL);
|
||||||
if (ret == NULL)
|
if (ret == NULL)
|
||||||
|
@ -6616,6 +6661,8 @@ xsltStylesheetPtr
|
||||||
xsltParseStylesheetDoc(xmlDocPtr doc) {
|
xsltParseStylesheetDoc(xmlDocPtr doc) {
|
||||||
xsltStylesheetPtr ret;
|
xsltStylesheetPtr ret;
|
||||||
|
|
||||||
|
xsltInitGlobals();
|
||||||
|
|
||||||
ret = xsltParseStylesheetImportedDoc(doc, NULL);
|
ret = xsltParseStylesheetImportedDoc(doc, NULL);
|
||||||
if (ret == NULL)
|
if (ret == NULL)
|
||||||
return(NULL);
|
return(NULL);
|
||||||
|
@ -6650,6 +6697,7 @@ xsltParseStylesheetFile(const xmlChar* filename) {
|
||||||
xsltStylesheetPtr ret;
|
xsltStylesheetPtr ret;
|
||||||
xmlDocPtr doc;
|
xmlDocPtr doc;
|
||||||
|
|
||||||
|
xsltInitGlobals();
|
||||||
|
|
||||||
if (filename == NULL)
|
if (filename == NULL)
|
||||||
return(NULL);
|
return(NULL);
|
||||||
|
@ -6811,6 +6859,8 @@ xsltLoadStylesheetPI(xmlDocPtr doc) {
|
||||||
xmlChar *href = NULL;
|
xmlChar *href = NULL;
|
||||||
xmlURIPtr URI;
|
xmlURIPtr URI;
|
||||||
|
|
||||||
|
xsltInitGlobals();
|
||||||
|
|
||||||
if (doc == NULL)
|
if (doc == NULL)
|
||||||
return(NULL);
|
return(NULL);
|
||||||
|
|
||||||
|
@ -6862,8 +6912,14 @@ xsltLoadStylesheetPI(xmlDocPtr doc) {
|
||||||
"xml-stylesheet : no ID %s found\n", URI->fragment);
|
"xml-stylesheet : no ID %s found\n", URI->fragment);
|
||||||
} else {
|
} else {
|
||||||
xmlDocPtr fake;
|
xmlDocPtr fake;
|
||||||
xmlNodePtr subtree;
|
xmlNodePtr subtree, newtree;
|
||||||
|
xmlNsPtr ns;
|
||||||
|
|
||||||
|
#ifdef WITH_XSLT_DEBUG
|
||||||
|
xsltGenericDebug(xsltGenericDebugContext,
|
||||||
|
"creating new document from %s for embedded stylesheet\n",
|
||||||
|
doc->URL);
|
||||||
|
#endif
|
||||||
/*
|
/*
|
||||||
* move the subtree in a new document passed to
|
* move the subtree in a new document passed to
|
||||||
* the stylesheet analyzer
|
* the stylesheet analyzer
|
||||||
|
@ -6871,20 +6927,38 @@ xsltLoadStylesheetPI(xmlDocPtr doc) {
|
||||||
subtree = ID->parent;
|
subtree = ID->parent;
|
||||||
fake = xmlNewDoc(NULL);
|
fake = xmlNewDoc(NULL);
|
||||||
if (fake != NULL) {
|
if (fake != NULL) {
|
||||||
/*
|
/*
|
||||||
* the dictionary should be shared since nodes are
|
* Should the dictionary still be shared even though
|
||||||
* moved over.
|
* the nodes are being copied rather than moved?
|
||||||
*/
|
*/
|
||||||
fake->dict = doc->dict;
|
fake->dict = doc->dict;
|
||||||
xmlDictReference(doc->dict);
|
xmlDictReference(doc->dict);
|
||||||
#ifdef WITH_XSLT_DEBUG
|
#ifdef WITH_XSLT_DEBUG
|
||||||
xsltGenericDebug(xsltGenericDebugContext,
|
xsltGenericDebug(xsltGenericDebugContext,
|
||||||
"reusing dictionary from %s for stylesheet\n",
|
"reusing dictionary from %s for embedded stylesheet\n",
|
||||||
doc->URL);
|
doc->URL);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
xmlUnlinkNode(subtree);
|
newtree = xmlDocCopyNode(subtree, fake, 1);
|
||||||
xmlAddChild((xmlNodePtr) fake, subtree);
|
|
||||||
|
fake->URL = xmlNodeGetBase(doc, subtree->parent);
|
||||||
|
#ifdef WITH_XSLT_DEBUG
|
||||||
|
xsltGenericDebug(xsltGenericDebugContext,
|
||||||
|
"set base URI for embedded stylesheet as %s\n",
|
||||||
|
fake->URL);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Add all namespaces in scope of embedded stylesheet to
|
||||||
|
* root element of newly created stylesheet document
|
||||||
|
*/
|
||||||
|
while ((subtree = subtree->parent) != (xmlNodePtr)doc) {
|
||||||
|
for (ns = subtree->ns; ns; ns = ns->next) {
|
||||||
|
xmlNewNs(newtree, ns->href, ns->prefix);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
xmlAddChild((xmlNodePtr)fake, newtree);
|
||||||
ret = xsltParseStylesheetDoc(fake);
|
ret = xsltParseStylesheetDoc(fake);
|
||||||
if (ret == NULL)
|
if (ret == NULL)
|
||||||
xmlFreeDoc(fake);
|
xmlFreeDoc(fake);
|
||||||
|
|
11
reactos/dll/3rdparty/libxslt/xsltInternals.h
vendored
11
reactos/dll/3rdparty/libxslt/xsltInternals.h
vendored
|
@ -21,6 +21,7 @@
|
||||||
#include <libxml/xmlstring.h>
|
#include <libxml/xmlstring.h>
|
||||||
#include <libxslt/xslt.h>
|
#include <libxslt/xslt.h>
|
||||||
#include "xsltexports.h"
|
#include "xsltexports.h"
|
||||||
|
#include "xsltlocale.h"
|
||||||
#include "numbersInternals.h"
|
#include "numbersInternals.h"
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
|
@ -1045,6 +1046,7 @@ struct _xsltStyleItemSort {
|
||||||
int descending; /* sort */
|
int descending; /* sort */
|
||||||
const xmlChar *lang; /* sort */
|
const xmlChar *lang; /* sort */
|
||||||
int has_lang; /* sort */
|
int has_lang; /* sort */
|
||||||
|
xsltLocale locale; /* sort */
|
||||||
const xmlChar *case_order; /* sort */
|
const xmlChar *case_order; /* sort */
|
||||||
int lower_first; /* sort */
|
int lower_first; /* sort */
|
||||||
|
|
||||||
|
@ -1246,10 +1248,6 @@ struct _xsltVarInfo {
|
||||||
const xmlChar *nsName;
|
const xmlChar *nsName;
|
||||||
};
|
};
|
||||||
|
|
||||||
#define XSLT_ELEMENT_CATEGORY_XSLT 0
|
|
||||||
#define XSLT_ELEMENT_CATEGORY_EXTENSION 1
|
|
||||||
#define XSLT_ELEMENT_CATEGORY_LRE 2
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* xsltCompilerNodeInfo:
|
* xsltCompilerNodeInfo:
|
||||||
*
|
*
|
||||||
|
@ -1381,6 +1379,7 @@ struct _xsltStylePreComp {
|
||||||
int descending; /* sort */
|
int descending; /* sort */
|
||||||
const xmlChar *lang; /* sort */
|
const xmlChar *lang; /* sort */
|
||||||
int has_lang; /* sort */
|
int has_lang; /* sort */
|
||||||
|
xsltLocale locale; /* sort */
|
||||||
const xmlChar *case_order; /* sort */
|
const xmlChar *case_order; /* sort */
|
||||||
int lower_first; /* sort */
|
int lower_first; /* sort */
|
||||||
|
|
||||||
|
@ -1417,9 +1416,6 @@ struct _xsltStylePreComp {
|
||||||
#endif /* XSLT_REFACTORED */
|
#endif /* XSLT_REFACTORED */
|
||||||
|
|
||||||
|
|
||||||
#define XSLT_VAR_GLOBAL 1<<0
|
|
||||||
#define XSLT_VAR_IN_SELECT 1<<1
|
|
||||||
#define XSLT_TCTXT_VARIABLE(c) ((xsltStackElemPtr) (c)->contextVariable)
|
|
||||||
/*
|
/*
|
||||||
* The in-memory structure corresponding to an XSLT Variable
|
* The in-memory structure corresponding to an XSLT Variable
|
||||||
* or Param.
|
* or Param.
|
||||||
|
@ -1778,6 +1774,7 @@ struct _xsltTransformContext {
|
||||||
exits */
|
exits */
|
||||||
xmlDocPtr localRVTBase;
|
xmlDocPtr localRVTBase;
|
||||||
int keyInitLevel; /* Needed to catch recursive keys issues */
|
int keyInitLevel; /* Needed to catch recursive keys issues */
|
||||||
|
int funcLevel; /* Needed to catch recursive functions issues */
|
||||||
};
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
23
reactos/dll/3rdparty/libxslt/xsltconfig.h
vendored
23
reactos/dll/3rdparty/libxslt/xsltconfig.h
vendored
|
@ -20,28 +20,28 @@ extern "C" {
|
||||||
*
|
*
|
||||||
* the version string like "1.2.3"
|
* the version string like "1.2.3"
|
||||||
*/
|
*/
|
||||||
#define LIBXSLT_DOTTED_VERSION "1.1.24"
|
#define LIBXSLT_DOTTED_VERSION "1.1.26"
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* LIBXSLT_VERSION:
|
* LIBXSLT_VERSION:
|
||||||
*
|
*
|
||||||
* the version number: 1.2.3 value is 10203
|
* the version number: 1.2.3 value is 10203
|
||||||
*/
|
*/
|
||||||
#define LIBXSLT_VERSION 10124
|
#define LIBXSLT_VERSION 10126
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* LIBXSLT_VERSION_STRING:
|
* LIBXSLT_VERSION_STRING:
|
||||||
*
|
*
|
||||||
* the version number string, 1.2.3 value is "10203"
|
* the version number string, 1.2.3 value is "10203"
|
||||||
*/
|
*/
|
||||||
#define LIBXSLT_VERSION_STRING "10124"
|
#define LIBXSLT_VERSION_STRING "10126"
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* LIBXSLT_VERSION_EXTRA:
|
* LIBXSLT_VERSION_EXTRA:
|
||||||
*
|
*
|
||||||
* extra version information, used to show a CVS compilation
|
* extra version information, used to show a CVS compilation
|
||||||
*/
|
*/
|
||||||
#define LIBXSLT_VERSION_EXTRA "-CVS1070"
|
#define LIBXSLT_VERSION_EXTRA "-GITv1.1.26"
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* WITH_XSLT_DEBUG:
|
* WITH_XSLT_DEBUG:
|
||||||
|
@ -116,13 +116,26 @@ extern "C" {
|
||||||
* Whether module support is configured into libxslt
|
* Whether module support is configured into libxslt
|
||||||
* Note: no default module path for win32 platforms
|
* Note: no default module path for win32 platforms
|
||||||
*/
|
*/
|
||||||
#if 0
|
#if 1
|
||||||
#ifndef WITH_MODULES
|
#ifndef WITH_MODULES
|
||||||
#define WITH_MODULES
|
#define WITH_MODULES
|
||||||
#endif
|
#endif
|
||||||
#define LIBXSLT_DEFAULT_PLUGINS_PATH() "/usr/lib/libxslt-plugins"
|
#define LIBXSLT_DEFAULT_PLUGINS_PATH() "/usr/lib/libxslt-plugins"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Locale support
|
||||||
|
*/
|
||||||
|
#if 1
|
||||||
|
#ifndef XSLT_LOCALE_XLOCALE
|
||||||
|
#define XSLT_LOCALE_XLOCALE
|
||||||
|
#endif
|
||||||
|
#elif 0
|
||||||
|
#ifndef XSLT_LOCALE_WINAPI
|
||||||
|
#define XSLT_LOCALE_WINAPI
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* ATTRIBUTE_UNUSED:
|
* ATTRIBUTE_UNUSED:
|
||||||
*
|
*
|
||||||
|
|
13
reactos/dll/3rdparty/libxslt/xsltconfig.h.in
vendored
13
reactos/dll/3rdparty/libxslt/xsltconfig.h.in
vendored
|
@ -123,6 +123,19 @@ extern "C" {
|
||||||
#define LIBXSLT_DEFAULT_PLUGINS_PATH() "@LIBXSLT_DEFAULT_PLUGINS_PATH@"
|
#define LIBXSLT_DEFAULT_PLUGINS_PATH() "@LIBXSLT_DEFAULT_PLUGINS_PATH@"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Locale support
|
||||||
|
*/
|
||||||
|
#if @XSLT_LOCALE_XLOCALE@
|
||||||
|
#ifndef XSLT_LOCALE_XLOCALE
|
||||||
|
#define XSLT_LOCALE_XLOCALE
|
||||||
|
#endif
|
||||||
|
#elif @XSLT_LOCALE_WINAPI@
|
||||||
|
#ifndef XSLT_LOCALE_WINAPI
|
||||||
|
#define XSLT_LOCALE_WINAPI
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* ATTRIBUTE_UNUSED:
|
* ATTRIBUTE_UNUSED:
|
||||||
*
|
*
|
||||||
|
|
509
reactos/dll/3rdparty/libxslt/xsltlocale.c
vendored
Normal file
509
reactos/dll/3rdparty/libxslt/xsltlocale.c
vendored
Normal file
|
@ -0,0 +1,509 @@
|
||||||
|
/*
|
||||||
|
* xsltlocale.c: locale handling
|
||||||
|
*
|
||||||
|
* Reference:
|
||||||
|
* RFC 3066: Tags for the Identification of Languages
|
||||||
|
* http://www.ietf.org/rfc/rfc3066.txt
|
||||||
|
* ISO 639-1, ISO 3166-1
|
||||||
|
*
|
||||||
|
* Author: Nick Wellnhofer
|
||||||
|
* winapi port: Roumen Petrov
|
||||||
|
*/
|
||||||
|
|
||||||
|
#define IN_LIBXSLT
|
||||||
|
#include "libxslt.h"
|
||||||
|
|
||||||
|
#include <string.h>
|
||||||
|
#include <libxml/xmlmemory.h>
|
||||||
|
|
||||||
|
#include "xsltlocale.h"
|
||||||
|
#include "xsltutils.h"
|
||||||
|
|
||||||
|
#if defined(__GLIBC__) && __GLIBC__ == 2 && __GLIBC_MINOR__ <= 2
|
||||||
|
#define newlocale __newlocale
|
||||||
|
#define freelocale __freelocale
|
||||||
|
#define strxfrm_l __strxfrm_l
|
||||||
|
#define LC_COLLATE_MASK (1 << LC_COLLATE)
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#define ISALPHA(c) ((c & 0xc0) == 0x40 && (unsigned)((c & 0x1f) - 1) < 26)
|
||||||
|
#define TOUPPER(c) (c & ~0x20)
|
||||||
|
#define TOLOWER(c) (c | 0x20)
|
||||||
|
|
||||||
|
/*without terminating null character*/
|
||||||
|
#define XSLTMAX_ISO639LANGLEN 8
|
||||||
|
#define XSLTMAX_ISO3166CNTRYLEN 8
|
||||||
|
/* <lang>-<cntry> */
|
||||||
|
#define XSLTMAX_LANGTAGLEN (XSLTMAX_ISO639LANGLEN+1+XSLTMAX_ISO3166CNTRYLEN)
|
||||||
|
|
||||||
|
static const xmlChar* xsltDefaultRegion(const xmlChar *localeName);
|
||||||
|
|
||||||
|
#ifdef XSLT_LOCALE_WINAPI
|
||||||
|
xmlRMutexPtr xsltLocaleMutex = NULL;
|
||||||
|
|
||||||
|
struct xsltRFC1766Info_s {
|
||||||
|
/*note typedef unsigned char xmlChar !*/
|
||||||
|
xmlChar tag[XSLTMAX_LANGTAGLEN+1];
|
||||||
|
/*note typedef LCID xsltLocale !*/
|
||||||
|
xsltLocale lcid;
|
||||||
|
};
|
||||||
|
typedef struct xsltRFC1766Info_s xsltRFC1766Info;
|
||||||
|
|
||||||
|
static int xsltLocaleListSize = 0;
|
||||||
|
static xsltRFC1766Info *xsltLocaleList = NULL;
|
||||||
|
|
||||||
|
|
||||||
|
static xsltLocale
|
||||||
|
xslt_locale_WINAPI(const xmlChar *languageTag) {
|
||||||
|
int k;
|
||||||
|
xsltRFC1766Info *p = xsltLocaleList;
|
||||||
|
|
||||||
|
for (k=0; k<xsltLocaleListSize; k++, p++)
|
||||||
|
if (xmlStrcmp(p->tag, languageTag) == 0) return p->lcid;
|
||||||
|
return((xsltLocale)0);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void xsltEnumSupportedLocales(void);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/**
|
||||||
|
* xsltNewLocale:
|
||||||
|
* @languageTag: RFC 3066 language tag
|
||||||
|
*
|
||||||
|
* Creates a new locale of an opaque system dependent type based on the
|
||||||
|
* language tag.
|
||||||
|
*
|
||||||
|
* Returns the locale or NULL on error or if no matching locale was found
|
||||||
|
*/
|
||||||
|
xsltLocale
|
||||||
|
xsltNewLocale(const xmlChar *languageTag) {
|
||||||
|
#ifdef XSLT_LOCALE_XLOCALE
|
||||||
|
xsltLocale locale;
|
||||||
|
char localeName[XSLTMAX_LANGTAGLEN+6]; /* 6 chars for ".utf8\0" */
|
||||||
|
const xmlChar *p = languageTag;
|
||||||
|
const char *region = NULL;
|
||||||
|
char *q = localeName;
|
||||||
|
int i, llen;
|
||||||
|
|
||||||
|
/* Convert something like "pt-br" to "pt_BR.utf8" */
|
||||||
|
|
||||||
|
if (languageTag == NULL)
|
||||||
|
return(NULL);
|
||||||
|
|
||||||
|
for (i=0; i<XSLTMAX_ISO639LANGLEN && ISALPHA(*p); ++i)
|
||||||
|
*q++ = TOLOWER(*p++);
|
||||||
|
|
||||||
|
if (i == 0)
|
||||||
|
return(NULL);
|
||||||
|
|
||||||
|
llen = i;
|
||||||
|
*q++ = '_';
|
||||||
|
|
||||||
|
if (*p) {
|
||||||
|
if (*p++ != '-')
|
||||||
|
return(NULL);
|
||||||
|
|
||||||
|
for (i=0; i<XSLTMAX_ISO3166CNTRYLEN && ISALPHA(*p); ++i)
|
||||||
|
*q++ = TOUPPER(*p++);
|
||||||
|
|
||||||
|
if (i == 0 || *p)
|
||||||
|
return(NULL);
|
||||||
|
|
||||||
|
memcpy(q, ".utf8", 6);
|
||||||
|
locale = newlocale(LC_COLLATE_MASK, localeName, NULL);
|
||||||
|
if (locale != NULL)
|
||||||
|
return(locale);
|
||||||
|
|
||||||
|
/* Continue without using country code */
|
||||||
|
|
||||||
|
q = localeName + llen + 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Try locale without territory, e.g. for Esperanto (eo) */
|
||||||
|
|
||||||
|
memcpy(q, ".utf8", 6);
|
||||||
|
locale = newlocale(LC_COLLATE_MASK, localeName, NULL);
|
||||||
|
if (locale != NULL)
|
||||||
|
return(locale);
|
||||||
|
|
||||||
|
/* Try to find most common country for language */
|
||||||
|
|
||||||
|
if (llen != 2)
|
||||||
|
return(NULL);
|
||||||
|
|
||||||
|
region = (char *)xsltDefaultRegion((xmlChar *)localeName);
|
||||||
|
if (region == NULL)
|
||||||
|
return(NULL);
|
||||||
|
|
||||||
|
q = localeName + llen + 1;
|
||||||
|
*q++ = region[0];
|
||||||
|
*q++ = region[1];
|
||||||
|
memcpy(q, ".utf8", 6);
|
||||||
|
locale = newlocale(LC_COLLATE_MASK, localeName, NULL);
|
||||||
|
|
||||||
|
return(locale);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef XSLT_LOCALE_WINAPI
|
||||||
|
{
|
||||||
|
xsltLocale locale = (xsltLocale)0;
|
||||||
|
xmlChar localeName[XSLTMAX_LANGTAGLEN+1];
|
||||||
|
xmlChar *q = localeName;
|
||||||
|
const xmlChar *p = languageTag;
|
||||||
|
int i, llen;
|
||||||
|
const xmlChar *region = NULL;
|
||||||
|
|
||||||
|
if (languageTag == NULL) goto end;
|
||||||
|
|
||||||
|
xsltEnumSupportedLocales();
|
||||||
|
|
||||||
|
for (i=0; i<XSLTMAX_ISO639LANGLEN && ISALPHA(*p); ++i)
|
||||||
|
*q++ = TOLOWER(*p++);
|
||||||
|
if (i == 0) goto end;
|
||||||
|
|
||||||
|
llen = i;
|
||||||
|
*q++ = '-';
|
||||||
|
if (*p) { /*if country tag is given*/
|
||||||
|
if (*p++ != '-') goto end;
|
||||||
|
|
||||||
|
for (i=0; i<XSLTMAX_ISO3166CNTRYLEN && ISALPHA(*p); ++i)
|
||||||
|
*q++ = TOUPPER(*p++);
|
||||||
|
if (i == 0 || *p) goto end;
|
||||||
|
|
||||||
|
*q = '\0';
|
||||||
|
locale = xslt_locale_WINAPI(localeName);
|
||||||
|
if (locale != (xsltLocale)0) goto end;
|
||||||
|
}
|
||||||
|
/* Try to find most common country for language */
|
||||||
|
region = xsltDefaultRegion(localeName);
|
||||||
|
if (region == NULL) goto end;
|
||||||
|
|
||||||
|
strcpy(localeName + llen + 1, region);
|
||||||
|
locale = xslt_locale_WINAPI(localeName);
|
||||||
|
end:
|
||||||
|
return(locale);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef XSLT_LOCALE_NONE
|
||||||
|
return(NULL);
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
static const xmlChar*
|
||||||
|
xsltDefaultRegion(const xmlChar *localeName) {
|
||||||
|
xmlChar c;
|
||||||
|
/* region should be xmlChar, but gcc warns on all string assignments */
|
||||||
|
const char *region = NULL;
|
||||||
|
|
||||||
|
c = localeName[1];
|
||||||
|
/* This is based on the locales from glibc 2.3.3 */
|
||||||
|
|
||||||
|
switch (localeName[0]) {
|
||||||
|
case 'a':
|
||||||
|
if (c == 'a' || c == 'm') region = "ET";
|
||||||
|
else if (c == 'f') region = "ZA";
|
||||||
|
else if (c == 'n') region = "ES";
|
||||||
|
else if (c == 'r') region = "AE";
|
||||||
|
else if (c == 'z') region = "AZ";
|
||||||
|
break;
|
||||||
|
case 'b':
|
||||||
|
if (c == 'e') region = "BY";
|
||||||
|
else if (c == 'g') region = "BG";
|
||||||
|
else if (c == 'n') region = "BD";
|
||||||
|
else if (c == 'r') region = "FR";
|
||||||
|
else if (c == 's') region = "BA";
|
||||||
|
break;
|
||||||
|
case 'c':
|
||||||
|
if (c == 'a') region = "ES";
|
||||||
|
else if (c == 's') region = "CZ";
|
||||||
|
else if (c == 'y') region = "GB";
|
||||||
|
break;
|
||||||
|
case 'd':
|
||||||
|
if (c == 'a') region = "DK";
|
||||||
|
else if (c == 'e') region = "DE";
|
||||||
|
break;
|
||||||
|
case 'e':
|
||||||
|
if (c == 'l') region = "GR";
|
||||||
|
else if (c == 'n' || c == 'o') region = "US";
|
||||||
|
else if (c == 's' || c == 'u') region = "ES";
|
||||||
|
else if (c == 't') region = "EE";
|
||||||
|
break;
|
||||||
|
case 'f':
|
||||||
|
if (c == 'a') region = "IR";
|
||||||
|
else if (c == 'i') region = "FI";
|
||||||
|
else if (c == 'o') region = "FO";
|
||||||
|
else if (c == 'r') region = "FR";
|
||||||
|
break;
|
||||||
|
case 'g':
|
||||||
|
if (c == 'a') region = "IE";
|
||||||
|
else if (c == 'l') region = "ES";
|
||||||
|
else if (c == 'v') region = "GB";
|
||||||
|
break;
|
||||||
|
case 'h':
|
||||||
|
if (c == 'e') region = "IL";
|
||||||
|
else if (c == 'i') region = "IN";
|
||||||
|
else if (c == 'r') region = "HT";
|
||||||
|
else if (c == 'u') region = "HU";
|
||||||
|
break;
|
||||||
|
case 'i':
|
||||||
|
if (c == 'd') region = "ID";
|
||||||
|
else if (c == 's') region = "IS";
|
||||||
|
else if (c == 't') region = "IT";
|
||||||
|
else if (c == 'w') region = "IL";
|
||||||
|
break;
|
||||||
|
case 'j':
|
||||||
|
if (c == 'a') region = "JP";
|
||||||
|
break;
|
||||||
|
case 'k':
|
||||||
|
if (c == 'l') region = "GL";
|
||||||
|
else if (c == 'o') region = "KR";
|
||||||
|
else if (c == 'w') region = "GB";
|
||||||
|
break;
|
||||||
|
case 'l':
|
||||||
|
if (c == 't') region = "LT";
|
||||||
|
else if (c == 'v') region = "LV";
|
||||||
|
break;
|
||||||
|
case 'm':
|
||||||
|
if (c == 'k') region = "MK";
|
||||||
|
else if (c == 'l' || c == 'r') region = "IN";
|
||||||
|
else if (c == 'n') region = "MN";
|
||||||
|
else if (c == 's') region = "MY";
|
||||||
|
else if (c == 't') region = "MT";
|
||||||
|
break;
|
||||||
|
case 'n':
|
||||||
|
if (c == 'b' || c == 'n' || c == 'o') region = "NO";
|
||||||
|
else if (c == 'e') region = "NP";
|
||||||
|
else if (c == 'l') region = "NL";
|
||||||
|
break;
|
||||||
|
case 'o':
|
||||||
|
if (c == 'm') region = "ET";
|
||||||
|
break;
|
||||||
|
case 'p':
|
||||||
|
if (c == 'a') region = "IN";
|
||||||
|
else if (c == 'l') region = "PL";
|
||||||
|
else if (c == 't') region = "PT";
|
||||||
|
break;
|
||||||
|
case 'r':
|
||||||
|
if (c == 'o') region = "RO";
|
||||||
|
else if (c == 'u') region = "RU";
|
||||||
|
break;
|
||||||
|
case 's':
|
||||||
|
switch (c) {
|
||||||
|
case 'e': region = "NO"; break;
|
||||||
|
case 'h': region = "YU"; break;
|
||||||
|
case 'k': region = "SK"; break;
|
||||||
|
case 'l': region = "SI"; break;
|
||||||
|
case 'o': region = "ET"; break;
|
||||||
|
case 'q': region = "AL"; break;
|
||||||
|
case 't': region = "ZA"; break;
|
||||||
|
case 'v': region = "SE"; break;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case 't':
|
||||||
|
if (c == 'a' || c == 'e') region = "IN";
|
||||||
|
else if (c == 'h') region = "TH";
|
||||||
|
else if (c == 'i') region = "ER";
|
||||||
|
else if (c == 'r') region = "TR";
|
||||||
|
else if (c == 't') region = "RU";
|
||||||
|
break;
|
||||||
|
case 'u':
|
||||||
|
if (c == 'k') region = "UA";
|
||||||
|
else if (c == 'r') region = "PK";
|
||||||
|
break;
|
||||||
|
case 'v':
|
||||||
|
if (c == 'i') region = "VN";
|
||||||
|
break;
|
||||||
|
case 'w':
|
||||||
|
if (c == 'a') region = "BE";
|
||||||
|
break;
|
||||||
|
case 'x':
|
||||||
|
if (c == 'h') region = "ZA";
|
||||||
|
break;
|
||||||
|
case 'z':
|
||||||
|
if (c == 'h') region = "CN";
|
||||||
|
else if (c == 'u') region = "ZA";
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
return((xmlChar *)region);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* xsltFreeLocale:
|
||||||
|
* @locale: the locale to free
|
||||||
|
*
|
||||||
|
* Frees a locale created with xsltNewLocale
|
||||||
|
*/
|
||||||
|
void
|
||||||
|
xsltFreeLocale(xsltLocale locale) {
|
||||||
|
#ifdef XSLT_LOCALE_XLOCALE
|
||||||
|
freelocale(locale);
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* xsltStrxfrm:
|
||||||
|
* @locale: locale created with xsltNewLocale
|
||||||
|
* @string: UTF-8 string to transform
|
||||||
|
*
|
||||||
|
* Transforms a string according to locale. The transformed string must then be
|
||||||
|
* compared with xsltLocaleStrcmp and freed with xmlFree.
|
||||||
|
*
|
||||||
|
* Returns the transformed string or NULL on error
|
||||||
|
*/
|
||||||
|
xsltLocaleChar *
|
||||||
|
xsltStrxfrm(xsltLocale locale, const xmlChar *string)
|
||||||
|
{
|
||||||
|
#ifdef XSLT_LOCALE_NONE
|
||||||
|
return(NULL);
|
||||||
|
#else
|
||||||
|
size_t xstrlen, r;
|
||||||
|
xsltLocaleChar *xstr;
|
||||||
|
|
||||||
|
#ifdef XSLT_LOCALE_XLOCALE
|
||||||
|
xstrlen = strxfrm_l(NULL, (const char *)string, 0, locale) + 1;
|
||||||
|
xstr = (xsltLocaleChar *) xmlMalloc(xstrlen);
|
||||||
|
if (xstr == NULL) {
|
||||||
|
xsltTransformError(NULL, NULL, NULL,
|
||||||
|
"xsltStrxfrm : out of memory error\n");
|
||||||
|
return(NULL);
|
||||||
|
}
|
||||||
|
|
||||||
|
r = strxfrm_l((char *)xstr, (const char *)string, xstrlen, locale);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef XSLT_LOCALE_WINAPI
|
||||||
|
xstrlen = MultiByteToWideChar(CP_UTF8, 0, string, -1, NULL, 0);
|
||||||
|
if (xstrlen == 0) {
|
||||||
|
xsltTransformError(NULL, NULL, NULL, "xsltStrxfrm : MultiByteToWideChar check failed\n");
|
||||||
|
return(NULL);
|
||||||
|
}
|
||||||
|
xstr = (xsltLocaleChar*) xmlMalloc(xstrlen * sizeof(xsltLocaleChar));
|
||||||
|
if (xstr == NULL) {
|
||||||
|
xsltTransformError(NULL, NULL, NULL, "xsltStrxfrm : out of memory\n");
|
||||||
|
return(NULL);
|
||||||
|
}
|
||||||
|
r = MultiByteToWideChar(CP_UTF8, 0, string, -1, xstr, xstrlen);
|
||||||
|
if (r == 0) {
|
||||||
|
xsltTransformError(NULL, NULL, NULL, "xsltStrxfrm : MultiByteToWideChar failed\n");
|
||||||
|
xmlFree(xstr);
|
||||||
|
return(NULL);
|
||||||
|
}
|
||||||
|
return(xstr);
|
||||||
|
#endif /* XSLT_LOCALE_WINAPI */
|
||||||
|
|
||||||
|
if (r >= xstrlen) {
|
||||||
|
xsltTransformError(NULL, NULL, NULL, "xsltStrxfrm : strxfrm failed\n");
|
||||||
|
xmlFree(xstr);
|
||||||
|
return(NULL);
|
||||||
|
}
|
||||||
|
|
||||||
|
return(xstr);
|
||||||
|
#endif /* XSLT_LOCALE_NONE */
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* xsltLocaleStrcmp:
|
||||||
|
* @locale: a locale identifier
|
||||||
|
* @str1: a string transformed with xsltStrxfrm
|
||||||
|
* @str2: a string transformed with xsltStrxfrm
|
||||||
|
*
|
||||||
|
* Compares two strings transformed with xsltStrxfrm
|
||||||
|
*
|
||||||
|
* Returns a value < 0 if str1 sorts before str2,
|
||||||
|
* a value > 0 if str1 sorts after str2,
|
||||||
|
* 0 if str1 and str2 are equal wrt sorting
|
||||||
|
*/
|
||||||
|
int
|
||||||
|
xsltLocaleStrcmp(xsltLocale locale, const xsltLocaleChar *str1, const xsltLocaleChar *str2) {
|
||||||
|
(void)locale;
|
||||||
|
#ifdef XSLT_LOCALE_WINAPI
|
||||||
|
{
|
||||||
|
int ret;
|
||||||
|
if (str1 == str2) return(0);
|
||||||
|
if (str1 == NULL) return(-1);
|
||||||
|
if (str2 == NULL) return(1);
|
||||||
|
ret = CompareStringW(locale, 0, str1, -1, str2, -1);
|
||||||
|
if (ret == 0) {
|
||||||
|
xsltTransformError(NULL, NULL, NULL, "xsltLocaleStrcmp : CompareStringW fail\n");
|
||||||
|
return(0);
|
||||||
|
}
|
||||||
|
return(ret - 2);
|
||||||
|
}
|
||||||
|
#else
|
||||||
|
return(xmlStrcmp(str1, str2));
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
#ifdef XSLT_LOCALE_WINAPI
|
||||||
|
/**
|
||||||
|
* xsltCountSupportedLocales:
|
||||||
|
* @lcid: not used
|
||||||
|
*
|
||||||
|
* callback used to count locales
|
||||||
|
*
|
||||||
|
* Returns TRUE
|
||||||
|
*/
|
||||||
|
BOOL CALLBACK
|
||||||
|
xsltCountSupportedLocales(LPSTR lcid) {
|
||||||
|
(void) lcid;
|
||||||
|
++xsltLocaleListSize;
|
||||||
|
return(TRUE);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* xsltIterateSupportedLocales:
|
||||||
|
* @lcid: not used
|
||||||
|
*
|
||||||
|
* callback used to track locales
|
||||||
|
*
|
||||||
|
* Returns TRUE if not at the end of the array
|
||||||
|
*/
|
||||||
|
BOOL CALLBACK
|
||||||
|
xsltIterateSupportedLocales(LPSTR lcid) {
|
||||||
|
static int count = 0;
|
||||||
|
xmlChar iso639lang [XSLTMAX_ISO639LANGLEN +1];
|
||||||
|
xmlChar iso3136ctry[XSLTMAX_ISO3166CNTRYLEN+1];
|
||||||
|
int k, l;
|
||||||
|
xsltRFC1766Info *p = xsltLocaleList + count;
|
||||||
|
|
||||||
|
k = sscanf(lcid, "%lx", (long*)&p->lcid);
|
||||||
|
if (k < 1) goto end;
|
||||||
|
/*don't count terminating null character*/
|
||||||
|
k = GetLocaleInfoA(p->lcid, LOCALE_SISO639LANGNAME , iso639lang , sizeof(iso639lang ));
|
||||||
|
if (--k < 1) goto end;
|
||||||
|
l = GetLocaleInfoA(p->lcid, LOCALE_SISO3166CTRYNAME, iso3136ctry, sizeof(iso3136ctry));
|
||||||
|
if (--l < 1) goto end;
|
||||||
|
|
||||||
|
{ /*fill results*/
|
||||||
|
xmlChar *q = p->tag;
|
||||||
|
memcpy(q, iso639lang, k);
|
||||||
|
q += k;
|
||||||
|
*q++ = '-';
|
||||||
|
memcpy(q, iso3136ctry, l);
|
||||||
|
q += l;
|
||||||
|
*q = '\0';
|
||||||
|
}
|
||||||
|
++count;
|
||||||
|
end:
|
||||||
|
return((count < xsltLocaleListSize) ? TRUE : FALSE);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
static void
|
||||||
|
xsltEnumSupportedLocales(void) {
|
||||||
|
xmlRMutexLock(xsltLocaleMutex);
|
||||||
|
if (xsltLocaleListSize <= 0) {
|
||||||
|
size_t len;
|
||||||
|
|
||||||
|
EnumSystemLocalesA(xsltCountSupportedLocales, LCID_SUPPORTED);
|
||||||
|
|
||||||
|
len = xsltLocaleListSize * sizeof(xsltRFC1766Info);
|
||||||
|
xsltLocaleList = xmlMalloc(len);
|
||||||
|
memset(xsltLocaleList, 0, len);
|
||||||
|
EnumSystemLocalesA(xsltIterateSupportedLocales, LCID_SUPPORTED);
|
||||||
|
}
|
||||||
|
xmlRMutexUnlock(xsltLocaleMutex);
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif /*def XSLT_LOCALE_WINAPI*/
|
57
reactos/dll/3rdparty/libxslt/xsltlocale.h
vendored
Normal file
57
reactos/dll/3rdparty/libxslt/xsltlocale.h
vendored
Normal file
|
@ -0,0 +1,57 @@
|
||||||
|
/*
|
||||||
|
* Summary: Locale handling
|
||||||
|
* Description: Interfaces for locale handling. Needed for language dependent
|
||||||
|
* sorting.
|
||||||
|
*
|
||||||
|
* Copy: See Copyright for the status of this software.
|
||||||
|
*
|
||||||
|
* Author: Nick Wellnhofer
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef __XML_XSLTLOCALE_H__
|
||||||
|
#define __XML_XSLTLOCALE_H__
|
||||||
|
|
||||||
|
#include <libxml/xmlstring.h>
|
||||||
|
|
||||||
|
#ifdef XSLT_LOCALE_XLOCALE
|
||||||
|
|
||||||
|
#include <locale.h>
|
||||||
|
#include <xlocale.h>
|
||||||
|
|
||||||
|
#ifdef __GLIBC__
|
||||||
|
/*locale_t is defined only if _GNU_SOURCE is defined*/
|
||||||
|
typedef __locale_t xsltLocale;
|
||||||
|
#else
|
||||||
|
typedef locale_t xsltLocale;
|
||||||
|
#endif
|
||||||
|
typedef xmlChar xsltLocaleChar;
|
||||||
|
|
||||||
|
#elif defined(XSLT_LOCALE_WINAPI)
|
||||||
|
|
||||||
|
#include <windows.h>
|
||||||
|
#include <winnls.h>
|
||||||
|
|
||||||
|
typedef LCID xsltLocale;
|
||||||
|
typedef wchar_t xsltLocaleChar;
|
||||||
|
|
||||||
|
#else
|
||||||
|
|
||||||
|
/*
|
||||||
|
* XSLT_LOCALE_NONE:
|
||||||
|
* Macro indicating that locale are not supported
|
||||||
|
*/
|
||||||
|
#ifndef XSLT_LOCALE_NONE
|
||||||
|
#define XSLT_LOCALE_NONE
|
||||||
|
#endif
|
||||||
|
|
||||||
|
typedef void *xsltLocale;
|
||||||
|
typedef xmlChar xsltLocaleChar;
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
|
xsltLocale xsltNewLocale(const xmlChar *langName);
|
||||||
|
void xsltFreeLocale(xsltLocale locale);
|
||||||
|
xsltLocaleChar *xsltStrxfrm(xsltLocale locale, const xmlChar *string);
|
||||||
|
int xsltLocaleStrcmp(xsltLocale locale, const xsltLocaleChar *str1, const xsltLocaleChar *str2);
|
||||||
|
|
||||||
|
#endif /* __XML_XSLTLOCALE_H__ */
|
16
reactos/dll/3rdparty/libxslt/xsltutils.c
vendored
16
reactos/dll/3rdparty/libxslt/xsltutils.c
vendored
|
@ -1039,6 +1039,12 @@ xsltComputeSortResult(xsltTransformContextPtr ctxt, xmlNodePtr sort) {
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
if (res->type == XPATH_STRING) {
|
if (res->type == XPATH_STRING) {
|
||||||
|
if (comp->locale != (xsltLocale)0) {
|
||||||
|
xmlChar *str = res->stringval;
|
||||||
|
res->stringval = (xmlChar *) xsltStrxfrm(comp->locale, str);
|
||||||
|
xmlFree(str);
|
||||||
|
}
|
||||||
|
|
||||||
results[i] = res;
|
results[i] = res;
|
||||||
} else {
|
} else {
|
||||||
#ifdef WITH_XSLT_DEBUG_PROCESS
|
#ifdef WITH_XSLT_DEBUG_PROCESS
|
||||||
|
@ -1191,6 +1197,11 @@ xsltDefaultSortFunction(xsltTransformContextPtr ctxt, xmlNodePtr *sorts,
|
||||||
results[j + incr]->floatval)
|
results[j + incr]->floatval)
|
||||||
tst = 1;
|
tst = 1;
|
||||||
else tst = -1;
|
else tst = -1;
|
||||||
|
} else if(comp->locale != (xsltLocale)0) {
|
||||||
|
tst = xsltLocaleStrcmp(
|
||||||
|
comp->locale,
|
||||||
|
(xsltLocaleChar *) results[j]->stringval,
|
||||||
|
(xsltLocaleChar *) results[j + incr]->stringval);
|
||||||
} else {
|
} else {
|
||||||
tst = xmlStrcmp(results[j]->stringval,
|
tst = xmlStrcmp(results[j]->stringval,
|
||||||
results[j + incr]->stringval);
|
results[j + incr]->stringval);
|
||||||
|
@ -1245,6 +1256,11 @@ xsltDefaultSortFunction(xsltTransformContextPtr ctxt, xmlNodePtr *sorts,
|
||||||
res[j + incr]->floatval)
|
res[j + incr]->floatval)
|
||||||
tst = 1;
|
tst = 1;
|
||||||
else tst = -1;
|
else tst = -1;
|
||||||
|
} else if(comp->locale != (xsltLocale)0) {
|
||||||
|
tst = xsltLocaleStrcmp(
|
||||||
|
comp->locale,
|
||||||
|
(xsltLocaleChar *) res[j]->stringval,
|
||||||
|
(xsltLocaleChar *) res[j + incr]->stringval);
|
||||||
} else {
|
} else {
|
||||||
tst = xmlStrcmp(res[j]->stringval,
|
tst = xmlStrcmp(res[j]->stringval,
|
||||||
res[j + incr]->stringval);
|
res[j + incr]->stringval);
|
||||||
|
|
|
@ -23,21 +23,21 @@ extern "C" {
|
||||||
*
|
*
|
||||||
* the version string like "1.2.3"
|
* the version string like "1.2.3"
|
||||||
*/
|
*/
|
||||||
#define LIBXSLT_DOTTED_VERSION "1.1.24"
|
#define LIBXSLT_DOTTED_VERSION "1.1.26"
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* LIBXSLT_VERSION:
|
* LIBXSLT_VERSION:
|
||||||
*
|
*
|
||||||
* the version number: 1.2.3 value is 1002003
|
* the version number: 1.2.3 value is 1002003
|
||||||
*/
|
*/
|
||||||
#define LIBXSLT_VERSION 10124
|
#define LIBXSLT_VERSION 10126
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* LIBXSLT_VERSION_STRING:
|
* LIBXSLT_VERSION_STRING:
|
||||||
*
|
*
|
||||||
* the version number string, 1.2.3 value is "1002003"
|
* the version number string, 1.2.3 value is "1002003"
|
||||||
*/
|
*/
|
||||||
#define LIBXSLT_VERSION_STRING "10124"
|
#define LIBXSLT_VERSION_STRING "10126"
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* LIBXSLT_VERSION_EXTRA:
|
* LIBXSLT_VERSION_EXTRA:
|
||||||
|
|
Loading…
Reference in a new issue