fixed type macro types
This commit is contained in:
parent
ffc6d32cd9
commit
5eb7fa0052
68
zahnrad.c
68
zahnrad.c
@ -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;
|
||||||
|
24
zahnrad.h
24
zahnrad.h
@ -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 */
|
||||||
|
Loading…
Reference in New Issue
Block a user