mirror of
https://github.com/Jozufozu/Flywheel.git
synced 2025-01-28 05:44:59 +01:00
Print final shader source on compilation error
This commit is contained in:
parent
12748cc208
commit
c887d326c6
3 changed files with 16 additions and 14 deletions
|
@ -94,7 +94,6 @@ sourceSets.main.resources { srcDir 'src/generated/resources' }
|
||||||
|
|
||||||
repositories {
|
repositories {
|
||||||
maven {
|
maven {
|
||||||
//location of the maven for mixed mappings and registrate
|
|
||||||
name "tterrag maven"
|
name "tterrag maven"
|
||||||
url "https://maven.tterrag.com/"
|
url "https://maven.tterrag.com/"
|
||||||
}
|
}
|
||||||
|
|
|
@ -15,25 +15,22 @@ public class GlShader extends GlObject {
|
||||||
public final ShaderType type;
|
public final ShaderType type;
|
||||||
|
|
||||||
public GlShader(Shader shader) {
|
public GlShader(Shader shader) {
|
||||||
this(shader.type, shader.name, shader.getSource());
|
this.type = shader.type;
|
||||||
}
|
this.name = shader.name;
|
||||||
|
int handle = GL20.glCreateShader(shader.type.glEnum);
|
||||||
|
|
||||||
public GlShader(ShaderType type, ResourceLocation name, String source) {
|
GlCompat.safeShaderSource(handle, shader.getSource());
|
||||||
this.type = type;
|
|
||||||
this.name = name;
|
|
||||||
int handle = GL20.glCreateShader(type.glEnum);
|
|
||||||
|
|
||||||
GlCompat.safeShaderSource(handle, source);
|
|
||||||
GL20.glCompileShader(handle);
|
GL20.glCompileShader(handle);
|
||||||
|
|
||||||
String log = GL20.glGetShaderInfoLog(handle);
|
String log = GL20.glGetShaderInfoLog(handle);
|
||||||
|
|
||||||
if (!log.isEmpty()) {
|
if (!log.isEmpty()) {
|
||||||
Backend.log.error("Shader compilation log for " + name + ": " + log);
|
Backend.log.error("Shader compilation log for " + shader.name + ": " + log);
|
||||||
|
Backend.log.error(shader.printSource());
|
||||||
}
|
}
|
||||||
|
|
||||||
if (GL20.glGetShaderi(handle, GL20.GL_COMPILE_STATUS) != GL20.GL_TRUE) {
|
if (GL20.glGetShaderi(handle, GL20.GL_COMPILE_STATUS) != GL20.GL_TRUE) {
|
||||||
throw new RuntimeException("Could not compile " + name + ". See log for details.");
|
throw new RuntimeException("Could not compile " + shader.name + ". See log for details.");
|
||||||
}
|
}
|
||||||
|
|
||||||
setHandle(handle);
|
setHandle(handle);
|
||||||
|
|
|
@ -135,12 +135,18 @@ public class Shader {
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
public void printSource() {
|
public String printSource() {
|
||||||
Backend.log.debug("Source for shader '" + name + "':");
|
StringBuilder builder = new StringBuilder();
|
||||||
|
|
||||||
|
builder.append("Source for shader '").append(name).append("':\n");
|
||||||
int i = 1;
|
int i = 1;
|
||||||
for (String s : source.split("\n")) {
|
for (String s : source.split("\n")) {
|
||||||
Backend.log.debug(String.format("%1$4s: ", i++) + s);
|
builder.append(String.format("%1$4s: ", i++))
|
||||||
|
.append(s)
|
||||||
|
.append('\n');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
return builder.toString();
|
||||||
}
|
}
|
||||||
|
|
||||||
public static Stream<String> lines(String s) {
|
public static Stream<String> lines(String s) {
|
||||||
|
|
Loading…
Reference in a new issue