mirror of
				https://github.com/nicbarker/clay.git
				synced 2025-11-04 08:36:17 +00:00 
			
		
		
		
	README updates
This commit is contained in:
		
							parent
							
								
									5261c1eef2
								
							
						
					
					
						commit
						f49ec15da8
					
				
							
								
								
									
										82
									
								
								README.md
									
									
									
									
									
								
							
							
						
						
									
										82
									
								
								README.md
									
									
									
									
									
								
							| 
						 | 
				
			
			@ -410,15 +410,12 @@ Clay supports C preprocessor directives to modulate functionality at compile tim
 | 
			
		|||
 | 
			
		||||
The supported directives are:
 | 
			
		||||
 | 
			
		||||
- `CLAY_MAX_ELEMENT_COUNT` - Controls the maximum number of clay elements that memory is pre-allocated for. Defaults to **8192**, which should be more than enough for the majority of use cases. Napkin math is ~450 bytes of memory overhead per element (8192 elements is ~3.5mb of memory) 
 | 
			
		||||
- `CLAY_DISABLE_CULLING` - Disables [Visibility Culling](#visibility-culling) of render commands.
 | 
			
		||||
- `CLAY_WASM` - Required when targeting Web Assembly.
 | 
			
		||||
- `CLAY_OVERFLOW_TRAP` - By default, clay will continue to allow function calls without crashing even when it exhausts all its available pre-allocated memory.  This can produce erroneous layout results that are difficult to interpret. If `CLAY_OVERFLOW_TRAP` is defined, clay will raise a `SIGTRAP` signal that will be caught by your debugger. Relies on `signal.h` being available in your environment.
 | 
			
		||||
- `CLAY_DEBUG` - Used for debugging clay's internal implementation. Useful if you want to modify or debug clay, or learn how things work. It enables a number of debug features such as preserving source strings for hash IDs to make debugging easier.
 | 
			
		||||
- `CLAY_EXTEND_CONFIG_RECTANGLE` - Provide additional struct members to `CLAY_RECTANGLE` that will be passed through with output render commands.
 | 
			
		||||
- `CLAY_EXTEND_CONFIG_TEXT` - Provide additional struct members to `CLAY_TEXT_CONFIG` that will be passed through with output render commands.
 | 
			
		||||
- `CLAY_EXTEND_CONFIG_IMAGE` - Provide additional struct members to `CLAY_IMAGE_CONFIG` that will be passed through with output render commands.
 | 
			
		||||
- `CLAY_EXTEND_CONFIG_CUSTOM` - Provide additional struct members to `CLAY_IMAGE_CONFIG` that will be passed through with output render commands.
 | 
			
		||||
- `CLAY_EXTEND_CONFIG_CUSTOM` - Provide additional struct members to `CLAY_CUSTOM_CONFIG` that will be passed through with output render commands.
 | 
			
		||||
 | 
			
		||||
### Bindings for non C
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			@ -485,9 +482,9 @@ Takes a pointer to a function that can be used to measure the `width, height` di
 | 
			
		|||
 | 
			
		||||
### Clay_Initialize
 | 
			
		||||
 | 
			
		||||
`void Clay_Initialize(Clay_Arena arena, Clay_Dimensions layoutDimensions)`
 | 
			
		||||
`void Clay_Initialize(Clay_Arena arena, Clay_Dimensions layoutDimensions, Clay_ErrorHandler errorHandler)`
 | 
			
		||||
 | 
			
		||||
Initializes the internal memory mapping, and sets the internal dimensions for layout.
 | 
			
		||||
Initializes the internal memory mapping, sets the internal dimensions for layout, and binds an error handler for clay to use when something goes wrong.
 | 
			
		||||
 | 
			
		||||
### Clay_SetLayoutDimensions
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			@ -1770,4 +1767,77 @@ An enum value representing the current "state" of the pointer interaction. As an
 | 
			
		|||
 | 
			
		||||
---
 | 
			
		||||
 | 
			
		||||
### Clay_ErrorHandler
 | 
			
		||||
 | 
			
		||||
```C
 | 
			
		||||
typedef struct
 | 
			
		||||
{
 | 
			
		||||
    void (*errorHandlerFunction)(Clay_ErrorData errorText);
 | 
			
		||||
    uintptr_t userData;
 | 
			
		||||
} Clay_ErrorHandler;
 | 
			
		||||
```
 | 
			
		||||
 | 
			
		||||
**Fields**
 | 
			
		||||
 | 
			
		||||
**`.errorHandlerFunction`** - `void (Clay_ErrorData errorText) {}`
 | 
			
		||||
 | 
			
		||||
A function pointer to an error handler function, which takes `Clay_ErrorData` as an argument. This function will be called whenever Clay encounters an internal error.
 | 
			
		||||
 | 
			
		||||
---
 | 
			
		||||
 | 
			
		||||
**`.userData`** - `uintptr_t`
 | 
			
		||||
 | 
			
		||||
A generic pointer to extra userdata that is transparently passed through from `Clay_Initialize` to Clay's error handler callback. Defaults to NULL.
 | 
			
		||||
 | 
			
		||||
---
 | 
			
		||||
 | 
			
		||||
### Clay_ErrorData
 | 
			
		||||
 | 
			
		||||
```C
 | 
			
		||||
typedef struct
 | 
			
		||||
{
 | 
			
		||||
    Clay_ErrorType errorType;
 | 
			
		||||
    Clay_String errorText;
 | 
			
		||||
    uintptr_t userData;
 | 
			
		||||
} Clay_ErrorData;
 | 
			
		||||
```
 | 
			
		||||
 | 
			
		||||
**Fields**
 | 
			
		||||
 | 
			
		||||
**`.errorType`** - `Clay_ErrorType`
 | 
			
		||||
 | 
			
		||||
```C
 | 
			
		||||
typedef enum {
 | 
			
		||||
    CLAY_ERROR_TYPE_TEXT_MEASUREMENT_FUNCTION_NOT_PROVIDED,
 | 
			
		||||
    CLAY_ERROR_TYPE_ARENA_CAPACITY_EXCEEDED,
 | 
			
		||||
    CLAY_ERROR_TYPE_ELEMENTS_CAPACITY_EXCEEDED,
 | 
			
		||||
    CLAY_ERROR_TYPE_TEXT_MEASUREMENT_CAPACITY_EXCEEDED,
 | 
			
		||||
    CLAY_ERROR_TYPE_DUPLICATE_ID,
 | 
			
		||||
    CLAY_ERROR_TYPE_FLOATING_CONTAINER_PARENT_NOT_FOUND,
 | 
			
		||||
    CLAY_ERROR_TYPE_INTERNAL_ERROR,
 | 
			
		||||
} Clay_ErrorType;
 | 
			
		||||
```
 | 
			
		||||
 | 
			
		||||
An enum representing the type of error Clay encountered. It's up to the user to handle on a case by case basis, but as some general guidance:
 | 
			
		||||
 | 
			
		||||
- `CLAY_ERROR_TYPE_TEXT_MEASUREMENT_FUNCTION_NOT_PROVIDED` - The user is attempting to use `CLAY_TEXT` and either forgot to call [Clay_SetMeasureTextFunction](#clay_setmeasuretextfunction) or accidentally passed a null function pointer.
 | 
			
		||||
- `CLAY_ERROR_TYPE_ARENA_CAPACITY_EXCEEDED` - Clay was initialized with an Arena that was too small for the configured [Clay_SetMaxElementCount](#clay_setmaxelementcount). Try using [Clay_MinMemorySize()](#clay_minmemorysize) to get the exact number of bytes required by the current configuration.
 | 
			
		||||
- `CLAY_ERROR_TYPE_ELEMENTS_CAPACITY_EXCEEDED` - The declared UI hierarchy has too many elements for the configured max element count. Use [Clay_SetMaxElementCount](#clay_setmaxelementcount) to increase the max, then call [Clay_MinMemorySize()](#clay_minmemorysize) again and reinitialize clay's memory with the required size.
 | 
			
		||||
- `CLAY_ERROR_TYPE_ELEMENTS_CAPACITY_EXCEEDED` - The declared UI hierarchy has too much text for the configured text measure cache size. Use [Clay_SetMeasureTextCacheSize](#clay_setmeasuretextcachesize) to increase the max, then call [Clay_MinMemorySize()](#clay_minmemorysize) again and reinitialize clay's memory with the required size.
 | 
			
		||||
- `CLAY_ERROR_TYPE_DUPLICATE_ID` - Two elements in Clays UI Hierarchy have been declared with exactly the same ID. Set a breakpoint in your error handler function for a stack trace back to exactly where this occured.
 | 
			
		||||
- `CLAY_ERROR_TYPE_FLOATING_CONTAINER_PARENT_NOT_FOUND` - A `CLAY_FLOATING` element was declared with the `.parentId` property, but no element with that ID was found. Set a breakpoint in your error handler function for a stack trace back to exactly where this occured.
 | 
			
		||||
- `CLAY_ERROR_TYPE_INTERNAL_ERROR` - Clay has encountered an internal logic or memory error. Please report this as a bug with a stack trace to help us fix these!
 | 
			
		||||
 | 
			
		||||
---
 | 
			
		||||
 | 
			
		||||
**`.errorText`** - `Clay_String`
 | 
			
		||||
 | 
			
		||||
A [Clay_String](#clay_string) that provides a human readable description of the error. May change in future and should not be relied on to detect error types.
 | 
			
		||||
 | 
			
		||||
---
 | 
			
		||||
 | 
			
		||||
**`.userData`** - `uintptr_t`
 | 
			
		||||
 | 
			
		||||
A generic pointer to extra userdata that is transparently passed through from `Clay_Initialize` to Clay's error handler callback. Defaults to NULL.
 | 
			
		||||
 | 
			
		||||
---
 | 
			
		||||
							
								
								
									
										10
									
								
								clay.h
									
									
									
									
									
								
							
							
						
						
									
										10
									
								
								clay.h
									
									
									
									
									
								
							| 
						 | 
				
			
			@ -515,10 +515,6 @@ extern uint32_t Clay__debugViewWidth;
 | 
			
		|||
#ifdef CLAY_IMPLEMENTATION
 | 
			
		||||
#undef CLAY_IMPLEMENTATION
 | 
			
		||||
 | 
			
		||||
#ifndef CLAY__TEXT_MEASURE_HASH_BUCKET_COUNT
 | 
			
		||||
#define CLAY__TEXT_MEASURE_HASH_BUCKET_COUNT 16
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
#ifndef CLAY__NULL
 | 
			
		||||
#define CLAY__NULL 0
 | 
			
		||||
#endif
 | 
			
		||||
| 
						 | 
				
			
			@ -528,8 +524,8 @@ extern uint32_t Clay__debugViewWidth;
 | 
			
		|||
#endif
 | 
			
		||||
 | 
			
		||||
bool Clay__warningsEnabled = true;
 | 
			
		||||
uint32_t Clay__maxElementCount = 128;
 | 
			
		||||
uint32_t Clay__measureTextCacheSize = 128;
 | 
			
		||||
uint32_t Clay__maxElementCount = 8192;
 | 
			
		||||
uint32_t Clay__measureTextCacheSize = 16384;
 | 
			
		||||
Clay_ErrorHandler Clay__errorHandler = CLAY__INIT(Clay_ErrorHandler) { .errorHandlerFunction = Clay__Noop };
 | 
			
		||||
 | 
			
		||||
void Clay__Noop() {};
 | 
			
		||||
| 
						 | 
				
			
			@ -1581,7 +1577,7 @@ Clay__MeasureTextCacheItem *Clay__MeasureTextCached(Clay_String *text, Clay_Text
 | 
			
		|||
        return NULL;
 | 
			
		||||
    }
 | 
			
		||||
    uint32_t id = Clay__HashTextWithConfig(text, config);
 | 
			
		||||
    uint32_t hashBucket = id % CLAY__TEXT_MEASURE_HASH_BUCKET_COUNT;
 | 
			
		||||
    uint32_t hashBucket = id % (Clay__measureTextCacheSize / 8);
 | 
			
		||||
    int32_t elementIndexPrevious = 0;
 | 
			
		||||
    int32_t elementIndex = Clay__measureTextHashMap.internalArray[hashBucket];
 | 
			
		||||
    while (elementIndex != 0) {
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
		Loading…
	
		Reference in a new issue