mirror of
https://github.com/nicbarker/clay.git
synced 2025-04-16 19:28:06 +00:00
[Core] Replace generated arrays with macro declarations, align cache lines to 64 bytes (#235)
Some checks are pending
CMake on multiple platforms / build (Release, cl, cl, windows-latest) (push) Waiting to run
CMake on multiple platforms / build (Release, clang, clang++, ubuntu-latest) (push) Waiting to run
CMake on multiple platforms / build (Release, gcc, g++, ubuntu-latest) (push) Waiting to run
Some checks are pending
CMake on multiple platforms / build (Release, cl, cl, windows-latest) (push) Waiting to run
CMake on multiple platforms / build (Release, clang, clang++, ubuntu-latest) (push) Waiting to run
CMake on multiple platforms / build (Release, gcc, g++, ubuntu-latest) (push) Waiting to run
This commit is contained in:
parent
e9f2e6c4f1
commit
1bcf256e4d
@ -13,7 +13,9 @@ int main(void) {
|
|||||||
Clay_Arena clayMemory = Clay_CreateArenaWithCapacityAndMemory(totalMemorySize, (char *)malloc(totalMemorySize));
|
Clay_Arena clayMemory = Clay_CreateArenaWithCapacityAndMemory(totalMemorySize, (char *)malloc(totalMemorySize));
|
||||||
Clay_Initialize(clayMemory, Clay_Dimensions {1024,768}, Clay_ErrorHandler { HandleClayErrors });
|
Clay_Initialize(clayMemory, Clay_Dimensions {1024,768}, Clay_ErrorHandler { HandleClayErrors });
|
||||||
Clay_BeginLayout();
|
Clay_BeginLayout();
|
||||||
CLAY(CLAY_RECTANGLE({ .color = {255,255,255,0} }), CLAY_LAYOUT(layoutElement)) {}
|
CLAY(CLAY_RECTANGLE({ .color = {255,255,255,0} }), CLAY_LAYOUT(layoutElement)) {
|
||||||
|
CLAY_TEXT(CLAY_STRING(""), CLAY_TEXT_CONFIG({ .fontId = 0 }));
|
||||||
|
}
|
||||||
Clay_EndLayout();
|
Clay_EndLayout();
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
@ -25,7 +25,7 @@ target_include_directories(clay_examples_raylib_multi_context PUBLIC .)
|
|||||||
|
|
||||||
target_link_libraries(clay_examples_raylib_multi_context PUBLIC raylib)
|
target_link_libraries(clay_examples_raylib_multi_context PUBLIC raylib)
|
||||||
|
|
||||||
set(CMAKE_C_FLAGS_DEBUG "-Wall -Werror -Wno-error=missing-braces -DCLAY_DEBUG")
|
set(CMAKE_C_FLAGS_DEBUG "${CMAKE_C_FLAGS_DEBUG}")
|
||||||
set(CMAKE_C_FLAGS_RELEASE "-O3")
|
set(CMAKE_C_FLAGS_RELEASE "-O3")
|
||||||
|
|
||||||
add_custom_command(
|
add_custom_command(
|
||||||
|
@ -10,7 +10,7 @@ void RenderHeaderButton(Clay_String text) {
|
|||||||
CLAY_LAYOUT({ .padding = { 16, 16, 8, 8 }}),
|
CLAY_LAYOUT({ .padding = { 16, 16, 8, 8 }}),
|
||||||
CLAY_RECTANGLE({
|
CLAY_RECTANGLE({
|
||||||
.color = { 140, 140, 140, 255 },
|
.color = { 140, 140, 140, 255 },
|
||||||
.cornerRadius = 5
|
.cornerRadius = CLAY_CORNER_RADIUS(5)
|
||||||
})
|
})
|
||||||
) {
|
) {
|
||||||
CLAY_TEXT(text, CLAY_TEXT_CONFIG({
|
CLAY_TEXT(text, CLAY_TEXT_CONFIG({
|
||||||
@ -79,7 +79,7 @@ typedef struct {
|
|||||||
intptr_t memory;
|
intptr_t memory;
|
||||||
} Arena;
|
} Arena;
|
||||||
|
|
||||||
Arena frameArena = {};
|
Arena frameArena = {0};
|
||||||
|
|
||||||
Clay_RenderCommandArray CreateLayout(Clay_Context* context, float yOffset, int32_t* documentIndex) {
|
Clay_RenderCommandArray CreateLayout(Clay_Context* context, float yOffset, int32_t* documentIndex) {
|
||||||
Clay_SetCurrentContext(context);
|
Clay_SetCurrentContext(context);
|
||||||
@ -104,13 +104,13 @@ Clay_RenderCommandArray CreateLayout(Clay_Context* context, float yOffset, int32
|
|||||||
);
|
);
|
||||||
|
|
||||||
Clay_Sizing layoutExpand = {
|
Clay_Sizing layoutExpand = {
|
||||||
.width = CLAY_SIZING_GROW(),
|
.width = CLAY_SIZING_GROW(0),
|
||||||
.height = CLAY_SIZING_GROW()
|
.height = CLAY_SIZING_GROW(0)
|
||||||
};
|
};
|
||||||
|
|
||||||
Clay_RectangleElementConfig contentBackgroundConfig = {
|
Clay_RectangleElementConfig contentBackgroundConfig = {
|
||||||
.color = { 90, 90, 90, 255 },
|
.color = { 90, 90, 90, 255 },
|
||||||
.cornerRadius = 8
|
.cornerRadius = CLAY_CORNER_RADIUS(8)
|
||||||
};
|
};
|
||||||
|
|
||||||
Clay_BeginLayout();
|
Clay_BeginLayout();
|
||||||
@ -138,14 +138,14 @@ Clay_RenderCommandArray CreateLayout(Clay_Context* context, float yOffset, int32
|
|||||||
.childGap = 8,
|
.childGap = 8,
|
||||||
.sizing = {
|
.sizing = {
|
||||||
.width = CLAY_SIZING_FIXED(250),
|
.width = CLAY_SIZING_FIXED(250),
|
||||||
.height = CLAY_SIZING_GROW()
|
.height = CLAY_SIZING_GROW(0)
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
) {
|
) {
|
||||||
for (int i = 0; i < documents.length; i++) {
|
for (int i = 0; i < documents.length; i++) {
|
||||||
Document document = documents.documents[i];
|
Document document = documents.documents[i];
|
||||||
Clay_LayoutConfig sidebarButtonLayout = {
|
Clay_LayoutConfig sidebarButtonLayout = {
|
||||||
.sizing = { .width = CLAY_SIZING_GROW() },
|
.sizing = { .width = CLAY_SIZING_GROW(0) },
|
||||||
.padding = CLAY_PADDING_ALL(16)
|
.padding = CLAY_PADDING_ALL(16)
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -154,7 +154,7 @@ Clay_RenderCommandArray CreateLayout(Clay_Context* context, float yOffset, int32
|
|||||||
CLAY_LAYOUT(sidebarButtonLayout),
|
CLAY_LAYOUT(sidebarButtonLayout),
|
||||||
CLAY_RECTANGLE({
|
CLAY_RECTANGLE({
|
||||||
.color = { 120, 120, 120, 255 },
|
.color = { 120, 120, 120, 255 },
|
||||||
.cornerRadius = 8,
|
.cornerRadius = CLAY_CORNER_RADIUS(8),
|
||||||
})
|
})
|
||||||
) {
|
) {
|
||||||
CLAY_TEXT(document.title, CLAY_TEXT_CONFIG({
|
CLAY_TEXT(document.title, CLAY_TEXT_CONFIG({
|
||||||
@ -173,9 +173,9 @@ Clay_RenderCommandArray CreateLayout(Clay_Context* context, float yOffset, int32
|
|||||||
Clay_Hovered()
|
Clay_Hovered()
|
||||||
? CLAY_RECTANGLE({
|
? CLAY_RECTANGLE({
|
||||||
.color = { 120, 120, 120, 120 },
|
.color = { 120, 120, 120, 120 },
|
||||||
.cornerRadius = 8
|
.cornerRadius = CLAY_CORNER_RADIUS(8)
|
||||||
})
|
})
|
||||||
: 0
|
: (void)0
|
||||||
) {
|
) {
|
||||||
CLAY_TEXT(document.title, CLAY_TEXT_CONFIG({
|
CLAY_TEXT(document.title, CLAY_TEXT_CONFIG({
|
||||||
.fontId = FONT_ID_BODY_16,
|
.fontId = FONT_ID_BODY_16,
|
||||||
|
@ -27,7 +27,7 @@ target_link_libraries(clay_examples_raylib_sidebar_scrolling_container PUBLIC ra
|
|||||||
if(MSVC)
|
if(MSVC)
|
||||||
set(CMAKE_C_FLAGS_DEBUG "/D CLAY_DEBUG")
|
set(CMAKE_C_FLAGS_DEBUG "/D CLAY_DEBUG")
|
||||||
else()
|
else()
|
||||||
set(CMAKE_C_FLAGS_DEBUG "${CMAKE_C_FLAGS_DEBUG} -DCLAY_DEBUG -fsanitize=address")
|
set(CMAKE_C_FLAGS_DEBUG "${CMAKE_C_FLAGS_DEBUG}")
|
||||||
set(CMAKE_C_FLAGS_RELEASE "${CMAKE_C_FLAGS_RELEASE} -O3")
|
set(CMAKE_C_FLAGS_RELEASE "${CMAKE_C_FLAGS_RELEASE} -O3")
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
|
@ -1,7 +0,0 @@
|
|||||||
$TYPE$ *$NAME$_Add($NAME$ *array, $TYPE$ item) {
|
|
||||||
if (Clay__Array_AddCapacityCheck(array->length, array->capacity)) {
|
|
||||||
array->internalArray[array->length++] = item;
|
|
||||||
return &array->internalArray[array->length - 1];
|
|
||||||
}
|
|
||||||
return $DEFAULT_VALUE$;
|
|
||||||
}
|
|
@ -1,5 +0,0 @@
|
|||||||
void $NAME$_Add($NAME$ *array, $TYPE$ item) {
|
|
||||||
if (Clay__Array_AddCapacityCheck(array->length, array->capacity)) {
|
|
||||||
array->internalArray[array->length++] = item;
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,3 +0,0 @@
|
|||||||
$NAME$ $NAME$_Allocate_Arena(int32_t capacity, Clay_Arena *arena) {
|
|
||||||
return CLAY__INIT($NAME$){.capacity = capacity, .length = 0, .internalArray = ($TYPE$ *)Clay__Array_Allocate_Arena(capacity, sizeof($TYPE$), CLAY__ALIGNMENT($TYPE$), arena)};
|
|
||||||
}
|
|
@ -1,3 +0,0 @@
|
|||||||
$NAME$ $NAME$_Allocate_Arena(int32_t capacity, Clay_Arena *arena) {
|
|
||||||
return CLAY__INIT($NAME$){.capacity = capacity, .length = 0, .internalArray = ($TYPE$ *)Clay__Array_Allocate_Arena(capacity, sizeof($TYPE$), CLAY__POINTER_ALIGNMENT, arena)};
|
|
||||||
}
|
|
@ -1,6 +0,0 @@
|
|||||||
CLAY__TYPEDEF($NAME$, struct
|
|
||||||
{
|
|
||||||
int32_t capacity;
|
|
||||||
int32_t length;
|
|
||||||
$TYPE$ *internalArray;
|
|
||||||
});
|
|
@ -1,5 +0,0 @@
|
|||||||
CLAY__TYPEDEF($NAME$Slice, struct
|
|
||||||
{
|
|
||||||
int32_t length;
|
|
||||||
$TYPE$ *internalArray;
|
|
||||||
});
|
|
@ -1,3 +0,0 @@
|
|||||||
$TYPE$ *$NAME$_Get($NAME$ *array, int32_t index) {
|
|
||||||
return Clay__Array_RangeCheck(index, array->length) ? &array->internalArray[index] : $DEFAULT_VALUE$;
|
|
||||||
}
|
|
@ -1,3 +0,0 @@
|
|||||||
$TYPE$ *$NAME$Slice_Get($NAME$Slice *slice, int32_t index) {
|
|
||||||
return Clay__Array_RangeCheck(index, slice->length) ? &slice->internalArray[index] : $DEFAULT_VALUE$;
|
|
||||||
}
|
|
@ -1,3 +0,0 @@
|
|||||||
$TYPE$ $NAME$_Get($NAME$ *array, int32_t index) {
|
|
||||||
return Clay__Array_RangeCheck(index, array->length) ? array->internalArray[index] : $DEFAULT_VALUE$;
|
|
||||||
}
|
|
@ -1,9 +0,0 @@
|
|||||||
$TYPE$ $NAME$_RemoveSwapback($NAME$ *array, int32_t index) {
|
|
||||||
if (Clay__Array_RangeCheck(index, array->length)) {
|
|
||||||
array->length--;
|
|
||||||
$TYPE$ removed = array->internalArray[index];
|
|
||||||
array->internalArray[index] = array->internalArray[array->length];
|
|
||||||
return removed;
|
|
||||||
}
|
|
||||||
return $DEFAULT_VALUE$;
|
|
||||||
}
|
|
@ -1,6 +0,0 @@
|
|||||||
void $NAME$_Set($NAME$ *array, int32_t index, $TYPE$ value) {
|
|
||||||
if (Clay__Array_RangeCheck(index, array->capacity)) {
|
|
||||||
array->internalArray[index] = value;
|
|
||||||
array->length = index < array->length ? array->length : index + 1;
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,69 +0,0 @@
|
|||||||
const fs = require('fs');
|
|
||||||
const path = require('path');
|
|
||||||
|
|
||||||
let files = ['../clay.h'];
|
|
||||||
|
|
||||||
let templates = ['./'];
|
|
||||||
function readCTemplatesRecursive(directory) {
|
|
||||||
fs.readdirSync(directory).forEach(template => {
|
|
||||||
const absolute = path.join(directory, template);
|
|
||||||
if (fs.statSync(absolute).isDirectory()) return readCTemplatesRecursive(absolute);
|
|
||||||
else if (template.endsWith('template.c')) {
|
|
||||||
return templates.push(absolute);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
readCTemplatesRecursive(__dirname);
|
|
||||||
|
|
||||||
for (const file of files) {
|
|
||||||
const contents = fs.readFileSync(file, 'utf8');
|
|
||||||
const lines = contents.split('\n');
|
|
||||||
for (let i = 0; i < lines.length; i++) {
|
|
||||||
const line = lines[i];
|
|
||||||
if (line.startsWith('// __GENERATED__ template')) {
|
|
||||||
const [comment, generated, templateOpen, templateNames, ...args] = line.split(" ");
|
|
||||||
let matchingEndingLine = -1;
|
|
||||||
for (let j = i + 1; j < lines.length; j++) {
|
|
||||||
if (lines[j].startsWith('// __GENERATED__ template')) {
|
|
||||||
matchingEndingLine = j;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (matchingEndingLine !== -1) {
|
|
||||||
i++;
|
|
||||||
lines.splice(i, matchingEndingLine - (i));
|
|
||||||
lines.splice(i, 0, ['#pragma region generated']);
|
|
||||||
i++;
|
|
||||||
for (const templateName of templateNames.split(',')) {
|
|
||||||
var matchingTemplate = templates.find(t => t.endsWith(`${templateName}.template.c`));
|
|
||||||
if (matchingTemplate) {
|
|
||||||
let templateContents = fs.readFileSync(matchingTemplate, 'utf8');
|
|
||||||
for (const arg of args) {
|
|
||||||
[argName, argValue] = arg.split('=');
|
|
||||||
templateContents = templateContents.replaceAll(`\$${argName}\$`, argValue);
|
|
||||||
}
|
|
||||||
let remainingTokens = templateContents.split('$');
|
|
||||||
if (remainingTokens.length > 1) {
|
|
||||||
console.log(`Error at ${file}:${i}: Template is missing parameter ${remainingTokens[1]}`)
|
|
||||||
process.exit();
|
|
||||||
} else {
|
|
||||||
templateContents = templateContents.split('\n');
|
|
||||||
lines.splice(i, 0, ...templateContents);
|
|
||||||
i += templateContents.length;
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
console.log(`Error at ${file}:${i + 1}: no template with name ${templateName}.template.c was found.`);
|
|
||||||
process.exit();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
lines.splice(i, 0, ['#pragma endregion']);
|
|
||||||
i++;
|
|
||||||
} else {
|
|
||||||
console.log(`Error at ${file}:${i + 1}: template was opened and not closed again.`);
|
|
||||||
process.exit();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
fs.writeFileSync(file, lines.join('\n'));
|
|
||||||
}
|
|
@ -35,7 +35,7 @@ typedef struct
|
|||||||
CustomLayoutElementType type;
|
CustomLayoutElementType type;
|
||||||
union {
|
union {
|
||||||
CustomLayoutElement_3DModel model;
|
CustomLayoutElement_3DModel model;
|
||||||
};
|
} customData;
|
||||||
} CustomLayoutElement;
|
} CustomLayoutElement;
|
||||||
|
|
||||||
// Get a ray trace from the screen position (i.e mouse) within a specific section of the screen
|
// Get a ray trace from the screen position (i.e mouse) within a specific section of the screen
|
||||||
@ -216,7 +216,7 @@ void Clay_Raylib_Render(Clay_RenderCommandArray renderCommands)
|
|||||||
float scaleValue = CLAY__MIN(CLAY__MIN(1, 768 / rootBox.height) * CLAY__MAX(1, rootBox.width / 1024), 1.5f);
|
float scaleValue = CLAY__MIN(CLAY__MIN(1, 768 / rootBox.height) * CLAY__MAX(1, rootBox.width / 1024), 1.5f);
|
||||||
Ray positionRay = GetScreenToWorldPointWithZDistance((Vector2) { renderCommand->boundingBox.x + renderCommand->boundingBox.width / 2, renderCommand->boundingBox.y + (renderCommand->boundingBox.height / 2) + 20 }, Raylib_camera, (int)roundf(rootBox.width), (int)roundf(rootBox.height), 140);
|
Ray positionRay = GetScreenToWorldPointWithZDistance((Vector2) { renderCommand->boundingBox.x + renderCommand->boundingBox.width / 2, renderCommand->boundingBox.y + (renderCommand->boundingBox.height / 2) + 20 }, Raylib_camera, (int)roundf(rootBox.width), (int)roundf(rootBox.height), 140);
|
||||||
BeginMode3D(Raylib_camera);
|
BeginMode3D(Raylib_camera);
|
||||||
DrawModel(customElement->model.model, positionRay.position, customElement->model.scale * scaleValue, WHITE); // Draw 3d model with texture
|
DrawModel(customElement->customData.model.model, positionRay.position, customElement->customData.model.scale * scaleValue, WHITE); // Draw 3d model with texture
|
||||||
EndMode3D();
|
EndMode3D();
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user