mirror of
https://github.com/Ed94/gencpp.git
synced 2025-01-08 16:03:32 -08:00
array.Parsed.hpp passed test!
This commit is contained in:
parent
1fb3db379c
commit
ddb3244467
2
.vscode/gencpp.natvis
vendored
2
.vscode/gencpp.natvis
vendored
@ -70,7 +70,7 @@
|
|||||||
</Type>
|
</Type>
|
||||||
|
|
||||||
<Type Name="gen::Parser::TokArray">
|
<Type Name="gen::Parser::TokArray">
|
||||||
<DisplayString>Current[ { Arr[Idx] } ]</DisplayString>
|
<DisplayString>Current[ { Arr[Idx] } ] Idx:{ Idx }</DisplayString>
|
||||||
<Expand>
|
<Expand>
|
||||||
<Synthetic Name="Header">
|
<Synthetic Name="Header">
|
||||||
<DisplayString>{(ArrayHeader*)((char*)Arr - sizeof(ArrayHeader))}</DisplayString>
|
<DisplayString>{(ArrayHeader*)((char*)Arr - sizeof(ArrayHeader))}</DisplayString>
|
||||||
|
452
project/gen.cpp
452
project/gen.cpp
@ -709,17 +709,27 @@ namespace gen
|
|||||||
|
|
||||||
case Parameters:
|
case Parameters:
|
||||||
{
|
{
|
||||||
result.append_fmt( "%s %s", entry( 0 )->to_string(), Name );
|
if ( Name )
|
||||||
|
{
|
||||||
|
result.append_fmt( "%s %s", entry( 0 )->to_string(), Name );
|
||||||
|
}
|
||||||
|
else
|
||||||
|
result.append_fmt( "%s", entry(0)->to_string() );
|
||||||
|
|
||||||
s32 index = 1;
|
s32 index = 1;
|
||||||
s32 left = num_entries() - 1;
|
s32 left = num_entries() - 1;
|
||||||
|
|
||||||
while ( left-- )
|
while ( left-- )
|
||||||
{
|
{
|
||||||
result.append_fmt( ", %s %s"
|
if ( Name )
|
||||||
, entry( index )->entry( 0 )->to_string()
|
result.append_fmt( ", %s %s"
|
||||||
, entry( index )->Name
|
, entry( index )->entry( 0 )->to_string()
|
||||||
);
|
, entry( index )->Name
|
||||||
|
);
|
||||||
|
|
||||||
|
else
|
||||||
|
result.append_fmt( "%s", entry(0)->to_string() );
|
||||||
|
|
||||||
index++;
|
index++;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -3213,6 +3223,7 @@ namespace gen
|
|||||||
Entry( Decl_Namespace, "namespace" ) \
|
Entry( Decl_Namespace, "namespace" ) \
|
||||||
Entry( Decl_Operator, "operator" ) \
|
Entry( Decl_Operator, "operator" ) \
|
||||||
Entry( Decl_Struct, "struct" ) \
|
Entry( Decl_Struct, "struct" ) \
|
||||||
|
Entry( Decl_Template, "template" ) \
|
||||||
Entry( Decl_Typedef, "typedef" ) \
|
Entry( Decl_Typedef, "typedef" ) \
|
||||||
Entry( Decl_Using, "using" ) \
|
Entry( Decl_Using, "using" ) \
|
||||||
Entry( Decl_Union, "union" ) \
|
Entry( Decl_Union, "union" ) \
|
||||||
@ -3238,7 +3249,6 @@ namespace gen
|
|||||||
Entry( Star, "*" ) \
|
Entry( Star, "*" ) \
|
||||||
Entry( Statement_End, ";" ) \
|
Entry( Statement_End, ";" ) \
|
||||||
Entry( String, "__String__" ) \
|
Entry( String, "__String__" ) \
|
||||||
Entry( Template, "template" ) \
|
|
||||||
Entry( Type_Unsigned, "unsigned" ) \
|
Entry( Type_Unsigned, "unsigned" ) \
|
||||||
Entry( Type_Signed, "signed" ) \
|
Entry( Type_Signed, "signed" ) \
|
||||||
Entry( Type_Short, "short" ) \
|
Entry( Type_Short, "short" ) \
|
||||||
@ -3294,6 +3304,9 @@ namespace gen
|
|||||||
s32 lookup_len = lookup[index].Len - 1;
|
s32 lookup_len = lookup[index].Len - 1;
|
||||||
char const* lookup_str = lookup[index].Ptr;
|
char const* lookup_str = lookup[index].Ptr;
|
||||||
|
|
||||||
|
if ( lookup_len != length )
|
||||||
|
continue;
|
||||||
|
|
||||||
if ( str_compare( word, lookup_str, lookup_len ) == 0 )
|
if ( str_compare( word, lookup_str, lookup_len ) == 0 )
|
||||||
return scast(TokType, index);
|
return scast(TokType, index);
|
||||||
}
|
}
|
||||||
@ -3901,6 +3914,7 @@ namespace gen
|
|||||||
internal Code parse_friend ( Parser::TokArray& toks, char const* context );
|
internal Code parse_friend ( Parser::TokArray& toks, char const* context );
|
||||||
internal Code parse_function ( Parser::TokArray& toks, char const* context );
|
internal Code parse_function ( Parser::TokArray& toks, char const* context );
|
||||||
internal Code parse_namespace ( Parser::TokArray& toks, char const* context );
|
internal Code parse_namespace ( Parser::TokArray& toks, char const* context );
|
||||||
|
internal Code parse_operator_cast ( Parser::TokArray& toks, char const* context );
|
||||||
internal Code parse_struct ( Parser::TokArray& toks, char const* context );
|
internal Code parse_struct ( Parser::TokArray& toks, char const* context );
|
||||||
internal Code parse_variable ( Parser::TokArray& toks, char const* context );
|
internal Code parse_variable ( Parser::TokArray& toks, char const* context );
|
||||||
internal Code parse_template ( Parser::TokArray& toks, char const* context );
|
internal Code parse_template ( Parser::TokArray& toks, char const* context );
|
||||||
@ -4017,55 +4031,11 @@ namespace gen
|
|||||||
if ( type == Code::Invalid )
|
if ( type == Code::Invalid )
|
||||||
return Code::Invalid;
|
return Code::Invalid;
|
||||||
|
|
||||||
Token name = currtok;
|
Token name = { nullptr, 0, TokType::Invalid, false };
|
||||||
eat( TokType::Identifier );
|
|
||||||
|
|
||||||
if ( currtok.IsAssign )
|
if ( check( TokType::Identifier ) )
|
||||||
{
|
{
|
||||||
eat( TokType::Operator );
|
name = currtok;
|
||||||
|
|
||||||
Token value_tok = currtok;
|
|
||||||
|
|
||||||
if ( currtok.Type == TokType::Statement_End )
|
|
||||||
{
|
|
||||||
log_failure( "gen::%s: Expected value after assignment operator", context );
|
|
||||||
return Code::Invalid;
|
|
||||||
}
|
|
||||||
|
|
||||||
while ( left && currtok.Type != TokType::Statement_End )
|
|
||||||
{
|
|
||||||
value_tok.Length = ( (sptr)currtok.Text + currtok.Length ) - (sptr)value_tok.Text;
|
|
||||||
eat( currtok.Type );
|
|
||||||
}
|
|
||||||
|
|
||||||
value = parse_type( toks, context );
|
|
||||||
}
|
|
||||||
|
|
||||||
Code
|
|
||||||
result = make_code();
|
|
||||||
result->Type = Parameters;
|
|
||||||
result->Name = get_cached_string( name );
|
|
||||||
|
|
||||||
result->add_entry( type );
|
|
||||||
|
|
||||||
if ( value )
|
|
||||||
result->add_entry( value );
|
|
||||||
|
|
||||||
while ( left
|
|
||||||
&& use_template_capture ?
|
|
||||||
currtok.Type != TokType::Operator && currtok.Text[0] != '>'
|
|
||||||
: currtok.Type != TokType::Capture_End )
|
|
||||||
{
|
|
||||||
eat( TokType::Comma );
|
|
||||||
|
|
||||||
Code type = { nullptr };
|
|
||||||
Code value = { nullptr };
|
|
||||||
|
|
||||||
type = parse_type( toks, context );
|
|
||||||
if ( type == Code::Invalid )
|
|
||||||
return Code::Invalid;
|
|
||||||
|
|
||||||
Token name = currtok;
|
|
||||||
eat( TokType::Identifier );
|
eat( TokType::Identifier );
|
||||||
|
|
||||||
if ( currtok.IsAssign )
|
if ( currtok.IsAssign )
|
||||||
@ -4088,11 +4058,69 @@ namespace gen
|
|||||||
|
|
||||||
value = parse_type( toks, context );
|
value = parse_type( toks, context );
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
Code
|
||||||
|
result = make_code();
|
||||||
|
result->Type = Parameters;
|
||||||
|
|
||||||
|
if ( name.Length > 0 )
|
||||||
|
result->Name = get_cached_string( name );
|
||||||
|
|
||||||
|
result->add_entry( type );
|
||||||
|
|
||||||
|
if ( value )
|
||||||
|
result->add_entry( value );
|
||||||
|
|
||||||
|
while ( left
|
||||||
|
&& use_template_capture ?
|
||||||
|
currtok.Type != TokType::Operator && currtok.Text[0] != '>'
|
||||||
|
: currtok.Type != TokType::Capture_End )
|
||||||
|
{
|
||||||
|
eat( TokType::Comma );
|
||||||
|
|
||||||
|
Code type = { nullptr };
|
||||||
|
Code value = { nullptr };
|
||||||
|
|
||||||
|
type = parse_type( toks, context );
|
||||||
|
if ( type == Code::Invalid )
|
||||||
|
return Code::Invalid;
|
||||||
|
|
||||||
|
name = { nullptr, 0, TokType::Invalid, false };
|
||||||
|
|
||||||
|
if ( check( TokType::Identifier ) )
|
||||||
|
{
|
||||||
|
name = currtok;
|
||||||
|
eat( TokType::Identifier );
|
||||||
|
|
||||||
|
if ( currtok.IsAssign )
|
||||||
|
{
|
||||||
|
eat( TokType::Operator );
|
||||||
|
|
||||||
|
Token value_tok = currtok;
|
||||||
|
|
||||||
|
if ( currtok.Type == TokType::Statement_End )
|
||||||
|
{
|
||||||
|
log_failure( "gen::%s: Expected value after assignment operator", context );
|
||||||
|
return Code::Invalid;
|
||||||
|
}
|
||||||
|
|
||||||
|
while ( left && currtok.Type != TokType::Statement_End )
|
||||||
|
{
|
||||||
|
value_tok.Length = ( (sptr)currtok.Text + currtok.Length ) - (sptr)value_tok.Text;
|
||||||
|
eat( currtok.Type );
|
||||||
|
}
|
||||||
|
|
||||||
|
value = parse_type( toks, context );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
Code
|
Code
|
||||||
param = make_code();
|
param = make_code();
|
||||||
param->Type = Parameters;
|
param->Type = Parameters;
|
||||||
param->Name = get_cached_string( name );
|
|
||||||
|
if ( name.Length > 0 )
|
||||||
|
param->Name = get_cached_string( name );
|
||||||
|
|
||||||
param->add_entry( type );
|
param->add_entry( type );
|
||||||
|
|
||||||
@ -4443,11 +4471,11 @@ namespace gen
|
|||||||
|
|
||||||
while ( left && currtok.Type != TokType::Statement_End )
|
while ( left && currtok.Type != TokType::Statement_End )
|
||||||
{
|
{
|
||||||
expr_tok.Length = ( (sptr)currtok.Text + currtok.Length ) - (sptr)expr_tok.Text;
|
|
||||||
eat( currtok.Type );
|
eat( currtok.Type );
|
||||||
}
|
}
|
||||||
|
|
||||||
expr = untyped_str( expr_tok );
|
expr_tok.Length = ( (sptr)currtok.Text + currtok.Length ) - (sptr)expr_tok.Text;
|
||||||
|
expr = untyped_str( expr_tok );
|
||||||
}
|
}
|
||||||
|
|
||||||
eat( TokType::Statement_End );
|
eat( TokType::Statement_End );
|
||||||
@ -4611,11 +4639,15 @@ namespace gen
|
|||||||
member = parse_friend( toks, context );
|
member = parse_friend( toks, context );
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
case TokType::Decl_Operator:
|
||||||
|
member = parse_operator_cast( toks, context );
|
||||||
|
break;
|
||||||
|
|
||||||
case TokType::Decl_Struct:
|
case TokType::Decl_Struct:
|
||||||
member = parse_struct( toks, context );
|
member = parse_struct( toks, context );
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case TokType::Template:
|
case TokType::Decl_Template:
|
||||||
member = parse_template( toks, context );
|
member = parse_template( toks, context );
|
||||||
break;
|
break;
|
||||||
|
|
||||||
@ -4717,6 +4749,7 @@ namespace gen
|
|||||||
{
|
{
|
||||||
member = parse_operator_function_or_variable( expects_function, attributes, specifiers, toks, context );
|
member = parse_operator_function_or_variable( expects_function, attributes, specifiers, toks, context );
|
||||||
}
|
}
|
||||||
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
Token untyped_tok = currtok;
|
Token untyped_tok = currtok;
|
||||||
@ -4829,7 +4862,7 @@ namespace gen
|
|||||||
Token start = currtok;
|
Token start = currtok;
|
||||||
|
|
||||||
s32 level = 0;
|
s32 level = 0;
|
||||||
while ( left && currtok.Type != TokType::BraceCurly_Close && level == 0 )
|
while ( left && ( currtok.Type != TokType::BraceCurly_Close || level > 0 ) )
|
||||||
{
|
{
|
||||||
if ( currtok.Type == TokType::BraceCurly_Open )
|
if ( currtok.Type == TokType::BraceCurly_Open )
|
||||||
level++;
|
level++;
|
||||||
@ -4862,7 +4895,8 @@ namespace gen
|
|||||||
if ( which != Namespace_Body && which != Global_Body && which != Export_Body && which != Extern_Linkage_Body )
|
if ( which != Namespace_Body && which != Global_Body && which != Export_Body && which != Extern_Linkage_Body )
|
||||||
return Code::Invalid;
|
return Code::Invalid;
|
||||||
|
|
||||||
eat( TokType::BraceCurly_Open );
|
if ( which != Global_Body )
|
||||||
|
eat( TokType::BraceCurly_Open );
|
||||||
|
|
||||||
Code
|
Code
|
||||||
result = make_code();
|
result = make_code();
|
||||||
@ -4906,7 +4940,7 @@ namespace gen
|
|||||||
member = parse_struct( toks, context );
|
member = parse_struct( toks, context );
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case TokType::Template:
|
case TokType::Decl_Template:
|
||||||
member = parse_template( toks, context );
|
member = parse_template( toks, context );
|
||||||
break;
|
break;
|
||||||
|
|
||||||
@ -5034,7 +5068,9 @@ namespace gen
|
|||||||
result->add_entry( member );
|
result->add_entry( member );
|
||||||
}
|
}
|
||||||
|
|
||||||
eat( TokType::BraceCurly_Close );
|
if ( which != Global_Body )
|
||||||
|
eat( TokType::BraceCurly_Close );
|
||||||
|
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -5495,14 +5531,23 @@ namespace gen
|
|||||||
|
|
||||||
Token body_str = currtok;
|
Token body_str = currtok;
|
||||||
|
|
||||||
while ( ! check( TokType::BraceCurly_Close ) )
|
s32 level = 0;
|
||||||
|
while ( left && ( currtok.Type != TokType::BraceCurly_Close || level > 0 ) )
|
||||||
{
|
{
|
||||||
|
if ( currtok.Type == TokType::BraceCurly_Open )
|
||||||
|
level++;
|
||||||
|
|
||||||
|
else if ( currtok.Type == TokType::BraceCurly_Close && level > 0 )
|
||||||
|
level--;
|
||||||
|
|
||||||
eat( currtok.Type );
|
eat( currtok.Type );
|
||||||
}
|
}
|
||||||
|
|
||||||
body_str.Length = ( (sptr)prevtok.Text + prevtok.Length ) - (sptr)body_str.Text;
|
body_str.Length = ( (sptr)prevtok.Text + prevtok.Length ) - (sptr)body_str.Text;
|
||||||
|
|
||||||
body = untyped_str( body_str );
|
body = untyped_str( body_str );
|
||||||
|
|
||||||
|
eat( TokType::BraceCurly_Close );
|
||||||
}
|
}
|
||||||
|
|
||||||
Code result = make_code();
|
Code result = make_code();
|
||||||
@ -5515,9 +5560,10 @@ namespace gen
|
|||||||
else
|
else
|
||||||
{
|
{
|
||||||
result->Type = ECode::Operator_Cast_Fwd;
|
result->Type = ECode::Operator_Cast_Fwd;
|
||||||
result->add_entry( type );
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
result->add_entry( type );
|
||||||
|
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -5560,7 +5606,7 @@ namespace gen
|
|||||||
|
|
||||||
// TODO : Parse Module specifier
|
// TODO : Parse Module specifier
|
||||||
|
|
||||||
eat( TokType::Template );
|
eat( TokType::Decl_Template );
|
||||||
|
|
||||||
Code params = parse_params( toks, txt(parse_template), UseTemplateCapture );
|
Code params = parse_params( toks, txt(parse_template), UseTemplateCapture );
|
||||||
if ( params == Code::Invalid )
|
if ( params == Code::Invalid )
|
||||||
@ -6110,281 +6156,7 @@ namespace gen
|
|||||||
sw Length;
|
sw Length;
|
||||||
};
|
};
|
||||||
|
|
||||||
typedef struct TokMapEntry
|
ZPL_TABLE( static, TokMap, tokmap_, TokEntry )
|
||||||
{
|
|
||||||
zpl::u64 key;
|
|
||||||
zpl::sw next;
|
|
||||||
TokEntry value;
|
|
||||||
} TokMapEntry;
|
|
||||||
typedef struct TokMap
|
|
||||||
{
|
|
||||||
zpl::sw *hashes;
|
|
||||||
TokMapEntry *entries;
|
|
||||||
} TokMap;
|
|
||||||
static void tokmap_init(TokMap *h, zpl::AllocatorInfo a);
|
|
||||||
static void tokmap_destroy(TokMap *h);
|
|
||||||
static void tokmap_clear(TokMap *h);
|
|
||||||
static TokEntry *tokmap_get(TokMap *h, zpl::u64 key);
|
|
||||||
static zpl::sw tokmap_slot(TokMap *h, zpl::u64 key);
|
|
||||||
static void tokmap_set(TokMap *h, zpl::u64 key, TokEntry value);
|
|
||||||
static void tokmap_grow(TokMap *h);
|
|
||||||
static void tokmap_rehash(TokMap *h, zpl::sw new_count);
|
|
||||||
static void tokmap_rehash_fast(TokMap *h);
|
|
||||||
static void tokmap_map(TokMap *h, void (*map_proc)(zpl::u64 key, TokEntry value));
|
|
||||||
static void tokmap_map_mut(TokMap *h, void (*map_proc)(zpl::u64 key, TokEntry *value));
|
|
||||||
static void tokmap_remove(TokMap *h, zpl::u64 key);
|
|
||||||
static void tokmap_remove_entry(TokMap *h, zpl::sw idx);
|
|
||||||
;
|
|
||||||
void tokmap_init(TokMap *h, zpl::AllocatorInfo a)
|
|
||||||
{
|
|
||||||
zpl::_array_init_reserve((void **)&(h->hashes), a, (zpl::sw)(sizeof(*(h->hashes))), ((2 * (0) + 8)));
|
|
||||||
zpl::_array_init_reserve((void **)&(h->entries), a, (zpl::sw)(sizeof(*(h->entries))), ((2 * (0) + 8)));
|
|
||||||
}
|
|
||||||
void tokmap_destroy(TokMap *h)
|
|
||||||
{
|
|
||||||
if (h->entries)
|
|
||||||
do
|
|
||||||
{
|
|
||||||
if (h->entries)
|
|
||||||
{
|
|
||||||
zpl::ArrayHeader *_ah = ((zpl::ArrayHeader *)(h->entries) - 1);
|
|
||||||
zpl::free(_ah->allocator, _ah);
|
|
||||||
}
|
|
||||||
} while (0);
|
|
||||||
if (h->hashes)
|
|
||||||
do
|
|
||||||
{
|
|
||||||
if (h->hashes)
|
|
||||||
{
|
|
||||||
zpl::ArrayHeader *_ah = ((zpl::ArrayHeader *)(h->hashes) - 1);
|
|
||||||
zpl::free(_ah->allocator, _ah);
|
|
||||||
}
|
|
||||||
} while (0);
|
|
||||||
}
|
|
||||||
void tokmap_clear(TokMap *h)
|
|
||||||
{
|
|
||||||
for (int i = 0; i < (((zpl::ArrayHeader *)(h->hashes) - 1)->count); i++)
|
|
||||||
h->hashes[i] = -1;
|
|
||||||
do
|
|
||||||
{
|
|
||||||
((zpl::ArrayHeader *)(h->entries) - 1)->count = 0;
|
|
||||||
} while (0);
|
|
||||||
}
|
|
||||||
zpl::sw tokmap_slot(TokMap *h, zpl::u64 key)
|
|
||||||
{
|
|
||||||
for (zpl::sw i = 0; i < (((zpl::ArrayHeader *)(h->entries) - 1)->count); i++)
|
|
||||||
{
|
|
||||||
if (h->entries[i].key == key)
|
|
||||||
{
|
|
||||||
return i;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
static zpl::sw tokmap__add_entry(TokMap *h, zpl::u64 key)
|
|
||||||
{
|
|
||||||
zpl::sw index;
|
|
||||||
TokMapEntry e = {0};
|
|
||||||
e.key = key;
|
|
||||||
e.next = -1;
|
|
||||||
index = (((zpl::ArrayHeader *)(h->entries) - 1)->count);
|
|
||||||
(zpl::_array_append_helper((void **)&(h->entries)) && (((h->entries)[(((zpl::ArrayHeader *)(h->entries) - 1)->count)++] = (e)), true));
|
|
||||||
return index;
|
|
||||||
}
|
|
||||||
static zpl::hash_table_find_result tokmap__find(TokMap *h, zpl::u64 key)
|
|
||||||
{
|
|
||||||
zpl::hash_table_find_result r = {-1, -1, -1};
|
|
||||||
if ((((zpl::ArrayHeader *)(h->hashes) - 1)->count) > 0)
|
|
||||||
{
|
|
||||||
r.hash_index = key % (((zpl::ArrayHeader *)(h->hashes) - 1)->count);
|
|
||||||
r.entry_index = h->hashes[r.hash_index];
|
|
||||||
while (r.entry_index >= 0)
|
|
||||||
{
|
|
||||||
if (h->entries[r.entry_index].key == key)
|
|
||||||
return r;
|
|
||||||
r.entry_prev = r.entry_index;
|
|
||||||
r.entry_index = h->entries[r.entry_index].next;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return r;
|
|
||||||
}
|
|
||||||
static zpl::b32 tokmap__full(TokMap *h) { return 0.75f * (((zpl::ArrayHeader *)(h->hashes) - 1)->count) < (((zpl::ArrayHeader *)(h->entries) - 1)->count); }
|
|
||||||
void tokmap_grow(TokMap *h)
|
|
||||||
{
|
|
||||||
zpl::sw new_count = (2 * ((((zpl::ArrayHeader *)(h->entries) - 1)->count)) + 8);
|
|
||||||
tokmap_rehash(h, new_count);
|
|
||||||
}
|
|
||||||
void tokmap_rehash(TokMap *h, zpl::sw new_count)
|
|
||||||
{
|
|
||||||
zpl::sw i, j;
|
|
||||||
TokMap nh = {0};
|
|
||||||
tokmap_init(&nh, (((zpl::ArrayHeader *)(h->hashes) - 1)->allocator));
|
|
||||||
zpl::_array_resize((void **)&(nh.hashes), (new_count));
|
|
||||||
zpl::_array_reserve((void **)&(nh.entries), ((((zpl::ArrayHeader *)(h->entries) - 1)->count)));
|
|
||||||
for (i = 0; i < new_count; i++)
|
|
||||||
nh.hashes[i] = -1;
|
|
||||||
for (i = 0; i < (((zpl::ArrayHeader *)(h->entries) - 1)->count); i++)
|
|
||||||
{
|
|
||||||
TokMapEntry *e;
|
|
||||||
zpl::hash_table_find_result fr;
|
|
||||||
if ((((zpl::ArrayHeader *)(nh.hashes) - 1)->count) == 0)
|
|
||||||
tokmap_grow(&nh);
|
|
||||||
e = &h->entries[i];
|
|
||||||
fr = tokmap__find(&nh, e->key);
|
|
||||||
j = tokmap__add_entry(&nh, e->key);
|
|
||||||
if (fr.entry_prev < 0)
|
|
||||||
nh.hashes[fr.hash_index] = j;
|
|
||||||
else
|
|
||||||
nh.entries[fr.entry_prev].next = j;
|
|
||||||
nh.entries[j].next = fr.entry_index;
|
|
||||||
nh.entries[j].value = e->value;
|
|
||||||
}
|
|
||||||
tokmap_destroy(h);
|
|
||||||
h->hashes = nh.hashes;
|
|
||||||
h->entries = nh.entries;
|
|
||||||
}
|
|
||||||
void tokmap_rehash_fast(TokMap *h)
|
|
||||||
{
|
|
||||||
zpl::sw i;
|
|
||||||
for (i = 0; i < (((zpl::ArrayHeader *)(h->entries) - 1)->count); i++)
|
|
||||||
h->entries[i].next = -1;
|
|
||||||
for (i = 0; i < (((zpl::ArrayHeader *)(h->hashes) - 1)->count); i++)
|
|
||||||
h->hashes[i] = -1;
|
|
||||||
for (i = 0; i < (((zpl::ArrayHeader *)(h->entries) - 1)->count); i++)
|
|
||||||
{
|
|
||||||
TokMapEntry *e;
|
|
||||||
zpl::hash_table_find_result fr;
|
|
||||||
e = &h->entries[i];
|
|
||||||
fr = tokmap__find(h, e->key);
|
|
||||||
if (fr.entry_prev < 0)
|
|
||||||
h->hashes[fr.hash_index] = i;
|
|
||||||
else
|
|
||||||
h->entries[fr.entry_prev].next = i;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
TokEntry *tokmap_get(TokMap *h, zpl::u64 key)
|
|
||||||
{
|
|
||||||
zpl::sw index = tokmap__find(h, key).entry_index;
|
|
||||||
if (index >= 0)
|
|
||||||
return &h->entries[index].value;
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
void tokmap_remove(TokMap *h, zpl::u64 key)
|
|
||||||
{
|
|
||||||
zpl::hash_table_find_result fr = tokmap__find(h, key);
|
|
||||||
if (fr.entry_index >= 0)
|
|
||||||
{
|
|
||||||
do
|
|
||||||
{
|
|
||||||
zpl::ArrayHeader *_ah = ((zpl::ArrayHeader *)(h->entries) - 1);
|
|
||||||
do
|
|
||||||
{
|
|
||||||
if (!(fr.entry_index < _ah->count))
|
|
||||||
{
|
|
||||||
zpl::assert_handler("fr.entry_index < _ah->count", "C:\\projects\\gencpp\\project\\gen.cpp", (zpl::s64)6113, 0);
|
|
||||||
__debugbreak();
|
|
||||||
}
|
|
||||||
} while (0);
|
|
||||||
zpl::mem_move(h->entries + fr.entry_index, h->entries + fr.entry_index + 1, (zpl::sw)(sizeof(h->entries[0])) * (_ah->count - fr.entry_index - 1));
|
|
||||||
--_ah->count;
|
|
||||||
} while (0);
|
|
||||||
tokmap_rehash_fast(h);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
void tokmap_remove_entry(TokMap *h, zpl::sw idx)
|
|
||||||
{
|
|
||||||
do
|
|
||||||
{
|
|
||||||
zpl::ArrayHeader *_ah = ((zpl::ArrayHeader *)(h->entries) - 1);
|
|
||||||
do
|
|
||||||
{
|
|
||||||
if (!(idx < _ah->count))
|
|
||||||
{
|
|
||||||
zpl::assert_handler("idx < _ah->count", "C:\\projects\\gencpp\\project\\gen.cpp", (zpl::s64)6113, 0);
|
|
||||||
__debugbreak();
|
|
||||||
}
|
|
||||||
} while (0);
|
|
||||||
zpl::mem_move(h->entries + idx, h->entries + idx + 1, (zpl::sw)(sizeof(h->entries[0])) * (_ah->count - idx - 1));
|
|
||||||
--_ah->count;
|
|
||||||
} while (0);
|
|
||||||
}
|
|
||||||
void tokmap_map(TokMap *h, void (*map_proc)(zpl::u64 key, TokEntry value))
|
|
||||||
{
|
|
||||||
do
|
|
||||||
{
|
|
||||||
if (!((h) != 0))
|
|
||||||
{
|
|
||||||
zpl::assert_handler("( h ) != NULL", "C:\\projects\\gencpp\\project\\gen.cpp", (zpl::s64)6113, "h"
|
|
||||||
" must not be NULL");
|
|
||||||
__debugbreak();
|
|
||||||
}
|
|
||||||
} while (0);
|
|
||||||
do
|
|
||||||
{
|
|
||||||
if (!((map_proc) != 0))
|
|
||||||
{
|
|
||||||
zpl::assert_handler("( map_proc ) != NULL", "C:\\projects\\gencpp\\project\\gen.cpp", (zpl::s64)6113, "map_proc"
|
|
||||||
" must not be NULL");
|
|
||||||
__debugbreak();
|
|
||||||
}
|
|
||||||
} while (0);
|
|
||||||
for (zpl::sw i = 0; i < (((zpl::ArrayHeader *)(h->entries) - 1)->count); ++i)
|
|
||||||
{
|
|
||||||
map_proc(h->entries[i].key, h->entries[i].value);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
void tokmap_map_mut(TokMap *h, void (*map_proc)(zpl::u64 key, TokEntry *value))
|
|
||||||
{
|
|
||||||
do
|
|
||||||
{
|
|
||||||
if (!((h) != 0))
|
|
||||||
{
|
|
||||||
zpl::assert_handler("( h ) != NULL", "C:\\projects\\gencpp\\project\\gen.cpp", (zpl::s64)6113, "h"
|
|
||||||
" must not be NULL");
|
|
||||||
__debugbreak();
|
|
||||||
}
|
|
||||||
} while (0);
|
|
||||||
do
|
|
||||||
{
|
|
||||||
if (!((map_proc) != 0))
|
|
||||||
{
|
|
||||||
zpl::assert_handler("( map_proc ) != NULL", "C:\\projects\\gencpp\\project\\gen.cpp", (zpl::s64)6113, "map_proc"
|
|
||||||
" must not be NULL");
|
|
||||||
__debugbreak();
|
|
||||||
}
|
|
||||||
} while (0);
|
|
||||||
for (zpl::sw i = 0; i < (((zpl::ArrayHeader *)(h->entries) - 1)->count); ++i)
|
|
||||||
{
|
|
||||||
map_proc(h->entries[i].key, &h->entries[i].value);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
void tokmap_set(TokMap *h, zpl::u64 key, TokEntry value)
|
|
||||||
{
|
|
||||||
zpl::sw index;
|
|
||||||
zpl::hash_table_find_result fr;
|
|
||||||
if ((((zpl::ArrayHeader *)(h->hashes) - 1)->count) == 0)
|
|
||||||
tokmap_grow(h);
|
|
||||||
fr = tokmap__find(h, key);
|
|
||||||
if (fr.entry_index >= 0)
|
|
||||||
{
|
|
||||||
index = fr.entry_index;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
index = tokmap__add_entry(h, key);
|
|
||||||
if (fr.entry_prev >= 0)
|
|
||||||
{
|
|
||||||
h->entries[fr.entry_prev].next = index;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
h->hashes[fr.hash_index] = index;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
h->entries[index].value = value;
|
|
||||||
if (tokmap__full(h))
|
|
||||||
tokmap_grow(h);
|
|
||||||
};
|
|
||||||
|
|
||||||
sw token_fmt_va( char* buf, uw buf_size, char const* fmt, s32 num_tokens, va_list va )
|
sw token_fmt_va( char* buf, uw buf_size, char const* fmt, s32 num_tokens, va_list va )
|
||||||
{
|
{
|
||||||
@ -6478,7 +6250,7 @@ namespace gen
|
|||||||
|
|
||||||
tokmap_clear( & tok_map );
|
tokmap_clear( & tok_map );
|
||||||
|
|
||||||
sw result = buf_size - remaining;
|
sw result = buf_size - remaining + 1;
|
||||||
|
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
@ -50,7 +50,7 @@ $path_scripts = Join-Path $path_root scripts
|
|||||||
Pop-Location
|
Pop-Location
|
||||||
|
|
||||||
# Test NonParsed
|
# Test NonParsed
|
||||||
if ($true) {
|
if ($false) {
|
||||||
$gencpp = Join-Path $path_gen_build gencpp.exe
|
$gencpp = Join-Path $path_gen_build gencpp.exe
|
||||||
|
|
||||||
Push-location $path_gen
|
Push-location $path_gen
|
||||||
|
@ -330,7 +330,7 @@ u32 gen_array_file()
|
|||||||
{
|
{
|
||||||
Builder
|
Builder
|
||||||
gen_array_file;
|
gen_array_file;
|
||||||
gen_array_file.open( "array.gen.hpp" );
|
gen_array_file.open( "array.NonParsed.gen.hpp" );
|
||||||
|
|
||||||
Code include_zpl = def_include( StrC::from("Bloat.hpp") );
|
Code include_zpl = def_include( StrC::from("Bloat.hpp") );
|
||||||
gen_array_file.print( include_zpl );
|
gen_array_file.print( include_zpl );
|
||||||
|
@ -235,7 +235,7 @@ u32 gen_buffer_file()
|
|||||||
{
|
{
|
||||||
Builder
|
Builder
|
||||||
gen_buffer_file;
|
gen_buffer_file;
|
||||||
gen_buffer_file.open( "buffer.gen.hpp" );
|
gen_buffer_file.open( "buffer.NonParsed.gen.hpp" );
|
||||||
|
|
||||||
gen_buffer_file.print( def_include( StrC::from("Bloat.hpp")) );
|
gen_buffer_file.print( def_include( StrC::from("Bloat.hpp")) );
|
||||||
gen_buffer_file.print( gen__buffer_base() );
|
gen_buffer_file.print( gen__buffer_base() );
|
||||||
|
@ -431,7 +431,7 @@ u32 gen_hashtable_file()
|
|||||||
{
|
{
|
||||||
Builder
|
Builder
|
||||||
gen_buffer_file;
|
gen_buffer_file;
|
||||||
gen_buffer_file.open( "hashtable.gen.hpp" );
|
gen_buffer_file.open( "hashtable.NonParsed.gen.hpp" );
|
||||||
|
|
||||||
gen_buffer_file.print( def_include( StrC::from("Bloat.hpp")) );
|
gen_buffer_file.print( def_include( StrC::from("Bloat.hpp")) );
|
||||||
gen_buffer_file.print( def_include( StrC::from("Array.NonParsed.hpp")) );
|
gen_buffer_file.print( def_include( StrC::from("Array.NonParsed.hpp")) );
|
||||||
|
@ -194,7 +194,7 @@ u32 gen_ring_file()
|
|||||||
{
|
{
|
||||||
Builder
|
Builder
|
||||||
gen_ring_file;
|
gen_ring_file;
|
||||||
gen_ring_file.open( "ring.gen.hpp" );
|
gen_ring_file.open( "ring.NonParsed.gen.hpp" );
|
||||||
|
|
||||||
gen_ring_file.print( def_include( StrC::from("Bloat.hpp")) );
|
gen_ring_file.print( def_include( StrC::from("Bloat.hpp")) );
|
||||||
gen_ring_file.print( def_include( StrC::from("buffer.gen.hpp")) );
|
gen_ring_file.print( def_include( StrC::from("buffer.gen.hpp")) );
|
||||||
|
@ -39,7 +39,7 @@ Code gen__array( StrC type, sw type_size )
|
|||||||
using Header = ArrayHeader;
|
using Header = ArrayHeader;
|
||||||
using Type = <type>;
|
using Type = <type>;
|
||||||
|
|
||||||
constexpr auto grow_formula = &array_glow_formula;
|
static constexpr auto grow_formula = &array_grow_formula;
|
||||||
|
|
||||||
static
|
static
|
||||||
<ArrayType> init( AllocatorInfo allocator )
|
<ArrayType> init( AllocatorInfo allocator )
|
||||||
@ -211,8 +211,8 @@ Code gen__array( StrC type, sw type_size )
|
|||||||
),
|
),
|
||||||
// Tokens
|
// Tokens
|
||||||
2
|
2
|
||||||
, "ArrayType", name
|
, "ArrayType", (char const*) name
|
||||||
, "type", type
|
, "type", (char const*) type
|
||||||
));
|
));
|
||||||
|
|
||||||
return array;
|
return array;
|
||||||
@ -254,7 +254,7 @@ u32 gen_array_file()
|
|||||||
{
|
{
|
||||||
Builder
|
Builder
|
||||||
gen_array_file;
|
gen_array_file;
|
||||||
gen_array_file.open( "array.gen.hpp" );
|
gen_array_file.open( "array.Parsed.gen.hpp" );
|
||||||
|
|
||||||
Code include_zpl = def_include( StrC::from("Bloat.hpp") );
|
Code include_zpl = def_include( StrC::from("Bloat.hpp") );
|
||||||
gen_array_file.print( include_zpl );
|
gen_array_file.print( include_zpl );
|
||||||
|
@ -17,7 +17,7 @@ int gen_main()
|
|||||||
Memory::setup();
|
Memory::setup();
|
||||||
gen::init();
|
gen::init();
|
||||||
|
|
||||||
gen_sanity();
|
// gen_sanity();
|
||||||
|
|
||||||
gen_array( u8 );
|
gen_array( u8 );
|
||||||
// gen_array( sw );
|
// gen_array( sw );
|
||||||
|
Loading…
Reference in New Issue
Block a user