Mixer: Fix plugin bypass and plugin insertion broken by 8b9ef85
.
This commit is contained in:
parent
70e0db1c47
commit
63c4f68b3b
|
@ -351,8 +351,8 @@ public:
|
|||
return control_output.size();
|
||||
}
|
||||
|
||||
bool bypass ( void ) const { return _bypass; }
|
||||
void bypass ( bool v ) { _bypass = v; redraw(); }
|
||||
virtual bool bypass ( void ) const { return _bypass; }
|
||||
virtual void bypass ( bool v ) { _bypass = v; redraw(); }
|
||||
|
||||
int control_input_port_index ( Port *p )
|
||||
{
|
||||
|
|
|
@ -669,9 +669,12 @@ Plugin_Module::set_output_buffer ( int n, void *buf )
|
|||
void
|
||||
Plugin_Module::activate ( void )
|
||||
{
|
||||
DMESSAGE( "Activating plugin \"%s\"", label() );
|
||||
|
||||
if ( _active )
|
||||
FATAL( "Attempt to activate already active plugin" );
|
||||
|
||||
if ( chain() )
|
||||
chain()->engine()->lock();
|
||||
|
||||
if ( _idata->descriptor->activate )
|
||||
|
@ -680,12 +683,16 @@ Plugin_Module::activate ( void )
|
|||
|
||||
_active = true;
|
||||
|
||||
if ( chain() )
|
||||
chain()->engine()->unlock();
|
||||
}
|
||||
|
||||
void
|
||||
Plugin_Module::deactivate( void )
|
||||
{
|
||||
DMESSAGE( "Deactivating plugin \"%s\"", label() );
|
||||
|
||||
if ( chain() )
|
||||
chain()->engine()->lock();
|
||||
|
||||
_active = false;
|
||||
|
@ -694,6 +701,7 @@ Plugin_Module::deactivate( void )
|
|||
for ( unsigned int i = 0; i < _idata->handle.size(); ++i )
|
||||
_idata->descriptor->deactivate( _idata->handle[i] );
|
||||
|
||||
if ( chain() )
|
||||
chain()->engine()->unlock();
|
||||
}
|
||||
|
||||
|
|
|
@ -66,7 +66,7 @@ private:
|
|||
|
||||
ImplementationData *_idata;
|
||||
|
||||
bool _active;
|
||||
volatile bool _active;
|
||||
int _plugin_ins;
|
||||
int _plugin_outs;
|
||||
bool _crosswire;
|
||||
|
|
Loading…
Reference in New Issue