fixed type macro types

This commit is contained in:
vurtun 2015-12-12 11:37:59 +01:00
parent ffc6d32cd9
commit 5eb7fa0052
2 changed files with 58 additions and 34 deletions

View File

@ -106,6 +106,14 @@ template<typename T> struct zr_alignof{struct Big {T x; char c;}; enum {
#else #else
#define ZR_ALIGNOF(t) ((char*)(&((struct {char c; t _h;}*)0)->_h) - (char*)0) #define ZR_ALIGNOF(t) ((char*)(&((struct {char c; t _h;}*)0)->_h) - (char*)0)
#endif #endif
/* make sure correct type size */
typedef int zr__check_size[(sizeof(void*) == sizeof(zr_size)) ? 1 : -1];
typedef int zr__check_ptr[(sizeof(void*) == sizeof(zr_ptr)) ? 1 : -1];
typedef int zr__check_flags[(sizeof(zr_flags) >= 4) ? 1 : -1];
typedef int zr__check_rune[(sizeof(zr_rune) >= 4) ? 1 : -1];
typedef int zr__check_uint[(sizeof(zr_uint) == 4) ? 1 : -1];
typedef int zr__check_ulong[(sizeof(zr_ulong) == 8) ? 1 : -1];
/* /*
* ============================================================== * ==============================================================
* *
@ -113,8 +121,8 @@ template<typename T> struct zr_alignof{struct Big {T x; char c;}; enum {
* *
* =============================================================== * ===============================================================
*/ */
static uint32_t static zr_uint
zr_round_up_pow2(uint32_t v) zr_round_up_pow2(zr_uint v)
{ {
v--; v--;
v |= v >> 1; v |= v >> 1;
@ -131,7 +139,7 @@ zr_inv_sqrt(float number)
{ {
float x2; float x2;
const float threehalfs = 1.5f; const float threehalfs = 1.5f;
union {uint32_t i; float f;} conv; union {zr_uint i; float f;} conv;
conv.f = number; conv.f = number;
x2 = number * 0.5f; x2 = number * 0.5f;
conv.i = 0x5f375A84 - (conv.i >> 1); conv.i = 0x5f375A84 - (conv.i >> 1);
@ -376,22 +384,22 @@ zr_pow(double x, int n)
return plus ? r : 1.0 / r; return plus ? r : 1.0 / r;
} }
static int32_t static zr_uint
zr_isinf(double x) zr_isinf(double x)
{ {
union {uint64_t u; double f;} ieee754; union {zr_ulong u; double f;} ieee754;
ieee754.f = x; ieee754.f = x;
return ( (unsigned)(ieee754.u >> 32) & 0x7fffffff ) == 0x7ff00000 && return ( (zr_uint)(ieee754.u >> 32) & 0x7fffffff ) == 0x7ff00000 &&
( (unsigned)ieee754.u == 0 ); ( (zr_uint)ieee754.u == 0 );
} }
static int32_t static zr_uint
zr_isnan(double x) zr_isnan(double x)
{ {
union {uint64_t u; double f;} ieee754; union {zr_ulong u; double f;} ieee754;
ieee754.f = x; ieee754.f = x;
return ( (unsigned)(ieee754.u >> 32) & 0x7fffffff ) + return ((zr_uint)(ieee754.u >> 32) & 0x7fffffff ) +
( (unsigned)ieee754.u != 0 ) > 0x7ff00000; ((zr_uint)ieee754.u != 0 ) > 0x7ff00000;
} }
static double static double
@ -527,7 +535,7 @@ zr_rgb(zr_byte r, zr_byte g, zr_byte b)
} }
struct zr_color struct zr_color
zr_rgba32(uint32_t in) zr_rgba32(zr_uint in)
{ {
struct zr_color ret; struct zr_color ret;
ret.r = (in & 0xFF); ret.r = (in & 0xFF);
@ -586,7 +594,7 @@ zr_hsva_f(float h, float s, float v, float a)
{ {
struct zr_colorf {float r,g,b,a;} out; struct zr_colorf {float r,g,b,a;} out;
float hh, p, q, t, ff; float hh, p, q, t, ff;
uint32_t i; zr_uint i;
if (s <= 0.0f) { if (s <= 0.0f) {
out.r = v; out.g = v; out.b = v; out.r = v; out.g = v; out.b = v;
@ -596,7 +604,7 @@ zr_hsva_f(float h, float s, float v, float a)
hh = h; hh = h;
if (hh >= 360.0f) hh = 0; if (hh >= 360.0f) hh = 0;
hh /= 60.0f; hh /= 60.0f;
i = (uint32_t)hh; i = (zr_uint)hh;
ff = hh - (float)i; ff = hh - (float)i;
p = v * (1.0f - s); p = v * (1.0f - s);
q = v * (1.0f - (s * ff)); q = v * (1.0f - (s * ff));
@ -638,13 +646,13 @@ zr_hsva_f(float h, float s, float v, float a)
return zr_rgba_f(out.r, out.g, out.b, a); return zr_rgba_f(out.r, out.g, out.b, a);
} }
uint32_t zr_uint
zr_color32(struct zr_color in) zr_color32(struct zr_color in)
{ {
uint32_t out = (uint32_t)in.r; zr_uint out = (zr_uint)in.r;
out |= ((uint32_t)in.g << 8); out |= ((zr_uint)in.g << 8);
out |= ((uint32_t)in.b << 16); out |= ((zr_uint)in.b << 16);
out |= ((uint32_t)in.a << 24); out |= ((zr_uint)in.a << 24);
return out; return out;
} }
@ -1452,7 +1460,7 @@ zr_buffer_alloc(struct zr_buffer *b, enum zr_buffer_allocation_type type,
if (b->type != ZR_BUFFER_DYNAMIC || !b->pool.alloc || !b->pool.free) return 0; if (b->type != ZR_BUFFER_DYNAMIC || !b->pool.alloc || !b->pool.free) return 0;
cap = (zr_size)((float)b->memory.size * b->grow_factor); cap = (zr_size)((float)b->memory.size * b->grow_factor);
cap = MAX(cap, zr_round_up_pow2((uint32_t)(b->allocated + size))); cap = MAX(cap, zr_round_up_pow2((zr_uint)(b->allocated + size)));
b->memory.ptr = zr_buffer_realloc(b, cap, &b->memory.size); b->memory.ptr = zr_buffer_realloc(b, cap, &b->memory.size);
if (!b->memory.ptr) return 0; if (!b->memory.ptr) return 0;
@ -1721,7 +1729,7 @@ zr_command_buffer_push_rect(struct zr_command_buffer *b, struct zr_rect rect,
cmd = (struct zr_command_rect*) cmd = (struct zr_command_rect*)
zr_command_buffer_push(b, ZR_COMMAND_RECT, sizeof(*cmd)); zr_command_buffer_push(b, ZR_COMMAND_RECT, sizeof(*cmd));
if (!cmd) return; if (!cmd) return;
cmd->rounding = (uint32_t)rounding; cmd->rounding = (unsigned int)rounding;
cmd->x = (short)rect.x; cmd->x = (short)rect.x;
cmd->y = (short)rect.y; cmd->y = (short)rect.y;
cmd->w = (unsigned short)MAX(0, rect.w); cmd->w = (unsigned short)MAX(0, rect.w);
@ -2397,6 +2405,7 @@ zr_draw_list_push_command(struct zr_draw_list *list, struct zr_rect clip,
ZR_ASSERT(list); ZR_ASSERT(list);
cmd = (struct zr_draw_command*) cmd = (struct zr_draw_command*)
zr_buffer_alloc(list->buffer, ZR_BUFFER_BACK, cmd_size, cmd_align); zr_buffer_alloc(list->buffer, ZR_BUFFER_BACK, cmd_size, cmd_align);
if (!cmd) return 0; if (!cmd) return 0;
if (!list->cmd_count) { if (!list->cmd_count) {
zr_byte *memory = (zr_byte*)zr_buffer_memory(list->buffer); zr_byte *memory = (zr_byte*)zr_buffer_memory(list->buffer);
@ -2408,6 +2417,7 @@ zr_draw_list_push_command(struct zr_draw_list *list, struct zr_rect clip,
cmd->elem_count = 0; cmd->elem_count = 0;
cmd->clip_rect = clip; cmd->clip_rect = clip;
cmd->texture = texture; cmd->texture = texture;
list->cmd_count++; list->cmd_count++;
list->clip_rect = clip; list->clip_rect = clip;
return cmd; return cmd;
@ -3480,7 +3490,7 @@ zr_font_bake_pack(zr_size *image_memory, int *width, int *height,
ZR_ASSERT(char_n == total_glyph_count); ZR_ASSERT(char_n == total_glyph_count);
ZR_ASSERT(range_n == total_range_count); ZR_ASSERT(range_n == total_range_count);
} }
*height = (int32_t)zr_round_up_pow2((uint32_t)*height); *height = (int)zr_round_up_pow2((zr_uint)*height);
*image_memory = (zr_size)(*width) * (zr_size)(*height); *image_memory = (zr_size)(*width) * (zr_size)(*height);
return zr_true; return zr_true;
} }
@ -3617,17 +3627,17 @@ zr_font_bake_convert(void *out_memory, int img_width, int img_height,
{ {
int n = 0; int n = 0;
const zr_byte *src; const zr_byte *src;
uint32_t *dst; zr_rune *dst;
ZR_ASSERT(out_memory); ZR_ASSERT(out_memory);
ZR_ASSERT(in_memory); ZR_ASSERT(in_memory);
ZR_ASSERT(img_width); ZR_ASSERT(img_width);
ZR_ASSERT(img_height); ZR_ASSERT(img_height);
if (!out_memory || !in_memory || !img_height || !img_width) return; if (!out_memory || !in_memory || !img_height || !img_width) return;
dst = (uint32_t*)out_memory; dst = (zr_rune*)out_memory;
src = (const zr_byte*)in_memory; src = (const zr_byte*)in_memory;
for (n = (int)(img_width * img_height); n > 0; n--) for (n = (int)(img_width * img_height); n > 0; n--)
*dst++ = ((uint32_t)(*src++) << 24) | 0x00FFFFFF; *dst++ = ((zr_rune)(*src++) << 24) | 0x00FFFFFF;
} }
/* ------------------------------------------------------------- /* -------------------------------------------------------------
* *
@ -5985,6 +5995,7 @@ zr_widget_spinner_float(struct zr_command_buffer *out, struct zr_rect r,
res = zr_widget_spinner_base(out, r, s, string, &len, ZR_INPUT_FLOAT, &is_active, in, font); res = zr_widget_spinner_base(out, r, s, string, &len, ZR_INPUT_FLOAT, &is_active, in, font);
if (res) { if (res) {
int val; int val;
/* account for floating point error */
float f = (float)zr_pow(10.0, ZR_MAX_FLOAT_PRECISION); float f = (float)zr_pow(10.0, ZR_MAX_FLOAT_PRECISION);
value += (res > 0) ? step : -step; value += (res > 0) ? step : -step;
value = CLAMP(min, value, max); value = CLAMP(min, value, max);
@ -6356,6 +6367,7 @@ zr_window_init(struct zr_window *window, struct zr_rect bounds,
window->offset.y = 0; window->offset.y = 0;
window->queue = queue; window->queue = queue;
window->input = input; window->input = input;
if (queue) { if (queue) {
zr_command_buffer_init(&window->buffer, &queue->buffer, ZR_CLIP); zr_command_buffer_init(&window->buffer, &queue->buffer, ZR_CLIP);
zr_command_queue_insert_back(queue, &window->buffer); zr_command_queue_insert_back(queue, &window->buffer);
@ -6598,7 +6610,7 @@ zr_begin(struct zr_context *context, struct zr_window *window, const char *title
} }
} }
/* setup panel context */ /* setup window context */
out = &window->buffer; out = &window->buffer;
context->input = in; context->input = in;
context->bounds = window->bounds; context->bounds = window->bounds;
@ -7044,7 +7056,7 @@ zr_panel_layout(struct zr_context *layout, float height, zr_size cols)
item_spacing = zr_style_property(config, ZR_PROPERTY_ITEM_SPACING); item_spacing = zr_style_property(config, ZR_PROPERTY_ITEM_SPACING);
panel_padding = zr_style_property(config, ZR_PROPERTY_PADDING); panel_padding = zr_style_property(config, ZR_PROPERTY_PADDING);
/* draw the current row and set the current row layout */ /* update the current row and set the current row layout */
layout->row.index = 0; layout->row.index = 0;
layout->at_y += layout->row.height; layout->at_y += layout->row.height;
layout->row.columns = cols; layout->row.columns = cols;
@ -7067,7 +7079,7 @@ zr_row_layout(struct zr_context *layout,
if (!layout) return; if (!layout) return;
if (!layout->valid) return; if (!layout->valid) return;
/* draw the current row and set the current row layout */ /* update the current row and set the current row layout */
zr_panel_layout(layout, height, cols); zr_panel_layout(layout, height, cols);
if (fmt == ZR_DYNAMIC) if (fmt == ZR_DYNAMIC)
layout->row.type = ZR_LAYOUT_DYNAMIC_FIXED; layout->row.type = ZR_LAYOUT_DYNAMIC_FIXED;

View File

@ -55,7 +55,7 @@ extern "C" {
* if 0 each type has to be set to the correct size*/ * if 0 each type has to be set to the correct size*/
#define ZR_COMPILE_WITH_ASSERT 1 #define ZR_COMPILE_WITH_ASSERT 1
/* setting this define to 1 adds header <assert.h> for the assert macro /* setting this define to 1 adds header <assert.h> for the assert macro
IMPORTANT: it also adds clib so only use it if wanted */ IMPORTANT: it also adds the standard library assert so only use it if wanted */
#define ZR_COMPILE_WITH_VERTEX_BUFFER 1 #define ZR_COMPILE_WITH_VERTEX_BUFFER 1
/* setting this define to 1 adds a vertex draw command list backend to this library, /* setting this define to 1 adds a vertex draw command list backend to this library,
which allows you to convert queue commands into vertex draw commands. which allows you to convert queue commands into vertex draw commands.
@ -74,12 +74,24 @@ extern "C" {
* *
* =============================================================== * ===============================================================
*/ */
#if ZR_COMPILE_WITH_FIXED_TYPES
#include <stdint.h> #include <stdint.h>
typedef uint32_t zr_uint;
typedef uint64_t zr_ulong;
typedef uint64_t zr_size; typedef uint64_t zr_size;
typedef uintptr_t zr_ptr; typedef uintptr_t zr_ptr;
typedef uint32_t zr_flags; typedef uint32_t zr_flags;
typedef uint32_t zr_rune; typedef uint32_t zr_rune;
typedef uint8_t zr_byte; typedef uint8_t zr_byte;
#else
typedef unsigned int zr_uint;
typedef unsigned long zr_ulong;
typedef unsigned long zr_size;
typedef zr_size zr_ptr;
typedef unsigned int zr_flags;
typedef unsigned int zr_rune;
typedef unsigned char zr_byte;
#endif
#if ZR_COMPILE_WITH_ASSERT #if ZR_COMPILE_WITH_ASSERT
#ifndef ZR_ASSERT #ifndef ZR_ASSERT
@ -168,8 +180,8 @@ struct zr_color zr_hsv(zr_byte h, zr_byte s, zr_byte v);
struct zr_color zr_hsv_f(float h, float s, float v); struct zr_color zr_hsv_f(float h, float s, float v);
struct zr_color zr_hsva(zr_byte h, zr_byte s, zr_byte v, zr_byte a); struct zr_color zr_hsva(zr_byte h, zr_byte s, zr_byte v, zr_byte a);
struct zr_color zr_hsva_f(float h, float s, float v, float a); struct zr_color zr_hsva_f(float h, float s, float v, float a);
struct zr_color zr_rgba32(uint32_t); struct zr_color zr_rgba32(zr_uint);
uint32_t zr_color32(struct zr_color); zr_uint zr_color32(struct zr_color);
void zr_colorf(float *r, float *g, float *b, float *a, struct zr_color); void zr_colorf(float *r, float *g, float *b, float *a, struct zr_color);
void zr_color_hsv(int *out_h, int *out_s, int *out_v, struct zr_color); void zr_color_hsv(int *out_h, int *out_s, int *out_v, struct zr_color);
void zr_color_hsv_f(float *out_h, float *out_s, float *out_v, struct zr_color); void zr_color_hsv_f(float *out_h, float *out_s, float *out_v, struct zr_color);
@ -632,7 +644,7 @@ struct zr_command_curve {
struct zr_command_rect { struct zr_command_rect {
struct zr_command header; struct zr_command header;
uint32_t rounding; unsigned int rounding;
short x, y; short x, y;
unsigned short w, h; unsigned short w, h;
struct zr_color color; struct zr_color color;
@ -1074,7 +1086,7 @@ const struct zr_command* zr_command_queue_next(struct zr_command_queue*,
zr_draw_list_path_stroke - connects each point in the path zr_draw_list_path_stroke - connects each point in the path
*/ */
typedef unsigned short zr_draw_index; typedef unsigned short zr_draw_index;
typedef uint32_t zr_draw_vertex_color; typedef zr_uint zr_draw_vertex_color;
typedef float(*zr_sin_f)(float); typedef float(*zr_sin_f)(float);
typedef float(*zr_cos_f)(float); typedef float(*zr_cos_f)(float);
@ -1099,7 +1111,7 @@ enum zr_draw_list_stroke {
}; };
struct zr_draw_command { struct zr_draw_command {
uint32_t elem_count; unsigned int elem_count;
/* number of elements in the current draw batch */ /* number of elements in the current draw batch */
struct zr_rect clip_rect; struct zr_rect clip_rect;
/* current screen clipping rectangle */ /* current screen clipping rectangle */