Print final shader source on compilation error

This commit is contained in:
JozsefA 2021-06-23 09:08:34 -07:00
parent 12748cc208
commit c887d326c6
3 changed files with 16 additions and 14 deletions

View file

@ -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/"
} }

View file

@ -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);

View file

@ -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) {