EXSLT func:function not registered for XSLT filter module
Maxim Dounin
mdounin at mdounin.ru
Mon Jul 15 17:32:14 UTC 2013
Hello!
On Sat, Jul 13, 2013 at 12:19:51PM +0200, Kate F wrote:
> Hi,
>
> I'm trying to use EXSLT's <func:function> with nginx's xslt filter
> module. The effect I think I'm seeing is that my functions are
> seemingly ignored.
[...]
> Looking at ngx_http_xslt_filter_module.c I see exsltRegisterAll() is
> called, which is what should register libexslt's handler for
> func:function and friends:
>
> #if (NGX_HAVE_EXSLT)
> exsltRegisterAll();
> #endif
>
> I know NGX_HAVE_EXSLT is defined because other EXSLT functions (such
> as things in the date: and str: namespaces) work fine.
It looks like exsltRegisterAll() is called too late for EXSLT
Functions extension.
Please try the following patch:
# HG changeset patch
# User Maxim Dounin <mdounin at mdounin.ru>
# Date 1373909466 -14400
# Node ID bc1cf51a5b0a5e8512a8170dc7991f9e966c5533
# Parent 8e7db77e5d88b20d113e77b574e676737d67bf0e
Xslt: exsltRegisterAll() moved to preconfiguration.
The exsltRegisterAll() needs to be called before XSLT stylesheets
are compiled, else stylesheet compilation hooks will not work. This
change fixes EXSLT Functions extension.
diff --git a/src/http/modules/ngx_http_xslt_filter_module.c b/src/http/modules/ngx_http_xslt_filter_module.c
--- a/src/http/modules/ngx_http_xslt_filter_module.c
+++ b/src/http/modules/ngx_http_xslt_filter_module.c
@@ -104,6 +104,7 @@ static void *ngx_http_xslt_filter_create
static void *ngx_http_xslt_filter_create_conf(ngx_conf_t *cf);
static char *ngx_http_xslt_filter_merge_conf(ngx_conf_t *cf, void *parent,
void *child);
+static ngx_int_t ngx_http_xslt_filter_preconfiguration(ngx_conf_t *cf);
static ngx_int_t ngx_http_xslt_filter_init(ngx_conf_t *cf);
static void ngx_http_xslt_filter_exit(ngx_cycle_t *cycle);
@@ -163,7 +164,7 @@ static ngx_command_t
static ngx_http_module_t ngx_http_xslt_filter_module_ctx = {
- NULL, /* preconfiguration */
+ ngx_http_xslt_filter_preconfiguration, /* preconfiguration */
ngx_http_xslt_filter_init, /* postconfiguration */
ngx_http_xslt_filter_create_main_conf, /* create main configuration */
@@ -1111,7 +1112,7 @@ ngx_http_xslt_filter_merge_conf(ngx_conf
static ngx_int_t
-ngx_http_xslt_filter_init(ngx_conf_t *cf)
+ngx_http_xslt_filter_preconfiguration(ngx_conf_t *cf)
{
xmlInitParser();
@@ -1119,6 +1120,13 @@ ngx_http_xslt_filter_init(ngx_conf_t
exsltRegisterAll();
#endif
+ return NGX_OK;
+}
+
+
+static ngx_int_t
+ngx_http_xslt_filter_init(ngx_conf_t *cf)
+{
ngx_http_next_header_filter = ngx_http_top_header_filter;
ngx_http_top_header_filter = ngx_http_xslt_header_filter;
--
Maxim Dounin
http://nginx.org/en/donation.html
More information about the nginx
mailing list