Jump to content
  • Advertisement
Sign in to follow this  
Quat

Building Shaders

This topic is 1868 days old which is more than the 365 day threshold we allow for new replies. Please post a new topic.

If you intended to correct an error in the post then please contact us.

Recommended Posts

How do pros compile their shaders as part of their build pipeline? 

 

Right now, I am using a custom build step in Visual Studio to call fxc.  I have to call fxc for each permutation (specifying the various #define), which is kind of annoying for shaders that have a lot of permutations.  On the other hand, the old "Effects" framework was not much better in that you had to define a technique for each permutation. 

Share this post


Link to post
Share on other sites
Advertisement

We have an complex in-house system that's used for building and processing content. It will export meshes and other data from maya files, process vertex data, compile shaders, pack archives and do anything else that's necessary to generate efficient, runtime-ready data that can be loaded on the target platform. In our content system materials will define which permutations they can have, and will also specify which shader code to use. Then when we process a mesh we will look at the materials assigned to it, figure out which permutation it needs, and compile the necessary shaders.

Share this post


Link to post
Share on other sites

How do pros compile their shaders as part of their build pipeline? 

 

Right now, I am using a custom build step in Visual Studio to call fxc.  I have to call fxc for each permutation (specifying the various #define), which is kind of annoying for shaders that have a lot of permutations.  On the other hand, the old "Effects" framework was not much better in that you had to define a technique for each permutation. 

Are you using VS2012?  If so, then you don't need to create a custom build step as there is integrated support for compiling HLSL files.  Unfortunately there is a limit of one build rule for each HLSL file, so you have to play games with adding an empty HLSL file and just include the original target file to be able to specify multiple build targets from a single file.

Share this post


Link to post
Share on other sites

It will export meshes and other data from maya files, process vertex data, compile shaders, pack archives and do anything else that's necessary to generate efficient, runtime-ready data that can be loaded on the target platform. In our content system materials will define which permutations they can have, and will also specify which shader code to use.

 

Thanks for the info.  I'll have to see if I can get time scheduled in to make a more sophisticated system.  Does your build system also take into consideration different render pass settings and global settings?  For example, one might want to use a simpler shader for a reflection pass.  Also global settings the user sets could affect which shader permutation (e.g., shadows on/off). 

 

Are you using VS2012?  If so, then you don't need to create a custom build step as there is integrated support for compiling HLSL files.  Unfortunately there is a limit of one build rule for each HLSL file, so you have to play games with adding an empty HLSL file and just include the original target file to be able to specify multiple build targets from a single file.

 

Still on VS2010, but I've played with VS2012 for metro apps, and yeah, the one build rule is kind of annoying. 

Share this post


Link to post
Share on other sites
Sign in to follow this  

  • Advertisement
×

Important Information

By using GameDev.net, you agree to our community Guidelines, Terms of Use, and Privacy Policy.

Participate in the game development conversation and more when you create an account on GameDev.net!

Sign me up!