blob: 6f519b5dc4417dce1d5c388cc4cc2442d7567ff1 [file] [log] [blame]
reed@google.comac10a2d2010-12-22 21:39:39 +00001/*
2 Copyright 2010 Google Inc.
3
4 Licensed under the Apache License, Version 2.0 (the "License");
5 you may not use this file except in compliance with the License.
6 You may obtain a copy of the License at
7
8 http://www.apache.org/licenses/LICENSE-2.0
9
10 Unless required by applicable law or agreed to in writing, software
11 distributed under the License is distributed on an "AS IS" BASIS,
12 WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 See the License for the specific language governing permissions and
14 limitations under the License.
15 */
16
17
18#ifndef GrConfig_DEFINED
19#define GrConfig_DEFINED
20
21///////////////////////////////////////////////////////////////////////////////
22// preconfig section:
23//
24// All the work before including GrUserConfig.h should center around guessing
25// what platform we're on, and defining low-level symbols based on that.
26//
27// A build environment may have already defined symbols, so we first check
28// for that
29//
30
31// hack to ensure we know what sort of Apple platform we're on
32#if defined(__APPLE_CPP__) || defined(__APPLE_CC__)
33 #include <TargetConditionals.h>
34#endif
35
36/**
37 * Gr defines are set to 0 or 1, rather than being undefined or defined
38 */
39
40#if !defined(GR_ANDROID_BUILD)
41 #define GR_ANDROID_BUILD 0
42#endif
43#if !defined(GR_IOS_BUILD)
44 #define GR_IOS_BUILD 0
45#endif
46#if !defined(GR_LINUX_BUILD)
47 #define GR_LINUX_BUILD 0
48#endif
49#if !defined(GR_MAC_BUILD)
50 #define GR_MAC_BUILD 0
51#endif
52#if !defined(GR_WIN32_BUILD)
53 #define GR_WIN32_BUILD 0
54#endif
55#if !defined(GR_QNX_BUILD)
56 #define GR_QNX_BUILD 0
57#endif
58
59/**
60 * If no build target has been defined, attempt to infer.
61 */
62#if !GR_ANDROID_BUILD && !GR_IOS_BUILD && !GR_LINUX_BUILD && !GR_MAC_BUILD && !GR_WIN32_BUILD && !GR_QNX_BUILD
63 #if defined(_WIN32)
64 #undef GR_WIN32_BUILD
65 #define GR_WIN32_BUILD 1
66// #error "WIN"
67 #elif TARGET_OS_IPHONE || TARGET_IPHONE_SIMULATOR
68 #undef GR_IOS_BUILD
69 #define GR_IOS_BUILD 1
70// #error "IOS"
reed@google.comc9218432011-01-25 19:05:12 +000071 #elif (defined(ANDROID_NDK) && ANDROID_NDK) || defined(ANDROID)
reed@google.comac10a2d2010-12-22 21:39:39 +000072 #undef GR_ANDROID_BUILD
73 #define GR_ANDROID_BUILD 1
74// #error "ANDROID"
75 #elif TARGET_OS_MAC
76 #undef GR_MAC_BUILD
77 #define GR_MAC_BUILD 1
78// #error "MAC"
79 #elif TARGET_OS_QNX || defined(__QNXNTO__)
80 #undef GR_QNX_BUILD
81 #define GR_QNX_BUILD 1
82// #error "QNX"
83 #else
84 #undef GR_LINUX_BUILD
85 #define GR_LINUX_BUILD 1
86// #error "LINUX"
bsalomon@google.com1c13c962011-02-14 16:51:21 +000087 #endif
reed@google.comac10a2d2010-12-22 21:39:39 +000088#endif
89
reed@google.comc9218432011-01-25 19:05:12 +000090// we need both GR_DEBUG and GR_RELEASE to be defined as 0 or 1
91//
92#ifndef GR_DEBUG
93 #ifdef GR_RELEASE
94 #define GR_DEBUG !GR_RELEASE
reed@google.comac10a2d2010-12-22 21:39:39 +000095 #else
reed@google.comc9218432011-01-25 19:05:12 +000096 #ifdef NDEBUG
97 #define GR_DEBUG 0
98 #else
99 #define GR_DEBUG 1
100 #endif
reed@google.comac10a2d2010-12-22 21:39:39 +0000101 #endif
reed@google.comc9218432011-01-25 19:05:12 +0000102#endif
103
104#ifndef GR_RELEASE
reed@google.comac10a2d2010-12-22 21:39:39 +0000105 #define GR_RELEASE !GR_DEBUG
106#endif
107
reed@google.comc9218432011-01-25 19:05:12 +0000108#if GR_DEBUG == GR_RELEASE
reed@google.com8752ad72011-01-26 04:55:57 +0000109 #error "GR_DEBUG and GR_RELEASE must not be the same"
reed@google.comc9218432011-01-25 19:05:12 +0000110#endif
111
reed@google.comac10a2d2010-12-22 21:39:39 +0000112///////////////////////////////////////////////////////////////////////////////
113///////////////////////////////////////////////////////////////////////////////
114
senorblanco@chromium.org9d18b782011-03-28 20:47:09 +0000115#if GR_WIN32_BUILD
116// VC8 doesn't support stdint.h, so we define those types here.
117typedef signed char int8_t;
118typedef unsigned char uint8_t;
119typedef short int16_t;
120typedef unsigned short uint16_t;
121typedef int int32_t;
122typedef unsigned uint32_t;
123#else
reed@google.comac10a2d2010-12-22 21:39:39 +0000124/*
bsalomon@google.com91826102011-03-21 19:51:57 +0000125 * Include stdint.h with defines that trigger declaration of C99 limit/const
126 * macros here before anyone else has a chance to include stdint.h without
127 * these.
reed@google.comac10a2d2010-12-22 21:39:39 +0000128 */
129#define __STDC_LIMIT_MACROS
130#define __STDC_CONSTANT_MACROS
131#include <stdint.h>
senorblanco@chromium.org9d18b782011-03-28 20:47:09 +0000132#endif
reed@google.comac10a2d2010-12-22 21:39:39 +0000133
134/*
bsalomon@google.com1c13c962011-02-14 16:51:21 +0000135 * The "user config" file can be empty, and everything should work. It is
reed@google.comac10a2d2010-12-22 21:39:39 +0000136 * meant to store a given platform/client's overrides of our guess-work.
137 *
bsalomon@google.com1c13c962011-02-14 16:51:21 +0000138 * A alternate user config file can be specified by defining
reed@google.comac10a2d2010-12-22 21:39:39 +0000139 * GR_USER_CONFIG_FILE. It should be defined relative to GrConfig.h
140 *
141 * e.g. it can specify GR_DEBUG/GR_RELEASE as it please, change the BUILD
142 * target, or supply its own defines for anything else (e.g. GR_SCALAR)
143 */
144#if !defined(GR_USER_CONFIG_FILE)
145 #include "GrUserConfig.h"
bsalomon@google.com1c13c962011-02-14 16:51:21 +0000146#else
reed@google.comac10a2d2010-12-22 21:39:39 +0000147 #include GR_USER_CONFIG_FILE
148#endif
149
150
151///////////////////////////////////////////////////////////////////////////////
152///////////////////////////////////////////////////////////////////////////////
153// postconfig section:
154//
bsalomon@google.com91826102011-03-21 19:51:57 +0000155
156// GR_IMPLEMENTATION should be define to 1 when building Gr and 0 when including
157// it in another dependent build. The Gr makefile/ide-project should define this
158// to 1.
159#if !defined(GR_IMPLEMENTATION)
160 #define GR_IMPLEMENTATION 0
161#endif
162
163// If Gr is built as a shared library then GR_DLL should be defined to 1 (both
164// when building Gr and when including its headers in dependent builds). Only
165// currently supported minimally for Chrome's Win32 Multi-DLL build (TODO:
166// correctly exort all of the public API correctly and support shared lib on
167// other platforms).
168#if !defined(GR_DLL)
169 #define GR_DLL 0
170#endif
171
172#if GR_WIN32_BUILD && GR_DLL
173 #if GR_IMPLEMENTATION
174 #define GR_API __declspec(dllexport)
175 #else
176 #define GR_API __declspec(dllimport)
177 #endif
178#else
179 #define GR_API
180#endif
181
reed@google.comac10a2d2010-12-22 21:39:39 +0000182// By now we must have a GR_..._BUILD symbol set to 1, and a decision about
183// debug -vs- release
184//
185
186extern void GrPrintf(const char format[], ...);
187
188/**
189 * GR_STRING makes a string of X where X is expanded before conversion to a string
190 * if X itself contains macros.
191 */
192#define GR_STRING(X) GR_STRING_IMPL(X)
193#define GR_STRING_IMPL(X) #X
194
195/**
bsalomon@google.com1c13c962011-02-14 16:51:21 +0000196 * GR_CONCAT concatenates X and Y where each is expanded before
reed@google.comac10a2d2010-12-22 21:39:39 +0000197 * contanenation if either contains macros.
198 */
199#define GR_CONCAT(X,Y) GR_CONCAT_IMPL(X,Y)
200#define GR_CONCAT_IMPL(X,Y) X##Y
201
202/**
203 * Creates a string of the form "<filename>(<linenumber>) : "
204 */
205#define GR_FILE_AND_LINE_STR __FILE__ "(" GR_STRING(__LINE__) ") : "
206
207/**
bsalomon@google.com1c13c962011-02-14 16:51:21 +0000208 * Compilers have different ways of issuing warnings. This macro
209 * attempts to abstract them, but may need to be specialized for your
reed@google.comac10a2d2010-12-22 21:39:39 +0000210 * particular compiler.
211 * To insert compiler warnings use "#pragma message GR_WARN(<string>)"
212 */
reed@google.comc9218432011-01-25 19:05:12 +0000213#if defined(_MSC_VER) && _MSC_VER
reed@google.comac10a2d2010-12-22 21:39:39 +0000214 #define GR_WARN(MSG) (GR_FILE_AND_LINE_STR "WARNING: " MSG)
215#else//__GNUC__ - may need other defines for different compilers
216 #define GR_WARN(MSG) ("WARNING: " MSG)
217#endif
218
219/**
220 * GR_ALWAYSBREAK is an unconditional break in all builds.
221 */
222#if !defined(GR_ALWAYSBREAK)
223 #if GR_WIN32_BUILD
224 #define GR_ALWAYSBREAK __debugbreak()
bsalomon@google.com1c13c962011-02-14 16:51:21 +0000225 #else
reed@google.comac10a2d2010-12-22 21:39:39 +0000226 // TODO: do other platforms really not have continuable breakpoints?
bsalomon@google.com1c13c962011-02-14 16:51:21 +0000227 // sign extend for 64bit architectures to be sure this is
reed@google.comac10a2d2010-12-22 21:39:39 +0000228 // in the high address range
229 #define GR_ALWAYSBREAK *((int*)(int64_t)(int32_t)0xbeefcafe) = 0;
230 #endif
231#endif
232
233/**
234 * GR_DEBUGBREAK is an unconditional break in debug builds.
235 */
236#if !defined(GR_DEBUGBREAK)
237 #if GR_DEBUG
238 #define GR_DEBUGBREAK GR_ALWAYSBREAK
239 #else
240 #define GR_DEBUGBREAK
241 #endif
242#endif
243
244/**
245 * GR_ALWAYSASSERT is an assertion in all builds.
246 */
247#if !defined(GR_ALWAYSASSERT)
248 #define GR_ALWAYSASSERT(COND) \
249 do { \
250 if (!(COND)) { \
251 GrPrintf("%s %s failed\n", GR_FILE_AND_LINE_STR, #COND); \
252 GR_ALWAYSBREAK; \
253 } \
254 } while (false)
255#endif
256
257/**
258 * GR_DEBUGASSERT is an assertion in debug builds only.
259 */
260#if !defined(GR_DEBUGASSERT)
261 #if GR_DEBUG
262 #define GR_DEBUGASSERT(COND) GR_ALWAYSASSERT(COND)
263 #else
264 #define GR_DEBUGASSERT(COND)
265 #endif
266#endif
267
268/**
269 * Prettier forms of the above macros.
270 */
271#define GrAssert(COND) GR_DEBUGASSERT(COND)
272#define GrAlwaysAssert(COND) GR_ALWAYSASSERT(COND)
273
274/**
bsalomon@google.com6f7fbc92011-02-01 19:12:40 +0000275 * Crash from unrecoverable condition, optionally with a message.
276 */
277inline void GrCrash() { GrAlwaysAssert(false); }
278inline void GrCrash(const char* msg) { GrPrintf(msg); GrAlwaysAssert(false); }
279
280/**
bsalomon@google.com1c13c962011-02-14 16:51:21 +0000281 * GR_DEBUGCODE compiles the code X in debug builds only
reed@google.comac10a2d2010-12-22 21:39:39 +0000282 */
283#if !defined(GR_DEBUGCODE)
284 #if GR_DEBUG
285 #define GR_DEBUGCODE(X) X
286 #else
287 #define GR_DEBUGCODE(X)
288 #endif
289#endif
290
291/**
292 * GR_STATIC_ASSERT is a compile time assertion. Depending on the platform
293 * it may print the message in the compiler log. Obviously, the condition must
294 * be evaluatable at compile time.
295 */
bsalomon@google.com1c13c962011-02-14 16:51:21 +0000296// VS 2010 and GCC compiled with c++0x or gnu++0x support the new
reed@google.comac10a2d2010-12-22 21:39:39 +0000297// static_assert.
298#if !defined(GR_STATIC_ASSERT)
reed@google.comc9218432011-01-25 19:05:12 +0000299 #if (defined(_MSC_VER) && _MSC_VER >= 1600) || (defined(__GXX_EXPERIMENTAL_CXX0X__) && __GXX_EXPERIMENTAL_CXX0X__)
reed@google.comac10a2d2010-12-22 21:39:39 +0000300 #define GR_STATIC_ASSERT(CONDITION) static_assert(CONDITION, "bug")
301 #else
302 template <bool> class GR_STATIC_ASSERT_FAILURE;
303 template <> class GR_STATIC_ASSERT_FAILURE<true> {};
304 #define GR_STATIC_ASSERT(CONDITION) \
305 enum {GR_CONCAT(X,__LINE__) = \
306 sizeof(GR_STATIC_ASSERT_FAILURE<CONDITION>)}
307 #endif
308#endif
309
310#if !defined(GR_SCALAR_IS_FLOAT)
311 #define GR_SCALAR_IS_FLOAT 0
312#endif
313#if !defined(GR_SCALAR_IS_FIXED)
314 #define GR_SCALAR_IS_FIXED 0
315#endif
316
317#if !defined(GR_TEXT_SCALAR_TYPE_IS_USHORT)
318 #define GR_TEXT_SCALAR_TYPE_IS_USHORT 0
bsalomon@google.com1c13c962011-02-14 16:51:21 +0000319#endif
reed@google.comac10a2d2010-12-22 21:39:39 +0000320#if !defined(GR_TEXT_SCALAR_TYPE_IS_FLOAT)
321 #define GR_TEXT_SCALAR_TYPE_IS_FLOAT 0
322#endif
323#if !defined(GR_TEXT_SCALAR_TYPE_IS_FIXED)
324 #define GR_TEXT_SCALAR_TYPE_IS_FIXED 0
325#endif
326
327#ifndef GR_DUMP_TEXTURE_UPLOAD
328 #define GR_DUMP_TEXTURE_UPLOAD 0
329#endif
330
junov@google.comf93e7172011-03-31 21:26:24 +0000331#ifndef GR_USE_NEW_GLSHADERS
332 #define GR_USE_NEW_GLSHADERS 0
333#endif
334
reed@google.comac10a2d2010-12-22 21:39:39 +0000335/**
336 * GR_COLLECT_STATS controls whether the GrGpu class collects stats.
337 * If not already defined then collect in debug build but not release.
338 */
339#if !defined(GR_COLLECT_STATS)
340 #define GR_COLLECT_STATS GR_DEBUG
341#endif
342
343/**
bsalomon@google.comd16983b2011-02-02 22:42:20 +0000344 * GR_STATIC_RECT_VB controls whether rects are drawn by issuing a vertex
345 * for each corner or using a static vb that is positioned by modifying the
346 * view / texture matrix.
347 */
bsalomon@google.com43333232011-02-02 19:24:54 +0000348#if !defined(GR_STATIC_RECT_VB)
349 #define GR_STATIC_RECT_VB 0
350#endif
351
bsalomon@google.comd16983b2011-02-02 22:42:20 +0000352/**
353 * GR_AGGRESSIVE_SHADER_OPTS controls how aggressively shaders are optimized
354 * for special cases. On systems where program changes are expensive this
bsalomon@google.com1c13c962011-02-14 16:51:21 +0000355 * may not be advantageous. Consecutive draws may no longer use the same
bsalomon@google.comd16983b2011-02-02 22:42:20 +0000356 * program.
357 */
358#if !defined(GR_AGGRESSIVE_SHADER_OPTS)
359 #define GR_AGGRESSIVE_SHADER_OPTS 0
360#endif
361
bsalomon@google.com1c13c962011-02-14 16:51:21 +0000362/**
363 * GR_GEOM_BUFFER_LOCK_THRESHOLD gives a threshold (in bytes) for when Gr should
364 * lock a GrGeometryBuffer to update its contents. It will use Lock() if the
365 * size of the udpated region is greater than the threshold. Otherwise it will
366 * use updateData() or updateSubData().
367 */
368#if !defined(GR_GEOM_BUFFER_LOCK_THRESHOLD)
369 #define GR_GEOM_BUFFER_LOCK_THRESHOLD (1 << 15)
370#endif
371
reed@google.comac10a2d2010-12-22 21:39:39 +0000372///////////////////////////////////////////////////////////////////////////////
373// tail section:
374//
375// Now we just assert if we are missing some required define, or if we detect
376// and inconsistent combination of defines
377//
378
379
380/**
381 * Only one build target macro should be 1 and the rest should be 0.
382 */
383#define GR_BUILD_SUM (GR_WIN32_BUILD + GR_MAC_BUILD + GR_IOS_BUILD + GR_ANDROID_BUILD + GR_LINUX_BUILD + GR_QNX_BUILD)
384#if 0 == GR_BUILD_SUM
385 #error "Missing a GR_BUILD define"
386#elif 1 != GR_BUILD_SUM
387 #error "More than one GR_BUILD defined"
388#endif
389
390
391#if !GR_SCALAR_IS_FLOAT && !GR_SCALAR_IS_FIXED
392 #undef GR_SCALAR_IS_FLOAT
393 #define GR_SCALAR_IS_FLOAT 1
394 #pragma message GR_WARN("Scalar type not defined, defaulting to float")
395#endif
396
397#if !GR_TEXT_SCALAR_IS_FLOAT && \
398 !GR_TEXT_SCALAR_IS_FIXED && \
399 !GR_TEXT_SCALAR_IS_USHORT
400 #undef GR_TEXT_SCALAR_IS_FLOAT
401 #define GR_TEXT_SCALAR_IS_FLOAT 1
402 #pragma message GR_WARN("Text scalar type not defined, defaulting to float")
403#endif
404
405#if 0
406#if GR_WIN32_BUILD
407// #pragma message GR_WARN("GR_WIN32_BUILD")
408#endif
409#if GR_MAC_BUILD
410// #pragma message GR_WARN("GR_MAC_BUILD")
411#endif
412#if GR_IOS_BUILD
413// #pragma message GR_WARN("GR_IOS_BUILD")
414#endif
415#if GR_ANDROID_BUILD
416// #pragma message GR_WARN("GR_ANDROID_BUILD")
417#endif
418#if GR_LINUX_BUILD
419// #pragma message GR_WARN("GR_LINUX_BUILD")
420#endif
421#if GR_QNX_BUILD
422// #pragma message GR_WARN("GR_QNX_BUILD")
423#endif
424#endif
425
426#endif
427