/*------------------------------------------------------------------------- * drawElements Quality Program EGL Utilities * ------------------------------------------ * * Copyright 2014 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. * *//*! * \file * \brief EGL String Utilities. *//*--------------------------------------------------------------------*/ #include "egluStrUtil.hpp" #include "egluHeaderWrapper.hpp" #include <EGL/eglext.h> #if !defined(EGL_OPENGL_ES3_BIT_KHR) # define EGL_OPENGL_ES3_BIT_KHR 0x0040 #endif namespace eglu { std::ostream& operator<< (std::ostream& str, const ConfigAttribValueFmt& attribFmt) { switch (attribFmt.attribute) { case EGL_COLOR_BUFFER_TYPE: return str << getColorBufferTypeStr(attribFmt.value); case EGL_CONFIG_CAVEAT: return str << getConfigCaveatStr(attribFmt.value); case EGL_CONFORMANT: case EGL_RENDERABLE_TYPE: return str << getAPIBitsStr(attribFmt.value); case EGL_SURFACE_TYPE: return str << getSurfaceBitsStr(attribFmt.value); case EGL_MATCH_NATIVE_PIXMAP: if (attribFmt.value == EGL_NONE) return str << "EGL_NONE"; else return str << tcu::toHex(attribFmt.value); case EGL_TRANSPARENT_TYPE: return str << getTransparentTypeStr(attribFmt.value); case EGL_BIND_TO_TEXTURE_RGB: case EGL_BIND_TO_TEXTURE_RGBA: case EGL_NATIVE_RENDERABLE: return str << getBoolDontCareStr(attribFmt.value); case EGL_ALPHA_MASK_SIZE: case EGL_ALPHA_SIZE: case EGL_BLUE_SIZE: case EGL_BUFFER_SIZE: case EGL_CONFIG_ID: case EGL_DEPTH_SIZE: case EGL_GREEN_SIZE: case EGL_LEVEL: case EGL_LUMINANCE_SIZE: case EGL_MAX_SWAP_INTERVAL: case EGL_MIN_SWAP_INTERVAL: case EGL_RED_SIZE: case EGL_SAMPLE_BUFFERS: case EGL_SAMPLES: case EGL_STENCIL_SIZE: case EGL_TRANSPARENT_RED_VALUE: case EGL_TRANSPARENT_GREEN_VALUE: case EGL_TRANSPARENT_BLUE_VALUE: return str << (int)attribFmt.value; default: return str << tcu::toHex(attribFmt.value); } } std::ostream& operator<< (std::ostream& str, const ContextAttribValueFmt& attribFmt) { switch (attribFmt.attribute) { case EGL_CONFIG_ID: case EGL_CONTEXT_CLIENT_VERSION: return str << (int)attribFmt.value; case EGL_CONTEXT_CLIENT_TYPE: return str << getAPIStr(attribFmt.value); case EGL_RENDER_BUFFER: return str << getRenderBufferStr(attribFmt.value); default: return str << tcu::toHex(attribFmt.value); } } std::ostream& operator<< (std::ostream& str, const SurfaceAttribValueFmt& attribFmt) { switch (attribFmt.attribute) { case EGL_CONFIG_ID: case EGL_WIDTH: case EGL_HEIGHT: case EGL_HORIZONTAL_RESOLUTION: case EGL_VERTICAL_RESOLUTION: case EGL_PIXEL_ASPECT_RATIO: return str << (int)attribFmt.value; case EGL_LARGEST_PBUFFER: case EGL_MIPMAP_TEXTURE: return str << getBoolDontCareStr(attribFmt.value); case EGL_MULTISAMPLE_RESOLVE: return str << getMultisampleResolveStr(attribFmt.value); case EGL_RENDER_BUFFER: return str << getRenderBufferStr(attribFmt.value); case EGL_SWAP_BEHAVIOR: return str << getSwapBehaviorStr(attribFmt.value); case EGL_TEXTURE_FORMAT: return str << getTextureFormatStr(attribFmt.value); case EGL_TEXTURE_TARGET: return str << getTextureTargetStr(attribFmt.value); case EGL_VG_ALPHA_FORMAT: return str << getVGAlphaFormatStr(attribFmt.value); case EGL_VG_COLORSPACE: return str << getVGColorspaceStr(attribFmt.value); default: return str << tcu::toHex(attribFmt.value); } } std::ostream& operator<< (std::ostream& str, const ConfigAttribListFmt& fmt) { int pos = 0; str << "{ "; for (;;) { int attrib = fmt.attribs[pos]; if (pos != 0) str << ", "; if (attrib == EGL_NONE) { // Terminate. str << "EGL_NONE"; break; } const char* attribName = getConfigAttribName(attrib); if (attribName) { // Valid attribute, print value. str << attribName << ", " << getConfigAttribValueStr(attrib, fmt.attribs[pos+1]); pos += 2; } else { // Invalid attribute. Terminate parsing. str << tcu::toHex(attrib) << ", ???"; break; } } str << " }"; return str; } std::ostream& operator<< (std::ostream& str, const SurfaceAttribListFmt& fmt) { int pos = 0; str << "{ "; for (;;) { int attrib = fmt.attribs[pos]; if (pos != 0) str << ", "; if (attrib == EGL_NONE) { // Terminate. str << "EGL_NONE"; break; } const char* attribName = getSurfaceAttribName(attrib); if (attribName) { // Valid attribute, print value. str << attribName << ", " << getSurfaceAttribValueStr(attrib, fmt.attribs[pos+1]); pos += 2; } else { // Invalid attribute. Terminate parsing. str << tcu::toHex(attrib) << ", ???"; break; } } str << " }"; return str; } std::ostream& operator<< (std::ostream& str, const ContextAttribListFmt& fmt) { int pos = 0; str << "{ "; for (;;) { int attrib = fmt.attribs[pos]; if (pos != 0) str << ", "; if (attrib == EGL_NONE) { // Terminate. str << "EGL_NONE"; break; } const char* attribName = getContextAttribName(attrib); if (attribName) { // Valid attribute, print value. str << attribName << ", " << getContextAttribValueStr(attrib, fmt.attribs[pos+1]); pos += 2; } else { // Invalid attribute. Terminate parsing. str << tcu::toHex(attrib) << ", ???"; break; } } str << " }"; return str; } #include "egluStrUtil.inl" } // eglu