src/ascension/shader.h

Sun, 15 Jun 2025 19:50:51 +0200

author
Mike Becker <universe@uap-core.de>
date
Sun, 15 Jun 2025 19:50:51 +0200
changeset 153
4116e2bd501b
parent 145
a3231310d66d
child 158
f650994ec543
permissions
-rw-r--r--

since we cannot pass NULL strings anyway, we do not need cxstring

15
362b7659dc76 add shader loading and unloading
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1 /*
362b7659dc76 add shader loading and unloading
Mike Becker <universe@uap-core.de>
parents:
diff changeset
2 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS HEADER.
362b7659dc76 add shader loading and unloading
Mike Becker <universe@uap-core.de>
parents:
diff changeset
3 * Copyright 2023 Mike Becker. All rights reserved.
362b7659dc76 add shader loading and unloading
Mike Becker <universe@uap-core.de>
parents:
diff changeset
4 *
362b7659dc76 add shader loading and unloading
Mike Becker <universe@uap-core.de>
parents:
diff changeset
5 * Redistribution and use in source and binary forms, with or without
362b7659dc76 add shader loading and unloading
Mike Becker <universe@uap-core.de>
parents:
diff changeset
6 * modification, are permitted provided that the following conditions are met:
362b7659dc76 add shader loading and unloading
Mike Becker <universe@uap-core.de>
parents:
diff changeset
7 *
362b7659dc76 add shader loading and unloading
Mike Becker <universe@uap-core.de>
parents:
diff changeset
8 * 1. Redistributions of source code must retain the above copyright
362b7659dc76 add shader loading and unloading
Mike Becker <universe@uap-core.de>
parents:
diff changeset
9 * notice, this list of conditions and the following disclaimer.
362b7659dc76 add shader loading and unloading
Mike Becker <universe@uap-core.de>
parents:
diff changeset
10 *
362b7659dc76 add shader loading and unloading
Mike Becker <universe@uap-core.de>
parents:
diff changeset
11 * 2. Redistributions in binary form must reproduce the above copyright
362b7659dc76 add shader loading and unloading
Mike Becker <universe@uap-core.de>
parents:
diff changeset
12 * notice, this list of conditions and the following disclaimer in the
362b7659dc76 add shader loading and unloading
Mike Becker <universe@uap-core.de>
parents:
diff changeset
13 * documentation and/or other materials provided with the distribution.
362b7659dc76 add shader loading and unloading
Mike Becker <universe@uap-core.de>
parents:
diff changeset
14 *
362b7659dc76 add shader loading and unloading
Mike Becker <universe@uap-core.de>
parents:
diff changeset
15 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
362b7659dc76 add shader loading and unloading
Mike Becker <universe@uap-core.de>
parents:
diff changeset
16 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
362b7659dc76 add shader loading and unloading
Mike Becker <universe@uap-core.de>
parents:
diff changeset
17 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
362b7659dc76 add shader loading and unloading
Mike Becker <universe@uap-core.de>
parents:
diff changeset
18 * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
362b7659dc76 add shader loading and unloading
Mike Becker <universe@uap-core.de>
parents:
diff changeset
19 * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
362b7659dc76 add shader loading and unloading
Mike Becker <universe@uap-core.de>
parents:
diff changeset
20 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
362b7659dc76 add shader loading and unloading
Mike Becker <universe@uap-core.de>
parents:
diff changeset
21 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
362b7659dc76 add shader loading and unloading
Mike Becker <universe@uap-core.de>
parents:
diff changeset
22 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
362b7659dc76 add shader loading and unloading
Mike Becker <universe@uap-core.de>
parents:
diff changeset
23 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
362b7659dc76 add shader loading and unloading
Mike Becker <universe@uap-core.de>
parents:
diff changeset
24 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
362b7659dc76 add shader loading and unloading
Mike Becker <universe@uap-core.de>
parents:
diff changeset
25 * POSSIBILITY OF SUCH DAMAGE.
362b7659dc76 add shader loading and unloading
Mike Becker <universe@uap-core.de>
parents:
diff changeset
26 */
362b7659dc76 add shader loading and unloading
Mike Becker <universe@uap-core.de>
parents:
diff changeset
27
362b7659dc76 add shader loading and unloading
Mike Becker <universe@uap-core.de>
parents:
diff changeset
28 #ifndef ASCENSION_SHADER_H
362b7659dc76 add shader loading and unloading
Mike Becker <universe@uap-core.de>
parents:
diff changeset
29 #define ASCENSION_SHADER_H
362b7659dc76 add shader loading and unloading
Mike Becker <universe@uap-core.de>
parents:
diff changeset
30
137
f8e6e0ae61a8 remove pre-defined dummy textures by introducing conditional compilation for shaders
Mike Becker <universe@uap-core.de>
parents: 88
diff changeset
31 #include "camera.h"
f8e6e0ae61a8 remove pre-defined dummy textures by introducing conditional compilation for shaders
Mike Becker <universe@uap-core.de>
parents: 88
diff changeset
32
f8e6e0ae61a8 remove pre-defined dummy textures by introducing conditional compilation for shaders
Mike Becker <universe@uap-core.de>
parents: 88
diff changeset
33 struct asc_shader_code_files_s {
f8e6e0ae61a8 remove pre-defined dummy textures by introducing conditional compilation for shaders
Mike Becker <universe@uap-core.de>
parents: 88
diff changeset
34 /**
f8e6e0ae61a8 remove pre-defined dummy textures by introducing conditional compilation for shaders
Mike Becker <universe@uap-core.de>
parents: 88
diff changeset
35 * File name of the vertex shader.
f8e6e0ae61a8 remove pre-defined dummy textures by introducing conditional compilation for shaders
Mike Becker <universe@uap-core.de>
parents: 88
diff changeset
36 */
77
2187a732f4d7 prepare code for embedding shader sources with c23 #embed
Mike Becker <universe@uap-core.de>
parents: 72
diff changeset
37 const char *vtx;
137
f8e6e0ae61a8 remove pre-defined dummy textures by introducing conditional compilation for shaders
Mike Becker <universe@uap-core.de>
parents: 88
diff changeset
38 /**
f8e6e0ae61a8 remove pre-defined dummy textures by introducing conditional compilation for shaders
Mike Becker <universe@uap-core.de>
parents: 88
diff changeset
39 * File name of the fragment shader.
f8e6e0ae61a8 remove pre-defined dummy textures by introducing conditional compilation for shaders
Mike Becker <universe@uap-core.de>
parents: 88
diff changeset
40 */
77
2187a732f4d7 prepare code for embedding shader sources with c23 #embed
Mike Becker <universe@uap-core.de>
parents: 72
diff changeset
41 const char *frag;
137
f8e6e0ae61a8 remove pre-defined dummy textures by introducing conditional compilation for shaders
Mike Becker <universe@uap-core.de>
parents: 88
diff changeset
42 };
f8e6e0ae61a8 remove pre-defined dummy textures by introducing conditional compilation for shaders
Mike Becker <universe@uap-core.de>
parents: 88
diff changeset
43
f8e6e0ae61a8 remove pre-defined dummy textures by introducing conditional compilation for shaders
Mike Becker <universe@uap-core.de>
parents: 88
diff changeset
44 struct asc_shader_code_defines_s {
f8e6e0ae61a8 remove pre-defined dummy textures by introducing conditional compilation for shaders
Mike Becker <universe@uap-core.de>
parents: 88
diff changeset
45 /**
f8e6e0ae61a8 remove pre-defined dummy textures by introducing conditional compilation for shaders
Mike Becker <universe@uap-core.de>
parents: 88
diff changeset
46 * Preprocessor code that shall be prepended to the vertex shader.
f8e6e0ae61a8 remove pre-defined dummy textures by introducing conditional compilation for shaders
Mike Becker <universe@uap-core.de>
parents: 88
diff changeset
47 */
f8e6e0ae61a8 remove pre-defined dummy textures by introducing conditional compilation for shaders
Mike Becker <universe@uap-core.de>
parents: 88
diff changeset
48 const char *vtx;
f8e6e0ae61a8 remove pre-defined dummy textures by introducing conditional compilation for shaders
Mike Becker <universe@uap-core.de>
parents: 88
diff changeset
49 /**
f8e6e0ae61a8 remove pre-defined dummy textures by introducing conditional compilation for shaders
Mike Becker <universe@uap-core.de>
parents: 88
diff changeset
50 * Preprocessor code that shall be prepended to the fragment shader.
f8e6e0ae61a8 remove pre-defined dummy textures by introducing conditional compilation for shaders
Mike Becker <universe@uap-core.de>
parents: 88
diff changeset
51 */
f8e6e0ae61a8 remove pre-defined dummy textures by introducing conditional compilation for shaders
Mike Becker <universe@uap-core.de>
parents: 88
diff changeset
52 const char *frag;
f8e6e0ae61a8 remove pre-defined dummy textures by introducing conditional compilation for shaders
Mike Becker <universe@uap-core.de>
parents: 88
diff changeset
53 };
f8e6e0ae61a8 remove pre-defined dummy textures by introducing conditional compilation for shaders
Mike Becker <universe@uap-core.de>
parents: 88
diff changeset
54
f8e6e0ae61a8 remove pre-defined dummy textures by introducing conditional compilation for shaders
Mike Becker <universe@uap-core.de>
parents: 88
diff changeset
55 typedef struct asc_shader_code_info_s {
f8e6e0ae61a8 remove pre-defined dummy textures by introducing conditional compilation for shaders
Mike Becker <universe@uap-core.de>
parents: 88
diff changeset
56 struct asc_shader_code_files_s files;
f8e6e0ae61a8 remove pre-defined dummy textures by introducing conditional compilation for shaders
Mike Becker <universe@uap-core.de>
parents: 88
diff changeset
57 struct asc_shader_code_defines_s defines;
f8e6e0ae61a8 remove pre-defined dummy textures by introducing conditional compilation for shaders
Mike Becker <universe@uap-core.de>
parents: 88
diff changeset
58 } AscShaderCodeInfo;
78
9bc544f4ce8f go back to reading shader code from files
Mike Becker <universe@uap-core.de>
parents: 77
diff changeset
59
145
a3231310d66d consistent naming of structs and their typedefs
Mike Becker <universe@uap-core.de>
parents: 144
diff changeset
60 typedef struct asc_shader_codes_s {
78
9bc544f4ce8f go back to reading shader code from files
Mike Becker <universe@uap-core.de>
parents: 77
diff changeset
61 char *vtx;
9bc544f4ce8f go back to reading shader code from files
Mike Becker <universe@uap-core.de>
parents: 77
diff changeset
62 char *frag;
137
f8e6e0ae61a8 remove pre-defined dummy textures by introducing conditional compilation for shaders
Mike Becker <universe@uap-core.de>
parents: 88
diff changeset
63 /**
f8e6e0ae61a8 remove pre-defined dummy textures by introducing conditional compilation for shaders
Mike Becker <universe@uap-core.de>
parents: 88
diff changeset
64 * Optional preprocessor code for the vertex shader.
f8e6e0ae61a8 remove pre-defined dummy textures by introducing conditional compilation for shaders
Mike Becker <universe@uap-core.de>
parents: 88
diff changeset
65 */
f8e6e0ae61a8 remove pre-defined dummy textures by introducing conditional compilation for shaders
Mike Becker <universe@uap-core.de>
parents: 88
diff changeset
66 const char *vtx_pp;
f8e6e0ae61a8 remove pre-defined dummy textures by introducing conditional compilation for shaders
Mike Becker <universe@uap-core.de>
parents: 88
diff changeset
67 /**
f8e6e0ae61a8 remove pre-defined dummy textures by introducing conditional compilation for shaders
Mike Becker <universe@uap-core.de>
parents: 88
diff changeset
68 * Optional preprocessor code for the fragment shader.
f8e6e0ae61a8 remove pre-defined dummy textures by introducing conditional compilation for shaders
Mike Becker <universe@uap-core.de>
parents: 88
diff changeset
69 */
f8e6e0ae61a8 remove pre-defined dummy textures by introducing conditional compilation for shaders
Mike Becker <universe@uap-core.de>
parents: 88
diff changeset
70 const char *frag_pp;
77
2187a732f4d7 prepare code for embedding shader sources with c23 #embed
Mike Becker <universe@uap-core.de>
parents: 72
diff changeset
71 } AscShaderCodes;
15
362b7659dc76 add shader loading and unloading
Mike Becker <universe@uap-core.de>
parents:
diff changeset
72
145
a3231310d66d consistent naming of structs and their typedefs
Mike Becker <universe@uap-core.de>
parents: 144
diff changeset
73 typedef struct asc_shader_program_s {
15
362b7659dc76 add shader loading and unloading
Mike Becker <universe@uap-core.de>
parents:
diff changeset
74 unsigned int id;
139
5d655459db85 refactor shader management - resolves #684
Mike Becker <universe@uap-core.de>
parents: 137
diff changeset
75 unsigned int gl_id;
16
c5dde81b6fb2 add text rendering and demo FPS counter
Mike Becker <universe@uap-core.de>
parents: 15
diff changeset
76 int model;
c5dde81b6fb2 add text rendering and demo FPS counter
Mike Becker <universe@uap-core.de>
parents: 15
diff changeset
77 int view;
c5dde81b6fb2 add text rendering and demo FPS counter
Mike Becker <universe@uap-core.de>
parents: 15
diff changeset
78 int projection;
139
5d655459db85 refactor shader management - resolves #684
Mike Becker <universe@uap-core.de>
parents: 137
diff changeset
79 cx_destructor_func destr_func;
15
362b7659dc76 add shader loading and unloading
Mike Becker <universe@uap-core.de>
parents:
diff changeset
80 } AscShaderProgram;
362b7659dc76 add shader loading and unloading
Mike Becker <universe@uap-core.de>
parents:
diff changeset
81
362b7659dc76 add shader loading and unloading
Mike Becker <universe@uap-core.de>
parents:
diff changeset
82 /**
139
5d655459db85 refactor shader management - resolves #684
Mike Becker <universe@uap-core.de>
parents: 137
diff changeset
83 * The maximum ID for a user defined shader.
5d655459db85 refactor shader management - resolves #684
Mike Becker <universe@uap-core.de>
parents: 137
diff changeset
84 *
5d655459db85 refactor shader management - resolves #684
Mike Becker <universe@uap-core.de>
parents: 137
diff changeset
85 * The IDs above this number are reserved for the engine.
5d655459db85 refactor shader management - resolves #684
Mike Becker <universe@uap-core.de>
parents: 137
diff changeset
86 */
5d655459db85 refactor shader management - resolves #684
Mike Becker <universe@uap-core.de>
parents: 137
diff changeset
87 #define ASC_SHADER_ID_USER_MAX 1'000'000'000u
5d655459db85 refactor shader management - resolves #684
Mike Becker <universe@uap-core.de>
parents: 137
diff changeset
88
5d655459db85 refactor shader management - resolves #684
Mike Becker <universe@uap-core.de>
parents: 137
diff changeset
89 typedef AscShaderProgram*(*asc_shader_create_func)(void);
5d655459db85 refactor shader management - resolves #684
Mike Becker <universe@uap-core.de>
parents: 137
diff changeset
90
5d655459db85 refactor shader management - resolves #684
Mike Becker <universe@uap-core.de>
parents: 137
diff changeset
91 /**
78
9bc544f4ce8f go back to reading shader code from files
Mike Becker <universe@uap-core.de>
parents: 77
diff changeset
92 * Loads shader codes from files.
9bc544f4ce8f go back to reading shader code from files
Mike Becker <universe@uap-core.de>
parents: 77
diff changeset
93 *
137
f8e6e0ae61a8 remove pre-defined dummy textures by introducing conditional compilation for shaders
Mike Becker <universe@uap-core.de>
parents: 88
diff changeset
94 * @param info the structure containing the file names and preprocessing info
78
9bc544f4ce8f go back to reading shader code from files
Mike Becker <universe@uap-core.de>
parents: 77
diff changeset
95 * @param codes the structure where to store the loaded codes
80
9f7bfc0a1dc3 some minor improvements
Mike Becker <universe@uap-core.de>
parents: 78
diff changeset
96 * @return zero on success, non-zero on failure
78
9bc544f4ce8f go back to reading shader code from files
Mike Becker <universe@uap-core.de>
parents: 77
diff changeset
97 */
137
f8e6e0ae61a8 remove pre-defined dummy textures by introducing conditional compilation for shaders
Mike Becker <universe@uap-core.de>
parents: 88
diff changeset
98 int asc_shader_load_code_files(AscShaderCodeInfo info, AscShaderCodes *codes);
78
9bc544f4ce8f go back to reading shader code from files
Mike Becker <universe@uap-core.de>
parents: 77
diff changeset
99
9bc544f4ce8f go back to reading shader code from files
Mike Becker <universe@uap-core.de>
parents: 77
diff changeset
100 /**
9bc544f4ce8f go back to reading shader code from files
Mike Becker <universe@uap-core.de>
parents: 77
diff changeset
101 * Deallocates the memory for the source codes.
9bc544f4ce8f go back to reading shader code from files
Mike Becker <universe@uap-core.de>
parents: 77
diff changeset
102 *
9bc544f4ce8f go back to reading shader code from files
Mike Becker <universe@uap-core.de>
parents: 77
diff changeset
103 * @param codes the structure containing pointers to the source codes
9bc544f4ce8f go back to reading shader code from files
Mike Becker <universe@uap-core.de>
parents: 77
diff changeset
104 */
9bc544f4ce8f go back to reading shader code from files
Mike Becker <universe@uap-core.de>
parents: 77
diff changeset
105 void asc_shader_free_codes(AscShaderCodes codes);
9bc544f4ce8f go back to reading shader code from files
Mike Becker <universe@uap-core.de>
parents: 77
diff changeset
106
9bc544f4ce8f go back to reading shader code from files
Mike Becker <universe@uap-core.de>
parents: 77
diff changeset
107 /**
77
2187a732f4d7 prepare code for embedding shader sources with c23 #embed
Mike Becker <universe@uap-core.de>
parents: 72
diff changeset
108 * Creates a shader program.
2187a732f4d7 prepare code for embedding shader sources with c23 #embed
Mike Becker <universe@uap-core.de>
parents: 72
diff changeset
109 *
139
5d655459db85 refactor shader management - resolves #684
Mike Becker <universe@uap-core.de>
parents: 137
diff changeset
110 * @note This function intentionally has an unspecified pointer return type
5d655459db85 refactor shader management - resolves #684
Mike Becker <universe@uap-core.de>
parents: 137
diff changeset
111 * so that you can assign the return value to your shader struct pointer without casts.
5d655459db85 refactor shader management - resolves #684
Mike Becker <universe@uap-core.de>
parents: 137
diff changeset
112 *
77
2187a732f4d7 prepare code for embedding shader sources with c23 #embed
Mike Becker <universe@uap-core.de>
parents: 72
diff changeset
113 * @param codes the (zero-terminated) source codes
139
5d655459db85 refactor shader management - resolves #684
Mike Becker <universe@uap-core.de>
parents: 137
diff changeset
114 * @param mem_size the memory size required for the structure
5d655459db85 refactor shader management - resolves #684
Mike Becker <universe@uap-core.de>
parents: 137
diff changeset
115 * @return the compiled and linked shader program with @c AscShaderProgram as base struct
77
2187a732f4d7 prepare code for embedding shader sources with c23 #embed
Mike Becker <universe@uap-core.de>
parents: 72
diff changeset
116 */
139
5d655459db85 refactor shader management - resolves #684
Mike Becker <universe@uap-core.de>
parents: 137
diff changeset
117 void *asc_shader_create(AscShaderCodes codes, size_t mem_size);
15
362b7659dc76 add shader loading and unloading
Mike Becker <universe@uap-core.de>
parents:
diff changeset
118
80
9f7bfc0a1dc3 some minor improvements
Mike Becker <universe@uap-core.de>
parents: 78
diff changeset
119 /**
139
5d655459db85 refactor shader management - resolves #684
Mike Becker <universe@uap-core.de>
parents: 137
diff changeset
120 * Frees a shader program.
80
9f7bfc0a1dc3 some minor improvements
Mike Becker <universe@uap-core.de>
parents: 78
diff changeset
121 *
9f7bfc0a1dc3 some minor improvements
Mike Becker <universe@uap-core.de>
parents: 78
diff changeset
122 * @param program the program
9f7bfc0a1dc3 some minor improvements
Mike Becker <universe@uap-core.de>
parents: 78
diff changeset
123 */
139
5d655459db85 refactor shader management - resolves #684
Mike Becker <universe@uap-core.de>
parents: 137
diff changeset
124 void asc_shader_free(AscShaderProgram *program);
5d655459db85 refactor shader management - resolves #684
Mike Becker <universe@uap-core.de>
parents: 137
diff changeset
125
140
d190fe5315bd add dynamic reload of all shaders
Mike Becker <universe@uap-core.de>
parents: 139
diff changeset
126 /**
d190fe5315bd add dynamic reload of all shaders
Mike Becker <universe@uap-core.de>
parents: 139
diff changeset
127 * Activates a shader for use.
d190fe5315bd add dynamic reload of all shaders
Mike Becker <universe@uap-core.de>
parents: 139
diff changeset
128 *
144
43636d6a6e25 do not try to use one distinct render group for each different shader
Mike Becker <universe@uap-core.de>
parents: 140
diff changeset
129 * Does nothing when the shader is already active.
43636d6a6e25 do not try to use one distinct render group for each different shader
Mike Becker <universe@uap-core.de>
parents: 140
diff changeset
130 *
43636d6a6e25 do not try to use one distinct render group for each different shader
Mike Becker <universe@uap-core.de>
parents: 140
diff changeset
131 * @param shader the shader program to use or @c NULL to deactivate any shader
140
d190fe5315bd add dynamic reload of all shaders
Mike Becker <universe@uap-core.de>
parents: 139
diff changeset
132 * @param camera the camera matrices (view/projection) to upload
d190fe5315bd add dynamic reload of all shaders
Mike Becker <universe@uap-core.de>
parents: 139
diff changeset
133 */
139
5d655459db85 refactor shader management - resolves #684
Mike Becker <universe@uap-core.de>
parents: 137
diff changeset
134 void asc_shader_use(const AscShaderProgram *shader, const AscCamera *camera);
80
9f7bfc0a1dc3 some minor improvements
Mike Becker <universe@uap-core.de>
parents: 78
diff changeset
135
139
5d655459db85 refactor shader management - resolves #684
Mike Becker <universe@uap-core.de>
parents: 137
diff changeset
136
140
d190fe5315bd add dynamic reload of all shaders
Mike Becker <universe@uap-core.de>
parents: 139
diff changeset
137 /**
d190fe5315bd add dynamic reload of all shaders
Mike Becker <universe@uap-core.de>
parents: 139
diff changeset
138 * Registers a shader under a certain ID.
d190fe5315bd add dynamic reload of all shaders
Mike Becker <universe@uap-core.de>
parents: 139
diff changeset
139 *
144
43636d6a6e25 do not try to use one distinct render group for each different shader
Mike Becker <universe@uap-core.de>
parents: 140
diff changeset
140 * @note This function intentionally has an unspecified pointer return type
43636d6a6e25 do not try to use one distinct render group for each different shader
Mike Becker <universe@uap-core.de>
parents: 140
diff changeset
141 * so that you can assign the return value to your shader struct pointer without casts.
43636d6a6e25 do not try to use one distinct render group for each different shader
Mike Becker <universe@uap-core.de>
parents: 140
diff changeset
142 * All shader structs must be based on @c AscShaderProgram.
43636d6a6e25 do not try to use one distinct render group for each different shader
Mike Becker <universe@uap-core.de>
parents: 140
diff changeset
143 *
140
d190fe5315bd add dynamic reload of all shaders
Mike Becker <universe@uap-core.de>
parents: 139
diff changeset
144 * @param id the custom ID of the shader
d190fe5315bd add dynamic reload of all shaders
Mike Becker <universe@uap-core.de>
parents: 139
diff changeset
145 * @param create_func the function that creates the shader
d190fe5315bd add dynamic reload of all shaders
Mike Becker <universe@uap-core.de>
parents: 139
diff changeset
146 * @return the shader created by the @c create_func
d190fe5315bd add dynamic reload of all shaders
Mike Becker <universe@uap-core.de>
parents: 139
diff changeset
147 * @see asc_shader_lookup()
d190fe5315bd add dynamic reload of all shaders
Mike Becker <universe@uap-core.de>
parents: 139
diff changeset
148 */
144
43636d6a6e25 do not try to use one distinct render group for each different shader
Mike Becker <universe@uap-core.de>
parents: 140
diff changeset
149 const void *asc_shader_register(unsigned int id, asc_shader_create_func create_func);
140
d190fe5315bd add dynamic reload of all shaders
Mike Becker <universe@uap-core.de>
parents: 139
diff changeset
150
d190fe5315bd add dynamic reload of all shaders
Mike Becker <universe@uap-core.de>
parents: 139
diff changeset
151 /**
d190fe5315bd add dynamic reload of all shaders
Mike Becker <universe@uap-core.de>
parents: 139
diff changeset
152 * Looks up a shader by ID.
d190fe5315bd add dynamic reload of all shaders
Mike Becker <universe@uap-core.de>
parents: 139
diff changeset
153 *
144
43636d6a6e25 do not try to use one distinct render group for each different shader
Mike Becker <universe@uap-core.de>
parents: 140
diff changeset
154 * @note This function intentionally has an unspecified pointer return type
43636d6a6e25 do not try to use one distinct render group for each different shader
Mike Becker <universe@uap-core.de>
parents: 140
diff changeset
155 * so that you can assign the return value to your shader struct pointer without casts.
43636d6a6e25 do not try to use one distinct render group for each different shader
Mike Becker <universe@uap-core.de>
parents: 140
diff changeset
156 * All shader structs must be based on @c AscShaderProgram.
43636d6a6e25 do not try to use one distinct render group for each different shader
Mike Becker <universe@uap-core.de>
parents: 140
diff changeset
157 *
140
d190fe5315bd add dynamic reload of all shaders
Mike Becker <universe@uap-core.de>
parents: 139
diff changeset
158 * @param id the ID of the shader to look up
d190fe5315bd add dynamic reload of all shaders
Mike Becker <universe@uap-core.de>
parents: 139
diff changeset
159 * @return the shader or @c NULL if no shader with such ID exists
d190fe5315bd add dynamic reload of all shaders
Mike Becker <universe@uap-core.de>
parents: 139
diff changeset
160 * @see asc_shader_register()
d190fe5315bd add dynamic reload of all shaders
Mike Becker <universe@uap-core.de>
parents: 139
diff changeset
161 */
144
43636d6a6e25 do not try to use one distinct render group for each different shader
Mike Becker <universe@uap-core.de>
parents: 140
diff changeset
162 const void *asc_shader_lookup(unsigned int id);
140
d190fe5315bd add dynamic reload of all shaders
Mike Becker <universe@uap-core.de>
parents: 139
diff changeset
163
d190fe5315bd add dynamic reload of all shaders
Mike Becker <universe@uap-core.de>
parents: 139
diff changeset
164 /**
d190fe5315bd add dynamic reload of all shaders
Mike Becker <universe@uap-core.de>
parents: 139
diff changeset
165 * Looks up a shader by ID or registers a new one if no shader exists with the specified ID.
d190fe5315bd add dynamic reload of all shaders
Mike Becker <universe@uap-core.de>
parents: 139
diff changeset
166 *
d190fe5315bd add dynamic reload of all shaders
Mike Becker <universe@uap-core.de>
parents: 139
diff changeset
167 * This function can be used for lazy initialization of shaders.
d190fe5315bd add dynamic reload of all shaders
Mike Becker <universe@uap-core.de>
parents: 139
diff changeset
168 *
144
43636d6a6e25 do not try to use one distinct render group for each different shader
Mike Becker <universe@uap-core.de>
parents: 140
diff changeset
169 * @note This function intentionally has an unspecified pointer return type
43636d6a6e25 do not try to use one distinct render group for each different shader
Mike Becker <universe@uap-core.de>
parents: 140
diff changeset
170 * so that you can assign the return value to your shader struct pointer without casts.
43636d6a6e25 do not try to use one distinct render group for each different shader
Mike Becker <universe@uap-core.de>
parents: 140
diff changeset
171 * All shader structs must be based on @c AscShaderProgram.
43636d6a6e25 do not try to use one distinct render group for each different shader
Mike Becker <universe@uap-core.de>
parents: 140
diff changeset
172 *
140
d190fe5315bd add dynamic reload of all shaders
Mike Becker <universe@uap-core.de>
parents: 139
diff changeset
173 * @param id the custom ID of the shader
d190fe5315bd add dynamic reload of all shaders
Mike Becker <universe@uap-core.de>
parents: 139
diff changeset
174 * @param create_func the function to create the shader
d190fe5315bd add dynamic reload of all shaders
Mike Becker <universe@uap-core.de>
parents: 139
diff changeset
175 * @return the found shader or the newly created shader
d190fe5315bd add dynamic reload of all shaders
Mike Becker <universe@uap-core.de>
parents: 139
diff changeset
176 * @see asc_shader_lookup()
d190fe5315bd add dynamic reload of all shaders
Mike Becker <universe@uap-core.de>
parents: 139
diff changeset
177 * @see asc_shader_register()
d190fe5315bd add dynamic reload of all shaders
Mike Becker <universe@uap-core.de>
parents: 139
diff changeset
178 */
144
43636d6a6e25 do not try to use one distinct render group for each different shader
Mike Becker <universe@uap-core.de>
parents: 140
diff changeset
179 const void *asc_shader_lookup_or_create(unsigned int id, asc_shader_create_func create_func);
80
9f7bfc0a1dc3 some minor improvements
Mike Becker <universe@uap-core.de>
parents: 78
diff changeset
180
140
d190fe5315bd add dynamic reload of all shaders
Mike Becker <universe@uap-core.de>
parents: 139
diff changeset
181
d190fe5315bd add dynamic reload of all shaders
Mike Becker <universe@uap-core.de>
parents: 139
diff changeset
182 /**
d190fe5315bd add dynamic reload of all shaders
Mike Becker <universe@uap-core.de>
parents: 139
diff changeset
183 * Frees all registered shaders.
d190fe5315bd add dynamic reload of all shaders
Mike Becker <universe@uap-core.de>
parents: 139
diff changeset
184 *
d190fe5315bd add dynamic reload of all shaders
Mike Becker <universe@uap-core.de>
parents: 139
diff changeset
185 * Completely wipes all shaders.
d190fe5315bd add dynamic reload of all shaders
Mike Becker <universe@uap-core.de>
parents: 139
diff changeset
186 * Be careful with this function when shaders are needed that have been registered with @c asc_shader_register().
d190fe5315bd add dynamic reload of all shaders
Mike Becker <universe@uap-core.de>
parents: 139
diff changeset
187 * Those need to be registered again, or @a asc_shader_lookup() will fail.
d190fe5315bd add dynamic reload of all shaders
Mike Becker <universe@uap-core.de>
parents: 139
diff changeset
188 * Shaders that are used with @a asc_shader_lookup_or_create() will be re-created automatically.
d190fe5315bd add dynamic reload of all shaders
Mike Becker <universe@uap-core.de>
parents: 139
diff changeset
189 *
d190fe5315bd add dynamic reload of all shaders
Mike Becker <universe@uap-core.de>
parents: 139
diff changeset
190 * TODO: maybe we should add another function that only clears lazy-initialized shaders
d190fe5315bd add dynamic reload of all shaders
Mike Becker <universe@uap-core.de>
parents: 139
diff changeset
191 * another alternative would be to keep the initialization info and lazy-initialize cleared shaders on lookup
d190fe5315bd add dynamic reload of all shaders
Mike Becker <universe@uap-core.de>
parents: 139
diff changeset
192 *
d190fe5315bd add dynamic reload of all shaders
Mike Becker <universe@uap-core.de>
parents: 139
diff changeset
193 * @see asc_shader_lookup_or_create()
d190fe5315bd add dynamic reload of all shaders
Mike Becker <universe@uap-core.de>
parents: 139
diff changeset
194 */
d190fe5315bd add dynamic reload of all shaders
Mike Becker <universe@uap-core.de>
parents: 139
diff changeset
195 void asc_shader_clear_registry(void);
d190fe5315bd add dynamic reload of all shaders
Mike Becker <universe@uap-core.de>
parents: 139
diff changeset
196
15
362b7659dc76 add shader loading and unloading
Mike Becker <universe@uap-core.de>
parents:
diff changeset
197 #endif //ASCENSION_SHADER_H

mercurial