gencpp/test/math.hpp

67 lines
1.3 KiB
C++
Raw Normal View History

2023-04-01 19:21:46 -07:00
#pragma once
#include "Bloat.hpp"
#include "gen.hpp"
2023-04-01 19:21:46 -07:00
#ifdef gen_time
2023-04-01 19:21:46 -07:00
using namespace gen;
2023-04-02 08:53:15 -07:00
char* sprintf_buf[ZPL_PRINTF_MAXLEN];
2023-04-01 19:21:46 -07:00
/*
What it should generate:
inline
type square_#type( type value )
{
return value * value;
}
*/
#define gen_square( Type_ ) gen__square( #Type_ )
Code gen__square( char const* type )
2023-04-01 19:21:46 -07:00
{
Code integral_type = make_type( type );
string name = string_sprintf( g_allocator, (char*)sprintf_buf, ZPL_PRINTF_MAXLEN, "square", type );
2023-04-01 19:21:46 -07:00
Code specifiers = make_specifiers( 1, Specifier::Inline );
Code params = make_parameters( 1, "value", integral_type );
Code ret_stmt = make_fmt( "\treturn value * value;" );
2023-04-01 19:21:46 -07:00
Code result = make_function( name,
specifiers,
params,
integral_type,
ret_stmt
);
if ( ! result )
fatal( "Failed to generate square function for: %s", type );
return result;
}
u32 gen_math()
{
Code fadd_u8 = gen_square( u8 );
2023-04-02 08:53:15 -07:00
Code fadd_u16 = gen_square( u16 );
Code fadd_u32 = gen_square( u32 );
Code fadd_u64 = gen_square( u64 );
2023-04-01 19:21:46 -07:00
Builder
2023-04-01 19:21:46 -07:00
mathgen;
mathgen.open( "math.gen.hpp" );
mathgen.print( fadd_u8 );
2023-04-02 08:53:15 -07:00
mathgen.print( fadd_u16 );
mathgen.print( fadd_u32 );
mathgen.print( fadd_u64 );
2023-04-01 19:21:46 -07:00
mathgen.write();
return 0;
}
#endif
#ifndef gen_time
#include "math.gen.hpp"
#undef square
#endif