mirror of
https://github.com/Ed94/gencpp.git
synced 2025-04-04 08:07:57 -07:00
Compare commits
5 Commits
1f958e121c
...
6481313969
Author | SHA1 | Date | |
---|---|---|---|
6481313969 | |||
5c17983a73 | |||
b6d95e8d70 | |||
6f2d81434e | |||
b8695a33db |
@ -52,6 +52,7 @@ void body_to_strbuilder_export( CodeBody body, StrBuilder* result )
|
|||||||
|
|
||||||
StrBuilder constructor_to_strbuilder(CodeConstructor self)
|
StrBuilder constructor_to_strbuilder(CodeConstructor self)
|
||||||
{
|
{
|
||||||
|
GEN_ASSERT(self);
|
||||||
StrBuilder result = strbuilder_make_reserve( _ctx->Allocator_Temp, 128 );
|
StrBuilder result = strbuilder_make_reserve( _ctx->Allocator_Temp, 128 );
|
||||||
switch (self->Type)
|
switch (self->Type)
|
||||||
{
|
{
|
||||||
@ -67,6 +68,8 @@ StrBuilder constructor_to_strbuilder(CodeConstructor self)
|
|||||||
|
|
||||||
void constructor_to_strbuilder_def(CodeConstructor self, StrBuilder* result )
|
void constructor_to_strbuilder_def(CodeConstructor self, StrBuilder* result )
|
||||||
{
|
{
|
||||||
|
GEN_ASSERT(self);
|
||||||
|
GEN_ASSERT(result);
|
||||||
Code ClassStructParent = self->Parent->Parent;
|
Code ClassStructParent = self->Parent->Parent;
|
||||||
if (ClassStructParent) {
|
if (ClassStructParent) {
|
||||||
strbuilder_append_str( result, ClassStructParent->Name );
|
strbuilder_append_str( result, ClassStructParent->Name );
|
||||||
@ -91,6 +94,8 @@ void constructor_to_strbuilder_def(CodeConstructor self, StrBuilder* result )
|
|||||||
|
|
||||||
void constructor_to_strbuilder_fwd(CodeConstructor self, StrBuilder* result )
|
void constructor_to_strbuilder_fwd(CodeConstructor self, StrBuilder* result )
|
||||||
{
|
{
|
||||||
|
GEN_ASSERT(self);
|
||||||
|
GEN_ASSERT(result);
|
||||||
Code ClassStructParent = self->Parent->Parent;
|
Code ClassStructParent = self->Parent->Parent;
|
||||||
if (ClassStructParent) {
|
if (ClassStructParent) {
|
||||||
strbuilder_append_str( result, ClassStructParent->Name );
|
strbuilder_append_str( result, ClassStructParent->Name );
|
||||||
@ -115,6 +120,7 @@ void constructor_to_strbuilder_fwd(CodeConstructor self, StrBuilder* result )
|
|||||||
|
|
||||||
StrBuilder class_to_strbuilder( CodeClass self )
|
StrBuilder class_to_strbuilder( CodeClass self )
|
||||||
{
|
{
|
||||||
|
GEN_ASSERT(self);
|
||||||
StrBuilder result = strbuilder_make_reserve( _ctx->Allocator_Temp, 512 );
|
StrBuilder result = strbuilder_make_reserve( _ctx->Allocator_Temp, 512 );
|
||||||
switch ( self->Type )
|
switch ( self->Type )
|
||||||
{
|
{
|
||||||
@ -131,6 +137,7 @@ StrBuilder class_to_strbuilder( CodeClass self )
|
|||||||
void class_to_strbuilder_def( CodeClass self, StrBuilder* result )
|
void class_to_strbuilder_def( CodeClass self, StrBuilder* result )
|
||||||
{
|
{
|
||||||
GEN_ASSERT(self);
|
GEN_ASSERT(self);
|
||||||
|
GEN_ASSERT(result);
|
||||||
|
|
||||||
if ( bitfield_is_set( u32, self->ModuleFlags, ModuleFlag_Export ))
|
if ( bitfield_is_set( u32, self->ModuleFlags, ModuleFlag_Export ))
|
||||||
strbuilder_append_str( result, txt("export ") );
|
strbuilder_append_str( result, txt("export ") );
|
||||||
@ -178,6 +185,7 @@ void class_to_strbuilder_def( CodeClass self, StrBuilder* result )
|
|||||||
void class_to_strbuilder_fwd( CodeClass self, StrBuilder* result )
|
void class_to_strbuilder_fwd( CodeClass self, StrBuilder* result )
|
||||||
{
|
{
|
||||||
GEN_ASSERT(self);
|
GEN_ASSERT(self);
|
||||||
|
GEN_ASSERT(result);
|
||||||
|
|
||||||
if ( bitfield_is_set( u32, self->ModuleFlags, ModuleFlag_Export ))
|
if ( bitfield_is_set( u32, self->ModuleFlags, ModuleFlag_Export ))
|
||||||
strbuilder_append_str( result, txt("export ") );
|
strbuilder_append_str( result, txt("export ") );
|
||||||
@ -230,6 +238,7 @@ void define_params_to_strbuilder_ref(CodeDefineParams self, StrBuilder* result)
|
|||||||
|
|
||||||
StrBuilder destructor_to_strbuilder(CodeDestructor self)
|
StrBuilder destructor_to_strbuilder(CodeDestructor self)
|
||||||
{
|
{
|
||||||
|
GEN_ASSERT(self);
|
||||||
StrBuilder result = strbuilder_make_reserve( _ctx->Allocator_Temp, 128 );
|
StrBuilder result = strbuilder_make_reserve( _ctx->Allocator_Temp, 128 );
|
||||||
switch ( self->Type )
|
switch ( self->Type )
|
||||||
{
|
{
|
||||||
@ -245,6 +254,8 @@ StrBuilder destructor_to_strbuilder(CodeDestructor self)
|
|||||||
|
|
||||||
void destructor_to_strbuilder_def(CodeDestructor self, StrBuilder* result )
|
void destructor_to_strbuilder_def(CodeDestructor self, StrBuilder* result )
|
||||||
{
|
{
|
||||||
|
GEN_ASSERT(self);
|
||||||
|
GEN_ASSERT(result);
|
||||||
if ( self->Name.Len )
|
if ( self->Name.Len )
|
||||||
{
|
{
|
||||||
strbuilder_append_fmt( result, "%S()", self->Name );
|
strbuilder_append_fmt( result, "%S()", self->Name );
|
||||||
@ -264,6 +275,8 @@ void destructor_to_strbuilder_def(CodeDestructor self, StrBuilder* result )
|
|||||||
|
|
||||||
void destructor_to_strbuilder_fwd(CodeDestructor self, StrBuilder* result )
|
void destructor_to_strbuilder_fwd(CodeDestructor self, StrBuilder* result )
|
||||||
{
|
{
|
||||||
|
GEN_ASSERT(self);
|
||||||
|
GEN_ASSERT(result);
|
||||||
if ( self->Specs )
|
if ( self->Specs )
|
||||||
{
|
{
|
||||||
if ( specifiers_has(self->Specs, Spec_Virtual ) )
|
if ( specifiers_has(self->Specs, Spec_Virtual ) )
|
||||||
@ -287,6 +300,7 @@ void destructor_to_strbuilder_fwd(CodeDestructor self, StrBuilder* result )
|
|||||||
|
|
||||||
StrBuilder enum_to_strbuilder(CodeEnum self)
|
StrBuilder enum_to_strbuilder(CodeEnum self)
|
||||||
{
|
{
|
||||||
|
GEN_ASSERT(self);
|
||||||
StrBuilder result = strbuilder_make_reserve( _ctx->Allocator_Temp, 512 );
|
StrBuilder result = strbuilder_make_reserve( _ctx->Allocator_Temp, 512 );
|
||||||
switch ( self->Type )
|
switch ( self->Type )
|
||||||
{
|
{
|
||||||
@ -308,6 +322,8 @@ StrBuilder enum_to_strbuilder(CodeEnum self)
|
|||||||
|
|
||||||
void enum_to_strbuilder_def(CodeEnum self, StrBuilder* result )
|
void enum_to_strbuilder_def(CodeEnum self, StrBuilder* result )
|
||||||
{
|
{
|
||||||
|
GEN_ASSERT(self);
|
||||||
|
GEN_ASSERT(result);
|
||||||
if ( bitfield_is_set( u32, self->ModuleFlags, ModuleFlag_Export ))
|
if ( bitfield_is_set( u32, self->ModuleFlags, ModuleFlag_Export ))
|
||||||
strbuilder_append_str( result, txt("export ") );
|
strbuilder_append_str( result, txt("export ") );
|
||||||
|
|
||||||
@ -341,6 +357,8 @@ void enum_to_strbuilder_def(CodeEnum self, StrBuilder* result )
|
|||||||
|
|
||||||
void enum_to_strbuilder_fwd(CodeEnum self, StrBuilder* result )
|
void enum_to_strbuilder_fwd(CodeEnum self, StrBuilder* result )
|
||||||
{
|
{
|
||||||
|
GEN_ASSERT(self);
|
||||||
|
GEN_ASSERT(result);
|
||||||
if ( bitfield_is_set( u32, self->ModuleFlags, ModuleFlag_Export ))
|
if ( bitfield_is_set( u32, self->ModuleFlags, ModuleFlag_Export ))
|
||||||
strbuilder_append_str( result, txt("export ") );
|
strbuilder_append_str( result, txt("export ") );
|
||||||
|
|
||||||
@ -368,6 +386,8 @@ void enum_to_strbuilder_fwd(CodeEnum self, StrBuilder* result )
|
|||||||
|
|
||||||
void enum_to_strbuilder_class_def(CodeEnum self, StrBuilder* result )
|
void enum_to_strbuilder_class_def(CodeEnum self, StrBuilder* result )
|
||||||
{
|
{
|
||||||
|
GEN_ASSERT(self);
|
||||||
|
GEN_ASSERT(result);
|
||||||
if ( bitfield_is_set( u32, self->ModuleFlags, ModuleFlag_Export ))
|
if ( bitfield_is_set( u32, self->ModuleFlags, ModuleFlag_Export ))
|
||||||
strbuilder_append_str( result, txt("export ") );
|
strbuilder_append_str( result, txt("export ") );
|
||||||
|
|
||||||
@ -400,6 +420,8 @@ void enum_to_strbuilder_class_def(CodeEnum self, StrBuilder* result )
|
|||||||
|
|
||||||
void enum_to_strbuilder_class_fwd(CodeEnum self, StrBuilder* result )
|
void enum_to_strbuilder_class_fwd(CodeEnum self, StrBuilder* result )
|
||||||
{
|
{
|
||||||
|
GEN_ASSERT(self);
|
||||||
|
GEN_ASSERT(result);
|
||||||
if ( bitfield_is_set( u32, self->ModuleFlags, ModuleFlag_Export ))
|
if ( bitfield_is_set( u32, self->ModuleFlags, ModuleFlag_Export ))
|
||||||
strbuilder_append_str( result, txt("export ") );
|
strbuilder_append_str( result, txt("export ") );
|
||||||
|
|
||||||
@ -421,6 +443,7 @@ void enum_to_strbuilder_class_fwd(CodeEnum self, StrBuilder* result )
|
|||||||
|
|
||||||
StrBuilder fn_to_strbuilder(CodeFn self)
|
StrBuilder fn_to_strbuilder(CodeFn self)
|
||||||
{
|
{
|
||||||
|
GEN_ASSERT(self);
|
||||||
StrBuilder result = strbuilder_make_reserve( _ctx->Allocator_Temp, 512 );
|
StrBuilder result = strbuilder_make_reserve( _ctx->Allocator_Temp, 512 );
|
||||||
switch ( self->Type )
|
switch ( self->Type )
|
||||||
{
|
{
|
||||||
@ -436,6 +459,8 @@ StrBuilder fn_to_strbuilder(CodeFn self)
|
|||||||
|
|
||||||
void fn_to_strbuilder_def(CodeFn self, StrBuilder* result )
|
void fn_to_strbuilder_def(CodeFn self, StrBuilder* result )
|
||||||
{
|
{
|
||||||
|
GEN_ASSERT(self);
|
||||||
|
GEN_ASSERT(result);
|
||||||
if ( bitfield_is_set( u32, self->ModuleFlags, ModuleFlag_Export ))
|
if ( bitfield_is_set( u32, self->ModuleFlags, ModuleFlag_Export ))
|
||||||
strbuilder_append_str( result, txt("export") );
|
strbuilder_append_str( result, txt("export") );
|
||||||
|
|
||||||
@ -493,6 +518,8 @@ void fn_to_strbuilder_def(CodeFn self, StrBuilder* result )
|
|||||||
|
|
||||||
void fn_to_strbuilder_fwd(CodeFn self, StrBuilder* result )
|
void fn_to_strbuilder_fwd(CodeFn self, StrBuilder* result )
|
||||||
{
|
{
|
||||||
|
GEN_ASSERT(self);
|
||||||
|
GEN_ASSERT(result);
|
||||||
if ( bitfield_is_set( u32, self->ModuleFlags, ModuleFlag_Export ))
|
if ( bitfield_is_set( u32, self->ModuleFlags, ModuleFlag_Export ))
|
||||||
strbuilder_append_str( result, txt("export ") );
|
strbuilder_append_str( result, txt("export ") );
|
||||||
|
|
||||||
@ -563,6 +590,8 @@ void fn_to_strbuilder_fwd(CodeFn self, StrBuilder* result )
|
|||||||
|
|
||||||
void module_to_strbuilder_ref(CodeModule self, StrBuilder* result )
|
void module_to_strbuilder_ref(CodeModule self, StrBuilder* result )
|
||||||
{
|
{
|
||||||
|
GEN_ASSERT(self);
|
||||||
|
GEN_ASSERT(result);
|
||||||
if (((scast(u32, ModuleFlag_Export) & scast(u32, self->ModuleFlags)) == scast(u32, ModuleFlag_Export)))
|
if (((scast(u32, ModuleFlag_Export) & scast(u32, self->ModuleFlags)) == scast(u32, ModuleFlag_Export)))
|
||||||
strbuilder_append_str( result, txt("export "));
|
strbuilder_append_str( result, txt("export "));
|
||||||
|
|
||||||
@ -574,6 +603,7 @@ void module_to_strbuilder_ref(CodeModule self, StrBuilder* result )
|
|||||||
|
|
||||||
StrBuilder code_op_to_strbuilder(CodeOperator self)
|
StrBuilder code_op_to_strbuilder(CodeOperator self)
|
||||||
{
|
{
|
||||||
|
GEN_ASSERT(self);
|
||||||
StrBuilder result = strbuilder_make_reserve( _ctx->Allocator_Temp, 512 );
|
StrBuilder result = strbuilder_make_reserve( _ctx->Allocator_Temp, 512 );
|
||||||
switch ( self->Type )
|
switch ( self->Type )
|
||||||
{
|
{
|
||||||
@ -591,6 +621,8 @@ StrBuilder code_op_to_strbuilder(CodeOperator self)
|
|||||||
|
|
||||||
void code_op_to_strbuilder_def(CodeOperator self, StrBuilder* result )
|
void code_op_to_strbuilder_def(CodeOperator self, StrBuilder* result )
|
||||||
{
|
{
|
||||||
|
GEN_ASSERT(self);
|
||||||
|
GEN_ASSERT(result);
|
||||||
if ( bitfield_is_set( u32, self->ModuleFlags, ModuleFlag_Export ))
|
if ( bitfield_is_set( u32, self->ModuleFlags, ModuleFlag_Export ))
|
||||||
strbuilder_append_str( result, txt("export ") );
|
strbuilder_append_str( result, txt("export ") );
|
||||||
|
|
||||||
@ -645,6 +677,8 @@ void code_op_to_strbuilder_def(CodeOperator self, StrBuilder* result )
|
|||||||
|
|
||||||
void code_op_to_strbuilder_fwd(CodeOperator self, StrBuilder* result )
|
void code_op_to_strbuilder_fwd(CodeOperator self, StrBuilder* result )
|
||||||
{
|
{
|
||||||
|
GEN_ASSERT(self);
|
||||||
|
GEN_ASSERT(result);
|
||||||
if ( bitfield_is_set( u32, self->ModuleFlags, ModuleFlag_Export ))
|
if ( bitfield_is_set( u32, self->ModuleFlags, ModuleFlag_Export ))
|
||||||
strbuilder_append_str( result, txt("export ") );
|
strbuilder_append_str( result, txt("export ") );
|
||||||
|
|
||||||
@ -696,6 +730,7 @@ void code_op_to_strbuilder_fwd(CodeOperator self, StrBuilder* result )
|
|||||||
|
|
||||||
StrBuilder opcast_to_strbuilder(CodeOpCast self)
|
StrBuilder opcast_to_strbuilder(CodeOpCast self)
|
||||||
{
|
{
|
||||||
|
GEN_ASSERT(self);
|
||||||
StrBuilder result = strbuilder_make_reserve( _ctx->Allocator_Temp, 128 );
|
StrBuilder result = strbuilder_make_reserve( _ctx->Allocator_Temp, 128 );
|
||||||
switch ( self->Type )
|
switch ( self->Type )
|
||||||
{
|
{
|
||||||
@ -711,6 +746,8 @@ StrBuilder opcast_to_strbuilder(CodeOpCast self)
|
|||||||
|
|
||||||
void opcast_to_strbuilder_def(CodeOpCast self, StrBuilder* result )
|
void opcast_to_strbuilder_def(CodeOpCast self, StrBuilder* result )
|
||||||
{
|
{
|
||||||
|
GEN_ASSERT(self);
|
||||||
|
GEN_ASSERT(result);
|
||||||
if ( self->Specs )
|
if ( self->Specs )
|
||||||
{
|
{
|
||||||
for ( Specifier* spec = begin_CodeSpecifiers(self->Specs); spec != end_CodeSpecifiers(self->Specs); spec = next_CodeSpecifiers(self->Specs, spec) )
|
for ( Specifier* spec = begin_CodeSpecifiers(self->Specs); spec != end_CodeSpecifiers(self->Specs); spec = next_CodeSpecifiers(self->Specs, spec) )
|
||||||
@ -748,6 +785,8 @@ void opcast_to_strbuilder_def(CodeOpCast self, StrBuilder* result )
|
|||||||
|
|
||||||
void opcast_to_strbuilder_fwd(CodeOpCast self, StrBuilder* result )
|
void opcast_to_strbuilder_fwd(CodeOpCast self, StrBuilder* result )
|
||||||
{
|
{
|
||||||
|
GEN_ASSERT(self);
|
||||||
|
GEN_ASSERT(result);
|
||||||
if ( self->Specs )
|
if ( self->Specs )
|
||||||
{
|
{
|
||||||
for ( Specifier* spec = begin_CodeSpecifiers(self->Specs); spec != end_CodeSpecifiers(self->Specs); spec = next_CodeSpecifiers(self->Specs, spec) )
|
for ( Specifier* spec = begin_CodeSpecifiers(self->Specs); spec != end_CodeSpecifiers(self->Specs); spec = next_CodeSpecifiers(self->Specs, spec) )
|
||||||
@ -977,6 +1016,8 @@ void template_to_strbuilder_ref(CodeTemplate self, StrBuilder* result )
|
|||||||
|
|
||||||
void typedef_to_strbuilder_ref(CodeTypedef self, StrBuilder* result )
|
void typedef_to_strbuilder_ref(CodeTypedef self, StrBuilder* result )
|
||||||
{
|
{
|
||||||
|
GEN_ASSERT(self);
|
||||||
|
GEN_ASSERT(result);
|
||||||
if ( bitfield_is_set( u32, self->ModuleFlags, ModuleFlag_Export ))
|
if ( bitfield_is_set( u32, self->ModuleFlags, ModuleFlag_Export ))
|
||||||
strbuilder_append_str( result, txt("export ") );
|
strbuilder_append_str( result, txt("export ") );
|
||||||
|
|
||||||
@ -1012,6 +1053,8 @@ void typedef_to_strbuilder_ref(CodeTypedef self, StrBuilder* result )
|
|||||||
|
|
||||||
void typename_to_strbuilder_ref(CodeTypename self, StrBuilder* result )
|
void typename_to_strbuilder_ref(CodeTypename self, StrBuilder* result )
|
||||||
{
|
{
|
||||||
|
GEN_ASSERT(self);
|
||||||
|
GEN_ASSERT(result);
|
||||||
#if defined(GEN_USE_NEW_TYPENAME_PARSING)
|
#if defined(GEN_USE_NEW_TYPENAME_PARSING)
|
||||||
if ( self->ReturnType && self->Params )
|
if ( self->ReturnType && self->Params )
|
||||||
{
|
{
|
||||||
@ -1068,6 +1111,7 @@ void typename_to_strbuilder_ref(CodeTypename self, StrBuilder* result )
|
|||||||
|
|
||||||
StrBuilder union_to_strbuilder(CodeUnion self)
|
StrBuilder union_to_strbuilder(CodeUnion self)
|
||||||
{
|
{
|
||||||
|
GEN_ASSERT(self);
|
||||||
StrBuilder result = strbuilder_make_reserve( _ctx->Allocator_Temp, 512 );
|
StrBuilder result = strbuilder_make_reserve( _ctx->Allocator_Temp, 512 );
|
||||||
switch ( self->Type )
|
switch ( self->Type )
|
||||||
{
|
{
|
||||||
@ -1083,6 +1127,8 @@ StrBuilder union_to_strbuilder(CodeUnion self)
|
|||||||
|
|
||||||
void union_to_strbuilder_def(CodeUnion self, StrBuilder* result )
|
void union_to_strbuilder_def(CodeUnion self, StrBuilder* result )
|
||||||
{
|
{
|
||||||
|
GEN_ASSERT(self);
|
||||||
|
GEN_ASSERT(result);
|
||||||
if ( bitfield_is_set( u32, self->ModuleFlags, ModuleFlag_Export ))
|
if ( bitfield_is_set( u32, self->ModuleFlags, ModuleFlag_Export ))
|
||||||
strbuilder_append_str( result, txt("export ") );
|
strbuilder_append_str( result, txt("export ") );
|
||||||
|
|
||||||
|
@ -134,12 +134,12 @@ GEN_API StrBuilder preprocess_to_strbuilder (CodePreprocessCond cond);
|
|||||||
StrBuilder template_to_strbuilder (CodeTemplate self);
|
StrBuilder template_to_strbuilder (CodeTemplate self);
|
||||||
GEN_API void template_to_strbuilder_ref(CodeTemplate self, StrBuilder* result);
|
GEN_API void template_to_strbuilder_ref(CodeTemplate self, StrBuilder* result);
|
||||||
|
|
||||||
StrBuilder typename_to_strbuilder (CodeTypename self);
|
|
||||||
GEN_API void typename_to_strbuilder_ref(CodeTypename self, StrBuilder* result);
|
|
||||||
|
|
||||||
StrBuilder typedef_to_strbuilder (CodeTypedef self);
|
StrBuilder typedef_to_strbuilder (CodeTypedef self);
|
||||||
GEN_API void typedef_to_strbuilder_ref(CodeTypedef self, StrBuilder* result );
|
GEN_API void typedef_to_strbuilder_ref(CodeTypedef self, StrBuilder* result );
|
||||||
|
|
||||||
|
StrBuilder typename_to_strbuilder (CodeTypename self);
|
||||||
|
GEN_API void typename_to_strbuilder_ref(CodeTypename self, StrBuilder* result);
|
||||||
|
|
||||||
GEN_API StrBuilder union_to_strbuilder (CodeUnion self);
|
GEN_API StrBuilder union_to_strbuilder (CodeUnion self);
|
||||||
GEN_API void union_to_strbuilder_def(CodeUnion self, StrBuilder* result);
|
GEN_API void union_to_strbuilder_def(CodeUnion self, StrBuilder* result);
|
||||||
GEN_API void union_to_strbuilder_fwd(CodeUnion self, StrBuilder* result);
|
GEN_API void union_to_strbuilder_fwd(CodeUnion self, StrBuilder* result);
|
||||||
|
@ -0,0 +1,85 @@
|
|||||||
|
#ifdef GEN_INTELLISENSE_DIRECTIVES
|
||||||
|
# pragma once
|
||||||
|
# include "interface.hpp"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#pragma region Constants
|
||||||
|
// Predefined typename codes. Are set to readonly and are setup during gen::init()
|
||||||
|
|
||||||
|
GEN_API extern Macro enum_underlying_macro;
|
||||||
|
|
||||||
|
GEN_API extern Code access_public;
|
||||||
|
GEN_API extern Code access_protected;
|
||||||
|
GEN_API extern Code access_private;
|
||||||
|
|
||||||
|
GEN_API extern CodeAttributes attrib_api_export;
|
||||||
|
GEN_API extern CodeAttributes attrib_api_import;
|
||||||
|
|
||||||
|
GEN_API extern Code module_global_fragment;
|
||||||
|
GEN_API extern Code module_private_fragment;
|
||||||
|
|
||||||
|
GEN_API extern Code fmt_newline;
|
||||||
|
|
||||||
|
GEN_API extern CodePragma pragma_once;
|
||||||
|
|
||||||
|
GEN_API extern CodeParams param_varadic;
|
||||||
|
|
||||||
|
GEN_API extern CodePreprocessCond preprocess_else;
|
||||||
|
GEN_API extern CodePreprocessCond preprocess_endif;
|
||||||
|
|
||||||
|
GEN_API extern CodeSpecifiers spec_const;
|
||||||
|
GEN_API extern CodeSpecifiers spec_consteval;
|
||||||
|
GEN_API extern CodeSpecifiers spec_constexpr;
|
||||||
|
GEN_API extern CodeSpecifiers spec_constinit;
|
||||||
|
GEN_API extern CodeSpecifiers spec_extern_linkage;
|
||||||
|
GEN_API extern CodeSpecifiers spec_final;
|
||||||
|
GEN_API extern CodeSpecifiers spec_forceinline;
|
||||||
|
GEN_API extern CodeSpecifiers spec_global;
|
||||||
|
GEN_API extern CodeSpecifiers spec_inline;
|
||||||
|
GEN_API extern CodeSpecifiers spec_internal_linkage;
|
||||||
|
GEN_API extern CodeSpecifiers spec_local_persist;
|
||||||
|
GEN_API extern CodeSpecifiers spec_mutable;
|
||||||
|
GEN_API extern CodeSpecifiers spec_neverinline;
|
||||||
|
GEN_API extern CodeSpecifiers spec_noexcept;
|
||||||
|
GEN_API extern CodeSpecifiers spec_override;
|
||||||
|
GEN_API extern CodeSpecifiers spec_ptr;
|
||||||
|
GEN_API extern CodeSpecifiers spec_pure;
|
||||||
|
GEN_API extern CodeSpecifiers spec_ref;
|
||||||
|
GEN_API extern CodeSpecifiers spec_register;
|
||||||
|
GEN_API extern CodeSpecifiers spec_rvalue;
|
||||||
|
GEN_API extern CodeSpecifiers spec_static_member;
|
||||||
|
GEN_API extern CodeSpecifiers spec_thread_local;
|
||||||
|
GEN_API extern CodeSpecifiers spec_virtual;
|
||||||
|
GEN_API extern CodeSpecifiers spec_volatile;
|
||||||
|
|
||||||
|
GEN_API extern CodeTypename t_empty; // Used with varaidc parameters. (Exposing just in case its useful for another circumstance)
|
||||||
|
GEN_API extern CodeTypename t_auto;
|
||||||
|
GEN_API extern CodeTypename t_void;
|
||||||
|
GEN_API extern CodeTypename t_int;
|
||||||
|
GEN_API extern CodeTypename t_bool;
|
||||||
|
GEN_API extern CodeTypename t_char;
|
||||||
|
GEN_API extern CodeTypename t_wchar_t;
|
||||||
|
GEN_API extern CodeTypename t_class;
|
||||||
|
GEN_API extern CodeTypename t_typename;
|
||||||
|
|
||||||
|
#ifdef GEN_DEFINE_LIBRARY_CODE_CONSTANTS
|
||||||
|
GEN_API extern CodeTypename t_b32;
|
||||||
|
|
||||||
|
GEN_API extern CodeTypename t_s8;
|
||||||
|
GEN_API extern CodeTypename t_s16;
|
||||||
|
GEN_API extern CodeTypename t_s32;
|
||||||
|
GEN_API extern CodeTypename t_s64;
|
||||||
|
|
||||||
|
GEN_API extern CodeTypename t_u8;
|
||||||
|
GEN_API extern CodeTypename t_u16;
|
||||||
|
GEN_API extern CodeTypename t_u32;
|
||||||
|
GEN_API extern CodeTypename t_u64;
|
||||||
|
|
||||||
|
GEN_API extern CodeTypename t_ssize;
|
||||||
|
GEN_API extern CodeTypename t_usize;
|
||||||
|
|
||||||
|
GEN_API extern CodeTypename t_f32;
|
||||||
|
GEN_API extern CodeTypename t_f64;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#pragma endregion Constants
|
@ -1,5 +0,0 @@
|
|||||||
#ifdef GEN_INTELLISENSE_DIRECTIVES
|
|
||||||
#pragma once
|
|
||||||
#include "inlines.hpp"
|
|
||||||
#include "gen/ast_inlines.hpp"
|
|
||||||
#endif
|
|
@ -15,7 +15,7 @@
|
|||||||
| \_____|\___}_l |_|\___} ,__/| ,__/ (_____/ \__\__/_|\__, |\___}\__,_l |
|
| \_____|\___}_l |_|\___} ,__/| ,__/ (_____/ \__\__/_|\__, |\___}\__,_l |
|
||||||
| | | | | __} | |
|
| | | | | __} | |
|
||||||
| l_l l_l {___/ |
|
| l_l l_l {___/ |
|
||||||
! ----------------------------------------------------------------------- VERSION: v0.23-Alpha |
|
! ----------------------------------------------------------------------- VERSION: v0.25-Alpha |
|
||||||
! ============================================================================================ |
|
! ============================================================================================ |
|
||||||
! WARNING: THIS IS AN ALPHA VERSION OF THE LIBRARY, USE AT YOUR OWN DISCRETION |
|
! WARNING: THIS IS AN ALPHA VERSION OF THE LIBRARY, USE AT YOUR OWN DISCRETION |
|
||||||
! NEVER DO CODE GENERATION WITHOUT AT LEAST HAVING CONTENT IN A CODEBASE UNDER VERSION CONTROL |
|
! NEVER DO CODE GENERATION WITHOUT AT LEAST HAVING CONTENT IN A CODEBASE UNDER VERSION CONTROL |
|
||||||
|
@ -52,6 +52,7 @@ void comment_to_strbuilder_ref(CodeComment comment, StrBuilder* result) {
|
|||||||
inline
|
inline
|
||||||
StrBuilder define_to_strbuilder(CodeDefine define)
|
StrBuilder define_to_strbuilder(CodeDefine define)
|
||||||
{
|
{
|
||||||
|
GEN_ASSERT(define);
|
||||||
StrBuilder result = strbuilder_make_reserve( _ctx->Allocator_Temp, 512 );
|
StrBuilder result = strbuilder_make_reserve( _ctx->Allocator_Temp, 512 );
|
||||||
define_to_strbuilder_ref(define, & result);
|
define_to_strbuilder_ref(define, & result);
|
||||||
return result;
|
return result;
|
||||||
@ -76,41 +77,27 @@ StrBuilder exec_to_strbuilder(CodeExec exec)
|
|||||||
}
|
}
|
||||||
|
|
||||||
inline
|
inline
|
||||||
StrBuilder exec_to_strbuilder_ref(CodeExec exec, StrBuilder* result) {
|
void exec_to_strbuilder_ref(CodeExec exec, StrBuilder* result) {
|
||||||
GEN_ASSERT(exec)
|
GEN_ASSERT(exec);
|
||||||
GEN_ASSERT(result)
|
GEN_ASSERT(result);
|
||||||
char* raw = ccast(char*, str_duplicate( exec->Content, get_context()->Allocator_Temp ).Ptr);
|
strbuilder_append_str(result, exec->Content);
|
||||||
StrBuilder result = { raw };
|
|
||||||
return result;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
inline
|
inline
|
||||||
void extern_to_strbuilder(CodeExtern self, StrBuilder* result )
|
void extern_to_strbuilder(CodeExtern self, StrBuilder* result )
|
||||||
{
|
{
|
||||||
|
GEN_ASSERT(self);
|
||||||
|
GEN_ASSERT(result);
|
||||||
if ( self->Body )
|
if ( self->Body )
|
||||||
strbuilder_append_fmt( result, "extern \"%S\"\n{\n%SB\n}\n", self->Name, body_to_strbuilder(self->Body) );
|
strbuilder_append_fmt( result, "extern \"%S\"\n{\n%SB\n}\n", self->Name, body_to_strbuilder(self->Body) );
|
||||||
else
|
else
|
||||||
strbuilder_append_fmt( result, "extern \"%S\"\n{}\n", self->Name );
|
strbuilder_append_fmt( result, "extern \"%S\"\n{}\n", self->Name );
|
||||||
}
|
}
|
||||||
|
|
||||||
inline
|
|
||||||
StrBuilder include_to_strbuilder(CodeInclude include)
|
|
||||||
{
|
|
||||||
GEN_ASSERT(include)
|
|
||||||
return strbuilder_fmt_buf( _ctx->Allocator_Temp, "#include %S\n", include->Content );
|
|
||||||
}
|
|
||||||
|
|
||||||
inline
|
|
||||||
void include_to_strbuilder_ref( CodeInclude include, StrBuilder* result )
|
|
||||||
{
|
|
||||||
GEN_ASSERT(include)
|
|
||||||
GEN_ASSERT(result)
|
|
||||||
strbuilder_append_fmt( result, "#include %S\n", include->Content );
|
|
||||||
}
|
|
||||||
|
|
||||||
inline
|
inline
|
||||||
StrBuilder friend_to_strbuilder(CodeFriend self)
|
StrBuilder friend_to_strbuilder(CodeFriend self)
|
||||||
{
|
{
|
||||||
|
GEN_ASSERT(self);
|
||||||
StrBuilder result = strbuilder_make_reserve( _ctx->Allocator_Temp, 256 );
|
StrBuilder result = strbuilder_make_reserve( _ctx->Allocator_Temp, 256 );
|
||||||
friend_to_strbuilder_ref( self, & result );
|
friend_to_strbuilder_ref( self, & result );
|
||||||
return result;
|
return result;
|
||||||
@ -119,6 +106,8 @@ StrBuilder friend_to_strbuilder(CodeFriend self)
|
|||||||
inline
|
inline
|
||||||
void friend_to_strbuilder_ref(CodeFriend self, StrBuilder* result )
|
void friend_to_strbuilder_ref(CodeFriend self, StrBuilder* result )
|
||||||
{
|
{
|
||||||
|
GEN_ASSERT(self);
|
||||||
|
GEN_ASSERT(result);
|
||||||
strbuilder_append_fmt( result, "friend %SB", code_to_strbuilder(self->Declaration) );
|
strbuilder_append_fmt( result, "friend %SB", code_to_strbuilder(self->Declaration) );
|
||||||
|
|
||||||
if ( self->Declaration->Type != CT_Function && self->Declaration->Type != CT_Operator && (* result)[ strbuilder_length(* result) - 1 ] != ';' )
|
if ( self->Declaration->Type != CT_Function && self->Declaration->Type != CT_Operator && (* result)[ strbuilder_length(* result) - 1 ] != ';' )
|
||||||
@ -132,9 +121,25 @@ void friend_to_strbuilder_ref(CodeFriend self, StrBuilder* result )
|
|||||||
strbuilder_append_str( result, txt("\n"));
|
strbuilder_append_str( result, txt("\n"));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
inline
|
||||||
|
StrBuilder include_to_strbuilder(CodeInclude include)
|
||||||
|
{
|
||||||
|
GEN_ASSERT(include);
|
||||||
|
return strbuilder_fmt_buf( _ctx->Allocator_Temp, "#include %S\n", include->Content );
|
||||||
|
}
|
||||||
|
|
||||||
|
inline
|
||||||
|
void include_to_strbuilder_ref( CodeInclude include, StrBuilder* result )
|
||||||
|
{
|
||||||
|
GEN_ASSERT(include);
|
||||||
|
GEN_ASSERT(result);
|
||||||
|
strbuilder_append_fmt( result, "#include %S\n", include->Content );
|
||||||
|
}
|
||||||
|
|
||||||
inline
|
inline
|
||||||
StrBuilder module_to_strbuilder(CodeModule self)
|
StrBuilder module_to_strbuilder(CodeModule self)
|
||||||
{
|
{
|
||||||
|
GEN_ASSERT(self);
|
||||||
StrBuilder result = strbuilder_make_reserve( _ctx->Allocator_Temp, 64 );
|
StrBuilder result = strbuilder_make_reserve( _ctx->Allocator_Temp, 64 );
|
||||||
module_to_strbuilder_ref( self, & result );
|
module_to_strbuilder_ref( self, & result );
|
||||||
return result;
|
return result;
|
||||||
@ -143,6 +148,7 @@ StrBuilder module_to_strbuilder(CodeModule self)
|
|||||||
inline
|
inline
|
||||||
StrBuilder namespace_to_strbuilder(CodeNS self)
|
StrBuilder namespace_to_strbuilder(CodeNS self)
|
||||||
{
|
{
|
||||||
|
GEN_ASSERT(self);
|
||||||
StrBuilder result = strbuilder_make_reserve( _ctx->Allocator_Temp, 512 );
|
StrBuilder result = strbuilder_make_reserve( _ctx->Allocator_Temp, 512 );
|
||||||
namespace_to_strbuilder_ref( self, & result );
|
namespace_to_strbuilder_ref( self, & result );
|
||||||
return result;
|
return result;
|
||||||
@ -151,6 +157,8 @@ StrBuilder namespace_to_strbuilder(CodeNS self)
|
|||||||
inline
|
inline
|
||||||
void namespace_to_strbuilder_ref(CodeNS self, StrBuilder* result )
|
void namespace_to_strbuilder_ref(CodeNS self, StrBuilder* result )
|
||||||
{
|
{
|
||||||
|
GEN_ASSERT(self);
|
||||||
|
GEN_ASSERT(result);
|
||||||
if ( bitfield_is_set( u32, self->ModuleFlags, ModuleFlag_Export ))
|
if ( bitfield_is_set( u32, self->ModuleFlags, ModuleFlag_Export ))
|
||||||
strbuilder_append_str( result, txt("export ") );
|
strbuilder_append_str( result, txt("export ") );
|
||||||
|
|
||||||
@ -166,48 +174,6 @@ StrBuilder params_to_strbuilder(CodeParams self)
|
|||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
inline
|
|
||||||
void preprocess_to_strbuilder_if(CodePreprocessCond cond, StrBuilder* result )
|
|
||||||
{
|
|
||||||
GEN_ASSERT(cond);
|
|
||||||
strbuilder_append_fmt( result, "#if %S", cond->Content );
|
|
||||||
}
|
|
||||||
|
|
||||||
inline
|
|
||||||
void preprocess_to_strbuilder_ifdef(CodePreprocessCond cond, StrBuilder* result )
|
|
||||||
{
|
|
||||||
GEN_ASSERT(cond);
|
|
||||||
strbuilder_append_fmt( result, "#ifdef %S\n", cond->Content );
|
|
||||||
}
|
|
||||||
|
|
||||||
inline
|
|
||||||
void preprocess_to_strbuilder_ifndef(CodePreprocessCond cond, StrBuilder* result )
|
|
||||||
{
|
|
||||||
GEN_ASSERT(cond);
|
|
||||||
strbuilder_append_fmt( result, "#ifndef %S", cond->Content );
|
|
||||||
}
|
|
||||||
|
|
||||||
inline
|
|
||||||
void preprocess_to_strbuilder_elif(CodePreprocessCond cond, StrBuilder* result )
|
|
||||||
{
|
|
||||||
GEN_ASSERT(cond);
|
|
||||||
strbuilder_append_fmt( result, "#elif %S\n", cond->Content );
|
|
||||||
}
|
|
||||||
|
|
||||||
inline
|
|
||||||
void preprocess_to_strbuilder_else(CodePreprocessCond cond, StrBuilder* result )
|
|
||||||
{
|
|
||||||
GEN_ASSERT(cond);
|
|
||||||
strbuilder_append_str( result, txt("#else\n") );
|
|
||||||
}
|
|
||||||
|
|
||||||
inline
|
|
||||||
void preprocess_to_strbuilder_endif(CodePreprocessCond cond, StrBuilder* result )
|
|
||||||
{
|
|
||||||
GEN_ASSERT(cond);
|
|
||||||
strbuilder_append_str( result, txt("#endif\n") );
|
|
||||||
}
|
|
||||||
|
|
||||||
inline
|
inline
|
||||||
StrBuilder pragma_to_strbuilder(CodePragma self)
|
StrBuilder pragma_to_strbuilder(CodePragma self)
|
||||||
{
|
{
|
||||||
@ -220,12 +186,63 @@ StrBuilder pragma_to_strbuilder(CodePragma self)
|
|||||||
inline
|
inline
|
||||||
void pragma_to_strbuilder_ref(CodePragma self, StrBuilder* result )
|
void pragma_to_strbuilder_ref(CodePragma self, StrBuilder* result )
|
||||||
{
|
{
|
||||||
|
GEN_ASSERT(self);
|
||||||
|
GEN_ASSERT(result);
|
||||||
strbuilder_append_fmt( result, "#pragma %S\n", self->Content );
|
strbuilder_append_fmt( result, "#pragma %S\n", self->Content );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
inline
|
||||||
|
void preprocess_to_strbuilder_if(CodePreprocessCond cond, StrBuilder* result )
|
||||||
|
{
|
||||||
|
GEN_ASSERT(cond);
|
||||||
|
GEN_ASSERT(result);
|
||||||
|
strbuilder_append_fmt( result, "#if %S", cond->Content );
|
||||||
|
}
|
||||||
|
|
||||||
|
inline
|
||||||
|
void preprocess_to_strbuilder_ifdef(CodePreprocessCond cond, StrBuilder* result )
|
||||||
|
{
|
||||||
|
GEN_ASSERT(cond);
|
||||||
|
GEN_ASSERT(result);
|
||||||
|
strbuilder_append_fmt( result, "#ifdef %S\n", cond->Content );
|
||||||
|
}
|
||||||
|
|
||||||
|
inline
|
||||||
|
void preprocess_to_strbuilder_ifndef(CodePreprocessCond cond, StrBuilder* result )
|
||||||
|
{
|
||||||
|
GEN_ASSERT(cond);
|
||||||
|
GEN_ASSERT(result);
|
||||||
|
strbuilder_append_fmt( result, "#ifndef %S", cond->Content );
|
||||||
|
}
|
||||||
|
|
||||||
|
inline
|
||||||
|
void preprocess_to_strbuilder_elif(CodePreprocessCond cond, StrBuilder* result )
|
||||||
|
{
|
||||||
|
GEN_ASSERT(cond);
|
||||||
|
GEN_ASSERT(result);
|
||||||
|
strbuilder_append_fmt( result, "#elif %S\n", cond->Content );
|
||||||
|
}
|
||||||
|
|
||||||
|
inline
|
||||||
|
void preprocess_to_strbuilder_else(CodePreprocessCond cond, StrBuilder* result )
|
||||||
|
{
|
||||||
|
GEN_ASSERT(cond);
|
||||||
|
GEN_ASSERT(result);
|
||||||
|
strbuilder_append_str( result, txt("#else\n") );
|
||||||
|
}
|
||||||
|
|
||||||
|
inline
|
||||||
|
void preprocess_to_strbuilder_endif(CodePreprocessCond cond, StrBuilder* result )
|
||||||
|
{
|
||||||
|
GEN_ASSERT(cond);
|
||||||
|
GEN_ASSERT(result);
|
||||||
|
strbuilder_append_str( result, txt("#endif\n") );
|
||||||
|
}
|
||||||
|
|
||||||
inline
|
inline
|
||||||
StrBuilder specifiers_to_strbuilder(CodeSpecifiers self)
|
StrBuilder specifiers_to_strbuilder(CodeSpecifiers self)
|
||||||
{
|
{
|
||||||
|
GEN_ASSERT(self);
|
||||||
StrBuilder result = strbuilder_make_reserve( _ctx->Allocator_Temp, 64 );
|
StrBuilder result = strbuilder_make_reserve( _ctx->Allocator_Temp, 64 );
|
||||||
specifiers_to_strbuilder_ref( self, & result );
|
specifiers_to_strbuilder_ref( self, & result );
|
||||||
return result;
|
return result;
|
||||||
@ -243,6 +260,7 @@ StrBuilder template_to_strbuilder(CodeTemplate self)
|
|||||||
inline
|
inline
|
||||||
StrBuilder typedef_to_strbuilder(CodeTypedef self)
|
StrBuilder typedef_to_strbuilder(CodeTypedef self)
|
||||||
{
|
{
|
||||||
|
GEN_ASSERT(self);
|
||||||
StrBuilder result = strbuilder_make_reserve( _ctx->Allocator_Temp, 128 );
|
StrBuilder result = strbuilder_make_reserve( _ctx->Allocator_Temp, 128 );
|
||||||
typedef_to_strbuilder_ref( self, & result );
|
typedef_to_strbuilder_ref( self, & result );
|
||||||
return result;
|
return result;
|
||||||
@ -251,6 +269,7 @@ StrBuilder typedef_to_strbuilder(CodeTypedef self)
|
|||||||
inline
|
inline
|
||||||
StrBuilder typename_to_strbuilder(CodeTypename self)
|
StrBuilder typename_to_strbuilder(CodeTypename self)
|
||||||
{
|
{
|
||||||
|
GEN_ASSERT(self);
|
||||||
StrBuilder result = strbuilder_make_str( _ctx->Allocator_Temp, txt("") );
|
StrBuilder result = strbuilder_make_str( _ctx->Allocator_Temp, txt("") );
|
||||||
typename_to_strbuilder_ref( self, & result );
|
typename_to_strbuilder_ref( self, & result );
|
||||||
return result;
|
return result;
|
||||||
|
@ -474,84 +474,3 @@ So the full call for this example would be:
|
|||||||
#pragma endregion Macros
|
#pragma endregion Macros
|
||||||
|
|
||||||
#pragma endregion Gen Interface
|
#pragma endregion Gen Interface
|
||||||
|
|
||||||
#pragma region Constants
|
|
||||||
// Predefined typename codes. Are set to readonly and are setup during gen::init()
|
|
||||||
|
|
||||||
GEN_API extern Macro enum_underlying_macro;
|
|
||||||
|
|
||||||
GEN_API extern Code access_public;
|
|
||||||
GEN_API extern Code access_protected;
|
|
||||||
GEN_API extern Code access_private;
|
|
||||||
|
|
||||||
GEN_API extern CodeAttributes attrib_api_export;
|
|
||||||
GEN_API extern CodeAttributes attrib_api_import;
|
|
||||||
|
|
||||||
GEN_API extern Code module_global_fragment;
|
|
||||||
GEN_API extern Code module_private_fragment;
|
|
||||||
|
|
||||||
GEN_API extern Code fmt_newline;
|
|
||||||
|
|
||||||
GEN_API extern CodePragma pragma_once;
|
|
||||||
|
|
||||||
GEN_API extern CodeParams param_varadic;
|
|
||||||
|
|
||||||
GEN_API extern CodePreprocessCond preprocess_else;
|
|
||||||
GEN_API extern CodePreprocessCond preprocess_endif;
|
|
||||||
|
|
||||||
GEN_API extern CodeSpecifiers spec_const;
|
|
||||||
GEN_API extern CodeSpecifiers spec_consteval;
|
|
||||||
GEN_API extern CodeSpecifiers spec_constexpr;
|
|
||||||
GEN_API extern CodeSpecifiers spec_constinit;
|
|
||||||
GEN_API extern CodeSpecifiers spec_extern_linkage;
|
|
||||||
GEN_API extern CodeSpecifiers spec_final;
|
|
||||||
GEN_API extern CodeSpecifiers spec_forceinline;
|
|
||||||
GEN_API extern CodeSpecifiers spec_global;
|
|
||||||
GEN_API extern CodeSpecifiers spec_inline;
|
|
||||||
GEN_API extern CodeSpecifiers spec_internal_linkage;
|
|
||||||
GEN_API extern CodeSpecifiers spec_local_persist;
|
|
||||||
GEN_API extern CodeSpecifiers spec_mutable;
|
|
||||||
GEN_API extern CodeSpecifiers spec_neverinline;
|
|
||||||
GEN_API extern CodeSpecifiers spec_noexcept;
|
|
||||||
GEN_API extern CodeSpecifiers spec_override;
|
|
||||||
GEN_API extern CodeSpecifiers spec_ptr;
|
|
||||||
GEN_API extern CodeSpecifiers spec_pure;
|
|
||||||
GEN_API extern CodeSpecifiers spec_ref;
|
|
||||||
GEN_API extern CodeSpecifiers spec_register;
|
|
||||||
GEN_API extern CodeSpecifiers spec_rvalue;
|
|
||||||
GEN_API extern CodeSpecifiers spec_static_member;
|
|
||||||
GEN_API extern CodeSpecifiers spec_thread_local;
|
|
||||||
GEN_API extern CodeSpecifiers spec_virtual;
|
|
||||||
GEN_API extern CodeSpecifiers spec_volatile;
|
|
||||||
|
|
||||||
GEN_API extern CodeTypename t_empty; // Used with varaidc parameters. (Exposing just in case its useful for another circumstance)
|
|
||||||
GEN_API extern CodeTypename t_auto;
|
|
||||||
GEN_API extern CodeTypename t_void;
|
|
||||||
GEN_API extern CodeTypename t_int;
|
|
||||||
GEN_API extern CodeTypename t_bool;
|
|
||||||
GEN_API extern CodeTypename t_char;
|
|
||||||
GEN_API extern CodeTypename t_wchar_t;
|
|
||||||
GEN_API extern CodeTypename t_class;
|
|
||||||
GEN_API extern CodeTypename t_typename;
|
|
||||||
|
|
||||||
#ifdef GEN_DEFINE_LIBRARY_CODE_CONSTANTS
|
|
||||||
GEN_API extern CodeTypename t_b32;
|
|
||||||
|
|
||||||
GEN_API extern CodeTypename t_s8;
|
|
||||||
GEN_API extern CodeTypename t_s16;
|
|
||||||
GEN_API extern CodeTypename t_s32;
|
|
||||||
GEN_API extern CodeTypename t_s64;
|
|
||||||
|
|
||||||
GEN_API extern CodeTypename t_u8;
|
|
||||||
GEN_API extern CodeTypename t_u16;
|
|
||||||
GEN_API extern CodeTypename t_u32;
|
|
||||||
GEN_API extern CodeTypename t_u64;
|
|
||||||
|
|
||||||
GEN_API extern CodeTypename t_ssize;
|
|
||||||
GEN_API extern CodeTypename t_usize;
|
|
||||||
|
|
||||||
GEN_API extern CodeTypename t_f32;
|
|
||||||
GEN_API extern CodeTypename t_f64;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#pragma endregion Constants
|
|
||||||
|
@ -488,6 +488,10 @@ void lex_found_token( LexContext* ctx )
|
|||||||
|
|
||||||
TokType type = str_to_toktype( ctx->token.Text );
|
TokType type = str_to_toktype( ctx->token.Text );
|
||||||
|
|
||||||
|
if (type == Tok_Preprocess_Define || type == Tok_Preprocess_Include) {
|
||||||
|
ctx->token.Flags |= TF_Identifier;
|
||||||
|
}
|
||||||
|
|
||||||
if (type <= Tok_Access_Public && type >= Tok_Access_Private ) {
|
if (type <= Tok_Access_Public && type >= Tok_Access_Private ) {
|
||||||
ctx->token.Flags |= TF_AccessSpecifier;
|
ctx->token.Flags |= TF_AccessSpecifier;
|
||||||
}
|
}
|
||||||
|
@ -2788,10 +2788,10 @@ CodeParams parse_params( bool use_template_capture )
|
|||||||
}
|
}
|
||||||
// ( <Macro> <ValueType>
|
// ( <Macro> <ValueType>
|
||||||
|
|
||||||
if ( check( Tok_Identifier ) )
|
if ( check( Tok_Identifier ) || bitfield_is_set(u32, currtok.Flags, TF_Identifier) )
|
||||||
{
|
{
|
||||||
name = currtok;
|
name = currtok;
|
||||||
eat( Tok_Identifier );
|
eat( currtok.Type );
|
||||||
// ( <Macro> <ValueType> <Name>
|
// ( <Macro> <ValueType> <Name>
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -2899,10 +2899,10 @@ CodeParams parse_params( bool use_template_capture )
|
|||||||
|
|
||||||
name = NullToken;
|
name = NullToken;
|
||||||
|
|
||||||
if ( check( Tok_Identifier ) )
|
if ( check( Tok_Identifier ) || bitfield_is_set(u32, currtok.Flags, TF_Identifier) )
|
||||||
{
|
{
|
||||||
name = currtok;
|
name = currtok;
|
||||||
eat( Tok_Identifier );
|
eat( currtok.Type );
|
||||||
// ( <Macro> <ValueType> <Name> = <Expression>, <Macro> <ValueType> <Name>
|
// ( <Macro> <ValueType> <Name> = <Expression>, <Macro> <ValueType> <Name>
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -11,17 +11,18 @@ enum TokFlags : u32
|
|||||||
{
|
{
|
||||||
TF_Operator = bit(0),
|
TF_Operator = bit(0),
|
||||||
TF_Assign = bit(1),
|
TF_Assign = bit(1),
|
||||||
TF_Preprocess = bit(2),
|
TF_Identifier = bit(2),
|
||||||
TF_Preprocess_Cond = bit(3),
|
TF_Preprocess = bit(3),
|
||||||
TF_Attribute = bit(6),
|
TF_Preprocess_Cond = bit(4),
|
||||||
TF_AccessOperator = bit(7),
|
TF_Attribute = bit(5),
|
||||||
TF_AccessSpecifier = bit(8),
|
TF_AccessOperator = bit(6),
|
||||||
TF_Specifier = bit(9),
|
TF_AccessSpecifier = bit(7),
|
||||||
TF_EndDefinition = bit(10), // Either ; or }
|
TF_Specifier = bit(8),
|
||||||
TF_Formatting = bit(11),
|
TF_EndDefinition = bit(9), // Either ; or }
|
||||||
TF_Literal = bit(12),
|
TF_Formatting = bit(10),
|
||||||
TF_Macro_Functional = bit(13),
|
TF_Literal = bit(11),
|
||||||
TF_Macro_Expects_Body = bit(14),
|
TF_Macro_Functional = bit(12),
|
||||||
|
TF_Macro_Expects_Body = bit(13),
|
||||||
|
|
||||||
TF_Null = 0,
|
TF_Null = 0,
|
||||||
TF_UnderlyingType = GEN_U32_MAX,
|
TF_UnderlyingType = GEN_U32_MAX,
|
||||||
|
@ -58,4 +58,120 @@ StrBuilder strbuilder_make_reserve( AllocatorInfo allocator, ssize capacity )
|
|||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool strbuilder_make_space_for(StrBuilder* str, char const* to_append, ssize add_len)
|
||||||
|
{
|
||||||
|
ssize available = strbuilder_avail_space(* str);
|
||||||
|
|
||||||
|
if (available >= add_len) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
ssize new_len, old_size, new_size;
|
||||||
|
void* ptr;
|
||||||
|
void* new_ptr;
|
||||||
|
|
||||||
|
AllocatorInfo allocator = strbuilder_get_header(* str)->Allocator;
|
||||||
|
StrBuilderHeader* header = nullptr;
|
||||||
|
|
||||||
|
new_len = strbuilder_grow_formula(strbuilder_length(* str) + add_len);
|
||||||
|
ptr = strbuilder_get_header(* str);
|
||||||
|
old_size = size_of(StrBuilderHeader) + strbuilder_length(* str) + 1;
|
||||||
|
new_size = size_of(StrBuilderHeader) + new_len + 1;
|
||||||
|
|
||||||
|
new_ptr = resize(allocator, ptr, old_size, new_size);
|
||||||
|
|
||||||
|
if (new_ptr == nullptr)
|
||||||
|
return false;
|
||||||
|
|
||||||
|
header = rcast(StrBuilderHeader*, new_ptr);
|
||||||
|
header->Allocator = allocator;
|
||||||
|
header->Capacity = new_len;
|
||||||
|
|
||||||
|
char** Data = rcast(char**, str);
|
||||||
|
* Data = rcast(char*, header + 1);
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
bool strbuilder_append_c_str_len(StrBuilder* str, char const* c_str_to_append, ssize append_length)
|
||||||
|
{
|
||||||
|
GEN_ASSERT(str != nullptr);
|
||||||
|
if ( rcast(sptr, c_str_to_append) > 0)
|
||||||
|
{
|
||||||
|
ssize curr_len = strbuilder_length(* str);
|
||||||
|
|
||||||
|
if ( ! strbuilder_make_space_for(str, c_str_to_append, append_length))
|
||||||
|
return false;
|
||||||
|
|
||||||
|
StrBuilderHeader* header = strbuilder_get_header(* str);
|
||||||
|
|
||||||
|
char* Data = * str;
|
||||||
|
mem_copy( Data + curr_len, c_str_to_append, append_length);
|
||||||
|
|
||||||
|
Data[curr_len + append_length] = '\0';
|
||||||
|
|
||||||
|
header->Length = curr_len + append_length;
|
||||||
|
}
|
||||||
|
return c_str_to_append != nullptr;
|
||||||
|
}
|
||||||
|
|
||||||
|
void strbuilder_trim(StrBuilder str, char const* cut_set)
|
||||||
|
{
|
||||||
|
ssize len = 0;
|
||||||
|
|
||||||
|
char* start_pos = str;
|
||||||
|
char* end_pos = scast(char*, str) + strbuilder_length(str) - 1;
|
||||||
|
|
||||||
|
while (start_pos <= end_pos && char_first_occurence(cut_set, *start_pos))
|
||||||
|
start_pos++;
|
||||||
|
|
||||||
|
while (end_pos > start_pos && char_first_occurence(cut_set, *end_pos))
|
||||||
|
end_pos--;
|
||||||
|
|
||||||
|
len = scast(ssize, (start_pos > end_pos) ? 0 : ((end_pos - start_pos) + 1));
|
||||||
|
|
||||||
|
if (str != start_pos)
|
||||||
|
mem_move(str, start_pos, len);
|
||||||
|
|
||||||
|
str[len] = '\0';
|
||||||
|
|
||||||
|
strbuilder_get_header(str)->Length = len;
|
||||||
|
}
|
||||||
|
|
||||||
|
StrBuilder strbuilder_visualize_whitespace(StrBuilder const str)
|
||||||
|
{
|
||||||
|
StrBuilderHeader* header = (StrBuilderHeader*)(scast(char const*, str) - sizeof(StrBuilderHeader));
|
||||||
|
StrBuilder result = strbuilder_make_reserve(header->Allocator, strbuilder_length(str) * 2); // Assume worst case for space requirements.
|
||||||
|
|
||||||
|
for (char const* c = strbuilder_begin(str); c != strbuilder_end(str); c = strbuilder_next(str, c))
|
||||||
|
switch ( * c )
|
||||||
|
{
|
||||||
|
case ' ':
|
||||||
|
strbuilder_append_str(& result, txt("·"));
|
||||||
|
break;
|
||||||
|
case '\t':
|
||||||
|
strbuilder_append_str(& result, txt("→"));
|
||||||
|
break;
|
||||||
|
case '\n':
|
||||||
|
strbuilder_append_str(& result, txt("↵"));
|
||||||
|
break;
|
||||||
|
case '\r':
|
||||||
|
strbuilder_append_str(& result, txt("⏎"));
|
||||||
|
break;
|
||||||
|
case '\v':
|
||||||
|
strbuilder_append_str(& result, txt("⇕"));
|
||||||
|
break;
|
||||||
|
case '\f':
|
||||||
|
strbuilder_append_str(& result, txt("⌂"));
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
strbuilder_append_char(& result, * c);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
#pragma endregion StrBuilder
|
#pragma endregion StrBuilder
|
||||||
|
@ -124,6 +124,10 @@ forceinline usize strbuilder_grow_formula(usize value);
|
|||||||
|
|
||||||
GEN_API StrBuilder strbuilder_make_reserve (AllocatorInfo allocator, ssize capacity);
|
GEN_API StrBuilder strbuilder_make_reserve (AllocatorInfo allocator, ssize capacity);
|
||||||
GEN_API StrBuilder strbuilder_make_length (AllocatorInfo allocator, char const* str, ssize length);
|
GEN_API StrBuilder strbuilder_make_length (AllocatorInfo allocator, char const* str, ssize length);
|
||||||
|
GEN_API bool strbuilder_make_space_for (StrBuilder* str, char const* to_append, ssize add_len);
|
||||||
|
GEN_API bool strbuilder_append_c_str_len (StrBuilder* str, char const* c_str_to_append, ssize length);
|
||||||
|
GEN_API void strbuilder_trim (StrBuilder str, char const* cut_set);
|
||||||
|
GEN_API StrBuilder strbuilder_visualize_whitespace(StrBuilder const str);
|
||||||
|
|
||||||
StrBuilder strbuilder_make_c_str (AllocatorInfo allocator, char const* str);
|
StrBuilder strbuilder_make_c_str (AllocatorInfo allocator, char const* str);
|
||||||
StrBuilder strbuilder_make_str (AllocatorInfo allocator, Str str);
|
StrBuilder strbuilder_make_str (AllocatorInfo allocator, Str str);
|
||||||
@ -132,10 +136,8 @@ StrBuilder strbuilder_fmt_buf (AllocatorInfo allocator, char
|
|||||||
StrBuilder strbuilder_join (AllocatorInfo allocator, char const** parts, ssize num_parts, char const* glue);
|
StrBuilder strbuilder_join (AllocatorInfo allocator, char const** parts, ssize num_parts, char const* glue);
|
||||||
bool strbuilder_are_equal (StrBuilder const lhs, StrBuilder const rhs);
|
bool strbuilder_are_equal (StrBuilder const lhs, StrBuilder const rhs);
|
||||||
bool strbuilder_are_equal_str (StrBuilder const lhs, Str rhs);
|
bool strbuilder_are_equal_str (StrBuilder const lhs, Str rhs);
|
||||||
bool strbuilder_make_space_for (StrBuilder* str, char const* to_append, ssize add_len);
|
|
||||||
bool strbuilder_append_char (StrBuilder* str, char c);
|
bool strbuilder_append_char (StrBuilder* str, char c);
|
||||||
bool strbuilder_append_c_str (StrBuilder* str, char const* c_str_to_append);
|
bool strbuilder_append_c_str (StrBuilder* str, char const* c_str_to_append);
|
||||||
bool strbuilder_append_c_str_len (StrBuilder* str, char const* c_str_to_append, ssize length);
|
|
||||||
bool strbuilder_append_str (StrBuilder* str, Str c_str_to_append);
|
bool strbuilder_append_str (StrBuilder* str, Str c_str_to_append);
|
||||||
bool strbuilder_append_string (StrBuilder* str, StrBuilder const other);
|
bool strbuilder_append_string (StrBuilder* str, StrBuilder const other);
|
||||||
bool strbuilder_append_fmt (StrBuilder* str, char const* fmt, ...);
|
bool strbuilder_append_fmt (StrBuilder* str, char const* fmt, ...);
|
||||||
@ -154,9 +156,7 @@ b32 strbuilder_starts_with_string (StrBuilder const str, StrBuild
|
|||||||
void strbuilder_skip_line (StrBuilder str);
|
void strbuilder_skip_line (StrBuilder str);
|
||||||
void strbuilder_strip_space (StrBuilder str);
|
void strbuilder_strip_space (StrBuilder str);
|
||||||
Str strbuilder_to_str (StrBuilder str);
|
Str strbuilder_to_str (StrBuilder str);
|
||||||
void strbuilder_trim (StrBuilder str, char const* cut_set);
|
|
||||||
void strbuilder_trim_space (StrBuilder str);
|
void strbuilder_trim_space (StrBuilder str);
|
||||||
StrBuilder strbuilder_visualize_whitespace(StrBuilder const str);
|
|
||||||
|
|
||||||
struct StrBuilderHeader {
|
struct StrBuilderHeader {
|
||||||
AllocatorInfo Allocator;
|
AllocatorInfo Allocator;
|
||||||
@ -358,29 +358,6 @@ bool strbuilder_append_c_str(StrBuilder* str, char const* c_str_to_append) {
|
|||||||
return strbuilder_append_c_str_len(str, c_str_to_append, c_str_len(c_str_to_append));
|
return strbuilder_append_c_str_len(str, c_str_to_append, c_str_len(c_str_to_append));
|
||||||
}
|
}
|
||||||
|
|
||||||
inline
|
|
||||||
bool strbuilder_append_c_str_len(StrBuilder* str, char const* c_str_to_append, ssize append_length)
|
|
||||||
{
|
|
||||||
GEN_ASSERT(str != nullptr);
|
|
||||||
if ( rcast(sptr, c_str_to_append) > 0)
|
|
||||||
{
|
|
||||||
ssize curr_len = strbuilder_length(* str);
|
|
||||||
|
|
||||||
if ( ! strbuilder_make_space_for(str, c_str_to_append, append_length))
|
|
||||||
return false;
|
|
||||||
|
|
||||||
StrBuilderHeader* header = strbuilder_get_header(* str);
|
|
||||||
|
|
||||||
char* Data = * str;
|
|
||||||
mem_copy( Data + curr_len, c_str_to_append, append_length);
|
|
||||||
|
|
||||||
Data[curr_len + append_length] = '\0';
|
|
||||||
|
|
||||||
header->Length = curr_len + append_length;
|
|
||||||
}
|
|
||||||
return c_str_to_append != nullptr;
|
|
||||||
}
|
|
||||||
|
|
||||||
forceinline
|
forceinline
|
||||||
bool strbuilder_append_str(StrBuilder* str, Str c_str_to_append) {
|
bool strbuilder_append_str(StrBuilder* str, Str c_str_to_append) {
|
||||||
GEN_ASSERT(str != nullptr);
|
GEN_ASSERT(str != nullptr);
|
||||||
@ -522,44 +499,6 @@ ssize strbuilder_length(StrBuilder const str)
|
|||||||
return header->Length;
|
return header->Length;
|
||||||
}
|
}
|
||||||
|
|
||||||
inline
|
|
||||||
bool strbuilder_make_space_for(StrBuilder* str, char const* to_append, ssize add_len)
|
|
||||||
{
|
|
||||||
ssize available = strbuilder_avail_space(* str);
|
|
||||||
|
|
||||||
if (available >= add_len) {
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
ssize new_len, old_size, new_size;
|
|
||||||
void* ptr;
|
|
||||||
void* new_ptr;
|
|
||||||
|
|
||||||
AllocatorInfo allocator = strbuilder_get_header(* str)->Allocator;
|
|
||||||
StrBuilderHeader* header = nullptr;
|
|
||||||
|
|
||||||
new_len = strbuilder_grow_formula(strbuilder_length(* str) + add_len);
|
|
||||||
ptr = strbuilder_get_header(* str);
|
|
||||||
old_size = size_of(StrBuilderHeader) + strbuilder_length(* str) + 1;
|
|
||||||
new_size = size_of(StrBuilderHeader) + new_len + 1;
|
|
||||||
|
|
||||||
new_ptr = resize(allocator, ptr, old_size, new_size);
|
|
||||||
|
|
||||||
if (new_ptr == nullptr)
|
|
||||||
return false;
|
|
||||||
|
|
||||||
header = rcast(StrBuilderHeader*, new_ptr);
|
|
||||||
header->Allocator = allocator;
|
|
||||||
header->Capacity = new_len;
|
|
||||||
|
|
||||||
char** Data = rcast(char**, str);
|
|
||||||
* Data = rcast(char*, header + 1);
|
|
||||||
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
forceinline
|
forceinline
|
||||||
b32 strbuilder_starts_with_str(StrBuilder const str, Str substring) {
|
b32 strbuilder_starts_with_str(StrBuilder const str, Str substring) {
|
||||||
if (substring.Len > strbuilder_length(str))
|
if (substring.Len > strbuilder_length(str))
|
||||||
@ -627,69 +566,11 @@ Str strbuilder_to_str(StrBuilder str) {
|
|||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
inline
|
|
||||||
void strbuilder_trim(StrBuilder str, char const* cut_set)
|
|
||||||
{
|
|
||||||
ssize len = 0;
|
|
||||||
|
|
||||||
char* start_pos = str;
|
|
||||||
char* end_pos = scast(char*, str) + strbuilder_length(str) - 1;
|
|
||||||
|
|
||||||
while (start_pos <= end_pos && char_first_occurence(cut_set, *start_pos))
|
|
||||||
start_pos++;
|
|
||||||
|
|
||||||
while (end_pos > start_pos && char_first_occurence(cut_set, *end_pos))
|
|
||||||
end_pos--;
|
|
||||||
|
|
||||||
len = scast(ssize, (start_pos > end_pos) ? 0 : ((end_pos - start_pos) + 1));
|
|
||||||
|
|
||||||
if (str != start_pos)
|
|
||||||
mem_move(str, start_pos, len);
|
|
||||||
|
|
||||||
str[len] = '\0';
|
|
||||||
|
|
||||||
strbuilder_get_header(str)->Length = len;
|
|
||||||
}
|
|
||||||
|
|
||||||
forceinline
|
forceinline
|
||||||
void strbuilder_trim_space(StrBuilder str) {
|
void strbuilder_trim_space(StrBuilder str) {
|
||||||
strbuilder_trim(str, " \t\r\n\v\f");
|
strbuilder_trim(str, " \t\r\n\v\f");
|
||||||
}
|
}
|
||||||
|
|
||||||
inline
|
|
||||||
StrBuilder strbuilder_visualize_whitespace(StrBuilder const str)
|
|
||||||
{
|
|
||||||
StrBuilderHeader* header = (StrBuilderHeader*)(scast(char const*, str) - sizeof(StrBuilderHeader));
|
|
||||||
StrBuilder result = strbuilder_make_reserve(header->Allocator, strbuilder_length(str) * 2); // Assume worst case for space requirements.
|
|
||||||
|
|
||||||
for (char const* c = strbuilder_begin(str); c != strbuilder_end(str); c = strbuilder_next(str, c))
|
|
||||||
switch ( * c )
|
|
||||||
{
|
|
||||||
case ' ':
|
|
||||||
strbuilder_append_str(& result, txt("·"));
|
|
||||||
break;
|
|
||||||
case '\t':
|
|
||||||
strbuilder_append_str(& result, txt("→"));
|
|
||||||
break;
|
|
||||||
case '\n':
|
|
||||||
strbuilder_append_str(& result, txt("↵"));
|
|
||||||
break;
|
|
||||||
case '\r':
|
|
||||||
strbuilder_append_str(& result, txt("⏎"));
|
|
||||||
break;
|
|
||||||
case '\v':
|
|
||||||
strbuilder_append_str(& result, txt("⇕"));
|
|
||||||
break;
|
|
||||||
case '\f':
|
|
||||||
strbuilder_append_str(& result, txt("⌂"));
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
strbuilder_append_char(& result, * c);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
return result;
|
|
||||||
}
|
|
||||||
#pragma endregion StrBuilder
|
#pragma endregion StrBuilder
|
||||||
|
|
||||||
#if GEN_COMPILER_CPP
|
#if GEN_COMPILER_CPP
|
||||||
|
@ -29,9 +29,9 @@ GEN_NS_BEGIN
|
|||||||
|
|
||||||
#include "components/interface.hpp"
|
#include "components/interface.hpp"
|
||||||
|
|
||||||
|
#include "components/constants.hpp"
|
||||||
#include "components/inlines.hpp"
|
#include "components/inlines.hpp"
|
||||||
#include "components/gen/ast_inlines.hpp"
|
#include "components/gen/ast_inlines.hpp"
|
||||||
#include "components/header_end.hpp"
|
|
||||||
|
|
||||||
#include "auxiliary/builder.hpp"
|
#include "auxiliary/builder.hpp"
|
||||||
#include "auxiliary/scanner.hpp"
|
#include "auxiliary/scanner.hpp"
|
||||||
|
@ -509,7 +509,7 @@ do \
|
|||||||
case CT_Variable:
|
case CT_Variable:
|
||||||
{
|
{
|
||||||
CodeVar var = cast(CodeVar, entry);
|
CodeVar var = cast(CodeVar, entry);
|
||||||
if (var->Specs.has(Spec_Constexpr) > -1)
|
if (var->Specs.has(Spec_Constexpr))
|
||||||
{
|
{
|
||||||
Opts_def_define opts = { {}, entry->Value->Content };
|
Opts_def_define opts = { {}, entry->Value->Content };
|
||||||
CodeDefine define = def_define(entry->Name, MT_Expression, opts);
|
CodeDefine define = def_define(entry->Name, MT_Expression, opts);
|
||||||
@ -769,7 +769,7 @@ do \
|
|||||||
case CT_Variable:
|
case CT_Variable:
|
||||||
{
|
{
|
||||||
CodeVar var = cast(CodeVar, entry);
|
CodeVar var = cast(CodeVar, entry);
|
||||||
if (var->Specs && var->Specs.has(Spec_Constexpr) > -1) {
|
if (var->Specs && var->Specs.has(Spec_Constexpr)) {
|
||||||
Code define_ver = untyped_str(token_fmt(
|
Code define_ver = untyped_str(token_fmt(
|
||||||
"name", var->Name
|
"name", var->Name
|
||||||
, "value", var->Value->Content
|
, "value", var->Value->Content
|
||||||
@ -1257,16 +1257,16 @@ R"(#define <interface_name>( code ) _Generic( (code), \
|
|||||||
}
|
}
|
||||||
|
|
||||||
s32 idx = 0;
|
s32 idx = 0;
|
||||||
CodeBody parsed_header_end = parse_file( path_base "components/header_end.hpp" );
|
CodeBody parsed_constants = parse_file( path_base "components/constants.hpp" );
|
||||||
CodeBody header_end = def_body(CT_Global_Body);
|
CodeBody constants = def_body(CT_Global_Body);
|
||||||
for ( Code entry = parsed_header_end.begin(); entry != parsed_header_end.end(); ++ entry, ++ idx ) switch( entry->Type )
|
for ( Code entry = parsed_constants.begin(); entry != parsed_constants.end(); ++ entry, ++ idx ) switch( entry->Type )
|
||||||
{
|
{
|
||||||
case CT_Preprocess_IfDef:
|
case CT_Preprocess_IfDef:
|
||||||
{
|
{
|
||||||
b32 found = ignore_preprocess_cond_block(txt("GEN_INTELLISENSE_DIRECTIVES"), entry, parsed_header_end, header_end );
|
b32 found = ignore_preprocess_cond_block(txt("GEN_INTELLISENSE_DIRECTIVES"), entry, parsed_constants, constants );
|
||||||
if (found) break;
|
if (found) break;
|
||||||
|
|
||||||
header_end.append(entry);
|
constants.append(entry);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
@ -1280,16 +1280,16 @@ R"(#define <interface_name>( code ) _Generic( (code), \
|
|||||||
{
|
{
|
||||||
Opts_def_define opts = { {}, entry->Value->Content };
|
Opts_def_define opts = { {}, entry->Value->Content };
|
||||||
CodeDefine define = def_define(entry->Name, MT_Expression, opts );
|
CodeDefine define = def_define(entry->Name, MT_Expression, opts );
|
||||||
header_end.append(define);
|
constants.append(define);
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
header_end.append(entry);
|
constants.append(entry);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
header_end.append(entry);
|
constants.append(entry);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
#pragma endregion Resolve Components
|
#pragma endregion Resolve Components
|
||||||
@ -1542,7 +1542,7 @@ R"(#define <interface_name>( code ) _Generic( (code), \
|
|||||||
case CT_Variable:
|
case CT_Variable:
|
||||||
{
|
{
|
||||||
CodeVar var = cast(CodeVar, entry);
|
CodeVar var = cast(CodeVar, entry);
|
||||||
if (var->Specs && var->Specs.has(Spec_Constexpr) > -1) {
|
if (var->Specs && var->Specs.has(Spec_Constexpr)) {
|
||||||
Code define_ver = untyped_str(token_fmt(
|
Code define_ver = untyped_str(token_fmt(
|
||||||
"name", var->Name
|
"name", var->Name
|
||||||
, "value", var->Value->Content
|
, "value", var->Value->Content
|
||||||
@ -1587,7 +1587,7 @@ R"(#define <interface_name>( code ) _Generic( (code), \
|
|||||||
case CT_Variable:
|
case CT_Variable:
|
||||||
{
|
{
|
||||||
CodeVar var = cast(CodeVar, entry);
|
CodeVar var = cast(CodeVar, entry);
|
||||||
if (var->Specs && var->Specs.has(Spec_Constexpr) > -1) {
|
if (var->Specs && var->Specs.has(Spec_Constexpr)) {
|
||||||
Code define_ver = untyped_str(token_fmt(
|
Code define_ver = untyped_str(token_fmt(
|
||||||
"name", var->Name
|
"name", var->Name
|
||||||
, "value", var->Value->Content
|
, "value", var->Value->Content
|
||||||
@ -1673,11 +1673,11 @@ R"(#define <interface_name>( code ) _Generic( (code), \
|
|||||||
Code rf_ast_types = refactor_and_format(ast_types);
|
Code rf_ast_types = refactor_and_format(ast_types);
|
||||||
|
|
||||||
Code rf_interface = refactor_and_format(interface);
|
Code rf_interface = refactor_and_format(interface);
|
||||||
|
Code rf_constants = refactor_and_format(constants);
|
||||||
Code rf_inlines = refactor_and_format(inlines);
|
Code rf_inlines = refactor_and_format(inlines);
|
||||||
|
|
||||||
Code rf_ht_preprocessor_macro = refactor_and_format(ht_preprocessor_macro);
|
Code rf_ht_preprocessor_macro = refactor_and_format(ht_preprocessor_macro);
|
||||||
Code rf_array_string_cached = refactor_and_format(array_string_cached);
|
Code rf_array_string_cached = refactor_and_format(array_string_cached);
|
||||||
Code rf_header_end = refactor_and_format(header_end);
|
|
||||||
Code rf_header_builder = refactor_and_format(header_builder);
|
Code rf_header_builder = refactor_and_format(header_builder);
|
||||||
Code rf_header_scanner = refactor_and_format( scan_file( path_base "auxiliary/scanner.hpp" ));
|
Code rf_header_scanner = refactor_and_format( scan_file( path_base "auxiliary/scanner.hpp" ));
|
||||||
|
|
||||||
@ -1788,6 +1788,7 @@ R"(#define <interface_name>( code ) _Generic( (code), \
|
|||||||
header.print( rf_ht_preprocessor_macro );
|
header.print( rf_ht_preprocessor_macro );
|
||||||
|
|
||||||
header.print( rf_interface );
|
header.print( rf_interface );
|
||||||
|
header.print( rf_constants );
|
||||||
header.print(fmt_newline);
|
header.print(fmt_newline);
|
||||||
|
|
||||||
header.print_fmt("#pragma region Inlines\n");
|
header.print_fmt("#pragma region Inlines\n");
|
||||||
@ -1796,7 +1797,6 @@ R"(#define <interface_name>( code ) _Generic( (code), \
|
|||||||
|
|
||||||
header.print(fmt_newline);
|
header.print(fmt_newline);
|
||||||
|
|
||||||
header.print( rf_header_end );
|
|
||||||
header.print( rf_header_builder );
|
header.print( rf_header_builder );
|
||||||
header.print( rf_header_scanner );
|
header.print( rf_header_scanner );
|
||||||
|
|
||||||
@ -1950,6 +1950,7 @@ R"(#define <interface_name>( code ) _Generic( (code), \
|
|||||||
header.print_fmt("\n#pragma endregion AST\n");
|
header.print_fmt("\n#pragma endregion AST\n");
|
||||||
|
|
||||||
header.print( rf_interface );
|
header.print( rf_interface );
|
||||||
|
header.print( rf_constants );
|
||||||
header.print(fmt_newline);
|
header.print(fmt_newline);
|
||||||
|
|
||||||
header.print_fmt("#pragma region Inlines\n");
|
header.print_fmt("#pragma region Inlines\n");
|
||||||
@ -1959,7 +1960,6 @@ R"(#define <interface_name>( code ) _Generic( (code), \
|
|||||||
header.print(fmt_newline);
|
header.print(fmt_newline);
|
||||||
header.print( rf_array_string_cached );
|
header.print( rf_array_string_cached );
|
||||||
|
|
||||||
header.print( rf_header_end );
|
|
||||||
header.print( rf_header_builder );
|
header.print( rf_header_builder );
|
||||||
header.print( rf_header_scanner );
|
header.print( rf_header_scanner );
|
||||||
|
|
||||||
|
@ -13,7 +13,7 @@
|
|||||||
| \_____|\___}_l |_|\___} .__/| .__/ {_____/ \__\__/_l\__. |\___/\__,_l \____}{_____}{_____} |
|
| \_____|\___}_l |_|\___} .__/| .__/ {_____/ \__\__/_l\__. |\___/\__,_l \____}{_____}{_____} |
|
||||||
| | | | | __} | |
|
| | | | | __} | |
|
||||||
| l_l l_l {___/ |
|
| l_l l_l {___/ |
|
||||||
! ----------------------------------------------------------------------- VERSION: v0.23-Alpha |
|
! ----------------------------------------------------------------------- VERSION: v0.25-Alpha |
|
||||||
! ============================================================================================= |
|
! ============================================================================================= |
|
||||||
! WARNING: THIS IS AN ALPHA VERSION OF THE LIBRARY, USE AT YOUR OWN DISCRETION |
|
! WARNING: THIS IS AN ALPHA VERSION OF THE LIBRARY, USE AT YOUR OWN DISCRETION |
|
||||||
! NEVER DO CODE GENERATION WITHOUT AT LEAST HAVING CONTENT IN A CODEBASE UNDER VERSION CONTROL |
|
! NEVER DO CODE GENERATION WITHOUT AT LEAST HAVING CONTENT IN A CODEBASE UNDER VERSION CONTROL |
|
||||||
|
@ -131,8 +131,8 @@ int gen_main()
|
|||||||
Code ast_types = scan_file( path_base "components/ast_types.hpp" );
|
Code ast_types = scan_file( path_base "components/ast_types.hpp" );
|
||||||
Code code_types = scan_file( path_base "components/code_types.hpp" );
|
Code code_types = scan_file( path_base "components/code_types.hpp" );
|
||||||
Code interface = scan_file( path_base "components/interface.hpp" );
|
Code interface = scan_file( path_base "components/interface.hpp" );
|
||||||
|
Code constants = scan_file( path_base "components/constants.hpp");
|
||||||
Code inlines = scan_file( path_base "components/inlines.hpp" );
|
Code inlines = scan_file( path_base "components/inlines.hpp" );
|
||||||
Code header_end = scan_file( path_base "components/header_end.hpp" );
|
|
||||||
|
|
||||||
CodeBody ecode = gen_ecode ( path_base "enums/ECodeTypes.csv" );
|
CodeBody ecode = gen_ecode ( path_base "enums/ECodeTypes.csv" );
|
||||||
CodeBody eoperator = gen_eoperator ( path_base "enums/EOperator.csv" );
|
CodeBody eoperator = gen_eoperator ( path_base "enums/EOperator.csv" );
|
||||||
@ -168,6 +168,7 @@ int gen_main()
|
|||||||
builder_print_fmt( header, "\n#pragma endregion AST\n" );
|
builder_print_fmt( header, "\n#pragma endregion AST\n" );
|
||||||
|
|
||||||
builder_print( header, interface );
|
builder_print( header, interface );
|
||||||
|
builder_print( header, constants );
|
||||||
|
|
||||||
builder_print_fmt( header, "\n#pragma region Inlines\n" );
|
builder_print_fmt( header, "\n#pragma region Inlines\n" );
|
||||||
builder_print( header, inlines );
|
builder_print( header, inlines );
|
||||||
@ -176,7 +177,6 @@ int gen_main()
|
|||||||
builder_print( header, fmt_newline );
|
builder_print( header, fmt_newline );
|
||||||
builder_print_fmt( header, "#pragma endregion Inlines\n" );
|
builder_print_fmt( header, "#pragma endregion Inlines\n" );
|
||||||
|
|
||||||
builder_print( header, header_end );
|
|
||||||
builder_print_fmt( header, "\nGEN_NS_END\n\n" );
|
builder_print_fmt( header, "\nGEN_NS_END\n\n" );
|
||||||
builder_print( header, pop_ignores );
|
builder_print( header, pop_ignores );
|
||||||
builder_write(header);
|
builder_write(header);
|
||||||
|
@ -15,7 +15,7 @@
|
|||||||
| \_____|\___}_l |_|\___} ,__/| ,__/ (_____/ \__\__/_|\__, |\___}\__,_l |
|
| \_____|\___}_l |_|\___} ,__/| ,__/ (_____/ \__\__/_|\__, |\___}\__,_l |
|
||||||
| Singleheader | | | | __} | |
|
| Singleheader | | | | __} | |
|
||||||
| l_l l_l {___/ |
|
| l_l l_l {___/ |
|
||||||
! ----------------------------------------------------------------------- VERSION: v0.23-Alpha |
|
! ----------------------------------------------------------------------- VERSION: v0.25-Alpha |
|
||||||
! ============================================================================================ |
|
! ============================================================================================ |
|
||||||
! WARNING: THIS IS AN ALPHA VERSION OF THE LIBRARY, USE AT YOUR OWN DISCRETION |
|
! WARNING: THIS IS AN ALPHA VERSION OF THE LIBRARY, USE AT YOUR OWN DISCRETION |
|
||||||
! NEVER DO CODE GENERATION WITHOUT AT LEAST HAVING CONTENT IN A CODEBASE UNDER VERSION CONTROL |
|
! NEVER DO CODE GENERATION WITHOUT AT LEAST HAVING CONTENT IN A CODEBASE UNDER VERSION CONTROL |
|
||||||
|
@ -117,8 +117,8 @@ int gen_main()
|
|||||||
Code ast_types = scan_file( path_base "components/ast_types.hpp" );
|
Code ast_types = scan_file( path_base "components/ast_types.hpp" );
|
||||||
Code code_types = scan_file( path_base "components/code_types.hpp" );
|
Code code_types = scan_file( path_base "components/code_types.hpp" );
|
||||||
Code interface = scan_file( path_base "components/interface.hpp" );
|
Code interface = scan_file( path_base "components/interface.hpp" );
|
||||||
|
Code constants = scan_file( path_base "components/constants.hpp" );
|
||||||
Code inlines = scan_file( path_base "components/inlines.hpp" );
|
Code inlines = scan_file( path_base "components/inlines.hpp" );
|
||||||
Code header_end = scan_file( path_base "components/header_end.hpp" );
|
|
||||||
|
|
||||||
CodeBody ecode = gen_ecode ( path_base "enums/ECodeTypes.csv" );
|
CodeBody ecode = gen_ecode ( path_base "enums/ECodeTypes.csv" );
|
||||||
CodeBody eoperator = gen_eoperator ( path_base "enums/EOperator.csv" );
|
CodeBody eoperator = gen_eoperator ( path_base "enums/EOperator.csv" );
|
||||||
@ -149,6 +149,7 @@ int gen_main()
|
|||||||
header.print_fmt("\n#pragma endregion AST\n");
|
header.print_fmt("\n#pragma endregion AST\n");
|
||||||
|
|
||||||
header.print( interface );
|
header.print( interface );
|
||||||
|
header.print( constants );
|
||||||
|
|
||||||
header.print_fmt( "\n#pragma region Inlines\n" );
|
header.print_fmt( "\n#pragma region Inlines\n" );
|
||||||
header.print( inlines );
|
header.print( inlines );
|
||||||
@ -156,8 +157,6 @@ int gen_main()
|
|||||||
header.print( fmt_newline );
|
header.print( fmt_newline );
|
||||||
header.print_fmt( "#pragma endregion Inlines\n" );
|
header.print_fmt( "#pragma endregion Inlines\n" );
|
||||||
|
|
||||||
header.print( header_end );
|
|
||||||
|
|
||||||
if ( generate_builder ) {
|
if ( generate_builder ) {
|
||||||
header.print( scan_file( path_base "auxiliary/builder.hpp" ) );
|
header.print( scan_file( path_base "auxiliary/builder.hpp" ) );
|
||||||
}
|
}
|
||||||
|
@ -16,7 +16,7 @@
|
|||||||
| \_____|\___}_l |_|\___} ,__/| ,__/ (_____/ \__\__/_|\__, |\___}\__,_l |
|
| \_____|\___}_l |_|\___} ,__/| ,__/ (_____/ \__\__/_|\__, |\___}\__,_l |
|
||||||
| Unreal Engine | | | | __} | |
|
| Unreal Engine | | | | __} | |
|
||||||
| l_l l_l {___/ |
|
| l_l l_l {___/ |
|
||||||
! ----------------------------------------------------------------------- VERSION: v0.23-Alpha |
|
! ----------------------------------------------------------------------- VERSION: v0.25-Alpha |
|
||||||
! ============================================================================================ |
|
! ============================================================================================ |
|
||||||
! WARNING: THIS IS AN ALPHA VERSION OF THE LIBRARY, USE AT YOUR OWN DISCRETION |
|
! WARNING: THIS IS AN ALPHA VERSION OF THE LIBRARY, USE AT YOUR OWN DISCRETION |
|
||||||
! NEVER DO CODE GENERATION WITHOUT AT LEAST HAVING CONTENT IN A CODEBASE UNDER VERSION CONTROL |
|
! NEVER DO CODE GENERATION WITHOUT AT LEAST HAVING CONTENT IN A CODEBASE UNDER VERSION CONTROL |
|
||||||
|
@ -224,8 +224,8 @@ int gen_main()
|
|||||||
Code ast_types = scan_file( path_base "components/ast_types.hpp" );
|
Code ast_types = scan_file( path_base "components/ast_types.hpp" );
|
||||||
Code code_types = scan_file( path_base "components/code_types.hpp" );
|
Code code_types = scan_file( path_base "components/code_types.hpp" );
|
||||||
Code interface = scan_file( path_base "components/interface.hpp" );
|
Code interface = scan_file( path_base "components/interface.hpp" );
|
||||||
|
Code constants = scan_file( path_base "components/constants.hpp" );
|
||||||
Code inlines = scan_file( path_base "components/inlines.hpp" );
|
Code inlines = scan_file( path_base "components/inlines.hpp" );
|
||||||
Code header_end = scan_file( path_base "components/header_end.hpp" );
|
|
||||||
|
|
||||||
CodeBody ecode = gen_ecode ( path_base "enums/ECodeTypes.csv" );
|
CodeBody ecode = gen_ecode ( path_base "enums/ECodeTypes.csv" );
|
||||||
CodeBody eoperator = gen_eoperator ( path_base "enums/EOperator.csv" );
|
CodeBody eoperator = gen_eoperator ( path_base "enums/EOperator.csv" );
|
||||||
@ -266,6 +266,7 @@ int gen_main()
|
|||||||
header.print_fmt( "\n#pragma endregion AST\n" );
|
header.print_fmt( "\n#pragma endregion AST\n" );
|
||||||
|
|
||||||
header.print( interface );
|
header.print( interface );
|
||||||
|
header.print( constants );
|
||||||
|
|
||||||
header.print_fmt( "\n#pragma region Inlines\n" );
|
header.print_fmt( "\n#pragma region Inlines\n" );
|
||||||
header.print( inlines );
|
header.print( inlines );
|
||||||
@ -274,7 +275,6 @@ int gen_main()
|
|||||||
header.print( fmt_newline );
|
header.print( fmt_newline );
|
||||||
header.print_fmt( "#pragma endregion Inlines\n" );
|
header.print_fmt( "#pragma endregion Inlines\n" );
|
||||||
|
|
||||||
header.print( header_end );
|
|
||||||
header.print_fmt( "\nGEN_NS_END\n\n" );
|
header.print_fmt( "\nGEN_NS_END\n\n" );
|
||||||
header.print( pop_ignores );
|
header.print( pop_ignores );
|
||||||
header.write();
|
header.write();
|
||||||
|
@ -172,7 +172,7 @@ if ( $segmented )
|
|||||||
write-host `t $_ -ForegroundColor Green
|
write-host `t $_ -ForegroundColor Green
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
write-host "`nBootstrap completed in $($time_taken.TotalMilliseconds) ms"
|
write-host "`nSegmented completed in $($time_taken.TotalMilliseconds) ms"
|
||||||
}
|
}
|
||||||
Pop-Location
|
Pop-Location
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user