/* * Copyright (C) 2008 The Android Open Source Project * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ package android.opengl; import java.io.IOException; import java.io.Writer; import javax.microedition.khronos.egl.EGL; import javax.microedition.khronos.egl.EGL10; import javax.microedition.khronos.egl.EGL11; import javax.microedition.khronos.egl.EGLConfig; import javax.microedition.khronos.egl.EGLContext; import javax.microedition.khronos.egl.EGLDisplay; import javax.microedition.khronos.egl.EGLSurface; class EGLLogWrapper implements EGL11 { private EGL10 mEgl10; Writer mLog; boolean mLogArgumentNames; boolean mCheckError; private int mArgCount; public EGLLogWrapper(EGL egl, int configFlags, Writer log) { mEgl10 = (EGL10) egl; mLog = log; mLogArgumentNames = (GLDebugHelper.CONFIG_LOG_ARGUMENT_NAMES & configFlags) != 0; mCheckError = (GLDebugHelper.CONFIG_CHECK_GL_ERROR & configFlags) != 0; } public boolean eglChooseConfig(EGLDisplay display, int[] attrib_list, EGLConfig[] configs, int config_size, int[] num_config) { begin("eglChooseConfig"); arg("display", display); arg("attrib_list", attrib_list); arg("config_size", config_size); end(); boolean result = mEgl10.eglChooseConfig(display, attrib_list, configs, config_size, num_config); arg("configs", configs); arg("num_config", num_config); returns(result); checkError(); return result; } public boolean eglCopyBuffers(EGLDisplay display, EGLSurface surface, Object native_pixmap) { begin("eglCopyBuffers"); arg("display", display); arg("surface", surface); arg("native_pixmap", native_pixmap); end(); boolean result = mEgl10.eglCopyBuffers(display, surface, native_pixmap); returns(result); checkError(); return result; } public EGLContext eglCreateContext(EGLDisplay display, EGLConfig config, EGLContext share_context, int[] attrib_list) { begin("eglCreateContext"); arg("display", display); arg("config", config); arg("share_context", share_context); arg("attrib_list", attrib_list); end(); EGLContext result = mEgl10.eglCreateContext(display, config, share_context, attrib_list); returns(result); checkError(); return result; } public EGLSurface eglCreatePbufferSurface(EGLDisplay display, EGLConfig config, int[] attrib_list) { begin("eglCreatePbufferSurface"); arg("display", display); arg("config", config); arg("attrib_list", attrib_list); end(); EGLSurface result = mEgl10.eglCreatePbufferSurface(display, config, attrib_list); returns(result); checkError(); return result; } public EGLSurface eglCreatePixmapSurface(EGLDisplay display, EGLConfig config, Object native_pixmap, int[] attrib_list) { begin("eglCreatePixmapSurface"); arg("display", display); arg("config", config); arg("native_pixmap", native_pixmap); arg("attrib_list", attrib_list); end(); EGLSurface result = mEgl10.eglCreatePixmapSurface(display, config, native_pixmap, attrib_list); returns(result); checkError(); return result; } public EGLSurface eglCreateWindowSurface(EGLDisplay display, EGLConfig config, Object native_window, int[] attrib_list) { begin("eglCreateWindowSurface"); arg("display", display); arg("config", config); arg("native_window", native_window); arg("attrib_list", attrib_list); end(); EGLSurface result = mEgl10.eglCreateWindowSurface(display, config, native_window, attrib_list); returns(result); checkError(); return result; } public boolean eglDestroyContext(EGLDisplay display, EGLContext context) { begin("eglDestroyContext"); arg("display", display); arg("context", context); end(); boolean result = mEgl10.eglDestroyContext(display, context); returns(result); checkError(); return result; } public boolean eglDestroySurface(EGLDisplay display, EGLSurface surface) { begin("eglDestroySurface"); arg("display", display); arg("surface", surface); end(); boolean result = mEgl10.eglDestroySurface(display, surface); returns(result); checkError(); return result; } public boolean eglGetConfigAttrib(EGLDisplay display, EGLConfig config, int attribute, int[] value) { begin("eglGetConfigAttrib"); arg("display", display); arg("config", config); arg("attribute", attribute); end(); boolean result = mEgl10.eglGetConfigAttrib(display, config, attribute, value); arg("value", value); returns(result); checkError(); return false; } public boolean eglGetConfigs(EGLDisplay display, EGLConfig[] configs, int config_size, int[] num_config) { begin("eglGetConfigs"); arg("display", display); arg("config_size", config_size); end(); boolean result = mEgl10.eglGetConfigs(display, configs, config_size, num_config); arg("configs", configs); arg("num_config", num_config); returns(result); checkError(); return result; } public EGLContext eglGetCurrentContext() { begin("eglGetCurrentContext"); end(); EGLContext result = mEgl10.eglGetCurrentContext(); returns(result); checkError(); return result; } public EGLDisplay eglGetCurrentDisplay() { begin("eglGetCurrentDisplay"); end(); EGLDisplay result = mEgl10.eglGetCurrentDisplay(); returns(result); checkError(); return result; } public EGLSurface eglGetCurrentSurface(int readdraw) { begin("eglGetCurrentSurface"); arg("readdraw", readdraw); end(); EGLSurface result = mEgl10.eglGetCurrentSurface(readdraw); returns(result); checkError(); return result; } public EGLDisplay eglGetDisplay(Object native_display) { begin("eglGetDisplay"); arg("native_display", native_display); end(); EGLDisplay result = mEgl10.eglGetDisplay(native_display); returns(result); checkError(); return result; } public int eglGetError() { begin("eglGetError"); end(); int result = mEgl10.eglGetError(); returns(getErrorString(result)); return result; } public boolean eglInitialize(EGLDisplay display, int[] major_minor) { begin("eglInitialize"); arg("display", display); end(); boolean result = mEgl10.eglInitialize(display, major_minor); returns(result); arg("major_minor", major_minor); checkError(); return result; } public boolean eglMakeCurrent(EGLDisplay display, EGLSurface draw, EGLSurface read, EGLContext context) { begin("eglMakeCurrent"); arg("display", display); arg("draw", draw); arg("read", read); arg("context", context); end(); boolean result = mEgl10.eglMakeCurrent(display, draw, read, context); returns(result); checkError(); return result; } public boolean eglQueryContext(EGLDisplay display, EGLContext context, int attribute, int[] value) { begin("eglQueryContext"); arg("display", display); arg("context", context); arg("attribute", attribute); end(); boolean result = mEgl10.eglQueryContext(display, context, attribute, value); returns(value[0]); returns(result); checkError(); return result; } public String eglQueryString(EGLDisplay display, int name) { begin("eglQueryString"); arg("display", display); arg("name", name); end(); String result = mEgl10.eglQueryString(display, name); returns(result); checkError(); return result; } public boolean eglQuerySurface(EGLDisplay display, EGLSurface surface, int attribute, int[] value) { begin("eglQuerySurface"); arg("display", display); arg("surface", surface); arg("attribute", attribute); end(); boolean result = mEgl10.eglQuerySurface(display, surface, attribute, value); returns(value[0]); returns(result); checkError(); return result; } /** @hide **/ public boolean eglReleaseThread() { begin("eglReleaseThread"); end(); boolean result = mEgl10.eglReleaseThread(); returns(result); checkError(); return result; } public boolean eglSwapBuffers(EGLDisplay display, EGLSurface surface) { begin("eglInitialize"); arg("display", display); arg("surface", surface); end(); boolean result = mEgl10.eglSwapBuffers(display, surface); returns(result); checkError(); return result; } public boolean eglTerminate(EGLDisplay display) { begin("eglTerminate"); arg("display", display); end(); boolean result = mEgl10.eglTerminate(display); returns(result); checkError(); return result; } public boolean eglWaitGL() { begin("eglWaitGL"); end(); boolean result = mEgl10.eglWaitGL(); returns(result); checkError(); return result; } public boolean eglWaitNative(int engine, Object bindTarget) { begin("eglWaitNative"); arg("engine", engine); arg("bindTarget", bindTarget); end(); boolean result = mEgl10.eglWaitNative(engine, bindTarget); returns(result); checkError(); return result; } private void checkError() { int eglError; if ((eglError = mEgl10.eglGetError()) != EGL_SUCCESS) { String errorMessage = "eglError: " + getErrorString(eglError); logLine(errorMessage); if (mCheckError) { throw new GLException(eglError, errorMessage); } } } private void logLine(String message) { log(message + '\n'); } private void log(String message) { try { mLog.write(message); } catch (IOException e) { // Ignore exception, keep on trying } } private void begin(String name) { log(name + '('); mArgCount = 0; } private void arg(String name, String value) { if (mArgCount++ > 0) { log(", "); } if (mLogArgumentNames) { log(name + "="); } log(value); } private void end() { log(");\n"); flush(); } private void flush() { try { mLog.flush(); } catch (IOException e) { mLog = null; } } private void arg(String name, int value) { arg(name, Integer.toString(value)); } private void arg(String name, Object object) { arg(name, toString(object)); } private void arg(String name, EGLDisplay object) { if (object == EGL10.EGL_DEFAULT_DISPLAY) { arg(name, "EGL10.EGL_DEFAULT_DISPLAY"); } else if (object == EGL_NO_DISPLAY) { arg(name, "EGL10.EGL_NO_DISPLAY"); } else { arg(name, toString(object)); } } private void arg(String name, EGLContext object) { if (object == EGL10.EGL_NO_CONTEXT) { arg(name, "EGL10.EGL_NO_CONTEXT"); } else { arg(name, toString(object)); } } private void arg(String name, EGLSurface object) { if (object == EGL10.EGL_NO_SURFACE) { arg(name, "EGL10.EGL_NO_SURFACE"); } else { arg(name, toString(object)); } } private void returns(String result) { log(" returns " + result + ";\n"); flush(); } private void returns(int result) { returns(Integer.toString(result)); } private void returns(boolean result) { returns(Boolean.toString(result)); } private void returns(Object result) { returns(toString(result)); } private String toString(Object obj) { if (obj == null) { return "null"; } else { return obj.toString(); } } private void arg(String name, int[] arr) { if (arr == null) { arg(name, "null"); } else { arg(name, toString(arr.length, arr, 0)); } } private void arg(String name, Object[] arr) { if (arr == null) { arg(name, "null"); } else { arg(name, toString(arr.length, arr, 0)); } } private String toString(int n, int[] arr, int offset) { StringBuilder buf = new StringBuilder(); buf.append("{\n"); int arrLen = arr.length; for (int i = 0; i < n; i++) { int index = offset + i; buf.append(" [" + index + "] = "); if (index < 0 || index >= arrLen) { buf.append("out of bounds"); } else { buf.append(arr[index]); } buf.append('\n'); } buf.append("}"); return buf.toString(); } private String toString(int n, Object[] arr, int offset) { StringBuilder buf = new StringBuilder(); buf.append("{\n"); int arrLen = arr.length; for (int i = 0; i < n; i++) { int index = offset + i; buf.append(" [" + index + "] = "); if (index < 0 || index >= arrLen) { buf.append("out of bounds"); } else { buf.append(arr[index]); } buf.append('\n'); } buf.append("}"); return buf.toString(); } private static String getHex(int value) { return "0x" + Integer.toHexString(value); } public static String getErrorString(int error) { switch (error) { case EGL_SUCCESS: return "EGL_SUCCESS"; case EGL_NOT_INITIALIZED: return "EGL_NOT_INITIALIZED"; case EGL_BAD_ACCESS: return "EGL_BAD_ACCESS"; case EGL_BAD_ALLOC: return "EGL_BAD_ALLOC"; case EGL_BAD_ATTRIBUTE: return "EGL_BAD_ATTRIBUTE"; case EGL_BAD_CONFIG: return "EGL_BAD_CONFIG"; case EGL_BAD_CONTEXT: return "EGL_BAD_CONTEXT"; case EGL_BAD_CURRENT_SURFACE: return "EGL_BAD_CURRENT_SURFACE"; case EGL_BAD_DISPLAY: return "EGL_BAD_DISPLAY"; case EGL_BAD_MATCH: return "EGL_BAD_MATCH"; case EGL_BAD_NATIVE_PIXMAP: return "EGL_BAD_NATIVE_PIXMAP"; case EGL_BAD_NATIVE_WINDOW: return "EGL_BAD_NATIVE_WINDOW"; case EGL_BAD_PARAMETER: return "EGL_BAD_PARAMETER"; case EGL_BAD_SURFACE: return "EGL_BAD_SURFACE"; case EGL11.EGL_CONTEXT_LOST: return "EGL_CONTEXT_LOST"; default: return getHex(error); } } }