aboutsummaryrefslogtreecommitdiff
path: root/build/tools/HLSLcc/May_2014/include
diff options
context:
space:
mode:
authorlbavoil <[email protected]>2016-03-25 13:01:54 +0100
committerlbavoil <[email protected]>2016-03-25 13:01:54 +0100
commit99174e4e5fb4b7079da80b35a6dfd68f3fd56a1c (patch)
treefbcd4260d6c953d569a887505336a1c3f202e10f /build/tools/HLSLcc/May_2014/include
downloadhbaoplus-99174e4e5fb4b7079da80b35a6dfd68f3fd56a1c.tar.xz
hbaoplus-99174e4e5fb4b7079da80b35a6dfd68f3fd56a1c.zip
GFSDK_HBAO+_distro_r3.0_cl20573789
Diffstat (limited to 'build/tools/HLSLcc/May_2014/include')
-rw-r--r--build/tools/HLSLcc/May_2014/include/hlslcc.h451
-rw-r--r--build/tools/HLSLcc/May_2014/include/hlslcc.hpp5
-rw-r--r--build/tools/HLSLcc/May_2014/include/pstdint.h800
3 files changed, 1256 insertions, 0 deletions
diff --git a/build/tools/HLSLcc/May_2014/include/hlslcc.h b/build/tools/HLSLcc/May_2014/include/hlslcc.h
new file mode 100644
index 0000000..5ab1108
--- /dev/null
+++ b/build/tools/HLSLcc/May_2014/include/hlslcc.h
@@ -0,0 +1,451 @@
+#ifndef HLSLCC_H_
+#define HLSLCC_H_
+
+#if defined (_WIN32) && defined(HLSLCC_DYNLIB)
+ #define HLSLCC_APIENTRY __stdcall
+ #if defined(libHLSLcc_EXPORTS)
+ #define HLSLCC_API __declspec(dllexport)
+ #else
+ #define HLSLCC_API __declspec(dllimport)
+ #endif
+#else
+ #define HLSLCC_APIENTRY
+ #define HLSLCC_API
+#endif
+
+#include "pstdint.h"
+
+typedef enum
+{
+ LANG_DEFAULT,// Depends on the HLSL shader model.
+ LANG_ES_100,
+ LANG_ES_300,
+ LANG_ES_310,
+ LANG_120,
+ LANG_130,
+ LANG_140,
+ LANG_150,
+ LANG_330,
+ LANG_400,
+ LANG_410,
+ LANG_420,
+ LANG_430,
+ LANG_440,
+} GLLang;
+
+typedef struct {
+ uint32_t ARB_explicit_attrib_location : 1;
+ uint32_t ARB_explicit_uniform_location : 1;
+ uint32_t ARB_shading_language_420pack : 1;
+}GlExtensions;
+
+enum {MAX_SHADER_VEC4_OUTPUT = 512};
+enum {MAX_SHADER_VEC4_INPUT = 512};
+enum {MAX_TEXTURES = 128};
+enum {MAX_FORK_PHASES = 2};
+enum {MAX_FUNCTION_BODIES = 1024};
+enum {MAX_CLASS_TYPES = 1024};
+enum {MAX_FUNCTION_POINTERS = 128};
+
+//Reflection
+#define MAX_REFLECT_STRING_LENGTH 512
+#define MAX_SHADER_VARS 256
+#define MAX_CBUFFERS 256
+#define MAX_UAV 256
+#define MAX_FUNCTION_TABLES 256
+#define MAX_RESOURCE_BINDINGS 256
+
+typedef enum SPECIAL_NAME
+{
+ NAME_UNDEFINED = 0,
+ NAME_POSITION = 1,
+ NAME_CLIP_DISTANCE = 2,
+ NAME_CULL_DISTANCE = 3,
+ NAME_RENDER_TARGET_ARRAY_INDEX = 4,
+ NAME_VIEWPORT_ARRAY_INDEX = 5,
+ NAME_VERTEX_ID = 6,
+ NAME_PRIMITIVE_ID = 7,
+ NAME_INSTANCE_ID = 8,
+ NAME_IS_FRONT_FACE = 9,
+ NAME_SAMPLE_INDEX = 10,
+ // The following are added for D3D11
+ NAME_FINAL_QUAD_U_EQ_0_EDGE_TESSFACTOR = 11,
+ NAME_FINAL_QUAD_V_EQ_0_EDGE_TESSFACTOR = 12,
+ NAME_FINAL_QUAD_U_EQ_1_EDGE_TESSFACTOR = 13,
+ NAME_FINAL_QUAD_V_EQ_1_EDGE_TESSFACTOR = 14,
+ NAME_FINAL_QUAD_U_INSIDE_TESSFACTOR = 15,
+ NAME_FINAL_QUAD_V_INSIDE_TESSFACTOR = 16,
+ NAME_FINAL_TRI_U_EQ_0_EDGE_TESSFACTOR = 17,
+ NAME_FINAL_TRI_V_EQ_0_EDGE_TESSFACTOR = 18,
+ NAME_FINAL_TRI_W_EQ_0_EDGE_TESSFACTOR = 19,
+ NAME_FINAL_TRI_INSIDE_TESSFACTOR = 20,
+ NAME_FINAL_LINE_DETAIL_TESSFACTOR = 21,
+ NAME_FINAL_LINE_DENSITY_TESSFACTOR = 22,
+} SPECIAL_NAME;
+
+
+typedef enum {
+ INOUT_COMPONENT_UNKNOWN = 0,
+ INOUT_COMPONENT_UINT32 = 1,
+ INOUT_COMPONENT_SINT32 = 2,
+ INOUT_COMPONENT_FLOAT32 = 3
+} INOUT_COMPONENT_TYPE;
+
+typedef enum MIN_PRECISION {
+ D3D_MIN_PRECISION_DEFAULT = 0,
+ D3D_MIN_PRECISION_FLOAT_16 = 1,
+ D3D_MIN_PRECISION_FLOAT_2_8 = 2,
+ D3D_MIN_PRECISION_RESERVED = 3,
+ D3D_MIN_PRECISION_SINT_16 = 4,
+ D3D_MIN_PRECISION_UINT_16 = 5,
+ D3D_MIN_PRECISION_ANY_16 = 0xf0,
+ D3D_MIN_PRECISION_ANY_10 = 0xf1
+} MIN_PRECISION;
+
+typedef struct InOutSignature_TAG
+{
+ char SemanticName[MAX_REFLECT_STRING_LENGTH];
+ uint32_t ui32SemanticIndex;
+ SPECIAL_NAME eSystemValueType;
+ INOUT_COMPONENT_TYPE eComponentType;
+ uint32_t ui32Register;
+ uint32_t ui32Mask;
+ uint32_t ui32ReadWriteMask;
+
+ uint32_t ui32Stream;
+ MIN_PRECISION eMinPrec;
+
+} InOutSignature;
+
+typedef enum ResourceType_TAG
+{
+ RTYPE_CBUFFER,//0
+ RTYPE_TBUFFER,//1
+ RTYPE_TEXTURE,//2
+ RTYPE_SAMPLER,//3
+ RTYPE_UAV_RWTYPED,//4
+ RTYPE_STRUCTURED,//5
+ RTYPE_UAV_RWSTRUCTURED,//6
+ RTYPE_BYTEADDRESS,//7
+ RTYPE_UAV_RWBYTEADDRESS,//8
+ RTYPE_UAV_APPEND_STRUCTURED,//9
+ RTYPE_UAV_CONSUME_STRUCTURED,//10
+ RTYPE_UAV_RWSTRUCTURED_WITH_COUNTER,//11
+ RTYPE_COUNT,
+} ResourceType;
+
+typedef enum ResourceGroup_TAG {
+ RGROUP_CBUFFER,
+ RGROUP_TEXTURE,
+ RGROUP_SAMPLER,
+ RGROUP_UAV,
+ RGROUP_COUNT,
+} ResourceGroup;
+
+typedef enum REFLECT_RESOURCE_DIMENSION
+{
+ REFLECT_RESOURCE_DIMENSION_UNKNOWN = 0,
+ REFLECT_RESOURCE_DIMENSION_BUFFER = 1,
+ REFLECT_RESOURCE_DIMENSION_TEXTURE1D = 2,
+ REFLECT_RESOURCE_DIMENSION_TEXTURE1DARRAY = 3,
+ REFLECT_RESOURCE_DIMENSION_TEXTURE2D = 4,
+ REFLECT_RESOURCE_DIMENSION_TEXTURE2DARRAY = 5,
+ REFLECT_RESOURCE_DIMENSION_TEXTURE2DMS = 6,
+ REFLECT_RESOURCE_DIMENSION_TEXTURE2DMSARRAY = 7,
+ REFLECT_RESOURCE_DIMENSION_TEXTURE3D = 8,
+ REFLECT_RESOURCE_DIMENSION_TEXTURECUBE = 9,
+ REFLECT_RESOURCE_DIMENSION_TEXTURECUBEARRAY = 10,
+ REFLECT_RESOURCE_DIMENSION_BUFFEREX = 11,
+} REFLECT_RESOURCE_DIMENSION;
+
+typedef struct ResourceBinding_TAG
+{
+ char Name[MAX_REFLECT_STRING_LENGTH];
+ ResourceType eType;
+ uint32_t ui32BindPoint;
+ uint32_t ui32BindCount;
+ uint32_t ui32Flags;
+ REFLECT_RESOURCE_DIMENSION eDimension;
+ uint32_t ui32ReturnType;
+ uint32_t ui32NumSamples;
+} ResourceBinding;
+
+typedef enum _SHADER_VARIABLE_TYPE {
+ SVT_VOID = 0,
+ SVT_BOOL = 1,
+ SVT_INT = 2,
+ SVT_FLOAT = 3,
+ SVT_STRING = 4,
+ SVT_TEXTURE = 5,
+ SVT_TEXTURE1D = 6,
+ SVT_TEXTURE2D = 7,
+ SVT_TEXTURE3D = 8,
+ SVT_TEXTURECUBE = 9,
+ SVT_SAMPLER = 10,
+ SVT_PIXELSHADER = 15,
+ SVT_VERTEXSHADER = 16,
+ SVT_UINT = 19,
+ SVT_UINT8 = 20,
+ SVT_GEOMETRYSHADER = 21,
+ SVT_RASTERIZER = 22,
+ SVT_DEPTHSTENCIL = 23,
+ SVT_BLEND = 24,
+ SVT_BUFFER = 25,
+ SVT_CBUFFER = 26,
+ SVT_TBUFFER = 27,
+ SVT_TEXTURE1DARRAY = 28,
+ SVT_TEXTURE2DARRAY = 29,
+ SVT_RENDERTARGETVIEW = 30,
+ SVT_DEPTHSTENCILVIEW = 31,
+ SVT_TEXTURE2DMS = 32,
+ SVT_TEXTURE2DMSARRAY = 33,
+ SVT_TEXTURECUBEARRAY = 34,
+ SVT_HULLSHADER = 35,
+ SVT_DOMAINSHADER = 36,
+ SVT_INTERFACE_POINTER = 37,
+ SVT_COMPUTESHADER = 38,
+ SVT_DOUBLE = 39,
+ SVT_RWTEXTURE1D = 40,
+ SVT_RWTEXTURE1DARRAY = 41,
+ SVT_RWTEXTURE2D = 42,
+ SVT_RWTEXTURE2DARRAY = 43,
+ SVT_RWTEXTURE3D = 44,
+ SVT_RWBUFFER = 45,
+ SVT_BYTEADDRESS_BUFFER = 46,
+ SVT_RWBYTEADDRESS_BUFFER = 47,
+ SVT_STRUCTURED_BUFFER = 48,
+ SVT_RWSTRUCTURED_BUFFER = 49,
+ SVT_APPEND_STRUCTURED_BUFFER = 50,
+ SVT_CONSUME_STRUCTURED_BUFFER = 51,
+
+ SVT_FORCE_DWORD = 0x7fffffff
+} SHADER_VARIABLE_TYPE;
+
+typedef enum _SHADER_VARIABLE_CLASS {
+ SVC_SCALAR = 0,
+ SVC_VECTOR = ( SVC_SCALAR + 1 ),
+ SVC_MATRIX_ROWS = ( SVC_VECTOR + 1 ),
+ SVC_MATRIX_COLUMNS = ( SVC_MATRIX_ROWS + 1 ),
+ SVC_OBJECT = ( SVC_MATRIX_COLUMNS + 1 ),
+ SVC_STRUCT = ( SVC_OBJECT + 1 ),
+ SVC_INTERFACE_CLASS = ( SVC_STRUCT + 1 ),
+ SVC_INTERFACE_POINTER = ( SVC_INTERFACE_CLASS + 1 ),
+ SVC_FORCE_DWORD = 0x7fffffff
+} SHADER_VARIABLE_CLASS;
+
+typedef struct ShaderVarType_TAG {
+ SHADER_VARIABLE_CLASS Class;
+ SHADER_VARIABLE_TYPE Type;
+ uint32_t Rows;
+ uint32_t Columns;
+ uint32_t Elements;
+ uint32_t MemberCount;
+ uint32_t Offset;
+ char Name[MAX_REFLECT_STRING_LENGTH];
+
+ uint32_t ParentCount;
+ struct ShaderVarType_TAG * Parent;
+ //Includes all parent names.
+ char FullName[MAX_REFLECT_STRING_LENGTH];
+
+ struct ShaderVarType_TAG * Members;
+} ShaderVarType;
+
+typedef struct ShaderVar_TAG
+{
+ char Name[MAX_REFLECT_STRING_LENGTH];
+ int haveDefaultValue;
+ uint32_t* pui32DefaultValues;
+ //Offset/Size in bytes.
+ uint32_t ui32StartOffset;
+ uint32_t ui32Size;
+
+ ShaderVarType sType;
+} ShaderVar;
+
+typedef struct ConstantBuffer_TAG
+{
+ char Name[MAX_REFLECT_STRING_LENGTH];
+
+ uint32_t ui32NumVars;
+ ShaderVar asVars [MAX_SHADER_VARS];
+
+ uint32_t ui32TotalSizeInBytes;
+} ConstantBuffer;
+
+typedef struct ClassType_TAG
+{
+ char Name[MAX_REFLECT_STRING_LENGTH];
+ uint16_t ui16ID;
+ uint16_t ui16ConstBufStride;
+ uint16_t ui16Texture;
+ uint16_t ui16Sampler;
+} ClassType;
+
+typedef struct ClassInstance_TAG
+{
+ char Name[MAX_REFLECT_STRING_LENGTH];
+ uint16_t ui16ID;
+ uint16_t ui16ConstBuf;
+ uint16_t ui16ConstBufOffset;
+ uint16_t ui16Texture;
+ uint16_t ui16Sampler;
+} ClassInstance;
+
+typedef enum TESSELLATOR_PARTITIONING
+{
+ TESSELLATOR_PARTITIONING_UNDEFINED = 0,
+ TESSELLATOR_PARTITIONING_INTEGER = 1,
+ TESSELLATOR_PARTITIONING_POW2 = 2,
+ TESSELLATOR_PARTITIONING_FRACTIONAL_ODD = 3,
+ TESSELLATOR_PARTITIONING_FRACTIONAL_EVEN = 4
+} TESSELLATOR_PARTITIONING;
+
+typedef enum TESSELLATOR_OUTPUT_PRIMITIVE
+{
+ TESSELLATOR_OUTPUT_UNDEFINED = 0,
+ TESSELLATOR_OUTPUT_POINT = 1,
+ TESSELLATOR_OUTPUT_LINE = 2,
+ TESSELLATOR_OUTPUT_TRIANGLE_CW = 3,
+ TESSELLATOR_OUTPUT_TRIANGLE_CCW = 4
+} TESSELLATOR_OUTPUT_PRIMITIVE;
+
+typedef struct ShaderInfo_TAG
+{
+ uint32_t ui32MajorVersion;
+ uint32_t ui32MinorVersion;
+
+ uint32_t ui32NumInputSignatures;
+ InOutSignature* psInputSignatures;
+
+ uint32_t ui32NumOutputSignatures;
+ InOutSignature* psOutputSignatures;
+
+ uint32_t ui32NumResourceBindings;
+ ResourceBinding* psResourceBindings;
+
+ uint32_t ui32NumConstantBuffers;
+ ConstantBuffer* psConstantBuffers;
+ ConstantBuffer* psThisPointerConstBuffer;
+
+ uint32_t ui32NumClassTypes;
+ ClassType* psClassTypes;
+
+ uint32_t ui32NumClassInstances;
+ ClassInstance* psClassInstances;
+
+ //Func table ID to class name ID.
+ uint32_t aui32TableIDToTypeID[MAX_FUNCTION_TABLES];
+
+ uint32_t aui32ResourceMap[RGROUP_COUNT][MAX_RESOURCE_BINDINGS];
+
+ TESSELLATOR_PARTITIONING eTessPartitioning;
+ TESSELLATOR_OUTPUT_PRIMITIVE eTessOutPrim;
+} ShaderInfo;
+
+typedef enum INTERPOLATION_MODE
+{
+ INTERPOLATION_UNDEFINED = 0,
+ INTERPOLATION_CONSTANT = 1,
+ INTERPOLATION_LINEAR = 2,
+ INTERPOLATION_LINEAR_CENTROID = 3,
+ INTERPOLATION_LINEAR_NOPERSPECTIVE = 4,
+ INTERPOLATION_LINEAR_NOPERSPECTIVE_CENTROID = 5,
+ INTERPOLATION_LINEAR_SAMPLE = 6,
+ INTERPOLATION_LINEAR_NOPERSPECTIVE_SAMPLE = 7,
+} INTERPOLATION_MODE;
+
+//The shader stages (Vertex, Pixel et al) do not depend on each other
+//in HLSL. GLSL is a different story. HLSLCrossCompiler requires
+//that hull shaders must be compiled before domain shaders, and
+//the pixel shader must be compiled before all of the others.
+//Durring compiliation the GLSLCrossDependencyData struct will
+//carry over any information needed about a different shader stage
+//in order to construct valid GLSL shader combinations.
+
+//Using GLSLCrossDependencyData is optional. However some shader
+//combinations may show link failures, or runtime errors.
+typedef struct
+{
+ //dcl_tessellator_partitioning and dcl_tessellator_output_primitive appear in hull shader for D3D,
+ //but they appear on inputs inside domain shaders for GL.
+ //Hull shader must be compiled before domain so the
+ //ensure correct partitioning and primitive type information
+ //can be saved when compiling hull and passed to domain compiliation.
+ TESSELLATOR_PARTITIONING eTessPartitioning;
+ TESSELLATOR_OUTPUT_PRIMITIVE eTessOutPrim;
+
+ //Required if PixelInterpDependency is true
+ INTERPOLATION_MODE aePixelInputInterpolation[MAX_SHADER_VEC4_INPUT];
+} GLSLCrossDependencyData;
+
+typedef struct
+{
+ int shaderType; //One of the GL enums.
+ char* sourceCode;
+ ShaderInfo reflection;
+ GLLang GLSLLanguage;
+} GLSLShader;
+
+/*HLSL constant buffers are treated as default-block unform arrays by default. This is done
+ to support versions of GLSL which lack ARB_uniform_buffer_object functionality.
+ Setting this flag causes each one to have its own uniform block.
+ Note: Currently the nth const buffer will be named UnformBufferN. This is likey to change to the original HLSL name in the future.*/
+static const unsigned int HLSLCC_FLAG_UNIFORM_BUFFER_OBJECT = 0x1;
+
+static const unsigned int HLSLCC_FLAG_ORIGIN_UPPER_LEFT = 0x2;
+
+static const unsigned int HLSLCC_FLAG_PIXEL_CENTER_INTEGER = 0x4;
+
+static const unsigned int HLSLCC_FLAG_GLOBAL_CONSTS_NEVER_IN_UBO = 0x8;
+
+//GS enabled?
+//Affects vertex shader (i.e. need to compile vertex shader again to use with/without GS).
+//This flag is needed in order for the interfaces between stages to match when GS is in use.
+//PS inputs VtxGeoOutput
+//GS outputs VtxGeoOutput
+//Vs outputs VtxOutput if GS enabled. VtxGeoOutput otherwise.
+static const unsigned int HLSLCC_FLAG_GS_ENABLED = 0x10;
+
+static const unsigned int HLSLCC_FLAG_TESS_ENABLED = 0x20;
+
+//Either use this flag or glBindFragDataLocationIndexed.
+//When set the first pixel shader output is the first input to blend
+//equation, the others go to the second input.
+static const unsigned int HLSLCC_FLAG_DUAL_SOURCE_BLENDING = 0x40;
+
+//If set, shader inputs and outputs are declared with their semantic name.
+static const unsigned int HLSLCC_FLAG_INOUT_SEMANTIC_NAMES = 0x80;
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+HLSLCC_API void HLSLCC_APIENTRY HLSLcc_SetMemoryFunctions( void* (*malloc_override)(size_t),
+ void* (*calloc_override)(size_t,size_t),
+ void (*free_override)(void *),
+ void* (*realloc_override)(void*,size_t));
+
+HLSLCC_API int HLSLCC_APIENTRY TranslateHLSLFromFile(const char* filename,
+ unsigned int flags,
+ GLLang language,
+ const GlExtensions *extensions,
+ GLSLCrossDependencyData* dependencies,
+ GLSLShader* result
+ );
+
+HLSLCC_API int HLSLCC_APIENTRY TranslateHLSLFromMem(const char* shader,
+ unsigned int flags,
+ GLLang language,
+ const GlExtensions *extensions,
+ GLSLCrossDependencyData* dependencies,
+ GLSLShader* result);
+
+HLSLCC_API void HLSLCC_APIENTRY FreeGLSLShader(GLSLShader*);
+
+#ifdef __cplusplus
+}
+#endif
+
+#endif
+
diff --git a/build/tools/HLSLcc/May_2014/include/hlslcc.hpp b/build/tools/HLSLcc/May_2014/include/hlslcc.hpp
new file mode 100644
index 0000000..fa4dd96
--- /dev/null
+++ b/build/tools/HLSLcc/May_2014/include/hlslcc.hpp
@@ -0,0 +1,5 @@
+
+extern "C" {
+#include "hlslcc.h"
+}
+
diff --git a/build/tools/HLSLcc/May_2014/include/pstdint.h b/build/tools/HLSLcc/May_2014/include/pstdint.h
new file mode 100644
index 0000000..00fc1fc
--- /dev/null
+++ b/build/tools/HLSLcc/May_2014/include/pstdint.h
@@ -0,0 +1,800 @@
+/* A portable stdint.h
+ ****************************************************************************
+ * BSD License:
+ ****************************************************************************
+ *
+ * Copyright (c) 2005-2011 Paul Hsieh
+ * All rights reserved.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions
+ * are met:
+ *
+ * 1. Redistributions of source code must retain the above copyright
+ * notice, this list of conditions and the following disclaimer.
+ * 2. Redistributions in binary form must reproduce the above copyright
+ * notice, this list of conditions and the following disclaimer in the
+ * documentation and/or other materials provided with the distribution.
+ * 3. The name of the author may not be used to endorse or promote products
+ * derived from this software without specific prior written permission.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
+ * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
+ * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
+ * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
+ * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
+ * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
+ * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
+ * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
+ * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
+ * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+ *
+ ****************************************************************************
+ *
+ * Version 0.1.12
+ *
+ * The ANSI C standard committee, for the C99 standard, specified the
+ * inclusion of a new standard include file called stdint.h. This is
+ * a very useful and long desired include file which contains several
+ * very precise definitions for integer scalar types that is
+ * critically important for making portable several classes of
+ * applications including cryptography, hashing, variable length
+ * integer libraries and so on. But for most developers its likely
+ * useful just for programming sanity.
+ *
+ * The problem is that most compiler vendors have decided not to
+ * implement the C99 standard, and the next C++ language standard
+ * (which has a lot more mindshare these days) will be a long time in
+ * coming and its unknown whether or not it will include stdint.h or
+ * how much adoption it will have. Either way, it will be a long time
+ * before all compilers come with a stdint.h and it also does nothing
+ * for the extremely large number of compilers available today which
+ * do not include this file, or anything comparable to it.
+ *
+ * So that's what this file is all about. Its an attempt to build a
+ * single universal include file that works on as many platforms as
+ * possible to deliver what stdint.h is supposed to. A few things
+ * that should be noted about this file:
+ *
+ * 1) It is not guaranteed to be portable and/or present an identical
+ * interface on all platforms. The extreme variability of the
+ * ANSI C standard makes this an impossibility right from the
+ * very get go. Its really only meant to be useful for the vast
+ * majority of platforms that possess the capability of
+ * implementing usefully and precisely defined, standard sized
+ * integer scalars. Systems which are not intrinsically 2s
+ * complement may produce invalid constants.
+ *
+ * 2) There is an unavoidable use of non-reserved symbols.
+ *
+ * 3) Other standard include files are invoked.
+ *
+ * 4) This file may come in conflict with future platforms that do
+ * include stdint.h. The hope is that one or the other can be
+ * used with no real difference.
+ *
+ * 5) In the current verison, if your platform can't represent
+ * int32_t, int16_t and int8_t, it just dumps out with a compiler
+ * error.
+ *
+ * 6) 64 bit integers may or may not be defined. Test for their
+ * presence with the test: #ifdef INT64_MAX or #ifdef UINT64_MAX.
+ * Note that this is different from the C99 specification which
+ * requires the existence of 64 bit support in the compiler. If
+ * this is not defined for your platform, yet it is capable of
+ * dealing with 64 bits then it is because this file has not yet
+ * been extended to cover all of your system's capabilities.
+ *
+ * 7) (u)intptr_t may or may not be defined. Test for its presence
+ * with the test: #ifdef PTRDIFF_MAX. If this is not defined
+ * for your platform, then it is because this file has not yet
+ * been extended to cover all of your system's capabilities, not
+ * because its optional.
+ *
+ * 8) The following might not been defined even if your platform is
+ * capable of defining it:
+ *
+ * WCHAR_MIN
+ * WCHAR_MAX
+ * (u)int64_t
+ * PTRDIFF_MIN
+ * PTRDIFF_MAX
+ * (u)intptr_t
+ *
+ * 9) The following have not been defined:
+ *
+ * WINT_MIN
+ * WINT_MAX
+ *
+ * 10) The criteria for defining (u)int_least(*)_t isn't clear,
+ * except for systems which don't have a type that precisely
+ * defined 8, 16, or 32 bit types (which this include file does
+ * not support anyways). Default definitions have been given.
+ *
+ * 11) The criteria for defining (u)int_fast(*)_t isn't something I
+ * would trust to any particular compiler vendor or the ANSI C
+ * committee. It is well known that "compatible systems" are
+ * commonly created that have very different performance
+ * characteristics from the systems they are compatible with,
+ * especially those whose vendors make both the compiler and the
+ * system. Default definitions have been given, but its strongly
+ * recommended that users never use these definitions for any
+ * reason (they do *NOT* deliver any serious guarantee of
+ * improved performance -- not in this file, nor any vendor's
+ * stdint.h).
+ *
+ * 12) The following macros:
+ *
+ * PRINTF_INTMAX_MODIFIER
+ * PRINTF_INT64_MODIFIER
+ * PRINTF_INT32_MODIFIER
+ * PRINTF_INT16_MODIFIER
+ * PRINTF_LEAST64_MODIFIER
+ * PRINTF_LEAST32_MODIFIER
+ * PRINTF_LEAST16_MODIFIER
+ * PRINTF_INTPTR_MODIFIER
+ *
+ * are strings which have been defined as the modifiers required
+ * for the "d", "u" and "x" printf formats to correctly output
+ * (u)intmax_t, (u)int64_t, (u)int32_t, (u)int16_t, (u)least64_t,
+ * (u)least32_t, (u)least16_t and (u)intptr_t types respectively.
+ * PRINTF_INTPTR_MODIFIER is not defined for some systems which
+ * provide their own stdint.h. PRINTF_INT64_MODIFIER is not
+ * defined if INT64_MAX is not defined. These are an extension
+ * beyond what C99 specifies must be in stdint.h.
+ *
+ * In addition, the following macros are defined:
+ *
+ * PRINTF_INTMAX_HEX_WIDTH
+ * PRINTF_INT64_HEX_WIDTH
+ * PRINTF_INT32_HEX_WIDTH
+ * PRINTF_INT16_HEX_WIDTH
+ * PRINTF_INT8_HEX_WIDTH
+ * PRINTF_INTMAX_DEC_WIDTH
+ * PRINTF_INT64_DEC_WIDTH
+ * PRINTF_INT32_DEC_WIDTH
+ * PRINTF_INT16_DEC_WIDTH
+ * PRINTF_INT8_DEC_WIDTH
+ *
+ * Which specifies the maximum number of characters required to
+ * print the number of that type in either hexadecimal or decimal.
+ * These are an extension beyond what C99 specifies must be in
+ * stdint.h.
+ *
+ * Compilers tested (all with 0 warnings at their highest respective
+ * settings): Borland Turbo C 2.0, WATCOM C/C++ 11.0 (16 bits and 32
+ * bits), Microsoft Visual C++ 6.0 (32 bit), Microsoft Visual Studio
+ * .net (VC7), Intel C++ 4.0, GNU gcc v3.3.3
+ *
+ * This file should be considered a work in progress. Suggestions for
+ * improvements, especially those which increase coverage are strongly
+ * encouraged.
+ *
+ * Acknowledgements
+ *
+ * The following people have made significant contributions to the
+ * development and testing of this file:
+ *
+ * Chris Howie
+ * John Steele Scott
+ * Dave Thorup
+ * John Dill
+ *
+ */
+
+#include <stddef.h>
+#include <limits.h>
+#include <signal.h>
+
+/*
+ * For gcc with _STDINT_H, fill in the PRINTF_INT*_MODIFIER macros, and
+ * do nothing else. On the Mac OS X version of gcc this is _STDINT_H_.
+ */
+
+#if ((defined(__STDC__) && __STDC__ && __STDC_VERSION__ >= 199901L) || (defined (__WATCOMC__) && (defined (_STDINT_H_INCLUDED) || __WATCOMC__ >= 1250)) || (defined(__GNUC__) && (defined(_STDINT_H) || defined(_STDINT_H_) || defined (__UINT_FAST64_TYPE__)) )) && !defined (_PSTDINT_H_INCLUDED)
+#include <stdint.h>
+#define _PSTDINT_H_INCLUDED
+# ifndef PRINTF_INT64_MODIFIER
+# define PRINTF_INT64_MODIFIER "ll"
+# endif
+# ifndef PRINTF_INT32_MODIFIER
+# define PRINTF_INT32_MODIFIER "l"
+# endif
+# ifndef PRINTF_INT16_MODIFIER
+# define PRINTF_INT16_MODIFIER "h"
+# endif
+# ifndef PRINTF_INTMAX_MODIFIER
+# define PRINTF_INTMAX_MODIFIER PRINTF_INT64_MODIFIER
+# endif
+# ifndef PRINTF_INT64_HEX_WIDTH
+# define PRINTF_INT64_HEX_WIDTH "16"
+# endif
+# ifndef PRINTF_INT32_HEX_WIDTH
+# define PRINTF_INT32_HEX_WIDTH "8"
+# endif
+# ifndef PRINTF_INT16_HEX_WIDTH
+# define PRINTF_INT16_HEX_WIDTH "4"
+# endif
+# ifndef PRINTF_INT8_HEX_WIDTH
+# define PRINTF_INT8_HEX_WIDTH "2"
+# endif
+# ifndef PRINTF_INT64_DEC_WIDTH
+# define PRINTF_INT64_DEC_WIDTH "20"
+# endif
+# ifndef PRINTF_INT32_DEC_WIDTH
+# define PRINTF_INT32_DEC_WIDTH "10"
+# endif
+# ifndef PRINTF_INT16_DEC_WIDTH
+# define PRINTF_INT16_DEC_WIDTH "5"
+# endif
+# ifndef PRINTF_INT8_DEC_WIDTH
+# define PRINTF_INT8_DEC_WIDTH "3"
+# endif
+# ifndef PRINTF_INTMAX_HEX_WIDTH
+# define PRINTF_INTMAX_HEX_WIDTH PRINTF_INT64_HEX_WIDTH
+# endif
+# ifndef PRINTF_INTMAX_DEC_WIDTH
+# define PRINTF_INTMAX_DEC_WIDTH PRINTF_INT64_DEC_WIDTH
+# endif
+
+/*
+ * Something really weird is going on with Open Watcom. Just pull some of
+ * these duplicated definitions from Open Watcom's stdint.h file for now.
+ */
+
+# if defined (__WATCOMC__) && __WATCOMC__ >= 1250
+# if !defined (INT64_C)
+# define INT64_C(x) (x + (INT64_MAX - INT64_MAX))
+# endif
+# if !defined (UINT64_C)
+# define UINT64_C(x) (x + (UINT64_MAX - UINT64_MAX))
+# endif
+# if !defined (INT32_C)
+# define INT32_C(x) (x + (INT32_MAX - INT32_MAX))
+# endif
+# if !defined (UINT32_C)
+# define UINT32_C(x) (x + (UINT32_MAX - UINT32_MAX))
+# endif
+# if !defined (INT16_C)
+# define INT16_C(x) (x)
+# endif
+# if !defined (UINT16_C)
+# define UINT16_C(x) (x)
+# endif
+# if !defined (INT8_C)
+# define INT8_C(x) (x)
+# endif
+# if !defined (UINT8_C)
+# define UINT8_C(x) (x)
+# endif
+# if !defined (UINT64_MAX)
+# define UINT64_MAX 18446744073709551615ULL
+# endif
+# if !defined (INT64_MAX)
+# define INT64_MAX 9223372036854775807LL
+# endif
+# if !defined (UINT32_MAX)
+# define UINT32_MAX 4294967295UL
+# endif
+# if !defined (INT32_MAX)
+# define INT32_MAX 2147483647L
+# endif
+# if !defined (INTMAX_MAX)
+# define INTMAX_MAX INT64_MAX
+# endif
+# if !defined (INTMAX_MIN)
+# define INTMAX_MIN INT64_MIN
+# endif
+# endif
+#endif
+
+#ifndef _PSTDINT_H_INCLUDED
+#define _PSTDINT_H_INCLUDED
+
+#ifndef SIZE_MAX
+# define SIZE_MAX (~(size_t)0)
+#endif
+
+/*
+ * Deduce the type assignments from limits.h under the assumption that
+ * integer sizes in bits are powers of 2, and follow the ANSI
+ * definitions.
+ */
+
+#ifndef UINT8_MAX
+# define UINT8_MAX 0xff
+#endif
+#ifndef uint8_t
+# if (UCHAR_MAX == UINT8_MAX) || defined (S_SPLINT_S)
+ typedef unsigned char uint8_t;
+# define UINT8_C(v) ((uint8_t) v)
+# else
+# error "Platform not supported"
+# endif
+#endif
+
+#ifndef INT8_MAX
+# define INT8_MAX 0x7f
+#endif
+#ifndef INT8_MIN
+# define INT8_MIN INT8_C(0x80)
+#endif
+#ifndef int8_t
+# if (SCHAR_MAX == INT8_MAX) || defined (S_SPLINT_S)
+ typedef signed char int8_t;
+# define INT8_C(v) ((int8_t) v)
+# else
+# error "Platform not supported"
+# endif
+#endif
+
+#ifndef UINT16_MAX
+# define UINT16_MAX 0xffff
+#endif
+#ifndef uint16_t
+#if (UINT_MAX == UINT16_MAX) || defined (S_SPLINT_S)
+ typedef unsigned int uint16_t;
+# ifndef PRINTF_INT16_MODIFIER
+# define PRINTF_INT16_MODIFIER ""
+# endif
+# define UINT16_C(v) ((uint16_t) (v))
+#elif (USHRT_MAX == UINT16_MAX)
+ typedef unsigned short uint16_t;
+# define UINT16_C(v) ((uint16_t) (v))
+# ifndef PRINTF_INT16_MODIFIER
+# define PRINTF_INT16_MODIFIER "h"
+# endif
+#else
+#error "Platform not supported"
+#endif
+#endif
+
+#ifndef INT16_MAX
+# define INT16_MAX 0x7fff
+#endif
+#ifndef INT16_MIN
+# define INT16_MIN INT16_C(0x8000)
+#endif
+#ifndef int16_t
+#if (INT_MAX == INT16_MAX) || defined (S_SPLINT_S)
+ typedef signed int int16_t;
+# define INT16_C(v) ((int16_t) (v))
+# ifndef PRINTF_INT16_MODIFIER
+# define PRINTF_INT16_MODIFIER ""
+# endif
+#elif (SHRT_MAX == INT16_MAX)
+ typedef signed short int16_t;
+# define INT16_C(v) ((int16_t) (v))
+# ifndef PRINTF_INT16_MODIFIER
+# define PRINTF_INT16_MODIFIER "h"
+# endif
+#else
+#error "Platform not supported"
+#endif
+#endif
+
+#ifndef UINT32_MAX
+# define UINT32_MAX (0xffffffffUL)
+#endif
+#ifndef uint32_t
+#if (ULONG_MAX == UINT32_MAX) || defined (S_SPLINT_S)
+ typedef unsigned long uint32_t;
+# define UINT32_C(v) v ## UL
+# ifndef PRINTF_INT32_MODIFIER
+# define PRINTF_INT32_MODIFIER "l"
+# endif
+#elif (UINT_MAX == UINT32_MAX)
+ typedef unsigned int uint32_t;
+# ifndef PRINTF_INT32_MODIFIER
+# define PRINTF_INT32_MODIFIER ""
+# endif
+# define UINT32_C(v) v ## U
+#elif (USHRT_MAX == UINT32_MAX)
+ typedef unsigned short uint32_t;
+# define UINT32_C(v) ((unsigned short) (v))
+# ifndef PRINTF_INT32_MODIFIER
+# define PRINTF_INT32_MODIFIER ""
+# endif
+#else
+#error "Platform not supported"
+#endif
+#endif
+
+#ifndef INT32_MAX
+# define INT32_MAX (0x7fffffffL)
+#endif
+#ifndef INT32_MIN
+# define INT32_MIN INT32_C(0x80000000)
+#endif
+#ifndef int32_t
+#if (LONG_MAX == INT32_MAX) || defined (S_SPLINT_S)
+ typedef signed long int32_t;
+# define INT32_C(v) v ## L
+# ifndef PRINTF_INT32_MODIFIER
+# define PRINTF_INT32_MODIFIER "l"
+# endif
+#elif (INT_MAX == INT32_MAX)
+ typedef signed int int32_t;
+# define INT32_C(v) v
+# ifndef PRINTF_INT32_MODIFIER
+# define PRINTF_INT32_MODIFIER ""
+# endif
+#elif (SHRT_MAX == INT32_MAX)
+ typedef signed short int32_t;
+# define INT32_C(v) ((short) (v))
+# ifndef PRINTF_INT32_MODIFIER
+# define PRINTF_INT32_MODIFIER ""
+# endif
+#else
+#error "Platform not supported"
+#endif
+#endif
+
+/*
+ * The macro stdint_int64_defined is temporarily used to record
+ * whether or not 64 integer support is available. It must be
+ * defined for any 64 integer extensions for new platforms that are
+ * added.
+ */
+
+#undef stdint_int64_defined
+#if (defined(__STDC__) && defined(__STDC_VERSION__)) || defined (S_SPLINT_S)
+# if (__STDC__ && __STDC_VERSION__ >= 199901L) || defined (S_SPLINT_S)
+# define stdint_int64_defined
+ typedef long long int64_t;
+ typedef unsigned long long uint64_t;
+# define UINT64_C(v) v ## ULL
+# define INT64_C(v) v ## LL
+# ifndef PRINTF_INT64_MODIFIER
+# define PRINTF_INT64_MODIFIER "ll"
+# endif
+# endif
+#endif
+
+#if !defined (stdint_int64_defined)
+# if defined(__GNUC__)
+# define stdint_int64_defined
+ __extension__ typedef long long int64_t;
+ __extension__ typedef unsigned long long uint64_t;
+# define UINT64_C(v) v ## ULL
+# define INT64_C(v) v ## LL
+# ifndef PRINTF_INT64_MODIFIER
+# define PRINTF_INT64_MODIFIER "ll"
+# endif
+# elif defined(__MWERKS__) || defined (__SUNPRO_C) || defined (__SUNPRO_CC) || defined (__APPLE_CC__) || defined (_LONG_LONG) || defined (_CRAYC) || defined (S_SPLINT_S)
+# define stdint_int64_defined
+ typedef long long int64_t;
+ typedef unsigned long long uint64_t;
+# define UINT64_C(v) v ## ULL
+# define INT64_C(v) v ## LL
+# ifndef PRINTF_INT64_MODIFIER
+# define PRINTF_INT64_MODIFIER "ll"
+# endif
+# elif (defined(__WATCOMC__) && defined(__WATCOM_INT64__)) || (defined(_MSC_VER) && _INTEGRAL_MAX_BITS >= 64) || (defined (__BORLANDC__) && __BORLANDC__ > 0x460) || defined (__alpha) || defined (__DECC)
+# define stdint_int64_defined
+ typedef __int64 int64_t;
+ typedef unsigned __int64 uint64_t;
+# define UINT64_C(v) v ## UI64
+# define INT64_C(v) v ## I64
+# ifndef PRINTF_INT64_MODIFIER
+# define PRINTF_INT64_MODIFIER "I64"
+# endif
+# endif
+#endif
+
+#if !defined (LONG_LONG_MAX) && defined (INT64_C)
+# define LONG_LONG_MAX INT64_C (9223372036854775807)
+#endif
+#ifndef ULONG_LONG_MAX
+# define ULONG_LONG_MAX UINT64_C (18446744073709551615)
+#endif
+
+#if !defined (INT64_MAX) && defined (INT64_C)
+# define INT64_MAX INT64_C (9223372036854775807)
+#endif
+#if !defined (INT64_MIN) && defined (INT64_C)
+# define INT64_MIN INT64_C (-9223372036854775808)
+#endif
+#if !defined (UINT64_MAX) && defined (INT64_C)
+# define UINT64_MAX UINT64_C (18446744073709551615)
+#endif
+
+/*
+ * Width of hexadecimal for number field.
+ */
+
+#ifndef PRINTF_INT64_HEX_WIDTH
+# define PRINTF_INT64_HEX_WIDTH "16"
+#endif
+#ifndef PRINTF_INT32_HEX_WIDTH
+# define PRINTF_INT32_HEX_WIDTH "8"
+#endif
+#ifndef PRINTF_INT16_HEX_WIDTH
+# define PRINTF_INT16_HEX_WIDTH "4"
+#endif
+#ifndef PRINTF_INT8_HEX_WIDTH
+# define PRINTF_INT8_HEX_WIDTH "2"
+#endif
+
+#ifndef PRINTF_INT64_DEC_WIDTH
+# define PRINTF_INT64_DEC_WIDTH "20"
+#endif
+#ifndef PRINTF_INT32_DEC_WIDTH
+# define PRINTF_INT32_DEC_WIDTH "10"
+#endif
+#ifndef PRINTF_INT16_DEC_WIDTH
+# define PRINTF_INT16_DEC_WIDTH "5"
+#endif
+#ifndef PRINTF_INT8_DEC_WIDTH
+# define PRINTF_INT8_DEC_WIDTH "3"
+#endif
+
+/*
+ * Ok, lets not worry about 128 bit integers for now. Moore's law says
+ * we don't need to worry about that until about 2040 at which point
+ * we'll have bigger things to worry about.
+ */
+
+#ifdef stdint_int64_defined
+ typedef int64_t intmax_t;
+ typedef uint64_t uintmax_t;
+# define INTMAX_MAX INT64_MAX
+# define INTMAX_MIN INT64_MIN
+# define UINTMAX_MAX UINT64_MAX
+# define UINTMAX_C(v) UINT64_C(v)
+# define INTMAX_C(v) INT64_C(v)
+# ifndef PRINTF_INTMAX_MODIFIER
+# define PRINTF_INTMAX_MODIFIER PRINTF_INT64_MODIFIER
+# endif
+# ifndef PRINTF_INTMAX_HEX_WIDTH
+# define PRINTF_INTMAX_HEX_WIDTH PRINTF_INT64_HEX_WIDTH
+# endif
+# ifndef PRINTF_INTMAX_DEC_WIDTH
+# define PRINTF_INTMAX_DEC_WIDTH PRINTF_INT64_DEC_WIDTH
+# endif
+#else
+ typedef int32_t intmax_t;
+ typedef uint32_t uintmax_t;
+# define INTMAX_MAX INT32_MAX
+# define UINTMAX_MAX UINT32_MAX
+# define UINTMAX_C(v) UINT32_C(v)
+# define INTMAX_C(v) INT32_C(v)
+# ifndef PRINTF_INTMAX_MODIFIER
+# define PRINTF_INTMAX_MODIFIER PRINTF_INT32_MODIFIER
+# endif
+# ifndef PRINTF_INTMAX_HEX_WIDTH
+# define PRINTF_INTMAX_HEX_WIDTH PRINTF_INT32_HEX_WIDTH
+# endif
+# ifndef PRINTF_INTMAX_DEC_WIDTH
+# define PRINTF_INTMAX_DEC_WIDTH PRINTF_INT32_DEC_WIDTH
+# endif
+#endif
+
+/*
+ * Because this file currently only supports platforms which have
+ * precise powers of 2 as bit sizes for the default integers, the
+ * least definitions are all trivial. Its possible that a future
+ * version of this file could have different definitions.
+ */
+
+#ifndef stdint_least_defined
+ typedef int8_t int_least8_t;
+ typedef uint8_t uint_least8_t;
+ typedef int16_t int_least16_t;
+ typedef uint16_t uint_least16_t;
+ typedef int32_t int_least32_t;
+ typedef uint32_t uint_least32_t;
+# define PRINTF_LEAST32_MODIFIER PRINTF_INT32_MODIFIER
+# define PRINTF_LEAST16_MODIFIER PRINTF_INT16_MODIFIER
+# define UINT_LEAST8_MAX UINT8_MAX
+# define INT_LEAST8_MAX INT8_MAX
+# define UINT_LEAST16_MAX UINT16_MAX
+# define INT_LEAST16_MAX INT16_MAX
+# define UINT_LEAST32_MAX UINT32_MAX
+# define INT_LEAST32_MAX INT32_MAX
+# define INT_LEAST8_MIN INT8_MIN
+# define INT_LEAST16_MIN INT16_MIN
+# define INT_LEAST32_MIN INT32_MIN
+# ifdef stdint_int64_defined
+ typedef int64_t int_least64_t;
+ typedef uint64_t uint_least64_t;
+# define PRINTF_LEAST64_MODIFIER PRINTF_INT64_MODIFIER
+# define UINT_LEAST64_MAX UINT64_MAX
+# define INT_LEAST64_MAX INT64_MAX
+# define INT_LEAST64_MIN INT64_MIN
+# endif
+#endif
+#undef stdint_least_defined
+
+/*
+ * The ANSI C committee pretending to know or specify anything about
+ * performance is the epitome of misguided arrogance. The mandate of
+ * this file is to *ONLY* ever support that absolute minimum
+ * definition of the fast integer types, for compatibility purposes.
+ * No extensions, and no attempt to suggest what may or may not be a
+ * faster integer type will ever be made in this file. Developers are
+ * warned to stay away from these types when using this or any other
+ * stdint.h.
+ */
+
+typedef int_least8_t int_fast8_t;
+typedef uint_least8_t uint_fast8_t;
+typedef int_least16_t int_fast16_t;
+typedef uint_least16_t uint_fast16_t;
+typedef int_least32_t int_fast32_t;
+typedef uint_least32_t uint_fast32_t;
+#define UINT_FAST8_MAX UINT_LEAST8_MAX
+#define INT_FAST8_MAX INT_LEAST8_MAX
+#define UINT_FAST16_MAX UINT_LEAST16_MAX
+#define INT_FAST16_MAX INT_LEAST16_MAX
+#define UINT_FAST32_MAX UINT_LEAST32_MAX
+#define INT_FAST32_MAX INT_LEAST32_MAX
+#define INT_FAST8_MIN INT_LEAST8_MIN
+#define INT_FAST16_MIN INT_LEAST16_MIN
+#define INT_FAST32_MIN INT_LEAST32_MIN
+#ifdef stdint_int64_defined
+ typedef int_least64_t int_fast64_t;
+ typedef uint_least64_t uint_fast64_t;
+# define UINT_FAST64_MAX UINT_LEAST64_MAX
+# define INT_FAST64_MAX INT_LEAST64_MAX
+# define INT_FAST64_MIN INT_LEAST64_MIN
+#endif
+
+#undef stdint_int64_defined
+
+/*
+ * Whatever piecemeal, per compiler thing we can do about the wchar_t
+ * type limits.
+ */
+
+#if defined(__WATCOMC__) || defined(_MSC_VER) || defined (__GNUC__)
+# include <wchar.h>
+# ifndef WCHAR_MIN
+# define WCHAR_MIN 0
+# endif
+# ifndef WCHAR_MAX
+# define WCHAR_MAX ((wchar_t)-1)
+# endif
+#endif
+
+/*
+ * Whatever piecemeal, per compiler/platform thing we can do about the
+ * (u)intptr_t types and limits.
+ */
+
+#if defined (_MSC_VER) && defined (_UINTPTR_T_DEFINED)
+# define STDINT_H_UINTPTR_T_DEFINED
+#endif
+
+#ifndef STDINT_H_UINTPTR_T_DEFINED
+# if defined (__alpha__) || defined (__ia64__) || defined (__x86_64__) || defined (_WIN64)
+# define stdint_intptr_bits 64
+# elif defined (__WATCOMC__) || defined (__TURBOC__)
+# if defined(__TINY__) || defined(__SMALL__) || defined(__MEDIUM__)
+# define stdint_intptr_bits 16
+# else
+# define stdint_intptr_bits 32
+# endif
+# elif defined (__i386__) || defined (_WIN32) || defined (WIN32)
+# define stdint_intptr_bits 32
+# elif defined (__INTEL_COMPILER)
+/* TODO -- what did Intel do about x86-64? */
+# endif
+
+# ifdef stdint_intptr_bits
+# define stdint_intptr_glue3_i(a,b,c) a##b##c
+# define stdint_intptr_glue3(a,b,c) stdint_intptr_glue3_i(a,b,c)
+# ifndef PRINTF_INTPTR_MODIFIER
+# define PRINTF_INTPTR_MODIFIER stdint_intptr_glue3(PRINTF_INT,stdint_intptr_bits,_MODIFIER)
+# endif
+# ifndef PTRDIFF_MAX
+# define PTRDIFF_MAX stdint_intptr_glue3(INT,stdint_intptr_bits,_MAX)
+# endif
+# ifndef PTRDIFF_MIN
+# define PTRDIFF_MIN stdint_intptr_glue3(INT,stdint_intptr_bits,_MIN)
+# endif
+# ifndef UINTPTR_MAX
+# define UINTPTR_MAX stdint_intptr_glue3(UINT,stdint_intptr_bits,_MAX)
+# endif
+# ifndef INTPTR_MAX
+# define INTPTR_MAX stdint_intptr_glue3(INT,stdint_intptr_bits,_MAX)
+# endif
+# ifndef INTPTR_MIN
+# define INTPTR_MIN stdint_intptr_glue3(INT,stdint_intptr_bits,_MIN)
+# endif
+# ifndef INTPTR_C
+# define INTPTR_C(x) stdint_intptr_glue3(INT,stdint_intptr_bits,_C)(x)
+# endif
+# ifndef UINTPTR_C
+# define UINTPTR_C(x) stdint_intptr_glue3(UINT,stdint_intptr_bits,_C)(x)
+# endif
+ typedef stdint_intptr_glue3(uint,stdint_intptr_bits,_t) uintptr_t;
+ typedef stdint_intptr_glue3( int,stdint_intptr_bits,_t) intptr_t;
+# else
+/* TODO -- This following is likely wrong for some platforms, and does
+ nothing for the definition of uintptr_t. */
+ typedef ptrdiff_t intptr_t;
+# endif
+# define STDINT_H_UINTPTR_T_DEFINED
+#endif
+
+/*
+ * Assumes sig_atomic_t is signed and we have a 2s complement machine.
+ */
+
+#ifndef SIG_ATOMIC_MAX
+# define SIG_ATOMIC_MAX ((((sig_atomic_t) 1) << (sizeof (sig_atomic_t)*CHAR_BIT-1)) - 1)
+#endif
+
+#endif
+
+#if defined (__TEST_PSTDINT_FOR_CORRECTNESS)
+
+/*
+ * Please compile with the maximum warning settings to make sure macros are not
+ * defined more than once.
+ */
+
+#include <stdlib.h>
+#include <stdio.h>
+#include <string.h>
+
+#define glue3_aux(x,y,z) x ## y ## z
+#define glue3(x,y,z) glue3_aux(x,y,z)
+
+#define DECLU(bits) glue3(uint,bits,_t) glue3(u,bits,=) glue3(UINT,bits,_C) (0);
+#define DECLI(bits) glue3(int,bits,_t) glue3(i,bits,=) glue3(INT,bits,_C) (0);
+
+#define DECL(us,bits) glue3(DECL,us,) (bits)
+
+#define TESTUMAX(bits) glue3(u,bits,=) glue3(~,u,bits); if (glue3(UINT,bits,_MAX) glue3(!=,u,bits)) printf ("Something wrong with UINT%d_MAX\n", bits)
+
+int main () {
+ DECL(I,8)
+ DECL(U,8)
+ DECL(I,16)
+ DECL(U,16)
+ DECL(I,32)
+ DECL(U,32)
+#ifdef INT64_MAX
+ DECL(I,64)
+ DECL(U,64)
+#endif
+ intmax_t imax = INTMAX_C(0);
+ uintmax_t umax = UINTMAX_C(0);
+ char str0[256], str1[256];
+
+ sprintf (str0, "%d %x\n", 0, ~0);
+
+ sprintf (str1, "%d %x\n", i8, ~0);
+ if (0 != strcmp (str0, str1)) printf ("Something wrong with i8 : %s\n", str1);
+ sprintf (str1, "%u %x\n", u8, ~0);
+ if (0 != strcmp (str0, str1)) printf ("Something wrong with u8 : %s\n", str1);
+ sprintf (str1, "%d %x\n", i16, ~0);
+ if (0 != strcmp (str0, str1)) printf ("Something wrong with i16 : %s\n", str1);
+ sprintf (str1, "%u %x\n", u16, ~0);
+ if (0 != strcmp (str0, str1)) printf ("Something wrong with u16 : %s\n", str1);
+ sprintf (str1, "%" PRINTF_INT32_MODIFIER "d %x\n", i32, ~0);
+ if (0 != strcmp (str0, str1)) printf ("Something wrong with i32 : %s\n", str1);
+ sprintf (str1, "%" PRINTF_INT32_MODIFIER "u %x\n", u32, ~0);
+ if (0 != strcmp (str0, str1)) printf ("Something wrong with u32 : %s\n", str1);
+#ifdef INT64_MAX
+ sprintf (str1, "%" PRINTF_INT64_MODIFIER "d %x\n", i64, ~0);
+ if (0 != strcmp (str0, str1)) printf ("Something wrong with i64 : %s\n", str1);
+#endif
+ sprintf (str1, "%" PRINTF_INTMAX_MODIFIER "d %x\n", imax, ~0);
+ if (0 != strcmp (str0, str1)) printf ("Something wrong with imax : %s\n", str1);
+ sprintf (str1, "%" PRINTF_INTMAX_MODIFIER "u %x\n", umax, ~0);
+ if (0 != strcmp (str0, str1)) printf ("Something wrong with umax : %s\n", str1);
+
+ TESTUMAX(8);
+ TESTUMAX(16);
+ TESTUMAX(32);
+#ifdef INT64_MAX
+ TESTUMAX(64);
+#endif
+
+ return EXIT_SUCCESS;
+}
+
+#endif