2023-08-28 20:46:50 -07:00
|
|
|
#ifdef GEN_INTELLISENSE_DIRECTIVES
|
2023-08-21 17:30:13 -07:00
|
|
|
#pragma once
|
2023-08-21 20:02:20 -07:00
|
|
|
#include "types.hpp"
|
2023-08-21 20:28:39 -07:00
|
|
|
#include "gen/ecode.hpp"
|
|
|
|
#include "gen/eoperator.hpp"
|
|
|
|
#include "gen/especifier.hpp"
|
2023-08-28 20:46:50 -07:00
|
|
|
#endif
|
2023-08-21 17:30:13 -07:00
|
|
|
|
2023-08-03 08:01:43 -07:00
|
|
|
struct AST;
|
|
|
|
struct AST_Body;
|
|
|
|
struct AST_Attributes;
|
|
|
|
struct AST_Comment;
|
2023-08-07 00:10:45 -07:00
|
|
|
struct AST_Constructor;
|
2023-11-21 20:36:56 -08:00
|
|
|
// struct AST_BaseClass;
|
2023-08-03 08:01:43 -07:00
|
|
|
struct AST_Class;
|
|
|
|
struct AST_Define;
|
2023-08-07 00:10:45 -07:00
|
|
|
struct AST_Destructor;
|
2023-08-03 08:01:43 -07:00
|
|
|
struct AST_Enum;
|
|
|
|
struct AST_Exec;
|
|
|
|
struct AST_Extern;
|
|
|
|
struct AST_Include;
|
|
|
|
struct AST_Friend;
|
|
|
|
struct AST_Fn;
|
|
|
|
struct AST_Module;
|
2023-08-06 11:58:43 -07:00
|
|
|
struct AST_NS;
|
2023-08-03 08:01:43 -07:00
|
|
|
struct AST_Operator;
|
|
|
|
struct AST_OpCast;
|
|
|
|
struct AST_Param;
|
|
|
|
struct AST_Pragma;
|
|
|
|
struct AST_PreprocessCond;
|
|
|
|
struct AST_Specifiers;
|
2023-11-21 17:07:49 -08:00
|
|
|
|
|
|
|
#if GEN_EXECUTION_EXPRESSION_SUPPORT
|
|
|
|
struct AST_Expr;
|
|
|
|
struct AST_Expr_Assign;
|
|
|
|
struct AST_Expr_Alignof;
|
|
|
|
struct AST_Expr_Binary;
|
|
|
|
struct AST_Expr_CStyleCast;
|
|
|
|
struct AST_Expr_FunctionalCast;
|
|
|
|
struct AST_Expr_CppCast;
|
|
|
|
struct AST_Expr_ProcCall;
|
|
|
|
struct AST_Expr_Decltype;
|
|
|
|
struct AST_Expr_Comma; // TODO(Ed) : This is a binary op not sure if it needs its own AST...
|
|
|
|
struct AST_Expr_AMS; // Access Member Symbol
|
|
|
|
struct AST_Expr_Sizeof;
|
|
|
|
struct AST_Expr_Subscript;
|
|
|
|
struct AST_Expr_Ternary;
|
|
|
|
struct AST_Expr_UnaryPrefix;
|
|
|
|
struct AST_Expr_UnaryPostfix;
|
|
|
|
struct AST_Expr_Element;
|
|
|
|
|
|
|
|
struct AST_Stmt;
|
|
|
|
struct AST_Stmt_Break;
|
|
|
|
struct AST_Stmt_Case;
|
|
|
|
struct AST_Stmt_Continue;
|
|
|
|
struct AST_Stmt_Decl;
|
|
|
|
struct AST_Stmt_Do;
|
|
|
|
struct AST_Stmt_Expr; // TODO(Ed) : Is this distinction needed? (Should it be a flag instead?)
|
|
|
|
struct AST_Stmt_Else;
|
|
|
|
struct AST_Stmt_If;
|
|
|
|
struct AST_Stmt_For;
|
|
|
|
struct AST_Stmt_Goto;
|
|
|
|
struct AST_Stmt_Label;
|
|
|
|
struct AST_Stmt_Switch;
|
|
|
|
struct AST_Stmt_While;
|
|
|
|
#endif
|
|
|
|
|
2023-08-03 08:01:43 -07:00
|
|
|
struct AST_Struct;
|
|
|
|
struct AST_Template;
|
|
|
|
struct AST_Type;
|
|
|
|
struct AST_Typedef;
|
|
|
|
struct AST_Union;
|
|
|
|
struct AST_Using;
|
|
|
|
struct AST_Var;
|
|
|
|
|
2024-12-01 22:56:49 -08:00
|
|
|
#if GEN_COMPILER_C
|
|
|
|
#define Define_Code(Type) typedef AST_##Type* Code##Type
|
|
|
|
#else
|
|
|
|
#define Define_Code(Type) struct Code##Type
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if GEN_COMPILER_C
|
|
|
|
typedef AST* code;
|
|
|
|
#else
|
2023-08-03 08:01:43 -07:00
|
|
|
struct Code;
|
2024-12-01 22:56:49 -08:00
|
|
|
#endif
|
|
|
|
Define_Code(Body);
|
2023-08-03 08:01:43 -07:00
|
|
|
// These are to offer ease of use and optionally strong type safety for the AST.
|
2024-12-01 22:56:49 -08:00
|
|
|
Define_Code(Attributes);
|
2023-11-21 20:36:56 -08:00
|
|
|
// struct CodeBaseClass;
|
2024-12-01 22:56:49 -08:00
|
|
|
Define_Code(Comment);
|
|
|
|
Define_Code(Class);
|
|
|
|
Define_Code(Constructor);
|
|
|
|
Define_Code(Define);
|
|
|
|
Define_Code(Destructor);
|
|
|
|
Define_Code(Enum);
|
|
|
|
Define_Code(Exec);
|
|
|
|
Define_Code(Extern);
|
|
|
|
Define_Code(Include);
|
|
|
|
Define_Code(Friend);
|
|
|
|
Define_Code(Fn);
|
|
|
|
Define_Code(Module);
|
|
|
|
Define_Code(NS);
|
|
|
|
Define_Code(Operator);
|
|
|
|
Define_Code(OpCast);
|
|
|
|
Define_Code(Param);
|
|
|
|
Define_Code(PreprocessCond);
|
|
|
|
Define_Code(Pragma);
|
|
|
|
Define_Code(Specifiers);
|
2023-11-21 17:07:49 -08:00
|
|
|
|
|
|
|
#if GEN_EXECUTION_EXPRESSION_SUPPORT
|
2024-12-01 22:56:49 -08:00
|
|
|
Define_Code(Expr);
|
|
|
|
Define_Code(Expr_Assign);
|
|
|
|
Define_Code(Expr_Alignof);
|
|
|
|
Define_Code(Expr_Binary);
|
|
|
|
Define_Code(Expr_CStyleCast);
|
|
|
|
Define_Code(Expr_FunctionalCast);
|
|
|
|
Define_Code(Expr_CppCast);
|
|
|
|
Define_Code(Expr_Element);
|
|
|
|
Define_Code(Expr_ProcCall);
|
|
|
|
Define_Code(Expr_Decltype);
|
|
|
|
Define_Code(Expr_Comma);
|
|
|
|
Define_Code(Expr_AMS); // Access Member Symbol
|
|
|
|
Define_Code(Expr_Sizeof);
|
|
|
|
Define_Code(Expr_Subscript);
|
|
|
|
Define_Code(Expr_Ternary);
|
|
|
|
Define_Code(Expr_UnaryPrefix);
|
|
|
|
Define_Code(Expr_UnaryPostfix);
|
|
|
|
|
|
|
|
Define_Code(Stmt);
|
|
|
|
Define_Code(Stmt_Break);
|
|
|
|
Define_Code(Stmt_Case);
|
|
|
|
Define_Code(Stmt_Continue);
|
|
|
|
Define_Code(Stmt_Decl);
|
|
|
|
Define_Code(Stmt_Do);
|
|
|
|
Define_Code(Stmt_Expr);
|
|
|
|
Define_Code(Stmt_Else);
|
|
|
|
Define_Code(Stmt_If);
|
|
|
|
Define_Code(Stmt_For);
|
|
|
|
Define_Code(Stmt_Goto);
|
|
|
|
Define_Code(Stmt_Label);
|
|
|
|
Define_Code(Stmt_Switch);
|
|
|
|
Define_Code(Stmt_While);
|
2023-11-21 17:07:49 -08:00
|
|
|
#endif
|
|
|
|
|
2024-12-01 22:56:49 -08:00
|
|
|
Define_Code(Struct);
|
|
|
|
Define_Code(Template);
|
|
|
|
Define_Code(Type);
|
|
|
|
Define_Code(Typedef);
|
|
|
|
Define_Code(Union);
|
|
|
|
Define_Code(Using);
|
|
|
|
Define_Code(Var);
|
|
|
|
#undef Define_Code
|
2023-08-03 08:01:43 -07:00
|
|
|
|
2023-11-21 17:07:49 -08:00
|
|
|
namespace parser
|
2023-09-25 13:42:29 -07:00
|
|
|
{
|
|
|
|
struct Token;
|
|
|
|
}
|
2023-09-25 09:12:11 -07:00
|
|
|
|
2024-12-01 23:38:55 -08:00
|
|
|
#if ! GEN_COMPILER_C
|
|
|
|
template< class Type> forceinline Type tmpl_cast( Code self ) { return * rcast( Type*, & self ); }
|
2024-12-01 15:50:37 -08:00
|
|
|
#endif
|
|
|
|
|
2024-12-01 21:03:38 -08:00
|
|
|
char const* debug_str (Code code);
|
|
|
|
Code duplicate (Code code);
|
|
|
|
bool is_equal (Code code, Code other);
|
|
|
|
bool is_body (Code code);
|
|
|
|
bool is_valid (Code code);
|
|
|
|
void set_global(Code code);
|
|
|
|
String to_string (Code code);
|
|
|
|
|
2024-12-01 22:56:49 -08:00
|
|
|
#if ! GEN_COMPILER_C
|
2023-08-03 08:01:43 -07:00
|
|
|
/*
|
|
|
|
AST* wrapper
|
|
|
|
- Not constantly have to append the '*' as this is written often..
|
|
|
|
- Allows for implicit conversion to any of the ASTs (raw or filtered).
|
|
|
|
*/
|
|
|
|
struct Code
|
|
|
|
{
|
2024-12-01 21:16:11 -08:00
|
|
|
AST* ast;
|
2023-08-03 08:01:43 -07:00
|
|
|
|
2024-12-01 22:56:49 -08:00
|
|
|
# define Using_Code( Typename ) \
|
|
|
|
char const* debug_str() { return GEN_NS debug_str(* this); } \
|
|
|
|
Code duplicate() { return GEN_NS duplicate(* this); } \
|
2024-12-01 21:34:40 -08:00
|
|
|
bool is_equal( Code other ) { return GEN_NS is_equal(* this, other); } \
|
2024-12-01 22:56:49 -08:00
|
|
|
bool is_body() { return GEN_NS is_body(* this); } \
|
|
|
|
bool is_valid() { return GEN_NS is_valid(* this); } \
|
|
|
|
void set_global() { return GEN_NS set_global(* this); }
|
|
|
|
|
|
|
|
# define Using_CodeOps( Typename ) \
|
|
|
|
Typename& operator = ( AST* other ); \
|
|
|
|
Typename& operator = ( Code other ); \
|
2024-12-01 21:03:38 -08:00
|
|
|
bool operator ==( Code other ) { return (AST*)ast == other.ast; } \
|
|
|
|
bool operator !=( Code other ) { return (AST*)ast != other.ast; } \
|
2023-08-03 08:01:43 -07:00
|
|
|
operator bool();
|
|
|
|
|
2024-12-01 23:38:55 -08:00
|
|
|
#if GEN_SUPPORT_CPP_MEMBER_FEATURES
|
2023-08-03 08:01:43 -07:00
|
|
|
Using_Code( Code );
|
2024-12-01 22:56:49 -08:00
|
|
|
String to_string() { return GEN_NS to_string(* this); }
|
|
|
|
#endif
|
|
|
|
|
|
|
|
Using_CodeOps( Code );
|
2023-08-03 08:01:43 -07:00
|
|
|
|
2024-12-01 22:56:49 -08:00
|
|
|
AST* operator ->() { return ast; }
|
2023-08-03 08:01:43 -07:00
|
|
|
Code& operator ++();
|
2023-11-20 12:09:01 -08:00
|
|
|
|
2023-11-19 17:34:46 -08:00
|
|
|
// TODO(Ed) : Remove this overload.
|
2023-11-20 12:09:01 -08:00
|
|
|
auto& operator*()
|
|
|
|
{
|
|
|
|
local_persist thread_local
|
|
|
|
Code NullRef = { nullptr };
|
|
|
|
|
|
|
|
if ( ast == nullptr )
|
|
|
|
return NullRef;
|
|
|
|
|
|
|
|
return *this;
|
|
|
|
}
|
2023-08-03 08:01:43 -07:00
|
|
|
|
|
|
|
#ifdef GEN_ENFORCE_STRONG_CODE_TYPES
|
|
|
|
# define operator explicit operator
|
|
|
|
#endif
|
2023-11-21 20:36:56 -08:00
|
|
|
operator CodeBody() const;
|
2023-08-03 08:01:43 -07:00
|
|
|
operator CodeAttributes() const;
|
2023-11-21 20:36:56 -08:00
|
|
|
// operator CodeBaseClass() const;
|
2023-08-03 08:01:43 -07:00
|
|
|
operator CodeComment() const;
|
|
|
|
operator CodeClass() const;
|
2023-11-21 20:36:56 -08:00
|
|
|
operator CodeConstructor() const;
|
2023-08-03 08:01:43 -07:00
|
|
|
operator CodeDefine() const;
|
2023-11-21 20:36:56 -08:00
|
|
|
operator CodeDestructor() const;
|
2023-08-03 08:01:43 -07:00
|
|
|
operator CodeExec() const;
|
|
|
|
operator CodeEnum() const;
|
|
|
|
operator CodeExtern() const;
|
|
|
|
operator CodeInclude() const;
|
|
|
|
operator CodeFriend() const;
|
|
|
|
operator CodeFn() const;
|
|
|
|
operator CodeModule() const;
|
2023-08-06 11:58:43 -07:00
|
|
|
operator CodeNS() const;
|
2023-08-03 08:01:43 -07:00
|
|
|
operator CodeOperator() const;
|
|
|
|
operator CodeOpCast() const;
|
|
|
|
operator CodeParam() const;
|
|
|
|
operator CodePragma() const;
|
|
|
|
operator CodePreprocessCond() const;
|
|
|
|
operator CodeSpecifiers() const;
|
|
|
|
operator CodeStruct() const;
|
|
|
|
operator CodeTemplate() const;
|
|
|
|
operator CodeType() const;
|
|
|
|
operator CodeTypedef() const;
|
|
|
|
operator CodeUnion() const;
|
|
|
|
operator CodeUsing() const;
|
|
|
|
operator CodeVar() const;
|
|
|
|
#undef operator
|
|
|
|
};
|
2024-12-01 22:56:49 -08:00
|
|
|
#endif
|
2023-08-03 08:01:43 -07:00
|
|
|
|
2024-12-01 21:03:38 -08:00
|
|
|
#pragma region Statics
|
|
|
|
// Used to identify ASTs that should always be duplicated. (Global constant ASTs)
|
|
|
|
extern Code Code_Global;
|
|
|
|
|
|
|
|
// Used to identify invalid generated code.
|
|
|
|
extern Code Code_Invalid;
|
|
|
|
#pragma endregion Statics
|
|
|
|
|
2023-08-03 08:01:43 -07:00
|
|
|
struct Code_POD
|
|
|
|
{
|
|
|
|
AST* ast;
|
|
|
|
};
|
|
|
|
static_assert( sizeof(Code) == sizeof(Code_POD), "ERROR: Code is not POD" );
|
|
|
|
|
|
|
|
// Desired width of the AST data structure.
|
2023-09-25 13:42:29 -07:00
|
|
|
constexpr int const AST_POD_Size = 128;
|
2023-08-03 08:01:43 -07:00
|
|
|
|
2024-12-02 00:18:52 -08:00
|
|
|
void append ( AST* self, AST* other );
|
|
|
|
char const* debug_str ( AST* self );
|
|
|
|
AST* duplicate ( AST* self );
|
|
|
|
Code* entry ( AST* self, u32 idx );
|
|
|
|
bool has_entries ( AST* self );
|
|
|
|
bool is_body ( AST* self );
|
|
|
|
bool is_equal ( AST* self, AST* other );
|
|
|
|
String to_string ( AST* self );
|
|
|
|
void to_string ( AST* self, String* result );
|
|
|
|
char const* type_str ( AST* self );
|
|
|
|
bool validate_body( AST* self );
|
2024-12-01 15:50:37 -08:00
|
|
|
|
|
|
|
#if GEN_CPP_SUPPORT_REFERENCES
|
|
|
|
void append ( AST& self, AST& other ) { return append(& self, & other); }
|
|
|
|
bool is_body ( AST& self ) { return is_body(& self); }
|
2024-12-01 21:34:40 -08:00
|
|
|
bool is_equal ( AST& self, AST& other ) { return is_equal(& self, & other); }
|
2024-12-01 15:50:37 -08:00
|
|
|
char const* debug_str( AST& self ) { return debug_str( & self ); }
|
|
|
|
String to_string( AST& self ) { return to_string( & self ); }
|
|
|
|
char const* type_str ( AST& self ) { return type_str( & self ); }
|
|
|
|
#endif
|
|
|
|
|
2024-12-02 00:18:52 -08:00
|
|
|
constexpr static
|
|
|
|
int AST_ArrSpecs_Cap =
|
|
|
|
(
|
|
|
|
AST_POD_Size
|
|
|
|
- sizeof(AST*) * 3
|
|
|
|
- sizeof(parser::Token*)
|
|
|
|
- sizeof(AST*)
|
|
|
|
- sizeof(StringCached)
|
|
|
|
- sizeof(CodeT)
|
|
|
|
- sizeof(ModuleFlag)
|
|
|
|
- sizeof(int)
|
|
|
|
)
|
|
|
|
/ sizeof(int) - 1; // -1 for 4 extra bytes
|
|
|
|
|
2023-08-03 08:01:43 -07:00
|
|
|
/*
|
|
|
|
Simple AST POD with functionality to seralize into C++ syntax.
|
|
|
|
*/
|
|
|
|
struct AST
|
|
|
|
{
|
2024-12-02 00:18:52 -08:00
|
|
|
#if GEN_SUPPORT_CPP_MEMBER_FEATURES
|
2023-08-03 08:01:43 -07:00
|
|
|
# pragma region Member Functions
|
2024-12-02 00:18:52 -08:00
|
|
|
void append ( AST* other ) { GEN_NS append(this, other); }
|
|
|
|
char const* debug_str () { return GEN_NS debug_str(this); }
|
|
|
|
AST* duplicate () { return GEN_NS duplicate(this); }
|
|
|
|
Code* entry ( u32 idx ) { return GEN_NS entry(this, idx); }
|
|
|
|
bool has_entries() { return GEN_NS has_entries(this); }
|
2024-12-01 21:34:40 -08:00
|
|
|
bool is_equal ( AST* other ) { return GEN_NS is_equal(this, other); }
|
2024-12-01 15:50:37 -08:00
|
|
|
bool is_body() { return GEN_NS is_body(this); }
|
|
|
|
char const* type_str() { return GEN_NS type_str(this); }
|
2024-12-02 00:18:52 -08:00
|
|
|
bool validate_body() { return GEN_NS validate_body(this); }
|
2023-08-03 08:01:43 -07:00
|
|
|
|
2024-12-02 00:18:52 -08:00
|
|
|
String to_string() { return GEN_NS to_string(this); }
|
|
|
|
void to_string( String& result ) { return GEN_NS to_string(this, & result); }
|
2023-08-03 08:01:43 -07:00
|
|
|
|
2024-12-01 15:50:37 -08:00
|
|
|
# pragma endregion Member Functions
|
|
|
|
#endif
|
|
|
|
|
2023-08-03 08:01:43 -07:00
|
|
|
operator Code();
|
|
|
|
operator CodeBody();
|
|
|
|
operator CodeAttributes();
|
2023-11-21 20:36:56 -08:00
|
|
|
// operator CodeBaseClass();
|
2023-08-03 08:01:43 -07:00
|
|
|
operator CodeComment();
|
2023-08-07 00:10:45 -07:00
|
|
|
operator CodeConstructor();
|
|
|
|
operator CodeDestructor();
|
2023-08-03 08:01:43 -07:00
|
|
|
operator CodeClass();
|
|
|
|
operator CodeDefine();
|
|
|
|
operator CodeEnum();
|
|
|
|
operator CodeExec();
|
|
|
|
operator CodeExtern();
|
|
|
|
operator CodeInclude();
|
|
|
|
operator CodeFriend();
|
|
|
|
operator CodeFn();
|
|
|
|
operator CodeModule();
|
2023-08-06 11:58:43 -07:00
|
|
|
operator CodeNS();
|
2023-08-03 08:01:43 -07:00
|
|
|
operator CodeOperator();
|
|
|
|
operator CodeOpCast();
|
|
|
|
operator CodeParam();
|
|
|
|
operator CodePragma();
|
|
|
|
operator CodePreprocessCond();
|
|
|
|
operator CodeSpecifiers();
|
|
|
|
operator CodeStruct();
|
|
|
|
operator CodeTemplate();
|
|
|
|
operator CodeType();
|
|
|
|
operator CodeTypedef();
|
|
|
|
operator CodeUnion();
|
|
|
|
operator CodeUsing();
|
|
|
|
operator CodeVar();
|
|
|
|
|
|
|
|
union {
|
|
|
|
struct
|
|
|
|
{
|
2023-09-06 00:06:30 -07:00
|
|
|
AST* InlineCmt; // Class, Constructor, Destructor, Enum, Friend, Functon, Operator, OpCast, Struct, Typedef, Using, Variable
|
2023-09-04 22:44:04 -07:00
|
|
|
AST* Attributes; // Class, Enum, Function, Struct, Typedef, Union, Using, Variable
|
|
|
|
AST* Specs; // Destructor, Function, Operator, Typename, Variable
|
2023-08-03 08:01:43 -07:00
|
|
|
union {
|
2023-08-22 21:05:58 -07:00
|
|
|
AST* InitializerList; // Constructor
|
2023-09-04 22:44:04 -07:00
|
|
|
AST* ParentType; // Class, Struct, ParentType->Next has a possible list of interfaces.
|
2023-09-06 00:06:30 -07:00
|
|
|
AST* ReturnType; // Function, Operator, Typename
|
2023-08-07 00:10:45 -07:00
|
|
|
AST* UnderlyingType; // Enum, Typedef
|
|
|
|
AST* ValueType; // Parameter, Variable
|
2023-08-03 08:01:43 -07:00
|
|
|
};
|
|
|
|
union {
|
2024-04-17 14:40:32 -07:00
|
|
|
AST* Macro; // Parameter
|
2023-09-06 00:06:30 -07:00
|
|
|
AST* BitfieldSize; // Variable (Class/Struct Data Member)
|
|
|
|
AST* Params; // Constructor, Function, Operator, Template, Typename
|
2023-08-03 08:01:43 -07:00
|
|
|
};
|
|
|
|
union {
|
2023-09-04 22:44:04 -07:00
|
|
|
AST* ArrExpr; // Typename
|
2024-10-24 22:04:17 -07:00
|
|
|
AST* Body; // Class, Constructor, Destructor, Enum, Friend, Function, Namespace, Struct, Union
|
2023-09-04 22:44:04 -07:00
|
|
|
AST* Declaration; // Friend, Template
|
|
|
|
AST* Value; // Parameter, Variable
|
2023-08-03 08:01:43 -07:00
|
|
|
};
|
2023-09-06 00:06:30 -07:00
|
|
|
union {
|
|
|
|
AST* NextVar; // Variable; Possible way to handle comma separated variables declarations. ( , NextVar->Specs NextVar->Name NextVar->ArrExpr = NextVar->Value )
|
2023-09-25 14:48:16 -07:00
|
|
|
AST* SuffixSpecs; // Only used with typenames, to store the function suffix if typename is function signature. ( May not be needed )
|
2024-10-24 22:04:17 -07:00
|
|
|
AST* PostNameMacro; // Only used with parameters for specifically UE_REQUIRES (Thanks Unreal)
|
2023-09-06 00:06:30 -07:00
|
|
|
};
|
2023-08-03 08:01:43 -07:00
|
|
|
};
|
2023-09-04 22:44:04 -07:00
|
|
|
StringCached Content; // Attributes, Comment, Execution, Include
|
2023-09-11 20:22:53 -07:00
|
|
|
struct {
|
2024-12-02 00:18:52 -08:00
|
|
|
SpecifierT ArrSpecs[AST_ArrSpecs_Cap]; // Specifiers
|
2023-11-19 17:34:46 -08:00
|
|
|
AST* NextSpecs; // Specifiers; If ArrSpecs is full, then NextSpecs is used.
|
2023-09-11 20:22:53 -07:00
|
|
|
};
|
2023-08-03 08:01:43 -07:00
|
|
|
};
|
|
|
|
union {
|
|
|
|
AST* Prev;
|
|
|
|
AST* Front;
|
|
|
|
AST* Last;
|
|
|
|
};
|
|
|
|
union {
|
|
|
|
AST* Next;
|
|
|
|
AST* Back;
|
|
|
|
};
|
2023-11-21 17:07:49 -08:00
|
|
|
parser::Token* Token; // Reference to starting token, only avaialble if it was derived from parsing.
|
2023-08-03 08:01:43 -07:00
|
|
|
AST* Parent;
|
|
|
|
StringCached Name;
|
|
|
|
CodeT Type;
|
2023-11-20 12:09:01 -08:00
|
|
|
// CodeFlag CodeFlags;
|
2023-08-03 08:01:43 -07:00
|
|
|
ModuleFlag ModuleFlags;
|
|
|
|
union {
|
2023-08-23 08:05:49 -07:00
|
|
|
b32 IsFunction; // Used by typedef to not serialize the name field.
|
|
|
|
b32 IsParamPack; // Used by typename to know if type should be considered a parameter pack.
|
2023-08-03 08:01:43 -07:00
|
|
|
OperatorT Op;
|
|
|
|
AccessSpec ParentAccess;
|
|
|
|
s32 NumEntries;
|
2024-12-01 02:30:37 -08:00
|
|
|
s32 VarConstructorInit; // Used by variables to know that initialization is using a constructor expression instead of an assignment expression.
|
|
|
|
b32 EnumUnderlyingMacro; // Used by enums incase the user wants to wrap underlying type specification in a macro
|
2023-08-03 08:01:43 -07:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
// Its intended for the AST to have equivalent size to its POD.
|
|
|
|
// All extra functionality within the AST namespace should just be syntatic sugar.
|
2024-12-02 15:58:07 -08:00
|
|
|
static_assert( sizeof(AST) == AST_POD_Size, "ERROR: AST POD is not size of AST_POD_Size" );
|
2023-08-03 08:01:43 -07:00
|
|
|
|
|
|
|
// Used when the its desired when omission is allowed in a definition.
|
|
|
|
#define NoCode { nullptr }
|
2024-12-01 21:03:38 -08:00
|
|
|
#define InvalidCode (* Code_Invalid.ast) // Uses an implicitly overloaded cast from the AST to the desired code type.
|