1
0
mirror of https://github.com/TomHarte/CLK.git synced 2024-12-02 17:51:12 +00:00
CLK/Outputs/CRT/Internals/Shaders/Shader.hpp

123 lines
4.2 KiB
C++
Raw Normal View History

//
// Shader.hpp
// Clock Signal
//
// Created by Thomas Harte on 07/02/2016.
// Copyright © 2016 Thomas Harte. All rights reserved.
//
#ifndef Shader_hpp
#define Shader_hpp
2016-02-08 00:21:22 +00:00
#include "OpenGL.hpp"
#include <string>
#include <functional>
#include <vector>
2016-05-15 19:19:52 +00:00
#include <mutex>
2016-02-08 00:21:22 +00:00
namespace OpenGL {
/*!
A @c Shader compiles and holds a shader object, based on a single
vertex program and a single fragment program. Attribute bindings
may be supplied if desired.
*/
class Shader {
public:
enum {
VertexShaderCompilationError,
FragmentShaderCompilationError,
ProgramLinkageError
};
struct AttributeBinding {
2016-11-21 03:57:45 +00:00
const GLchar *const name;
const GLuint index;
};
/*!
Attempts to compile a shader, throwing @c VertexShaderCompilationError, @c FragmentShaderCompilationError or @c ProgramLinkageError upon failure.
@param vertex_shader The vertex shader source code.
@param fragment_shader The fragment shader source code.
@param attribute_bindings Either @c nullptr or an array terminated by an entry with a @c nullptr-name of attribute bindings.
*/
Shader(const std::string &vertex_shader, const std::string &fragment_shader, const AttributeBinding *attribute_bindings);
~Shader();
/*!
Performs an @c glUseProgram to make this the active shader unless:
(i) it was the previous shader bound; and
(ii) no calls have been received to unbind in the interim.
Subsequently performs all work queued up for the next bind irrespective of whether a @c glUseProgram call occurred.
*/
void bind();
/*!
Unbinds the current instance of Shader, if one is bound.
*/
static void unbind();
/*!
Performs a @c glGetAttribLocation call.
@param name The name of the attribute to locate.
@returns The location of the requested attribute.
*/
GLint get_attrib_location(const GLchar *name);
/*!
Performs a @c glGetUniformLocation call.
@param name The name of the uniform to locate.
@returns The location of the requested uniform.
*/
GLint get_uniform_location(const GLchar *name);
/*!
Shorthand for an appropriate sequence of:
* @c get_attrib_location;
* @c glEnableVertexAttribArray;
* @c glVertexAttribPointer;
* @c glVertexAttribDivisor.
*/
void enable_vertex_attribute_with_pointer(const char *name, GLint size, GLenum type, GLboolean normalised, GLsizei stride, const GLvoid *pointer, GLuint divisor);
/*!
All @c set_uniforms queue up the requested uniform changes. Changes are applied automatically the next time the shader is bound.
*/
void set_uniform(const std::string &name, GLint value);
void set_uniform(const std::string &name, GLint value1, GLint value2);
void set_uniform(const std::string &name, GLint value1, GLint value2, GLint value3);
void set_uniform(const std::string &name, GLint value1, GLint value2, GLint value3, GLint value4);
void set_uniform(const std::string &name, GLint size, GLsizei count, const GLint *values);
void set_uniform(const std::string &name, GLfloat value);
void set_uniform(const std::string &name, GLfloat value1, GLfloat value2);
void set_uniform(const std::string &name, GLfloat value1, GLfloat value2, GLfloat value3);
void set_uniform(const std::string &name, GLfloat value1, GLfloat value2, GLfloat value3, GLfloat value4);
void set_uniform(const std::string &name, GLint size, GLsizei count, const GLfloat *values);
void set_uniform(const std::string &name, GLuint value);
void set_uniform(const std::string &name, GLuint value1, GLuint value2);
void set_uniform(const std::string &name, GLuint value1, GLuint value2, GLuint value3);
void set_uniform(const std::string &name, GLuint value1, GLuint value2, GLuint value3, GLuint value4);
void set_uniform(const std::string &name, GLint size, GLsizei count, const GLuint *values);
void set_uniform_matrix(const std::string &name, GLint size, bool transpose, const GLfloat *values);
void set_uniform_matrix(const std::string &name, GLint size, GLsizei count, bool transpose, const GLfloat *values);
private:
GLuint compile_shader(const std::string &source, GLenum type);
2016-11-21 03:57:45 +00:00
GLuint shader_program_;
void flush_functions();
2016-11-21 03:57:45 +00:00
std::vector<std::function<void(void)>> enqueued_functions_;
std::mutex function_mutex_;
protected:
void enqueue_function(std::function<void(void)> function);
};
}
#endif /* Shader_hpp */