demotool/demo.cc
Emmanuel BENOîT 4774426962 UI - More refactoring
The idea is to split off all UI/display code from e.g. the parser. This
could take a while.
2017-11-23 14:15:17 +01:00

79 lines
1.8 KiB
C++

#include "externals.hh"
#include "demo.hh"
#include "sync.hh"
#include "rendertarget.hh"
#include "globals.hh"
#include "opemu.hh"
#include "opcomp.hh"
#include <ebcl/Files.hh>
#include <ebcl/SRDText.hh>
bool T_Demo::initialise(
const uint32_t w ,
const uint32_t h )
{
width = w;
height = h;
return program && runInit( *program );
}
void T_Demo::render( )
{
if ( Globals::Ops( ).hasNewProgram( ) ) {
auto nProgram{ Globals::Ops( ).program( ) };
if ( runInit( *nProgram ) ) {
program = std::move( nProgram );
}
}
auto& sync( Globals::Sync( ) );
sync.updateTime( );
if ( context && !context->aborted ) {
try {
context->run( ops::T_OpContext::R_RENDER , sync.time( ) , width , height );
} catch ( ops::X_OpFailure const& fail ) {
printf( "FAILED TO RUN FRAME!\n\t%s\n" , fail.what( ) );
context->aborted = true;
}
}
}
bool T_Demo::runInit(
ops::T_OpProgram& p )
{
auto nContext{ NewOwned< ops::T_OpContext >( p ) };
try {
nContext->run( ops::T_OpContext::R_INIT , 0 , width , height );
} catch ( ops::X_OpFailure const& fail ) {
printf( "FAILED TO RUN INIT!\n\t%s\n" , fail.what( ) );
nContext.clear( );
}
if ( !nContext ) {
return false;
}
context = std::move( nContext );
Globals::Sync( ).clearInputs( );
Globals::Sync( ).clearOverrides( );
const auto n( context->initialInputs.size( ) );
assert( n == p.inputs.size( ) );
for ( auto i = 0u ; i < n ; i ++ ) {
Globals::Sync( ).addInput( p.inputs[ i ] ,
context->initialInputs[ i ] );
#ifdef INVASIVE_TRACES
printf( "#%d %s pos %d\n" , i , p.inputs[ i ].toOSString( ).data( ) ,
Globals::Sync( ).inputPos( p.inputs[ i ] ) );
#endif //INVASIVE_TRACES
}
Globals::Sync( ).updateCurveCaches( );
if ( context->installOverrides ) {
Globals::Sync( ).mergeOverrides( *( context->installOverrides ) );
context->installOverrides.clear( );
}
return true;
}