Note
Access to this page requires authorization. You can try signing in or changing directories.
Access to this page requires authorization. You can try changing directories.
The XSLT compiler (xsltc.exe) compiles XSLT style sheets and generates an assembly. The compiled style sheet can then be passed directly into the XslCompiledTransform.Load(Type) method. You cannot generate signed assemblies with xsltc.exe.
Note
Script blocks are supported only in .NET Framework. They are not supported on .NET Core or .NET 5 or later.
The xsltc.exe tool is included with Visual Studio. For more information, see the Visual Studio Downloads.
Syntax
xsltc [options] [/class:<name>] <sourceFile> [[/class:<name>] <sourceFile>...]  
Argument
| Argument | Description | 
|---|---|
| sourceFile | Specifies the name of the style sheet. The style sheet must be a local file or be located on the intranet. | 
Options
| Option | Description | 
|---|---|
| /c[lass]:name | Specifies the name of the class for the following style sheet. The class name can be fully qualified. The class name defaults to the name of the style sheet. For example, if the style sheet customers.xsl is compiled, the default class name is customers. | 
| /debug[+|-] | Specifies whether to generate debugging information. Specifying +or/debug, causes the compiler to generate debugging information and put it in a program database (PDB) file. The name of the generated PDB file isassemblyName.pdb.Specifying -, which is in effect if you don't specify/debug, causes no debug information to be created. A retail assembly is generated. Note:  Compiling in debug mode can affect XSLT performance significantly. | 
| /help | Displays command syntax and options for the tool. | 
| /nologo | Suppresses the compiler copyright message from displaying. | 
| /platform:string | Specifies the platforms that the assembly can be run on. The following describes the valid platform values: x86compiles your assembly to be run by the 32-bit, x86-compatible common language runtimex64compiles your assembly to be run by the 64-bit common language runtime on a computer that supports the AMD64 or EM64T instruction set.Itanium compiles your assembly to be run by the 64-bit common language runtime on a computer that has an Itanium processor. anycpucompiles your assembly to run on any platform. This is the default. | 
| /out:assemblyName | Specifies the name of the assembly that is output. The assembly name defaults to the name of the main style sheet or the first style sheet if multiple style sheets are present. If the style sheet contains scripts, the scripts are saved to a separate assembly. Script assembly names are generated from the main assembly name. For example, if you specified CustOrders.dll for your assembly name, the first script assembly is named CustOrders_Script1.dll. | 
| /settings:document+-, script+-, DTD+-, | Specifies whether to allow document()functions, XSLT script, or document type definition (DTD) in the style sheet.The default behavior disables support for DTD, the document()function and scripting. | 
| @file | Lets you specify a file that contains the compiler options. | 
| ? | Displays command syntax and options for the tool. | 
Remarks
XSLT solutions can consist of multiple style sheet modules. The xsltc.exe tool generates assemblies from style sheets. The assemblies can then be passed into the XslCompiledTransform.Load(Type) method. This can help decrease performance costs in some XSLT deployment scenarios.
Note
You must also include the compiled assembly as a reference in your application.
The xsltc.exe tool does not validate the class (/class:name) or assembly (/out:assemblyName) names. Errors are thrown by the common language runtime if the names aren't valid.
Examples
The following command compiles the style sheet and creates an assembly named booksort.dll.
xsltc booksort.xsl  
The following command compiles the style sheet and creates an assembly and PDB file that are named booksort.dll and booksort.pdb respectively.
xsltc booksort.xsl /debug  
The following command compiles a style sheet that contains an msxsl:script element and creates two assemblies named calc.dll and calc_Script1.dll.
xsltc /settings:script+ calc.xsl  
The following command enables DTD processing and script support and creates two assemblies named myTest.dll and myTest_Script1.dll.
xsltc /settings:DTD+,script+ /out:myTest calc.xsl  
The following command compiles two style sheet modules and creates a single assembly named booksort.dll.
xsltc booksort.xsl output.xsl