CeresEngine 0.2.0
A game development framework
Loading...
Searching...
No Matches
CeresEngine::GLShaderProgram Class Referencefinal

#include <CeresEngine/RenderAPI/OpenGL/GLShader.hpp>

Inheritance diagram for CeresEngine::GLShaderProgram:
CeresEngine::GPUShaderProgram CeresEngine::GLDeviceObject< GLShaderProgram, GPUShaderProgram > CeresEngine::TDeviceObject< GPUShaderProgramDescriptor > CeresEngine::GLObject< ChildTypeName, ParentType > CeresEngine::GPUDeviceObject CeresEngine::GPUObject

Public Member Functions

 GLShaderProgram (GLDevicePtr device, const GPUShaderProgramDescriptor &descriptor)
 
 ~GLShaderProgram () final
 
GPUPipelineLayoutPtr getPipelineLayout () const override
 The pipeline layout deduced for this shader program.
 
void activate (GLCommandBuffer &commandBuffer) const
 Activates the shader for rendering in OpenGL.
 
GLuint handle () const
 
- Public Member Functions inherited from CeresEngine::GPUShaderProgram
 GPUShaderProgram (GPUDevice &device, const Descriptor &descriptor, const GPUShaderReflectionDescriptor &reflection)
 Initializes a new ShaderProgram object instance.
 
 GPUShaderProgram (const GPUShaderProgram &)=delete
 Deleted copy constructor.
 
GPUShaderProgramoperator= (const GPUShaderProgram &)=delete
 
 GPUShaderProgram (GPUShaderProgram &&)=delete
 Deleted move constructor.
 
GPUShaderProgramoperator= (GPUShaderProgram &&)=delete
 
const GPUShaderReflectionDescriptorreflect () const
 Extracts reflection information from the shader.
 
 TDeviceObject (GPUDevice &device, const Descriptor &descriptor)
 Inherited constructors.
 
 TDeviceObject (const TDeviceObject &)=delete
 Inherited constructors.
 
 TDeviceObject (TDeviceObject &&)=delete
 Inherited constructors.
 
- Public Member Functions inherited from CeresEngine::TDeviceObject< GPUShaderProgramDescriptor >
 TDeviceObject (GPUDevice &device, const Descriptor &descriptor)
 Initializes a new RenderAPI device object instance.
 
 TDeviceObject (const TDeviceObject &)=delete
 
 TDeviceObject (TDeviceObject &&)=delete
 
 ~TDeviceObject () override=default
 
TDeviceObjectoperator= (const TDeviceObject &)=delete
 
TDeviceObjectoperator= (TDeviceObject &&)=delete
 
- Public Member Functions inherited from CeresEngine::GPUDeviceObject
 GPUDeviceObject (GPUDevice &device)
 
 ~GPUDeviceObject () override
 
- Public Member Functions inherited from CeresEngine::GPUObject
 GPUObject ()=default
 
virtual ~GPUObject ()=default
 
 GPUObject (const GPUObject &)=delete
 
GPUObjectoperator= (const GPUObject &)=delete
 
 GPUObject (GPUObject &&)=delete
 
GPUObjectoperator= (GPUObject &&)=delete
 
void retain () noexcept
 Retains the object by increment it's reference count by one.
 
bool release () noexcept
 Releases the object by decrementing it's reference count by one.
 

Private Attributes

const GPUShaderProgramDescriptor descriptorGL
 A structure that describes the shader program and it's properties.
 
GLObjectHandle<&glad_glCreateProgram, &glad_glDeleteProgram, falseprogramID {}
 The OpenGL shader program object.
 
GPUShaderProgramDescriptor mDescriptor
 The shader descriptor.
 
GPUShaderReflectionDescriptor mReflectionDescriptor
 The shader reflection descriptor.
 
GLPipelineLayoutPtr mPipelineLayout = nullptr
 The pipeline layout for this shader program.
 

Additional Inherited Members

- Public Types inherited from CeresEngine::TDeviceObject< GPUShaderProgramDescriptor >
using Descriptor = GPUShaderProgramDescriptor
 An type-alias to the descriptor struct type.
 
