From 142a9c3f1153dd9d5e7933662bea01563f62c0e4 Mon Sep 17 00:00:00 2001 From: Igor Sysoev Date: Fri, 17 Jul 2009 08:04:52 +0000 Subject: [PATCH] preserve XML wellFormed field before freeing memory --- src/http/modules/ngx_http_xslt_filter_module.c | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) diff --git a/src/http/modules/ngx_http_xslt_filter_module.c b/src/http/modules/ngx_http_xslt_filter_module.c index c43747b06..ca9e15dc6 100644 --- a/src/http/modules/ngx_http_xslt_filter_module.c +++ b/src/http/modules/ngx_http_xslt_filter_module.c @@ -247,6 +247,7 @@ ngx_http_xslt_header_filter(ngx_http_request_t *r) static ngx_int_t ngx_http_xslt_body_filter(ngx_http_request_t *r, ngx_chain_t *in) { + int wellFormed; ngx_chain_t *cl; ngx_http_xslt_filter_ctx_t *ctx; @@ -288,9 +289,11 @@ ngx_http_xslt_body_filter(ngx_http_request_t *r, ngx_chain_t *in) ctx->doc->extSubset = NULL; #endif + wellFormed = ctx->ctxt->wellFormed; + xmlFreeParserCtxt(ctx->ctxt); - if (ctx->ctxt->wellFormed) { + if (wellFormed) { return ngx_http_xslt_send(r, ctx, ngx_http_xslt_apply_stylesheet(r, ctx)); }