projects
/
demo
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Fixed shaders to be SPIR-V compatible, added a script that converts
[demo]
/
src
/
shader.cc
diff --git
a/src/shader.cc
b/src/shader.cc
index
f8f1c15
..
b39401f
100644
(file)
--- a/
src/shader.cc
+++ b/
src/shader.cc
@@
-24,24
+24,17
@@
bool Shader::load(const char *fname, SType type)
unsigned int fsz;
if(!(fp = fopen(fname, "rb"))) {
unsigned int fsz;
if(!(fp = fopen(fname, "rb"))) {
- fprintf(stderr, "Failed to open shader: %s.\n", fname);
-
+ fprintf(stderr, "Failed to open shader: %s\n", fname);
return false;
}
fseek(fp, 0, SEEK_END);
fsz = ftell(fp);
rewind(fp);
return false;
}
fseek(fp, 0, SEEK_END);
fsz = ftell(fp);
rewind(fp);
- char *buf;
- if(!(buf = new char[fsz + 1])) {
- fprintf(stderr, "Failed to allocate %u buffers.\n", fsz + 1);
- fclose(fp);
-
- return false;
- }
+ char *buf = new char[fsz + 1];
if(fread(buf, 1, fsz, fp) < fsz) {
if(fread(buf, 1, fsz, fp) < fsz) {
- fprintf(stderr, "Failed to read shader: %s.\n", fname);
+ fprintf(stderr, "Failed to read shader: %s\n", fname);
delete buf;
fclose(fp);
delete buf;
fclose(fp);
@@
-50,8
+43,12
@@
bool Shader::load(const char *fname, SType type)
buf[fsz] = '\0';
fclose(fp);
buf[fsz] = '\0';
fclose(fp);
- create(buf, fsz, fname);
- return true;
+ return create(buf, fsz, fname);
+}
+
+SType Shader::get_type()
+{
+ return type;
}
ShaderProgram::ShaderProgram()
}
ShaderProgram::ShaderProgram()
@@
-69,4
+66,4
@@
ShaderProgram::~ShaderProgram()
for(int i=0; i<len; ++i) {
delete shaders[i];
}
for(int i=0; i<len; ++i) {
delete shaders[i];
}
-}
\ No newline at end of file
+}