Timeline: Split OSC send and receive functionality into different threads.
This commit is contained in:
parent
362a153412
commit
ad6dbba07c
|
@ -601,7 +601,7 @@ Control_Sequence::menu_cb ( const Fl_Menu_ *m )
|
||||||
void
|
void
|
||||||
Control_Sequence::connect_osc ( void )
|
Control_Sequence::connect_osc ( void )
|
||||||
{
|
{
|
||||||
timeline->osc_thread->lock();
|
timeline->osc_receive_thread->lock();
|
||||||
|
|
||||||
if ( _persistent_osc_connections.size() )
|
if ( _persistent_osc_connections.size() )
|
||||||
{
|
{
|
||||||
|
@ -623,7 +623,7 @@ Control_Sequence::connect_osc ( void )
|
||||||
|
|
||||||
/* header()->outputs_indicator->value( _osc_output() && _osc_output()->connected() ); */
|
/* header()->outputs_indicator->value( _osc_output() && _osc_output()->connected() ); */
|
||||||
|
|
||||||
timeline->osc_thread->unlock();
|
timeline->osc_receive_thread->unlock();
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
|
|
|
@ -0,0 +1,87 @@
|
||||||
|
|
||||||
|
/*******************************************************************************/
|
||||||
|
/* Copyright (C) 2012 Jonathan Moore Liles */
|
||||||
|
/* */
|
||||||
|
/* This program is free software; you can redistribute it and/or modify it */
|
||||||
|
/* under the terms of the GNU General Public License as published by the */
|
||||||
|
/* Free Software Foundation; either version 2 of the License, or (at your */
|
||||||
|
/* option) any later version. */
|
||||||
|
/* */
|
||||||
|
/* This program is distributed in the hope that it will be useful, but WITHOUT */
|
||||||
|
/* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or */
|
||||||
|
/* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for */
|
||||||
|
/* more details. */
|
||||||
|
/* */
|
||||||
|
/* You should have received a copy of the GNU General Public License along */
|
||||||
|
/* with This program; see the file COPYING. If not,write to the Free Software */
|
||||||
|
/* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */
|
||||||
|
/*******************************************************************************/
|
||||||
|
|
||||||
|
#include "OSC_Receive_Thread.H"
|
||||||
|
|
||||||
|
#include "Timeline.H"
|
||||||
|
|
||||||
|
#include <stdlib.h>
|
||||||
|
#include <unistd.h>
|
||||||
|
|
||||||
|
#include "debug.h"
|
||||||
|
|
||||||
|
#include "OSC/Endpoint.H"
|
||||||
|
|
||||||
|
extern Timeline *timeline;
|
||||||
|
|
||||||
|
OSC_Receive_Thread::OSC_Receive_Thread ( )
|
||||||
|
{
|
||||||
|
// _thread.init();
|
||||||
|
_shutdown = false;
|
||||||
|
}
|
||||||
|
|
||||||
|
OSC_Receive_Thread::~OSC_Receive_Thread ( )
|
||||||
|
{
|
||||||
|
lock();
|
||||||
|
if ( _shutdown == false )
|
||||||
|
{
|
||||||
|
_shutdown = true;
|
||||||
|
_thread.join();
|
||||||
|
}
|
||||||
|
unlock();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void
|
||||||
|
OSC_Receive_Thread::start ( )
|
||||||
|
{
|
||||||
|
_thread.clone( &OSC_Receive_Thread::process, this );
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
OSC_Receive_Thread::join ( )
|
||||||
|
{
|
||||||
|
_thread.join();
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
OSC_Receive_Thread::process ( void )
|
||||||
|
{
|
||||||
|
_thread.name( "OSC_Receive" );
|
||||||
|
|
||||||
|
DMESSAGE( "OSC Thread starting" );
|
||||||
|
|
||||||
|
while ( !_shutdown )
|
||||||
|
{
|
||||||
|
timeline->osc->wait(20);
|
||||||
|
}
|
||||||
|
|
||||||
|
DMESSAGE( "OSC Thread stopping." );
|
||||||
|
}
|
||||||
|
|
||||||
|
void *
|
||||||
|
OSC_Receive_Thread::process ( void *v )
|
||||||
|
{
|
||||||
|
OSC_Receive_Thread *t = (OSC_Receive_Thread*)v;
|
||||||
|
|
||||||
|
t->process();
|
||||||
|
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
|
@ -22,7 +22,7 @@
|
||||||
#include "Thread.H"
|
#include "Thread.H"
|
||||||
#include "Mutex.H"
|
#include "Mutex.H"
|
||||||
|
|
||||||
class OSC_Thread : public Mutex
|
class OSC_Receive_Thread : public Mutex
|
||||||
{
|
{
|
||||||
Thread _thread; /* io thread */
|
Thread _thread; /* io thread */
|
||||||
|
|
||||||
|
@ -30,9 +30,9 @@ class OSC_Thread : public Mutex
|
||||||
|
|
||||||
public:
|
public:
|
||||||
|
|
||||||
OSC_Thread ( );
|
OSC_Receive_Thread ( );
|
||||||
|
|
||||||
virtual ~OSC_Thread ( );
|
virtual ~OSC_Receive_Thread ( );
|
||||||
|
|
||||||
void join ( void );
|
void join ( void );
|
||||||
void shutdown ( void ) { _shutdown = true; }
|
void shutdown ( void ) { _shutdown = true; }
|
|
@ -17,7 +17,7 @@
|
||||||
/* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */
|
/* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */
|
||||||
/*******************************************************************************/
|
/*******************************************************************************/
|
||||||
|
|
||||||
#include "OSC_Thread.H"
|
#include "OSC_Transmit_Thread.H"
|
||||||
|
|
||||||
#include "Timeline.H"
|
#include "Timeline.H"
|
||||||
|
|
||||||
|
@ -30,13 +30,13 @@
|
||||||
|
|
||||||
extern Timeline *timeline;
|
extern Timeline *timeline;
|
||||||
|
|
||||||
OSC_Thread::OSC_Thread ( )
|
OSC_Transmit_Thread::OSC_Transmit_Thread ( )
|
||||||
{
|
{
|
||||||
// _thread.init();
|
// _thread.init();
|
||||||
_shutdown = false;
|
_shutdown = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
OSC_Thread::~OSC_Thread ( )
|
OSC_Transmit_Thread::~OSC_Transmit_Thread ( )
|
||||||
{
|
{
|
||||||
lock();
|
lock();
|
||||||
if ( _shutdown == false )
|
if ( _shutdown == false )
|
||||||
|
@ -49,29 +49,29 @@ OSC_Thread::~OSC_Thread ( )
|
||||||
|
|
||||||
|
|
||||||
void
|
void
|
||||||
OSC_Thread::start ( )
|
OSC_Transmit_Thread::start ( )
|
||||||
{
|
{
|
||||||
_thread.clone( &OSC_Thread::process, this );
|
_thread.clone( &OSC_Transmit_Thread::process, this );
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
OSC_Thread::join ( )
|
OSC_Transmit_Thread::join ( )
|
||||||
{
|
{
|
||||||
_thread.join();
|
_thread.join();
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
OSC_Thread::process ( void )
|
OSC_Transmit_Thread::process ( void )
|
||||||
{
|
{
|
||||||
_thread.name( "OSC" );
|
_thread.name( "OSC_Transmit" );
|
||||||
|
|
||||||
DMESSAGE( "OSC Thread starting" );
|
DMESSAGE( "OSC Thread starting" );
|
||||||
|
|
||||||
while ( !_shutdown )
|
while ( !_shutdown )
|
||||||
{
|
{
|
||||||
|
|
||||||
if ( trylock() )
|
if ( trylock() )
|
||||||
{
|
{
|
||||||
timeline->osc->check();
|
|
||||||
timeline->process_osc();
|
timeline->process_osc();
|
||||||
unlock();
|
unlock();
|
||||||
}
|
}
|
||||||
|
@ -83,9 +83,9 @@ OSC_Thread::process ( void )
|
||||||
}
|
}
|
||||||
|
|
||||||
void *
|
void *
|
||||||
OSC_Thread::process ( void *v )
|
OSC_Transmit_Thread::process ( void *v )
|
||||||
{
|
{
|
||||||
OSC_Thread *t = (OSC_Thread*)v;
|
OSC_Transmit_Thread *t = (OSC_Transmit_Thread*)v;
|
||||||
|
|
||||||
t->process();
|
t->process();
|
||||||
|
|
|
@ -0,0 +1,42 @@
|
||||||
|
|
||||||
|
/*******************************************************************************/
|
||||||
|
/* Copyright (C) 2012 Jonathan Moore Liles */
|
||||||
|
/* */
|
||||||
|
/* This program is free software; you can redistribute it and/or modify it */
|
||||||
|
/* under the terms of the GNU General Public License as published by the */
|
||||||
|
/* Free Software Foundation; either version 2 of the License, or (at your */
|
||||||
|
/* option) any later version. */
|
||||||
|
/* */
|
||||||
|
/* This program is distributed in the hope that it will be useful, but WITHOUT */
|
||||||
|
/* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or */
|
||||||
|
/* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for */
|
||||||
|
/* more details. */
|
||||||
|
/* */
|
||||||
|
/* You should have received a copy of the GNU General Public License along */
|
||||||
|
/* with This program; see the file COPYING. If not,write to the Free Software */
|
||||||
|
/* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */
|
||||||
|
/*******************************************************************************/
|
||||||
|
|
||||||
|
#pragma once
|
||||||
|
|
||||||
|
#include "Thread.H"
|
||||||
|
#include "Mutex.H"
|
||||||
|
|
||||||
|
class OSC_Transmit_Thread : public Mutex
|
||||||
|
{
|
||||||
|
Thread _thread; /* io thread */
|
||||||
|
|
||||||
|
volatile bool _shutdown;
|
||||||
|
|
||||||
|
public:
|
||||||
|
|
||||||
|
OSC_Transmit_Thread ( );
|
||||||
|
|
||||||
|
virtual ~OSC_Transmit_Thread ( );
|
||||||
|
|
||||||
|
void join ( void );
|
||||||
|
void shutdown ( void ) { _shutdown = true; }
|
||||||
|
void start ( void );
|
||||||
|
void process ( void );
|
||||||
|
static void *process ( void * );
|
||||||
|
};
|
|
@ -53,7 +53,7 @@
|
||||||
#include "TLE.H"
|
#include "TLE.H"
|
||||||
/* */
|
/* */
|
||||||
|
|
||||||
#include "OSC_Thread.H"
|
|
||||||
#include "OSC/Endpoint.H"
|
#include "OSC/Endpoint.H"
|
||||||
|
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
|
@ -612,8 +612,10 @@ Timeline::ntracks ( void ) const
|
||||||
|
|
||||||
Timeline::~Timeline ( )
|
Timeline::~Timeline ( )
|
||||||
{
|
{
|
||||||
delete osc_thread;
|
delete osc_transmit_thread;
|
||||||
osc_thread = 0;
|
osc_transmit_thread = 0;
|
||||||
|
delete osc_receive_thread;
|
||||||
|
osc_receive_thread = 0;
|
||||||
delete osc;
|
delete osc;
|
||||||
osc = 0;
|
osc = 0;
|
||||||
}
|
}
|
||||||
|
@ -627,7 +629,8 @@ Timeline::Timeline ( int X, int Y, int W, int H, const char* L ) : BASE( X, Y, W
|
||||||
play_cursor_track = NULL;
|
play_cursor_track = NULL;
|
||||||
|
|
||||||
_created_new_takes = 0;
|
_created_new_takes = 0;
|
||||||
osc_thread = 0;
|
osc_transmit_thread = 0;
|
||||||
|
osc_receive_thread = 0;
|
||||||
_sample_rate = 44100;
|
_sample_rate = 44100;
|
||||||
|
|
||||||
box( FL_FLAT_BOX );
|
box( FL_FLAT_BOX );
|
||||||
|
@ -2179,11 +2182,18 @@ Timeline::init_osc ( const char *osc_port )
|
||||||
|
|
||||||
// osc->start();
|
// osc->start();
|
||||||
|
|
||||||
if ( ! osc_thread )
|
if ( ! osc_transmit_thread )
|
||||||
{
|
{
|
||||||
osc_thread = new OSC_Thread();
|
osc_transmit_thread = new OSC_Transmit_Thread();
|
||||||
|
|
||||||
osc_thread->start();
|
osc_transmit_thread->start();
|
||||||
|
}
|
||||||
|
|
||||||
|
if ( ! osc_receive_thread )
|
||||||
|
{
|
||||||
|
osc_receive_thread = new OSC_Receive_Thread();
|
||||||
|
|
||||||
|
osc_receive_thread->start();
|
||||||
}
|
}
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
|
@ -2262,7 +2272,7 @@ Timeline::update_osc_connection_state ( void )
|
||||||
void
|
void
|
||||||
Timeline::process_osc ( void )
|
Timeline::process_osc ( void )
|
||||||
{
|
{
|
||||||
THREAD_ASSERT( OSC );
|
THREAD_ASSERT( OSC_Transmit );
|
||||||
|
|
||||||
sequence_lock.rdlock();
|
sequence_lock.rdlock();
|
||||||
|
|
||||||
|
|
|
@ -31,7 +31,8 @@
|
||||||
#include <assert.h>
|
#include <assert.h>
|
||||||
#include <list>
|
#include <list>
|
||||||
|
|
||||||
#include "OSC_Thread.H"
|
#include "OSC_Transmit_Thread.H"
|
||||||
|
#include "OSC_Receive_Thread.H"
|
||||||
|
|
||||||
class Fl_Scroll;
|
class Fl_Scroll;
|
||||||
class Fl_Pack;
|
class Fl_Pack;
|
||||||
|
@ -136,7 +137,8 @@ public:
|
||||||
void damage_sequence ( void );
|
void damage_sequence ( void );
|
||||||
|
|
||||||
OSC::Endpoint *osc;
|
OSC::Endpoint *osc;
|
||||||
OSC_Thread *osc_thread;
|
OSC_Transmit_Thread *osc_transmit_thread;
|
||||||
|
OSC_Receive_Thread *osc_receive_thread;
|
||||||
|
|
||||||
void process_osc ( void );
|
void process_osc ( void );
|
||||||
#undef Bars
|
#undef Bars
|
||||||
|
|
|
@ -76,7 +76,8 @@ src/Engine/Record_DS.C
|
||||||
src/Engine/Timeline.C
|
src/Engine/Timeline.C
|
||||||
src/Engine/Track.C
|
src/Engine/Track.C
|
||||||
src/NSM.C
|
src/NSM.C
|
||||||
src/OSC_Thread.C
|
src/OSC_Transmit_Thread.C
|
||||||
|
src/OSC_Receive_Thread.C
|
||||||
src/Project.C
|
src/Project.C
|
||||||
src/Sequence.C
|
src/Sequence.C
|
||||||
src/Sequence_Point.C
|
src/Sequence_Point.C
|
||||||
|
|
Loading…
Reference in New Issue