From cd82ce6fcf6edb2252292ca974c7a66496c3f84b Mon Sep 17 00:00:00 2001 From: Michael Savage Date: Tue, 14 Jan 2025 23:06:22 +0200 Subject: [PATCH] [Core] Don't divide zero by zero (#200) Co-authored-by: Nic Barker --- clay.h | 22 ++++++++++++++-------- 1 file changed, 14 insertions(+), 8 deletions(-) diff --git a/clay.h b/clay.h index 59c7fd6..fc54d02 100644 --- a/clay.h +++ b/clay.h @@ -2117,9 +2117,9 @@ void Clay__InitializePersistentMemory(Clay_Context* context) { void Clay__CompressChildrenAlongAxis(bool xAxis, float totalSizeToDistribute, Clay__int32_tArray resizableContainerBuffer) { Clay_Context* context = Clay_GetCurrentContext(); Clay__int32_tArray largestContainers = context->openClipElementStack; - largestContainers.length = 0; while (totalSizeToDistribute > 0.1) { + largestContainers.length = 0; float largestSize = 0; float targetSize = 0; for (int32_t i = 0; i < resizableContainerBuffer.length; ++i) { @@ -2141,23 +2141,29 @@ void Clay__CompressChildrenAlongAxis(bool xAxis, float totalSizeToDistribute, Cl } } + if (largestContainers.length == 0) { + return; + } + targetSize = CLAY__MAX(targetSize, (largestSize * largestContainers.length) - totalSizeToDistribute) / largestContainers.length; + for (int32_t childOffset = 0; childOffset < largestContainers.length; childOffset++) { - Clay_LayoutElement *childElement = Clay_LayoutElementArray_Get(&context->layoutElements, Clay__int32_tArray_Get(&largestContainers, childOffset)); + int32_t childIndex = Clay__int32_tArray_Get(&largestContainers, childOffset); + Clay_LayoutElement *childElement = Clay_LayoutElementArray_Get(&context->layoutElements, childIndex); float *childSize = xAxis ? &childElement->dimensions.width : &childElement->dimensions.height; float childMinSize = xAxis ? childElement->minDimensions.width : childElement->minDimensions.height; float oldChildSize = *childSize; *childSize = CLAY__MAX(childMinSize, targetSize); totalSizeToDistribute -= (oldChildSize - *childSize); if (*childSize == childMinSize) { - Clay__int32_tArray_RemoveSwapback(&largestContainers, childOffset); - childOffset--; + for (int32_t i = 0; i < resizableContainerBuffer.length; i++) { + if (Clay__int32_tArray_Get(&resizableContainerBuffer, i) == childIndex) { + Clay__int32_tArray_RemoveSwapback(&resizableContainerBuffer, i); + break; + } + } } } - - if (largestContainers.length == 0) { - break; - } } }