7 /* Copyright (C) 2021-2022 Harry Godden (hgn) - All Rights Reserved */
9 typedef unsigned int uint
;
24 typedef struct vg_tex2d vg_tex2d
;
32 #define vg_static_assert _Static_assert
33 #define vg_list_size( A ) (sizeof(A)/sizeof(A[0]))
34 #define VG_MUST_USE_RESULT __attribute__((warn_unused_result))
48 enum strncpy_behaviour
{
49 k_strncpy_always_add_null
= 0,
50 k_strncpy_allow_cutoff
= 1,
51 k_strncpy_overflow_fatal
= 2
54 static void vg_fatal_error( const char *fmt
, ... );
55 static u32
vg_strncpy( const char *src
, char *dst
, u32 len
,
56 enum strncpy_behaviour behaviour
)
58 for( u32 i
=0; i
<len
; i
++ ){
61 if( !src
[i
] ) return i
;
64 if( behaviour
== k_strncpy_always_add_null
){
68 else if( behaviour
== k_strncpy_overflow_fatal
){
69 vg_fatal_error( "Strncpy dest exceeded buffer length\n" );
77 typedef struct vg_str vg_str
;
83 static void vg_strnull( vg_str
*str
, char *buffer
, u32 len
)
86 str
->buffer
[0] = '\0';
91 static void vg_strcat( vg_str
*str
, const char *append
)
94 for( u32 i
=0; str
->i
< str
->len
; i
++, str
->i
++ ){
95 str
->buffer
[ str
->i
] = append
[i
];
97 if( append
[i
] == '\0' ) return;
101 static int vg_strgood( vg_str
*str
)
103 if( str
->i
== str
->len
){
104 if( str
->buffer
[str
->i
-1] == '\0' ) return 1;
110 static char *vg_strch( vg_str
*str
, char c
)
113 for( u32 i
=0; i
<str
->i
; i
++ ){
114 if( str
->buffer
[i
] == c
)
121 static u32
vg_strdjb2( const char *str
)
125 while( (c
= *str
++) )
126 hash
= ((hash
<< 5) + hash
) + c
; /* hash * 33 + c */
131 static int vg_strdjb2_eq( const char *s1
, u32 h1
,
132 const char *s2
, u32 h2
)
135 if(!strcmp(s1
, s2
)) return 1;
140 #define VG_STRDJB2_EQ( CS1, S2, H2 ) \
141 vg_strdjb2_eq( CS1, vg_strdjb2(CS1), S2, H2 )
144 #define VG_MIN( A, B ) ((A)<(B)?(A):(B))
145 #define VG_MAX( A, B ) ((A)>(B)?(A):(B))