- Static Public Member Functions inherited from CeresEngine::GLObject< ChildTypeName, ParentType >
static RC< ChildTypeNamecast (const RC< ParentType > &ptr)
 Casts a RC containing a ParentType pointer to a pointer to a pointer to a ChildTypeName.
 
static RC< ChildTypeNamesafeCast (const RC< ParentType > &ptr)
 Safely casts a RC containing a ParentType pointer to a pointer to a pointer to a ChildTypeName.
 
static ChildTypeNamecast (ParentType &object)
 Casts a object of type ParentType to a object of type ChildTypeName.
 
static const ChildTypeNamecast (const ParentType &object)
 Casts a object of type ParentType to a object of type ChildTypeName.
 
static ChildTypeNamecast (ParentType *object)
 Casts a object of type ParentType to a object of type ChildTypeName.
 
static const ChildTypeNamecast (const ParentType *object)
 Casts a object of type ParentType to a object of type ChildTypeName.
 
static ChildTypeNamesafeCast (ParentType *object)
 Casts a object of type ParentType to a object of type ChildTypeName.
 
static const ChildTypeNamesafeCast (const ParentType *object)
 Casts a object of type ParentType to a object of type ChildTypeName.
 
- Public Attributes inherited from CeresEngine::GPUShaderProgram
const GPUShaderReflectionDescriptorreflection
 The shader reflection descriptor.
 
- Public Attributes inherited from CeresEngine::TDeviceObject< GPUShaderProgramDescriptor >
const Descriptordescriptor
 A structure that describes the object and it's properties.
 
- Public Attributes inherited from CeresEngine::GPUDeviceObject
GPUDevicedevice
 The owning device this object was created from.
 
- Protected Member Functions inherited from CeresEngine::GPUObject
virtual void destroy () noexcept
 A internal method called by the system when the object reference count reaches zero.
 
- Protected Member Functions inherited from CeresEngine::GLDeviceObject< GLShaderProgram, GPUShaderProgram >
 GLDeviceObject (GLDevicePtr device)
 Creates a new GLDeviceObject from the given device.
 
- Protected Attributes inherited from CeresEngine::GLDeviceObject< GLShaderProgram, GPUShaderProgram >
GLDevicedeviceGL
 The owning GLDevice instance.
 

Constructor & Destructor Documentation

◆ GLShaderProgram()

CeresEngine::GLShaderProgram::GLShaderProgram ( GLDevicePtr  device,
const GPUShaderProgramDescriptor descriptor 
)

◆ ~GLShaderProgram()

CeresEngine::GLShaderProgram::~GLShaderProgram ( )
final

Member Function Documentation

◆ activate()

void CeresEngine::GLShaderProgram::activate ( GLCommandBuffer commandBuffer) const

Activates the shader for rendering in OpenGL.

◆ getPipelineLayout()

GPUPipelineLayoutPtr CeresEngine::GLShaderProgram::getPipelineLayout ( ) const
inlineoverridevirtual

The pipeline layout deduced for this shader program.

Will be used if the user doesn't provide another when creating a new pipeline.

Can be null if the shader doesn't have any reflection metadata to create a pipeline layout for the program.

Implements CeresEngine::GPUShaderProgram.

◆ handle()

GLuint CeresEngine::GLShaderProgram::handle ( ) const
inline
Returns
The OpenGL object handle

Member Data Documentation

◆ descriptorGL

const GPUShaderProgramDescriptor CeresEngine::GLShaderProgram::descriptorGL
private

A structure that describes the shader program and it's properties.

◆ mDescriptor

GPUShaderProgramDescriptor CeresEngine::GLShaderProgram::mDescriptor
private

The shader descriptor.

◆ mPipelineLayout

GLPipelineLayoutPtr CeresEngine::GLShaderProgram::mPipelineLayout = nullptr
private

The pipeline layout for this shader program.

Will be used in-case the user doesn't provide another when creating a new pipeline.

◆ mReflectionDescriptor

GPUShaderReflectionDescriptor CeresEngine::GLShaderProgram::mReflectionDescriptor
private

The shader reflection descriptor.

◆ programID

GLObjectHandle<& glad_glCreateProgram , & glad_glDeleteProgram , false> CeresEngine::GLShaderProgram::programID {}
private

The OpenGL shader program object.


The documentation for this class was generated from the following file: