Shader authoring/Compiling Shaders: Difference between revisions
		
		
		
		
		
		Jump to navigation
		Jump to search
		
				
		
 
	
 Note:The text file that lists the FXC files should be in the same directory as your shader DLL source code, because your shader DLL source code will need to refer to files that are generated by
Note:The text file that lists the FXC files should be in the same directory as your shader DLL source code, because your shader DLL source code will need to refer to files that are generated by 
 Note:Shader names should adhere to the same convention as the sample ones distributed in the SDK (e.g.
Note:Shader names should adhere to the same convention as the sample ones distributed in the SDK (e.g. 
 Note:A shader compile may fail for many reasons. One of these is a high number of static combinations. This may cause the shader compiler to stop working. It may also stop because of the termination the process externally. A shader compile may also stop if the user terminates the process. When a shader compile is stopped in an unhanded manor, it may cause an issue within the Windows file system on some machines. If you encounter this complication, there are a few steps you can take to fix it. The first step is terminate all instances of the shadercompile executable. This can be dof the executable.one with the following command:
Note:A shader compile may fail for many reasons. One of these is a high number of static combinations. This may cause the shader compiler to stop working. It may also stop because of the termination the process externally. A shader compile may also stop if the user terminates the process. When a shader compile is stopped in an unhanded manor, it may cause an issue within the Windows file system on some machines. If you encounter this complication, there are a few steps you can take to fix it. The first step is terminate all instances of the shadercompile executable. This can be dof the executable.one with the following command: 
		
	
| m (Add a recommendation made to me for Soid State storage media.) | Kestrelguy (talk | contribs)  m (added language bar.) | ||
| Line 1: | Line 1: | ||
| {{Lang|{{PAGENAME}}|title=Compiling Shaders}} | |||
| {{shadertut}} | {{shadertut}} | ||
| To compile  | To compile [[FXC]] files, list them in a text file (one per line), then run <code>src\materialsystem\stdshaders\buildshaders.bat</code> on the text file. It will go process your <code>.fxc</code> code and compile all the combinations into your mod's directory. The syntax of the <code>buildshaders.bat</code> command line is:   | ||
|   buildshaders.bat [text filename] -game [mod directory] -source [source directory] |   buildshaders.bat [text filename] -game [mod directory] -source [source directory] | ||
| Line 9: | Line 10: | ||
|   buildshaders.bat MyShaders -game "C:\Steam\SteamApps\SourceMods\MyMod" -source "C:\MyMod\Src" |   buildshaders.bat MyShaders -game "C:\Steam\SteamApps\SourceMods\MyMod" -source "C:\MyMod\Src" | ||
| {{note|The text file that lists the  | {{note|The text file that lists the FXC files should be in the same directory as your shader DLL source code, because your shader DLL source code will need to refer to files that are generated by <code>buildshaders.bat</code>. | ||
| Before building your shader DLL, you need to run <code>buildshaders.bat</code>, so it can generate include files that your shader DLL will need.}} | Before building your shader DLL, you need to run <code>buildshaders.bat</code>, so it can generate include files that your shader DLL will need.}} | ||
| Refer to <code>stdshaders_dx8.txt</code> and <code>stdshaders_dx9.txt</code> as examples of how to set up your shaders text file. All the source code for the shader DLL should be in the same directory as the . | Refer to <code>stdshaders_dx8.txt</code> and <code>stdshaders_dx9.txt</code> as examples of how to set up your shaders text file. All the source code for the shader DLL should be in the same directory as the <code>.fxc</code>, <code>.[[VSH|vsh]]</code>, and <code>.[[PSH|psh]]</code> files. After <code>buildshaders.bat</code> runs, you can look in the <code>fxctmp9</code> sub-directory to see the include files generated by the shader compiler. | ||
| {{note|Shader names should adhere to the same convention as the sample ones distributed in the SDK (e.g. <code>*_ps20.fxc</code> for pixel shaders conforming to the 2.0 spec, <code>*_vs11.fxc</code> for vertex shaders conforming to the 1.1 spec.)}} | {{note|Shader names should adhere to the same convention as the sample ones distributed in the SDK (e.g. <code>*_ps20.fxc</code> for pixel shaders conforming to the 2.0 spec, <code>*_vs11.fxc</code> for vertex shaders conforming to the 1.1 spec.)}} | ||
| Line 19: | Line 20: | ||
| {{note|A shader compile may fail for many reasons. One of these is a high number of static combinations. This may cause the shader compiler to stop working. It may also stop because of the termination the process externally. A shader compile may also stop if the user terminates the process. When a shader compile is stopped in an unhanded manor, it may cause an issue within the Windows file system on some machines. If you encounter this complication, there are a few steps you can take to fix it. The first step is terminate all instances of the shadercompile executable. This can be dof the executable.one with the following command: <code>taskkill /IM shadercompile /F</code>. This will terminate all instances of shadercompile.exe. The next step is deleting the following folder: <code>%localappdata%/temp/shadercompiletemp</code>. Finally, run the Windows Defragment and Optimize Drives utility and allow it to Defragment the hard drive where your User Directory and Source Code can be found. If you are using a Solid State Drive, use CHKDSK.}} | {{note|A shader compile may fail for many reasons. One of these is a high number of static combinations. This may cause the shader compiler to stop working. It may also stop because of the termination the process externally. A shader compile may also stop if the user terminates the process. When a shader compile is stopped in an unhanded manor, it may cause an issue within the Windows file system on some machines. If you encounter this complication, there are a few steps you can take to fix it. The first step is terminate all instances of the shadercompile executable. This can be dof the executable.one with the following command: <code>taskkill /IM shadercompile /F</code>. This will terminate all instances of shadercompile.exe. The next step is deleting the following folder: <code>%localappdata%/temp/shadercompiletemp</code>. Finally, run the Windows Defragment and Optimize Drives utility and allow it to Defragment the hard drive where your User Directory and Source Code can be found. If you are using a Solid State Drive, use CHKDSK.}} | ||
| [[Category: Programming]][[Category: Shaders]] | |||
| [[Category: Programming]] | |||
| [[Category: Shaders]] | |||
Revision as of 06:49, 9 May 2022

 
To compile FXC files, list them in a text file (one per line), then run src\materialsystem\stdshaders\buildshaders.bat on the text file. It will go process your .fxc code and compile all the combinations into your mod's directory. The syntax of the buildshaders.bat command line is: 
buildshaders.bat [text filename] -game [mod directory] -source [source directory]
Example:
buildshaders.bat MyShaders -game "C:\Steam\SteamApps\SourceMods\MyMod" -source "C:\MyMod\Src"
 Note:The text file that lists the FXC files should be in the same directory as your shader DLL source code, because your shader DLL source code will need to refer to files that are generated by
Note:The text file that lists the FXC files should be in the same directory as your shader DLL source code, because your shader DLL source code will need to refer to files that are generated by buildshaders.bat.
Before building your shader DLL, you need to run buildshaders.bat, so it can generate include files that your shader DLL will need.Refer to stdshaders_dx8.txt and stdshaders_dx9.txt as examples of how to set up your shaders text file. All the source code for the shader DLL should be in the same directory as the .fxc, .vsh, and .psh files. After buildshaders.bat runs, you can look in the fxctmp9 sub-directory to see the include files generated by the shader compiler.
 Note:Shader names should adhere to the same convention as the sample ones distributed in the SDK (e.g.
Note:Shader names should adhere to the same convention as the sample ones distributed in the SDK (e.g. *_ps20.fxc for pixel shaders conforming to the 2.0 spec, *_vs11.fxc for vertex shaders conforming to the 1.1 spec.) Note:A shader compile may fail for many reasons. One of these is a high number of static combinations. This may cause the shader compiler to stop working. It may also stop because of the termination the process externally. A shader compile may also stop if the user terminates the process. When a shader compile is stopped in an unhanded manor, it may cause an issue within the Windows file system on some machines. If you encounter this complication, there are a few steps you can take to fix it. The first step is terminate all instances of the shadercompile executable. This can be dof the executable.one with the following command:
Note:A shader compile may fail for many reasons. One of these is a high number of static combinations. This may cause the shader compiler to stop working. It may also stop because of the termination the process externally. A shader compile may also stop if the user terminates the process. When a shader compile is stopped in an unhanded manor, it may cause an issue within the Windows file system on some machines. If you encounter this complication, there are a few steps you can take to fix it. The first step is terminate all instances of the shadercompile executable. This can be dof the executable.one with the following command: taskkill /IM shadercompile /F. This will terminate all instances of shadercompile.exe. The next step is deleting the following folder: %localappdata%/temp/shadercompiletemp. Finally, run the Windows Defragment and Optimize Drives utility and allow it to Defragment the hard drive where your User Directory and Source Code can be found. If you are using a Solid State Drive, use CHKDSK.






















