XSLT转换不会返回任何内容

时间:2012-02-14 17:21:30

标签: c# xslt code-generation

我正在尝试基于XSLT转换创建一个小代码生成器。我是XSLT的新手,似乎我在转换中犯了错误(不知道在哪里)。我有两个转换(main和util),元数据从XML文件中提取(它存储有关表名的信息,这些信息将用于类生成 - 表名=类名;列名=字段名)。以下是我的转变:

主要转型

<?xml version="1.0" encoding="utf-8"?>
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
    xmlns:msxsl="urn:schemas-microsoft-com:xslt" exclude-result-prefixes="msxsl"
    xmlns:dbs="http://kadgen/DatabaseStructure">
  <xsl:import href="..\MySolution\UtilTemplates.xslt"/>      
  <xsl:output method="text" encoding="UTF-8" indent="yes"/>    
  <xsl:param name="Name"/> 
  <xsl:param name ="filedName"/>    
  <xsl:template match="/">
    <xsl:apply-templates select=
            "//dbs:DataStructure//dbs:Table[@Name='Customer']"
          mode="BuildClasses" />
  </xsl:template>    
  <xsl:template match="dbs:Table" mode="BuildClasses">
    <xsl:call-template name="Header"/>    
    Public Class <xsl:value-of select="@Name"/>
    {
    <xsl:call-template name="ClassConstructors"/>
    <xsl:call-template name="ClassLevelDeclarations"/>
    <xsl:call-template name="FieldAccessProperties"/>
    }
  </xsl:template>    
  <xsl:template name="ClassConstructors">        
  </xsl:template>
      <xsl:template name="ClassLevelDeclarations">
      </xsl:template>    
  <xsl:template name="FieldAccessProperties">    
  </xsl:template>      
</xsl:stylesheet>

这是util转换:

<?xml version="1.0" encoding="utf-8"?>
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
    xmlns:msxsl="urn:schemas-microsoft-com:xslt" exclude-result-prefixes="msxsl">
    <xsl:output method="text"/>
    <xsl:template name="Header">      
     using System;
     using System.Collections.Generic;
     using System.Xml;     
     using System.Linq;
     using System.Text;
    </xsl:template>  
</xsl:stylesheet>

以下是我的XML文件的一部分:

<?xml version="1.0" encoding="utf-8" ?>
<dbs:MetaDataRoot FreeForm="true" xmlns:dbs="http://kadgen/DatabaseStructure">
  <dbs:DataStructures>
    <dbs:DataStructure Name="ASPDatabase">
      <dbs:Tables>
        <dbs:Table Name="Customer" OriginalName="Customer">
          <dbs:TableColumns>
            <dbs:TableColumn Name="CustomerID" NETType="int" IsPrimaryKey="true" />
            <dbs:TableColumn Name="Name" NETType="string" IsPrimaryKey="false"/>
          </dbs:TableColumns>
          <dbs:TableConstraints>
            <dbs:PrimaryKey>
              <dbs:PKField Name="CustomerID"/>
            </dbs:PrimaryKey>
          </dbs:TableConstraints>
          </dbs:Table>
        </dbs:Tables>
      </dbs:DataStructure>
  </dbs:DataStructures>
</dbs:MetaDataRoot>

以下是我开始转型的方式:

    XslCompiledTransform myXslTrans = new XslCompiledTransform();
    myXslTrans.Load("xslt transformation location");
    myXslTrans.Transform("XML source location", "Empty class file location");

执行上面的代码后,我得到的只是空cs文件。它可能看起来很健壮,但请通过它并帮助我。

感谢。

2 个答案:

答案 0 :(得分:2)

您是否尝试使用VS XSLT调试器调试XSLT文件? 看起来它会产生正确的输出。 Debugger screenshot

答案 1 :(得分:1)

这对我有用,但我做了一些小改动并修复了你的XML文档。

这是我的测试应用程序。

private static void Main(string[] args)
{
    var myXslTrans = new XslCompiledTransform();

    var doc = new XmlDocument();
    doc.LoadXml(GetResourceTextFile("ProjectName.MainTransform.xslt"));

    myXslTrans.Load(doc);

    var sb = new StringBuilder();
    var sw = new StringWriter(sb);

    var xsltArgs = new XsltArgumentList();
    xsltArgs.AddParam("Name", "", "test name");
    xsltArgs.AddParam("filedName", "", "test filed name");

    var docXml = new XmlDocument();
    docXml.LoadXml(GetResourceTextFile("ProjectName.Test.xml"));

    myXslTrans.Transform(docXml, xsltArgs, sw);

    var test = sw.ToString();

}

public static string GetResourceTextFile(string filename)
{
    string result = string.Empty;

    var assembly = Assembly.GetExecutingAssembly();

    using (Stream stream = assembly.GetManifestResourceStream(filename))
    {
        if (stream != null)
        {
            using (var sr = new StreamReader(stream))
            {
                result = sr.ReadToEnd();
            }
        }
    }

    return result;
}

我做的主要区别是添加XSLT参数并首先将嵌入文件加载到XmlDocuments中。我无法重现空白输出,因此我无法确定问题的根本原因是什么。