1 /*-------------------------------------------------------------------------
2  * drawElements Quality Program OpenGL ES Utilities
3  * ------------------------------------------------
4  *
5  * Copyright 2014 The Android Open Source Project
6  *
7  * Licensed under the Apache License, Version 2.0 (the "License");
8  * you may not use this file except in compliance with the License.
9  * You may obtain a copy of the License at
10  *
11  *      http://www.apache.org/licenses/LICENSE-2.0
12  *
13  * Unless required by applicable law or agreed to in writing, software
14  * distributed under the License is distributed on an "AS IS" BASIS,
15  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
16  * See the License for the specific language governing permissions and
17  * limitations under the License.
18  *
19  *//*!
20  * \file
21  * \brief GL call wrapper for logging.
22  *//*--------------------------------------------------------------------*/
23 
24 #include "gluCallLogWrapper.hpp"
25 #include "gluStrUtil.hpp"
26 #include "glwFunctions.hpp"
27 #include "glwEnums.hpp"
28 
29 using tcu::TestLog;
30 using tcu::toHex;
31 
32 namespace glu
33 {
34 
CallLogWrapper(const glw::Functions & gl,tcu::TestLog & log)35 CallLogWrapper::CallLogWrapper (const glw::Functions& gl, tcu::TestLog& log)
36 	: m_gl			(gl)
37 	, m_log			(log)
38 	, m_enableLog	(false)
39 {
40 }
41 
~CallLogWrapper(void)42 CallLogWrapper::~CallLogWrapper (void)
43 {
44 }
45 
46 template <typename T>
getPointerStr(const T * arr,deUint32 size)47 inline tcu::Format::ArrayPointer<T> getPointerStr (const T* arr, deUint32 size)
48 {
49 	return tcu::formatArray(arr, (int)size);
50 }
51 
52 template <typename T>
getPointerStr(const T * arr,int size)53 inline tcu::Format::ArrayPointer<T> getPointerStr (const T* arr, int size)
54 {
55 	return tcu::formatArray(arr, de::max(size, 0));
56 }
57 
58 // String formatter.
59 
60 class StringFmt
61 {
62 public:
63 	const glw::GLchar* str;
StringFmt(const glw::GLchar * str_)64 	StringFmt (const glw::GLchar* str_) : str(str_) {}
65 };
66 
operator <<(std::ostream & str,StringFmt fmt)67 inline std::ostream& operator<< (std::ostream& str, StringFmt fmt)
68 {
69 	return str << (fmt.str ? (const char*)fmt.str : "NULL");
70 }
71 
getStringStr(const char * value)72 inline StringFmt getStringStr (const char*			value)	{ return StringFmt(value);				}
getStringStr(const glw::GLubyte * value)73 inline StringFmt getStringStr (const glw::GLubyte*	value)	{ return StringFmt((const char*)value);	}
74 
75 // Framebuffer parameter pointer formatter.
76 
77 class FboParamPtrFmt
78 {
79 public:
80 	deUint32	param;
81 	const int*	value;
82 
FboParamPtrFmt(deUint32 param_,const int * value_)83 	FboParamPtrFmt (deUint32 param_, const int* value_) : param(param_), value(value_) {}
84 };
85 
operator <<(std::ostream & str,FboParamPtrFmt fmt)86 std::ostream& operator<< (std::ostream& str, FboParamPtrFmt fmt)
87 {
88 	if (fmt.value)
89 	{
90 		switch (fmt.param)
91 		{
92 			case GL_FRAMEBUFFER_ATTACHMENT_OBJECT_TYPE:
93 				return str << tcu::Format::Enum<int, 2>(getFramebufferAttachmentTypeName, *fmt.value);
94 
95 			case GL_FRAMEBUFFER_ATTACHMENT_TEXTURE_CUBE_MAP_FACE:
96 				return str << tcu::Format::Enum<int, 2>(getCubeMapFaceName, *fmt.value);
97 
98 			case GL_FRAMEBUFFER_ATTACHMENT_COMPONENT_TYPE:
99 				return str << tcu::Format::Enum<int, 2>(getTypeName, *fmt.value);
100 
101 			case GL_FRAMEBUFFER_ATTACHMENT_COLOR_ENCODING:
102 				return str << tcu::Format::Enum<int, 2>(getFramebufferColorEncodingName, *fmt.value);
103 
104 			case GL_FRAMEBUFFER_ATTACHMENT_LAYERED:
105 				return str << tcu::Format::Enum<int, 2>(getBooleanName, *fmt.value);
106 
107 			case GL_FRAMEBUFFER_ATTACHMENT_OBJECT_NAME:
108 			case GL_FRAMEBUFFER_ATTACHMENT_TEXTURE_LAYER:
109 			case GL_FRAMEBUFFER_ATTACHMENT_TEXTURE_LEVEL:
110 			case GL_FRAMEBUFFER_ATTACHMENT_RED_SIZE:
111 			case GL_FRAMEBUFFER_ATTACHMENT_GREEN_SIZE:
112 			case GL_FRAMEBUFFER_ATTACHMENT_BLUE_SIZE:
113 			case GL_FRAMEBUFFER_ATTACHMENT_ALPHA_SIZE:
114 			case GL_FRAMEBUFFER_ATTACHMENT_DEPTH_SIZE:
115 			case GL_FRAMEBUFFER_ATTACHMENT_STENCIL_SIZE:
116 				return str << *fmt.value;
117 
118 			default:
119 				return str << tcu::toHex(*fmt.value);
120 		}
121 	}
122 	else
123 		return str << "(null)";
124 }
125 
getFramebufferAttachmentParameterValueStr(deUint32 param,const int * value)126 inline FboParamPtrFmt getFramebufferAttachmentParameterValueStr (deUint32 param, const int* value)
127 {
128 	return FboParamPtrFmt(param, value);
129 }
130 
131 #include "gluQueryUtil.inl"
132 #include "gluCallLogUtil.inl"
133 
134 // API entry-point implementations are auto-generated
135 #include "gluCallLogWrapper.inl"
136 
137 } // glu
138