当Saxon XSLT转换失败时,如何检索错误详细信息?

时间:2017-05-31 13:08:17

标签: c# .net xml xslt saxon

我正在使用Saxon 9 HE 9.7.0.7 for .NET。通常,当我运行XsltTransformer.Run时,将填充DomDestination.XmlDocument属性。但是,对于某些文档,该属性将为null。当属性为null时,我假设遇到某种错误,但没有抛出异常,我没有在控制台上看到任何错误。如何检索有关转换失败原因的详细信息?

对于一个这样的示例文档,我尝试从命令行进行转换,并且完成没有任何问题。

以下是一些示例代码。最后一行的destination.XmlDocument属性有时为null。

        // Compile stylesheet
        var processor = new Processor();
        var compiler = processor.NewXsltCompiler();
        var executable = compiler.Compile(new Uri(xsltFilePath));
        var declaredArgs = executable.GetGlobalParameters();

        // Do transformation to a destination
        var destination = new DomDestination();
        using (var inputStream = new MemoryStream())
        {
            xml.Save(inputStream);
            inputStream.Position = 0;
            var transformer = executable.Load();
            transformer.SetInputStream(inputStream, new Uri(inputXmlFileInfo.DirectoryName));
            foreach (var arg in args)
            {
                var matchingArgDeclaration = declaredArgs.FirstOrDefault(a => a.Key.LocalName.ToLower() == arg.Key.ToLower());
                if (matchingArgDeclaration.Key == null)
                {
                    transformer.SetParameter(new QName(arg.Key), new XdmAtomicValue(arg.Value));
                }
                else
                {
                    // try to load up the specific parameter type
                    // list is based on http://www.saxonica.com/documentation/#!dotnetdoc/Saxon.Api/XdmAtomicValue
                    XdmItemType argType = matchingArgDeclaration.Value.getDeclaredItemType();
                    var argTypeName = "";
                    if (argType != null &&
                        argType is XdmAtomicType)
                        argTypeName = ((XdmAtomicType)argType).Name.LocalName;
                    switch (argTypeName.ToLower())
                    {
                        case "boolean":
                            transformer.SetParameter(new QName(arg.Key), new XdmAtomicValue(Convert.ToBoolean(arg.Value)));
                            break;

                        case "integer":
                            transformer.SetParameter(new QName(arg.Key), new XdmAtomicValue(Convert.ToInt32(arg.Value)));
                            break;

                        case "decimal":
                            transformer.SetParameter(new QName(arg.Key), new XdmAtomicValue(Convert.ToDecimal(arg.Value)));
                            break;

                        case "float":
                            transformer.SetParameter(new QName(arg.Key), new XdmAtomicValue(Convert.ToSingle(arg.Value)));
                            break;

                        case "double":
                            transformer.SetParameter(new QName(arg.Key), new XdmAtomicValue(Convert.ToDouble(arg.Value)));
                            break;

                        case "anyuri":
                            transformer.SetParameter(new QName(arg.Key), new XdmAtomicValue(new Uri(arg.Value)));
                            break;

                        case "qname":
                            transformer.SetParameter(new QName(arg.Key), new XdmAtomicValue(new QName(arg.Value)));
                            break;

                        default:
                            transformer.SetParameter(new QName(arg.Key), new XdmAtomicValue(((arg.Value))));
                            break;
                    }
                }
            }

            transformer.Run(destination);
        }

        // Save result to a file (or whatever else you wanna do)
        destination.XmlDocument.Save(outputFileName);

2 个答案:

答案 0 :(得分:2)

有两种错误:静态错误和动态错误。

静态错误(例如,语法错误或使用未声明的变量或函数)将添加到ErrorList的{​​{1}}属性中。 XsltCompiler方法将引发异常,然后您应该检查ErrorList中的详细信息以进行详细诊断。

动态错误(例如除以零)导致Compile()方法抛出类XsltTransformer.Run()的异常。

答案 1 :(得分:0)

事实证明,我给出的样式表是尝试使用xsl:result-document输出到文件。因此,XmlDocument属性为null,并且没有抛出任何错误。

根据documentation,执行transformer.Run时,通常会将错误抛出为DynamicError异常。