gencpp/base/components/interface.untyped.cpp

180 lines
3.2 KiB
C++
Raw Normal View History

#ifdef GEN_INTELLISENSE_DIRECTIVES
#pragma once
#include "interface.parsing.cpp"
#endif
ssize token_fmt_va( char* buf, usize buf_size, s32 num_tokens, va_list va )
{
char const* buf_begin = buf;
ssize remaining = buf_size;
local_persist StringTable tok_map;
do_once() {
tok_map = hashtable_init(Str, _ctx->Allocator_DyanmicContainers );
}
// Populate token pairs
{
s32 left = num_tokens - 1;
while ( left-- )
{
char const* token = va_arg( va, char const* );
Str value = va_arg( va, Str );
u32 key = crc32( token, c_str_len(token) );
hashtable_set( tok_map, key, value );
}
}
char const* fmt = va_arg( va, char const* );
char current = *fmt;
while ( current )
{
ssize len = 0;
while ( current && current != '<' && remaining )
{
* buf = * fmt;
buf++;
fmt++;
remaining--;
current = * fmt;
}
if ( current == '<' )
{
char const* scanner = fmt + 1;
s32 tok_len = 0;
while ( *scanner != '>' )
{
tok_len++;
scanner++;
}
char const* token = fmt + 1;
u32 key = crc32( token, tok_len );
Str* value = hashtable_get(tok_map, key );
if ( value )
{
ssize left = value->Len;
char const* str = value->Ptr;
while ( left-- )
{
* buf = * str;
buf++;
str++;
remaining--;
}
scanner++;
fmt = scanner;
current = * fmt;
continue;
}
* buf = * fmt;
buf++;
fmt++;
remaining--;
current = * fmt;
}
}
hashtable_clear(tok_map);
ssize result = buf_size - remaining;
return result;
}
Code untyped_str( Str content )
{
2023-08-01 14:02:54 -04:00
if ( content.Len == 0 )
{
log_failure( "untyped_str: empty string" );
2024-12-02 00:03:38 -05:00
return InvalidCode;
2023-08-01 14:02:54 -04:00
}
Code
2023-07-24 20:59:20 -04:00
result = make_code();
result->Name = cache_str( content );
2024-12-03 15:19:39 -05:00
result->Type = CT_Untyped;
result->Content = result->Name;
if ( result->Name.Len == 0 )
2023-08-01 14:02:54 -04:00
{
log_failure( "untyped_str: could not cache string" );
2024-12-02 00:03:38 -05:00
return InvalidCode;
2023-08-01 14:02:54 -04:00
}
return result;
}
Code untyped_fmt( char const* fmt, ...)
{
2023-08-01 14:02:54 -04:00
if ( fmt == nullptr )
{
log_failure( "untyped_fmt: null format string" );
2024-12-02 00:03:38 -05:00
return InvalidCode;
2023-08-01 14:02:54 -04:00
}
local_persist thread_local
2023-07-24 20:59:20 -04:00
char buf[GEN_PRINTF_MAXLEN] = { 0 };
va_list va;
va_start(va, fmt);
ssize length = c_str_fmt_va(buf, GEN_PRINTF_MAXLEN, fmt, va);
va_end(va);
Str content = { buf, length };
Code
2023-07-24 20:59:20 -04:00
result = make_code();
2024-12-03 15:19:39 -05:00
result->Type = CT_Untyped;
result->Content = cache_str( content );
if ( result->Name.Len == 0 )
2023-08-01 14:02:54 -04:00
{
log_failure( "untyped_fmt: could not cache string" );
2024-12-02 00:03:38 -05:00
return InvalidCode;
2023-08-01 14:02:54 -04:00
}
return result;
}
Code untyped_token_fmt( s32 num_tokens, char const* fmt, ... )
{
2023-08-01 14:02:54 -04:00
if ( num_tokens == 0 )
{
log_failure( "untyped_token_fmt: zero tokens" );
2024-12-02 00:03:38 -05:00
return InvalidCode;
2023-08-01 14:02:54 -04:00
}
local_persist thread_local
2023-07-24 20:59:20 -04:00
char buf[GEN_PRINTF_MAXLEN] = { 0 };
va_list va;
va_start(va, fmt);
ssize length = token_fmt_va(buf, GEN_PRINTF_MAXLEN, num_tokens, va);
va_end(va);
Str buf_str = { buf, length };
Code
2023-07-24 20:59:20 -04:00
result = make_code();
2024-12-03 15:19:39 -05:00
result->Type = CT_Untyped;
result->Content = cache_str( buf_str );
if ( result->Name.Len == 0 )
2023-08-01 14:02:54 -04:00
{
log_failure( "untyped_fmt: could not cache string" );
2024-12-02 00:03:38 -05:00
return InvalidCode;
2023-08-01 14:02:54 -04:00
}
return result;
}