1
0
Fork 0
mirror of https://github.com/OpenMW/openmw.git synced 2025-10-24 16:26:36 +00:00
openmw/extern/shiny/Main/ShaderSet.hpp

69 lines
2.3 KiB
C++

#ifndef SH_SHADERSET_H
#define SH_SHADERSET_H
#include <string>
#include <vector>
#include <map>
#include "ShaderInstance.hpp"
namespace sh
{
class PropertySetGet;
typedef std::map<size_t, ShaderInstance> ShaderInstanceMap;
/**
* @brief Contains possible shader permutations of a single uber-shader (represented by one source file)
*/
class ShaderSet
{
public:
ShaderSet (const std::string& type, const std::string& cgProfile, const std::string& hlslProfile, const std::string& sourceFile, const std::string& basePath,
const std::string& name, PropertySetGet* globalSettingsPtr);
~ShaderSet();
/// Retrieve a shader instance for the given properties. \n
/// If a \a ShaderInstance with the same properties exists already, simply returns this instance. \n
/// Otherwise, creates a new \a ShaderInstance (i.e. compiles a new shader). \n
/// Might also return NULL if the shader failed to compile. \n
/// @note Only the properties that actually affect the shader source are taken into consideration here,
/// so it does not matter if you pass any extra properties that the shader does not care about.
ShaderInstance* getInstance (PropertySetGet* properties);
private:
PropertySetGet* getCurrentGlobalSettings() const;
std::string getBasePath() const;
std::string getSource() const;
std::string getCgProfile() const;
std::string getHlslProfile() const;
int getType() const;
friend class ShaderInstance;
private:
GpuProgramType mType;
std::string mSource;
std::string mBasePath;
std::string mCgProfile;
std::string mHlslProfile;
std::string mName;
std::vector <size_t> mFailedToCompile;
std::vector <std::string> mGlobalSettings; ///< names of the global settings that affect the shader source
std::vector <std::string> mProperties; ///< names of the per-material properties that affect the shader source
std::vector <std::string> mPropertiesToExist;
///< same as mProperties, however in this case, it is only relevant if the property is empty or not
/// (we don't care about the value)
ShaderInstanceMap mInstances; ///< maps permutation ID (generated from the properties) to \a ShaderInstance
void parse(); ///< find out which properties and global settings affect the shader source
size_t buildHash (PropertySetGet* properties);
};
}
#endif