GlShader.smali
.class public Lio/agora/base/internal/video/GlShader;
.super Ljava/lang/Object;
.source "GlShader.java"
# static fields
.field private static final TAG:Ljava/lang/String; = "GlShader"
# instance fields
.field private program:I
# direct methods
.method public constructor <init>(Ljava/lang/String;Ljava/lang/String;)V
.registers 9
.line 42
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
const/4 v0, -0x1
.line 40
iput v0, p0, Lio/agora/base/internal/video/GlShader;->program:I
const v0, 0x8b31
.line 43
invoke-static {v0, p1}, Lio/agora/base/internal/video/GlShader;->compileShader(ILjava/lang/String;)I
move-result p1
const v0, 0x8b30
.line 44
invoke-static {v0, p2}, Lio/agora/base/internal/video/GlShader;->compileShader(ILjava/lang/String;)I
move-result p2
.line 45
invoke-static {}, Landroid/opengl/GLES20;->glCreateProgram()I
move-result v0
iput v0, p0, Lio/agora/base/internal/video/GlShader;->program:I
if-eqz v0, :cond_7b
const-string v0, "GlShader"
const-string v1, "program created."
.line 51
invoke-static {v0, v1}, Lio/agora/base/internal/Logging;->d(Ljava/lang/String;Ljava/lang/String;)V
.line 52
iget v1, p0, Lio/agora/base/internal/video/GlShader;->program:I
invoke-static {v1, p1}, Landroid/opengl/GLES20;->glAttachShader(II)V
.line 53
iget v1, p0, Lio/agora/base/internal/video/GlShader;->program:I
invoke-static {v1, p2}, Landroid/opengl/GLES20;->glAttachShader(II)V
.line 54
iget v1, p0, Lio/agora/base/internal/video/GlShader;->program:I
invoke-static {v1}, Landroid/opengl/GLES20;->glLinkProgram(I)V
const/4 v1, 0x1
new-array v2, v1, [I
const/4 v3, 0x0
aput v3, v2, v3
.line 56
iget v4, p0, Lio/agora/base/internal/video/GlShader;->program:I
const v5, 0x8b82
invoke-static {v4, v5, v2, v3}, Landroid/opengl/GLES20;->glGetProgramiv(II[II)V
.line 57
aget v2, v2, v3
if-ne v2, v1, :cond_50
.line 69
invoke-static {p1}, Landroid/opengl/GLES20;->glDeleteShader(I)V
.line 70
invoke-static {p2}, Landroid/opengl/GLES20;->glDeleteShader(I)V
const-string p1, "Creating GlShader"
.line 71
invoke-static {p1}, Lio/agora/base/internal/video/GlUtil;->checkNoGLES2Error(Ljava/lang/String;)V
return-void
.line 58
:cond_50
new-instance p1, Ljava/lang/StringBuilder;
invoke-direct {p1}, Ljava/lang/StringBuilder;-><init>()V
const-string p2, "Could not link program: "
invoke-virtual {p1, p2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget p2, p0, Lio/agora/base/internal/video/GlShader;->program:I
invoke-static {p2}, Landroid/opengl/GLES20;->glGetProgramInfoLog(I)Ljava/lang/String;
move-result-object p2
invoke-virtual {p1, p2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {p1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p1
invoke-static {v0, p1}, Lio/agora/base/internal/Logging;->e(Ljava/lang/String;Ljava/lang/String;)V
.line 59
iget p1, p0, Lio/agora/base/internal/video/GlShader;->program:I
invoke-static {p1}, Landroid/opengl/GLES20;->glDeleteProgram(I)V
.line 60
new-instance p1, Ljava/lang/RuntimeException;
iget p2, p0, Lio/agora/base/internal/video/GlShader;->program:I
invoke-static {p2}, Landroid/opengl/GLES20;->glGetProgramInfoLog(I)Ljava/lang/String;
move-result-object p2
invoke-direct {p1, p2}, Ljava/lang/RuntimeException;-><init>(Ljava/lang/String;)V
throw p1
.line 47
:cond_7b
invoke-static {p1}, Landroid/opengl/GLES20;->glDeleteShader(I)V
.line 48
invoke-static {p2}, Landroid/opengl/GLES20;->glDeleteShader(I)V
.line 49
new-instance p1, Ljava/lang/RuntimeException;
new-instance p2, Ljava/lang/StringBuilder;
invoke-direct {p2}, Ljava/lang/StringBuilder;-><init>()V
const-string v0, "glCreateProgram() failed. GLES20 error: "
invoke-virtual {p2, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-static {}, Landroid/opengl/GLES20;->glGetError()I
move-result v0
invoke-virtual {p2, v0}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
invoke-virtual {p2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p2
invoke-direct {p1, p2}, Ljava/lang/RuntimeException;-><init>(Ljava/lang/String;)V
throw p1
.end method
.method private static compileShader(ILjava/lang/String;)I
.registers 6
.line 22
invoke-static {p0}, Landroid/opengl/GLES20;->glCreateShader(I)I
move-result p0
if-eqz p0, :cond_51
.line 26
invoke-static {p0, p1}, Landroid/opengl/GLES20;->glShaderSource(ILjava/lang/String;)V
.line 27
invoke-static {p0}, Landroid/opengl/GLES20;->glCompileShader(I)V
const/4 v0, 0x1
new-array v1, v0, [I
const/4 v2, 0x0
aput v2, v1, v2
const v3, 0x8b81
.line 29
invoke-static {p0, v3, v1, v2}, Landroid/opengl/GLES20;->glGetShaderiv(II[II)V
.line 30
aget v1, v1, v2
if-ne v1, v0, :cond_22
const-string p1, "compileShader"
.line 36
invoke-static {p1}, Lio/agora/base/internal/video/GlUtil;->checkNoGLES2Error(Ljava/lang/String;)V
return p0
.line 31
:cond_22
new-instance v0, Ljava/lang/StringBuilder;
invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V
const-string v1, "Compile error "
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
.line 32
invoke-static {p0}, Landroid/opengl/GLES20;->glGetShaderInfoLog(I)Ljava/lang/String;
move-result-object v1
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v1, " in shader:\n"
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v0, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p1
const-string v0, "GlShader"
.line 31
invoke-static {v0, p1}, Lio/agora/base/internal/Logging;->e(Ljava/lang/String;Ljava/lang/String;)V
.line 33
invoke-static {p0}, Landroid/opengl/GLES20;->glDeleteShader(I)V
.line 34
new-instance p1, Ljava/lang/RuntimeException;
invoke-static {p0}, Landroid/opengl/GLES20;->glGetShaderInfoLog(I)Ljava/lang/String;
move-result-object p0
invoke-direct {p1, p0}, Ljava/lang/RuntimeException;-><init>(Ljava/lang/String;)V
throw p1
.line 24
:cond_51
new-instance p0, Ljava/lang/RuntimeException;
new-instance p1, Ljava/lang/StringBuilder;
invoke-direct {p1}, Ljava/lang/StringBuilder;-><init>()V
const-string v0, "glCreateShader() failed. GLES20 error: "
invoke-virtual {p1, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-static {}, Landroid/opengl/GLES20;->glGetError()I
move-result v0
invoke-virtual {p1, v0}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
invoke-virtual {p1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p1
invoke-direct {p0, p1}, Ljava/lang/RuntimeException;-><init>(Ljava/lang/String;)V
throw p0
.end method
# virtual methods
.method public getAttribLocation(Ljava/lang/String;)I
.registers 5
.line 75
iget v0, p0, Lio/agora/base/internal/video/GlShader;->program:I
const/4 v1, -0x1
if-eq v0, v1, :cond_28
.line 78
invoke-static {v0, p1}, Landroid/opengl/GLES20;->glGetAttribLocation(ILjava/lang/String;)I
move-result v0
if-ltz v0, :cond_c
return v0
.line 80
:cond_c
new-instance v0, Ljava/lang/RuntimeException;
new-instance v1, Ljava/lang/StringBuilder;
invoke-direct {v1}, Ljava/lang/StringBuilder;-><init>()V
const-string v2, "Could not locate \'"
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v1, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string p1, "\' in program"
invoke-virtual {v1, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p1
invoke-direct {v0, p1}, Ljava/lang/RuntimeException;-><init>(Ljava/lang/String;)V
throw v0
.line 76
:cond_28
new-instance p1, Ljava/lang/RuntimeException;
const-string v0, "The program has been released"
invoke-direct {p1, v0}, Ljava/lang/RuntimeException;-><init>(Ljava/lang/String;)V
throw p1
.end method
.method public getUniformLocation(Ljava/lang/String;)I
.registers 5
.line 108
iget v0, p0, Lio/agora/base/internal/video/GlShader;->program:I
const/4 v1, -0x1
if-eq v0, v1, :cond_28
.line 111
invoke-static {v0, p1}, Landroid/opengl/GLES20;->glGetUniformLocation(ILjava/lang/String;)I
move-result v0
if-ltz v0, :cond_c
return v0
.line 113
:cond_c
new-instance v0, Ljava/lang/RuntimeException;
new-instance v1, Ljava/lang/StringBuilder;
invoke-direct {v1}, Ljava/lang/StringBuilder;-><init>()V
const-string v2, "Could not locate uniform \'"
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v1, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string p1, "\' in program"
invoke-virtual {v1, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p1
invoke-direct {v0, p1}, Ljava/lang/RuntimeException;-><init>(Ljava/lang/String;)V
throw v0
.line 109
:cond_28
new-instance p1, Ljava/lang/RuntimeException;
const-string v0, "The program has been released"
invoke-direct {p1, v0}, Ljava/lang/RuntimeException;-><init>(Ljava/lang/String;)V
throw p1
.end method
.method public release()V
.registers 3
const-string v0, "GlShader"
const-string v1, "Deleting shader."
.line 129
invoke-static {v0, v1}, Lio/agora/base/internal/Logging;->d(Ljava/lang/String;Ljava/lang/String;)V
.line 131
iget v0, p0, Lio/agora/base/internal/video/GlShader;->program:I
const/4 v1, -0x1
if-eq v0, v1, :cond_11
.line 132
invoke-static {v0}, Landroid/opengl/GLES20;->glDeleteProgram(I)V
.line 133
iput v1, p0, Lio/agora/base/internal/video/GlShader;->program:I
:cond_11
return-void
.end method
.method public setVertexAttribArray(Ljava/lang/String;IILjava/nio/FloatBuffer;)V
.registers 13
.line 98
iget v0, p0, Lio/agora/base/internal/video/GlShader;->program:I
const/4 v1, -0x1
if-eq v0, v1, :cond_1b
.line 101
invoke-virtual {p0, p1}, Lio/agora/base/internal/video/GlShader;->getAttribLocation(Ljava/lang/String;)I
move-result v2
.line 102
invoke-static {v2}, Landroid/opengl/GLES20;->glEnableVertexAttribArray(I)V
const/16 v4, 0x1406
const/4 v5, 0x0
move v3, p2
move v6, p3
move-object v7, p4
.line 103
invoke-static/range {v2 .. v7}, Landroid/opengl/GLES20;->glVertexAttribPointer(IIIZILjava/nio/Buffer;)V
const-string p1, "setVertexAttribArray"
.line 104
invoke-static {p1}, Lio/agora/base/internal/video/GlUtil;->checkNoGLES2Error(Ljava/lang/String;)V
return-void
.line 99
:cond_1b
new-instance p1, Ljava/lang/RuntimeException;
const-string p2, "The program has been released"
invoke-direct {p1, p2}, Ljava/lang/RuntimeException;-><init>(Ljava/lang/String;)V
throw p1
.end method
.method public setVertexAttribArray(Ljava/lang/String;ILjava/nio/FloatBuffer;)V
.registers 5
const/4 v0, 0x0
.line 90
invoke-virtual {p0, p1, p2, v0, p3}, Lio/agora/base/internal/video/GlShader;->setVertexAttribArray(Ljava/lang/String;IILjava/nio/FloatBuffer;)V
return-void
.end method
.method public useProgram()V
.registers 3
.line 119
iget v0, p0, Lio/agora/base/internal/video/GlShader;->program:I
const/4 v1, -0x1
if-eq v0, v1, :cond_17
.line 122
sget-object v0, Lio/agora/base/internal/video/EglBase;->lock:Ljava/lang/Object;
monitor-enter v0
.line 123
:try_start_8
iget v1, p0, Lio/agora/base/internal/video/GlShader;->program:I
invoke-static {v1}, Landroid/opengl/GLES20;->glUseProgram(I)V
.line 124
monitor-exit v0
:try_end_e
.catchall {:try_start_8 .. :try_end_e} :catchall_14
const-string v0, "glUseProgram"
.line 125
invoke-static {v0}, Lio/agora/base/internal/video/GlUtil;->checkNoGLES2Error(Ljava/lang/String;)V
return-void
:catchall_14
move-exception v1
.line 124
:try_start_15
monitor-exit v0
:try_end_16
.catchall {:try_start_15 .. :try_end_16} :catchall_14
throw v1
.line 120
:cond_17
new-instance v0, Ljava/lang/RuntimeException;
const-string v1, "The program has been released"
invoke-direct {v0, v1}, Ljava/lang/RuntimeException;-><init>(Ljava/lang/String;)V
throw v0
.end method