Finished implementing the Upfront construcotrs, started to flesh out the incremental constructors.

This commit is contained in:
Edward R. Gonzalez 2023-04-11 22:18:02 -04:00
parent 6ca30828c0
commit d167f74243
2 changed files with 869 additions and 823 deletions

File diff suppressed because it is too large Load Diff

View File

@ -581,8 +581,7 @@ namespace gen
# define Thread_Local_Code "NOT DEFINED" # define Thread_Local_Code "NOT DEFINED"
# endif # endif
# define Define_Specifiers \
#define Define_Specifiers \
Entry( API_Import, API_Export_Code ) \ Entry( API_Import, API_Export_Code ) \
Entry( API_Export, API_Import_Code ) \ Entry( API_Export, API_Import_Code ) \
Entry( Attribute, " You cannot stringize an attribute this way" ) \ Entry( Attribute, " You cannot stringize an attribute this way" ) \
@ -632,6 +631,7 @@ namespace gen
return lookup[ specifier ]; return lookup[ specifier ];
} }
inline
Type to_type( char const* str, s32 length ) Type to_type( char const* str, s32 length )
{ {
local_persist local_persist
@ -689,7 +689,6 @@ namespace gen
// Adds and checks entries to see if they are valid additions the type of ast. // Adds and checks entries to see if they are valid additions the type of ast.
bool add( AST* other ); bool add( AST* other );
inline
void add_entry( AST* other ); void add_entry( AST* other );
forceinline forceinline
@ -723,6 +722,8 @@ namespace gen
// Parameter // Parameter
bool add_param( AST* type, s32 length, char const* name );
forceinline forceinline
AST* get_param( s32 index ) AST* get_param( s32 index )
{ {
@ -745,6 +746,34 @@ namespace gen
return Entries[0]; return Entries[0];
} }
// Specifiers
inline
bool add_specifier( SpecifierT spec )
{
if ( StaticIndex == AST::ArrSpecs_Cap )
{
log_failure("AST::add_specifier: Attempted to add over %d specifiers to a specifiers AST!", AST::ArrSpecs_Cap );
return false;
}
ArrSpecs[ StaticIndex ] = spec;
StaticIndex++;
return true;
}
inline
bool has_specifier( SpecifierT spec )
{
for ( s32 Index = 0; Index < StaticIndex; Index++ )
{
if ( ArrSpecs[StaticIndex] == spec )
return true;
}
return false;
}
// Typename // Typename
forceinline forceinline
@ -765,11 +794,6 @@ namespace gen
return Entries[0]; return Entries[0];
} }
// AST*& operator=(AST* const& b)
// {
// }
// Serialization // Serialization
forceinline forceinline
@ -805,8 +829,8 @@ namespace gen
String to_string() const; String to_string() const;
# pragma endregion Member Functions # pragma endregion Member Functions
constexpr constexpr static
static uw ArrS_Cap = uw ArrS_Cap =
( AST_POD_Size ( AST_POD_Size
- sizeof(AST*) - sizeof(AST*)
- sizeof(StringCached) * 2 - sizeof(StringCached) * 2
@ -816,14 +840,15 @@ namespace gen
- sizeof(u8) * 7 ) - sizeof(u8) * 7 )
/ sizeof(AST*); / sizeof(AST*);
// SpecifierT Specifiers[] \ constexpr static
uw ArrSpecs_Cap = ArrS_Cap * (sizeof(AST*) / sizeof(SpecifierT));
// Size : 256 bytes
# define Using_Code_POD \ # define Using_Code_POD \
union { \ union { \
AST* ArrStatic[AST::ArrS_Cap]; \ AST* ArrStatic[AST::ArrS_Cap]; \
Array(AST*) Entries; \ Array(AST*) Entries; \
StringCached Content; \ StringCached Content; \
SpecifierT ArrSpecs[AST::ArrSpecs_Cap]; \
}; \ }; \
AST* Parent; \ AST* Parent; \
StringCached Name; \ StringCached Name; \
@ -838,7 +863,6 @@ namespace gen
Using_Code_POD Using_Code_POD
}; };
struct CodePOD struct CodePOD
{ {
Using_Code_POD Using_Code_POD
@ -1051,6 +1075,7 @@ namespace gen
Code def_specifier ( SpecifierT specifier ); Code def_specifier ( SpecifierT specifier );
Code def_struct ( s32 length, char const* name, Code parent = NoCode, Code specifiers = NoCode, Code body = NoCode ); Code def_struct ( s32 length, char const* name, Code parent = NoCode, Code specifiers = NoCode, Code body = NoCode );
Code def_typedef ( s32 length, char const* name, Code type );
Code def_type ( s32 length, char const* name, Code specifiers = NoCode ); Code def_type ( s32 length, char const* name, Code specifiers = NoCode );
Code def_using ( s32 length, char const* name, Code type = NoCode, UsingT specifier = UsingRegular ); Code def_using ( s32 length, char const* name, Code type = NoCode, UsingT specifier = UsingRegular );
@ -1427,13 +1452,11 @@ namespace gen
} }
#pragma endregion Constants #pragma endregion Constants
// end: gen_time
#endif
#pragma region Inlines #pragma region Inlines
namespace gen namespace gen
{ {
inline void AST::add_entry( AST* other ) inline
void AST::add_entry( AST* other )
{ {
AST* to_add = other->Parent ? AST* to_add = other->Parent ?
other->duplicate() : other; other->duplicate() : other;
@ -1465,8 +1488,48 @@ namespace gen
to_add->Parent = this; to_add->Parent = this;
} }
inline
bool AST::add_param( AST* type, s32 length, char const* name )
{
if ( length <= 0 )
{
log_failure( "gen::AST::add_param: Invalid name length provided - %d", length );
return Code::Invalid;
}
if ( name == nullptr )
{
log_failure( "gen::AST::add_param: name is null");
return Code::Invalid;
}
s32
score = 0;
score += Name == nullptr;
score += Entries[0] == nullptr;
if ( score == 1 )
{
log_failure("gen::AST::add_param: this AST has bad data - %s", debug_str() );
return false;
}
else if ( score == 2)
{
Name = name;
Entries[0] = type;
return true;
}
Code
result = make_code();
result->Type = ECode::Parameters;
result->add_entry( result );
return true;
}
} }
#pragma endregion Inlines #pragma endregion Inlines
#pragma region Undefines // end: gen_time
#pragma endregion Undefines #endif