/*-------------------------------------------------------------------------
* drawElements Quality Program OpenGL ES 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 GL call wrapper for logging.
*//*--------------------------------------------------------------------*/
#include "gluCallLogWrapper.hpp"
#include "gluStrUtil.hpp"
#include "glwFunctions.hpp"
#include "glwEnums.hpp"
using tcu::TestLog;
using tcu::toHex;
namespace glu
{
CallLogWrapper::CallLogWrapper (const glw::Functions& gl, tcu::TestLog& log)
: m_gl (gl)
, m_log (log)
, m_enableLog (false)
{
}
CallLogWrapper::~CallLogWrapper (void)
{
}
template <typename T>
inline tcu::Format::ArrayPointer<T> getPointerStr (const T* arr, deUint32 size)
{
return tcu::formatArray(arr, (int)size);
}
template <typename T>
inline tcu::Format::ArrayPointer<T> getPointerStr (const T* arr, int size)
{
return tcu::formatArray(arr, de::max(size, 0));
}
inline detail::EnumPointerFmt getEnumPointerStr (const deUint32* value, glw::GLsizei size, detail::EnumPointerFmt::GetEnumNameFunc getName)
{
return detail::EnumPointerFmt(value, (deUint32)de::max(0, size), getName);
}
// String formatter.
class StringFmt
{
public:
const glw::GLchar* str;
StringFmt (const glw::GLchar* str_) : str(str_) {}
};
inline std::ostream& operator<< (std::ostream& str, StringFmt fmt)
{
return str << (fmt.str ? (const char*)fmt.str : "NULL");
}
inline StringFmt getStringStr (const char* value) { return StringFmt(value); }
inline StringFmt getStringStr (const glw::GLubyte* value) { return StringFmt((const char*)value); }
// Framebuffer parameter pointer formatter.
class FboParamPtrFmt
{
public:
deUint32 param;
const int* value;
FboParamPtrFmt (deUint32 param_, const int* value_) : param(param_), value(value_) {}
};
std::ostream& operator<< (std::ostream& str, FboParamPtrFmt fmt)
{
if (fmt.value)
{
switch (fmt.param)
{
case GL_FRAMEBUFFER_ATTACHMENT_OBJECT_TYPE:
return str << tcu::Format::Enum(getFramebufferAttachmentTypeName, *fmt.value);
case GL_FRAMEBUFFER_ATTACHMENT_TEXTURE_CUBE_MAP_FACE:
return str << tcu::Format::Enum(getCubeMapFaceName, *fmt.value);
case GL_FRAMEBUFFER_ATTACHMENT_COMPONENT_TYPE:
return str << tcu::Format::Enum(getTypeName, *fmt.value);
case GL_FRAMEBUFFER_ATTACHMENT_COLOR_ENCODING:
return str << tcu::Format::Enum(getFramebufferColorEncodingName, *fmt.value);
case GL_FRAMEBUFFER_ATTACHMENT_LAYERED:
return str << tcu::Format::Enum(getBooleanName, *fmt.value);
case GL_FRAMEBUFFER_ATTACHMENT_OBJECT_NAME:
case GL_FRAMEBUFFER_ATTACHMENT_TEXTURE_LAYER:
case GL_FRAMEBUFFER_ATTACHMENT_TEXTURE_LEVEL:
case GL_FRAMEBUFFER_ATTACHMENT_RED_SIZE:
case GL_FRAMEBUFFER_ATTACHMENT_GREEN_SIZE:
case GL_FRAMEBUFFER_ATTACHMENT_BLUE_SIZE:
case GL_FRAMEBUFFER_ATTACHMENT_ALPHA_SIZE:
case GL_FRAMEBUFFER_ATTACHMENT_DEPTH_SIZE:
case GL_FRAMEBUFFER_ATTACHMENT_STENCIL_SIZE:
return str << *fmt.value;
default:
return str << tcu::toHex(*fmt.value);
}
}
else
return str << "(null)";
}
inline FboParamPtrFmt getFramebufferAttachmentParameterValueStr (deUint32 param, const int* value)
{
return FboParamPtrFmt(param, value);
}
// API entry-point implementations are auto-generated
#include "gluCallLogWrapper.inl"
} // glu