cwIoFlow.h/cpp : Now interfaces to the flow DSP system through cwFlowCross.

This commit is contained in:
kevin 2021-12-19 12:12:39 -05:00
parent b158516a6a
commit 6578f69369
2 changed files with 40 additions and 18 deletions

View File

@ -12,7 +12,7 @@
#include "cwDspTypes.h" #include "cwDspTypes.h"
#include "cwFlow.h" #include "cwFlow.h"
#include "cwFlowTypes.h" #include "cwFlowTypes.h"
#include "cwFlowCross.h"
#include "cwIo.h" #include "cwIo.h"
@ -34,9 +34,9 @@ namespace cw
typedef struct audio_group_str typedef struct audio_group_str
{ {
double srate; double srate;
unsigned dspFrameCnt; unsigned dspFrameCnt;
unsigned ioGroupIdx; unsigned ioGroupIdx;
audio_dev_t* iDeviceA; audio_dev_t* iDeviceA;
unsigned iDeviceN; unsigned iDeviceN;
@ -48,15 +48,15 @@ namespace cw
typedef struct io_flow_str typedef struct io_flow_str
{ {
io::handle_t ioH; io::handle_t ioH; //
flow::external_device_t* deviceA; // Array of generic device descriptions used by the ioFlow controller flow::external_device_t* deviceA; // Array of generic device descriptions used by the ioFlow controller
unsigned deviceN; // (This array must exist for the life of ioFlow controller) unsigned deviceN; // (This array must exist for the life of ioFlow controller)
audio_group_t* audioGroupA; // Array of real time audio device control records. audio_group_t* audioGroupA; // Array of real time audio device control records.
unsigned audioGroupN; // unsigned audioGroupN; //
flow::handle_t flowH; flow_cross::handle_t crossFlowH; //
} io_flow_t; } io_flow_t;
@ -65,6 +65,9 @@ namespace cw
rc_t _destroy( io_flow_t* p ) rc_t _destroy( io_flow_t* p )
{ {
flow_cross::destroy( p->crossFlowH );
mem::release(p->deviceA); mem::release(p->deviceA);
p->deviceN = 0; p->deviceN = 0;
@ -138,7 +141,6 @@ namespace cw
for(unsigned gdi=0; gdi<ag->oDeviceN; ++gdi) for(unsigned gdi=0; gdi<ag->oDeviceN; ++gdi)
_setup_audio_device( p, ag->oDeviceA + gdi, io::kOutFl, audioGroupDeviceIndex( p->ioH, gi, io::kOutFl, gdi), ag->dspFrameCnt ); _setup_audio_device( p, ag->oDeviceA + gdi, io::kOutFl, audioGroupDeviceIndex( p->ioH, gi, io::kOutFl, gdi), ag->dspFrameCnt );
} }
} }
@ -247,7 +249,6 @@ namespace cw
rc_t _audio_callback( io_flow_t* p, io::audio_msg_t& m ) rc_t _audio_callback( io_flow_t* p, io::audio_msg_t& m )
{ {
rc_t rc = kOkRC; rc_t rc = kOkRC;
flow::abuf_t* abuf; flow::abuf_t* abuf;
@ -289,7 +290,7 @@ namespace cw
// update the flow network - this will generate audio into the output audio buffers // update the flow network - this will generate audio into the output audio buffers
flow::exec_cycle(p->flowH); flow_cross::exec_cycle(p->crossFlowH);
// if there are empty output (playback) buffers // if there are empty output (playback) buffers
@ -323,7 +324,12 @@ namespace cw
} }
cw::rc_t cw::io_flow::create( handle_t& hRef, io::handle_t ioH, const object_t& flow_class_dict, const object_t& network_cfg ) cw::rc_t cw::io_flow::create( handle_t& hRef,
io::handle_t ioH,
double srate,
unsigned crossFadeCnt,
const object_t& flow_class_dict,
const object_t& network_cfg )
{ {
rc_t rc; rc_t rc;
@ -341,12 +347,14 @@ cw::rc_t cw::io_flow::create( handle_t& hRef, io::handle_t ioH, const object_t&
_setup_generic_device_array(p); _setup_generic_device_array(p);
// create the flow object // create the flow object
if((rc = create( p->flowH, flow_class_dict, network_cfg, p->deviceA, p->deviceN )) != kOkRC ) if((rc = flow_cross::create( p->crossFlowH, flow_class_dict, network_cfg, srate, crossFadeCnt, p->deviceA, p->deviceN )) != kOkRC )
{ {
cwLogError(rc,"The 'flow' object create failed."); cwLogError(rc,"The 'flow' object create failed.");
goto errLabel; goto errLabel;
} }
//flow_cross::print(p->crossFlowH);
hRef.set(p); hRef.set(p);
@ -396,3 +404,15 @@ cw::rc_t cw::io_flow::exec( handle_t h, const io::msg_t& msg )
return rc; return rc;
} }
cw::rc_t cw::io_flow::apply_preset( handle_t h, double crossFadeMs, const char* presetLabel )
{
cw::rc_t rc = kOkRC;
io_flow_t* p = _handleToPtr(h);
rc = apply_preset( p->crossFlowH, crossFadeMs, presetLabel );
return rc;
}

View File

@ -7,11 +7,13 @@ namespace cw
{ {
typedef handle< struct io_flow_str > handle_t; typedef handle< struct io_flow_str > handle_t;
rc_t create( handle_t& hRef, io::handle_t ioH, const object_t& flow_class_dict, const object_t& cfg ); rc_t create( handle_t& hRef, io::handle_t ioH, double srate, unsigned crossFadeCnt, const object_t& flow_class_dict, const object_t& cfg );
rc_t destroy( handle_t& hRef ); rc_t destroy( handle_t& hRef );
rc_t exec( handle_t h, const io::msg_t& msg ); rc_t exec( handle_t h, const io::msg_t& msg );
rc_t apply_preset( handle_t h, double crossFadeMs, const char* presetLabel );
} }
} }