cwFlowTypes.h : Changes to account for changed dsp::types.

Added is_connected_to_source_proc(), var_is_source() and is_source_var().
This commit is contained in:
kevin 2024-04-26 17:04:03 -04:00
parent a0b4e9c120
commit bdcb26ac72
2 changed files with 111 additions and 64 deletions

View File

@ -24,7 +24,6 @@ namespace cw
{ kUIntTFl, "uint" }, { kUIntTFl, "uint" },
{ kIntTFl, "int", }, { kIntTFl, "int", },
{ kFloatTFl, "float"}, { kFloatTFl, "float"},
{ kRealTFl, "real"},
{ kDoubleTFl,"double"}, { kDoubleTFl,"double"},
{ kBoolMtxTFl, "bool_mtx" }, { kBoolMtxTFl, "bool_mtx" },
@ -38,6 +37,14 @@ namespace cw
{ kMBufTFl, "midi" }, { kMBufTFl, "midi" },
{ kStringTFl, "string" }, { kStringTFl, "string" },
{ kTimeTFl, "time" }, { kTimeTFl, "time" },
{ kCfgTFl, "cfg" },
// alias types to map to cwDspTypes.h
{ kFloatTFl, "srate"},
{ kFloatTFl, "sample"},
{ kFloatTFl, "coeff"},
{ kDoubleTFl, "ftime" },
{ kInvalidTFl, nullptr } { kInvalidTFl, nullptr }
}; };
@ -461,12 +468,18 @@ namespace cw
rc_t _var_broadcast_new_value( variable_t* var ) rc_t _var_broadcast_new_value( variable_t* var )
{ {
rc_t rc = kOkRC; rc_t rc = kOkRC;
/*
// notify each connected var that the value has changed // notify each connected var that the value has changed
for(variable_t* con_var = var->connect_link; con_var!=nullptr; con_var=con_var->connect_link) for(variable_t* con_var = var->connect_link; con_var!=nullptr; con_var=con_var->connect_link)
if((rc = con_var->inst->class_desc->members->value( con_var->inst, con_var )) != kOkRC ) {
break; // the var->local_value[] slot used by the source variable may have changed - update the destination variable
*/ // so that it points to the correct value.
con_var->value = var->value;
//if((rc = con_var->inst->class_desc->members->value( con_var->inst, con_var )) != kOkRC )
// break;
}
return rc; return rc;
} }
@ -604,7 +617,7 @@ namespace cw
} }
bool is_connected_to_external_proc( const variable_t* var ) bool is_connected_to_source_proc( const variable_t* var )
{ {
// if this var does not have a 'src_ptr' then it can't be connected to an external proc // if this var does not have a 'src_ptr' then it can't be connected to an external proc
if( var->src_var == nullptr || var->value == nullptr ) if( var->src_var == nullptr || var->value == nullptr )
@ -618,13 +631,16 @@ namespace cw
return true; return true;
} }
bool is_a_source_var( const variable_t* var )
{ return var->connect_link != nullptr; }
template< typename T > template< typename T >
rc_t _var_set_driver( variable_t* var, unsigned typeFlag, T value ) rc_t _var_set_driver( variable_t* var, unsigned typeFlag, T value )
{ {
rc_t rc; rc_t rc;
// if this variable is fed from the output of an external proc - then it's local value cannot be set // if this variable is fed from the output of an external proc - then it's local value cannot be set
if(is_connected_to_external_proc(var) ) if(is_connected_to_source_proc(var) )
return kOkRC; return kOkRC;
@ -687,6 +703,7 @@ namespace cw
{ {
rc_t rc = kOkRC; rc_t rc = kOkRC;
// get the variable type - note that the value type (value->flags) may be differnt
unsigned typeFlag = var->varDesc->type & kTypeMask; unsigned typeFlag = var->varDesc->type & kTypeMask;
switch( typeFlag ) switch( typeFlag )
@ -882,7 +899,7 @@ namespace cw
void _var_print( const variable_t* var ) void _var_print( const variable_t* var )
{ {
const char* conn_label = is_connected_to_external_proc(var) ? "extern" : " "; const char* conn_label = is_connected_to_source_proc(var) ? "extern" : " ";
printf(" %20s:%5i id:%4i ch:%3i : %s : ", var->label, var->label_sfx_id, var->vid, var->chIdx, conn_label ); printf(" %20s:%5i id:%4i ch:%3i : %s : ", var->label, var->label_sfx_id, var->vid, var->chIdx, conn_label );
@ -969,7 +986,7 @@ const cw::flow::sample_t* cw::flow::abuf_get_channel( abuf_t* abuf, unsigned c
return abuf->buf + (chIdx*abuf->frameN); return abuf->buf + (chIdx*abuf->frameN);
} }
cw::flow::fbuf_t* cw::flow::fbuf_create( srate_t srate, unsigned chN, const unsigned* maxBinN_V, const unsigned* binN_V, const unsigned* hopSmpN_V, const fd_real_t** magV, const fd_real_t** phsV, const fd_real_t** hzV ) cw::flow::fbuf_t* cw::flow::fbuf_create( srate_t srate, unsigned chN, const unsigned* maxBinN_V, const unsigned* binN_V, const unsigned* hopSmpN_V, const fd_sample_t** magV, const fd_sample_t** phsV, const fd_sample_t** hzV )
{ {
for(unsigned i=0; i<chN; ++i) for(unsigned i=0; i<chN; ++i)
if( binN_V[i] > maxBinN_V[i] ) if( binN_V[i] > maxBinN_V[i] )
@ -985,9 +1002,9 @@ cw::flow::fbuf_t* cw::flow::fbuf_create( srate_t srate, unsigned chN, const unsi
f->maxBinN_V = mem::allocZ<unsigned>(chN); f->maxBinN_V = mem::allocZ<unsigned>(chN);
f->binN_V = mem::allocZ<unsigned>(chN); f->binN_V = mem::allocZ<unsigned>(chN);
f->hopSmpN_V = mem::allocZ<unsigned>(chN); f->hopSmpN_V = mem::allocZ<unsigned>(chN);
f->magV = mem::allocZ<fd_real_t*>(chN); f->magV = mem::allocZ<fd_sample_t*>(chN);
f->phsV = mem::allocZ<fd_real_t*>(chN); f->phsV = mem::allocZ<fd_sample_t*>(chN);
f->hzV = mem::allocZ<fd_real_t*>(chN); f->hzV = mem::allocZ<fd_sample_t*>(chN);
f->readyFlV = mem::allocZ<bool>(chN); f->readyFlV = mem::allocZ<bool>(chN);
vop::copy( f->binN_V, binN_V, chN ); vop::copy( f->binN_V, binN_V, chN );
@ -998,17 +1015,17 @@ cw::flow::fbuf_t* cw::flow::fbuf_create( srate_t srate, unsigned chN, const unsi
{ {
for(unsigned chIdx=0; chIdx<chN; ++chIdx) for(unsigned chIdx=0; chIdx<chN; ++chIdx)
{ {
f->magV[ chIdx ] = (fd_real_t*)magV[chIdx]; f->magV[ chIdx ] = (fd_sample_t*)magV[chIdx];
f->phsV[ chIdx ] = (fd_real_t*)phsV[chIdx]; f->phsV[ chIdx ] = (fd_sample_t*)phsV[chIdx];
f->hzV[ chIdx ] = (fd_real_t*)hzV[chIdx]; f->hzV[ chIdx ] = (fd_sample_t*)hzV[chIdx];
} }
} }
else else
{ {
unsigned maxTotalBinsN = vop::sum( maxBinN_V, chN ); unsigned maxTotalBinsN = vop::sum( maxBinN_V, chN );
fd_real_t* buf = mem::allocZ<fd_real_t>( kFbufVectN * maxTotalBinsN ); fd_sample_t* buf = mem::allocZ<fd_sample_t>( kFbufVectN * maxTotalBinsN );
fd_real_t* m = buf; fd_sample_t* m = buf;
for(unsigned chIdx=0; chIdx<chN; ++chIdx) for(unsigned chIdx=0; chIdx<chN; ++chIdx)
{ {
f->magV[chIdx] = m + 0 * f->binN_V[chIdx]; f->magV[chIdx] = m + 0 * f->binN_V[chIdx];
@ -1026,7 +1043,7 @@ cw::flow::fbuf_t* cw::flow::fbuf_create( srate_t srate, unsigned chN, const unsi
} }
cw::flow::fbuf_t* cw::flow::fbuf_create( srate_t srate, unsigned chN, unsigned maxBinN, unsigned binN, unsigned hopSmpN, const fd_real_t** magV, const fd_real_t** phsV, const fd_real_t** hzV ) cw::flow::fbuf_t* cw::flow::fbuf_create( srate_t srate, unsigned chN, unsigned maxBinN, unsigned binN, unsigned hopSmpN, const fd_sample_t** magV, const fd_sample_t** phsV, const fd_sample_t** hzV )
{ {
unsigned maxBinN_V[ chN ]; unsigned maxBinN_V[ chN ];
unsigned binN_V[ chN ]; unsigned binN_V[ chN ];
@ -1250,11 +1267,9 @@ cw::rc_t cw::flow::var_channelize( instance_t* inst, const char* var_label, uns
goto errLabel; goto errLabel;
} }
// locate the variable with the stated chIdx // locate the variable with the stated chIdx
var = _var_find_on_label_and_ch( inst, var_label, sfx_id, chIdx ); var = _var_find_on_label_and_ch( inst, var_label, sfx_id, chIdx );
// 'src' variables cannot be channelized // 'src' variables cannot be channelized
if( cwIsFlag(base_var->varDesc->flags,kSrcVarFl) ) if( cwIsFlag(base_var->varDesc->flags,kSrcVarFl) )
{ {
@ -1287,6 +1302,7 @@ cw::rc_t cw::flow::var_channelize( instance_t* inst, const char* var_label, uns
// a correctly channelized var was found - but we still may need to set the value // a correctly channelized var was found - but we still may need to set the value
if( value_cfg != nullptr ) if( value_cfg != nullptr )
{ {
//cwLogInfo("%s ch:%i",var_label,chIdx);
rc = _set_var_value_from_cfg( var, value_cfg ); rc = _set_var_value_from_cfg( var, value_cfg );
} }
else else
@ -1300,7 +1316,7 @@ cw::rc_t cw::flow::var_channelize( instance_t* inst, const char* var_label, uns
errLabel: errLabel:
if( rc != kOkRC ) if( rc != kOkRC )
rc = cwLogError(rc,"Channelize failed for variable '%s:%i' on instance '%s:i' ch:%i.", var_label, sfx_id, inst->label, inst->label_sfx_id, chIdx ); rc = cwLogError(rc,"Channelize failed for variable '%s:%i' on instance '%s:%i' ch:%i.", var_label, sfx_id, inst->label, inst->label_sfx_id, chIdx );
return rc; return rc;
} }
@ -1319,6 +1335,31 @@ bool cw::flow::var_has_value( instance_t* inst, const char* label, unsigned sfx_
return varPtr->value != nullptr; return varPtr->value != nullptr;
} }
bool cw::flow::var_is_a_source( instance_t* inst, const char* label, unsigned sfx_id, unsigned chIdx )
{
rc_t rc;
variable_t* varPtr = nullptr;
if((rc = var_find( inst, label, sfx_id, chIdx, varPtr)) != kOkRC )
{
cwLogError(kEleNotFoundRC,"The variable '%s:%i' was not found on proc:'%s:%i'. 'source' state query is invalid.",cwStringNullGuard(label),sfx_id,cwStringNullGuard(inst->label),inst->label_sfx_id);
return false;
}
return is_a_source_var(varPtr);
}
bool cw::flow::var_is_a_source( instance_t* inst, unsigned vid, unsigned chIdx )
{
rc_t rc;
variable_t* varPtr = nullptr;
if((rc = var_find( inst, vid, chIdx, varPtr)) != kOkRC )
{
cwLogError(kEleNotFoundRC,"The variable with vid '%i' was not found on proc:'%s:%i'. 'source' state query is invalid.",vid,cwStringNullGuard(inst->label),inst->label_sfx_id);
return false;
}
return is_a_source_var(varPtr);
}
cw::rc_t cw::flow::var_find( instance_t* inst, unsigned vid, unsigned chIdx, variable_t*& varRef ) cw::rc_t cw::flow::var_find( instance_t* inst, unsigned vid, unsigned chIdx, variable_t*& varRef )
{ {
@ -1471,7 +1512,7 @@ cw::rc_t cw::flow::var_register_and_set( instance_t* inst, const char* va
return rc; return rc;
} }
cw::rc_t cw::flow::var_register_and_set( instance_t* inst, const char* var_label, unsigned sfx_id, unsigned vid, unsigned chIdx, srate_t srate, unsigned chN, const unsigned* maxBinN_V, const unsigned* binN_V, const unsigned* hopSmpN_V, const fd_real_t** magV, const fd_real_t** phsV, const fd_real_t** hzV ) cw::rc_t cw::flow::var_register_and_set( instance_t* inst, const char* var_label, unsigned sfx_id, unsigned vid, unsigned chIdx, srate_t srate, unsigned chN, const unsigned* maxBinN_V, const unsigned* binN_V, const unsigned* hopSmpN_V, const fd_sample_t** magV, const fd_sample_t** phsV, const fd_sample_t** hzV )
{ {
rc_t rc = kOkRC; rc_t rc = kOkRC;
fbuf_t* fbuf; fbuf_t* fbuf;
@ -1499,7 +1540,7 @@ cw::rc_t cw::flow::var_register_and_set( instance_t* inst, const char* va
} }
cw::rc_t cw::flow::var_register_and_set( instance_t* inst, const char* var_label, unsigned sfx_id, unsigned vid, unsigned chIdx, srate_t srate, unsigned chN, unsigned maxBinN, unsigned binN, unsigned hopSmpN, const fd_real_t** magV, const fd_real_t** phsV, const fd_real_t** hzV ) cw::rc_t cw::flow::var_register_and_set( instance_t* inst, const char* var_label, unsigned sfx_id, unsigned vid, unsigned chIdx, srate_t srate, unsigned chN, unsigned maxBinN, unsigned binN, unsigned hopSmpN, const fd_sample_t** magV, const fd_sample_t** phsV, const fd_sample_t** hzV )
{ {
unsigned maxBinN_V[ chN ]; unsigned maxBinN_V[ chN ];
unsigned binN_V[ chN ]; unsigned binN_V[ chN ];

View File

@ -3,13 +3,13 @@ namespace cw
namespace flow namespace flow
{ {
#define kRealTFl kFloatTFl typedef dsp::coeff_t coeff_t;
typedef dsp::real_t real_t; typedef dsp::sample_t sample_t;
typedef dsp::sample_t sample_t; typedef dsp::fd_sample_t fd_sample_t;
typedef dsp::fd_real_t fd_real_t; typedef dsp::srate_t srate_t;
typedef dsp::srate_t srate_t; typedef dsp::ftime_t ftime_t;
typedef unsigned uint_t; typedef unsigned uint_t;
typedef int int_t; typedef int int_t;
typedef unsigned vid_t; typedef unsigned vid_t;
@ -40,11 +40,11 @@ namespace cw
unsigned* maxBinN_V; // max value that binN_V[i] is allowed to take unsigned* maxBinN_V; // max value that binN_V[i] is allowed to take
unsigned* binN_V; // binN_V[ chN ] count of sample frames per channel unsigned* binN_V; // binN_V[ chN ] count of sample frames per channel
unsigned* hopSmpN_V; // hopSmpN_V[ chN ] hop sample count unsigned* hopSmpN_V; // hopSmpN_V[ chN ] hop sample count
fd_real_t** magV; // magV[ chN ][ binN ] fd_sample_t** magV; // magV[ chN ][ binN ]
fd_real_t** phsV; // phsV[ chN ][ binN ] fd_sample_t** phsV; // phsV[ chN ][ binN ]
fd_real_t** hzV; // hzV[ chN ][ binN ] fd_sample_t** hzV; // hzV[ chN ][ binN ]
bool* readyFlV; // readyFlV[chN] true if this channel is ready to be processed (used to sync. fbuf rate to abuf rate) bool* readyFlV; // readyFlV[chN] true if this channel is ready to be processed (used to sync. fbuf rate to abuf rate)
fd_real_t* buf; // memory used by this buffer (or NULL if magV,phsV,hzV point are proxied to another buffer) fd_sample_t* buf; // memory used by this buffer (or NULL if magV,phsV,hzV point are proxied to another buffer)
} fbuf_t; } fbuf_t;
typedef struct mbuf_str typedef struct mbuf_str
@ -66,15 +66,15 @@ namespace cw
kBoolMtxTFl = 0x00000020, kBoolMtxTFl = 0x00000020,
kUIntMtxTFl = 0x00000040, kUIntMtxTFl = 0x00000040,
kIntMtxTFl = 0x00000080, kIntMtxTFl = 0x00000080,
kRealMtxTFl = 0x00000100, kFloatMtxTFl = 0x00000100,
kFloatMtxTFl = 0x00000200, kDoubleMtxTFl= 0x00000200,
kDoubleMtxTFl= 0x00000400,
kABufTFl = 0x00000800, kABufTFl = 0x00000400,
kFBufTFl = 0x00001000, kFBufTFl = 0x00000800,
kMBufTFl = 0x00002000, kMBufTFl = 0x00001000,
kStringTFl = 0x00004000, kStringTFl = 0x00002000,
kTimeTFl = 0x00008000, kTimeTFl = 0x00004000,
kCfgTFl = 0x00008000,
kTypeMask = 0x0000ffff, kTypeMask = 0x0000ffff,
@ -85,7 +85,6 @@ namespace cw
union { union {
struct mtx::mtx_str< unsigned >* u; struct mtx::mtx_str< unsigned >* u;
struct mtx::mtx_str< int >* i; struct mtx::mtx_str< int >* i;
struct mtx::mtx_str< real_t >* r;
struct mtx::mtx_str< float >* f; struct mtx::mtx_str< float >* f;
struct mtx::mtx_str< double >* d; struct mtx::mtx_str< double >* d;
} u; } u;
@ -95,20 +94,20 @@ namespace cw
{ {
unsigned flags; unsigned flags;
union { union {
bool b; bool b;
uint_t u; uint_t u;
int_t i; int_t i;
float f; float f;
double d; double d;
mtx_t* mtx; mtx_t* mtx;
abuf_t* abuf;
fbuf_t* fbuf;
mbuf_t* mbuf;
abuf_t* abuf; char* s;
fbuf_t* fbuf;
mbuf_t* mbuf;
char* s; const object_t* cfg;
char* fname;
} u; } u;
@ -269,8 +268,8 @@ namespace cw
rc_t abuf_set_channel( abuf_t* buf, unsigned chIdx, const sample_t* v, unsigned vN ); rc_t abuf_set_channel( abuf_t* buf, unsigned chIdx, const sample_t* v, unsigned vN );
const sample_t* abuf_get_channel( abuf_t* buf, unsigned chIdx ); const sample_t* abuf_get_channel( abuf_t* buf, unsigned chIdx );
fbuf_t* fbuf_create( srate_t srate, unsigned chN, const unsigned* maxBinN_V, const unsigned* binN_V, const unsigned* hopSmpN_V, const fd_real_t** magV=nullptr, const fd_real_t** phsV=nullptr, const fd_real_t** hzV=nullptr ); fbuf_t* fbuf_create( srate_t srate, unsigned chN, const unsigned* maxBinN_V, const unsigned* binN_V, const unsigned* hopSmpN_V, const fd_sample_t** magV=nullptr, const fd_sample_t** phsV=nullptr, const fd_sample_t** hzV=nullptr );
fbuf_t* fbuf_create( srate_t srate, unsigned chN, unsigned maxBinN, unsigned binN, unsigned hopSmpN, const fd_real_t** magV=nullptr, const fd_real_t** phsV=nullptr, const fd_real_t** hzV=nullptr ); fbuf_t* fbuf_create( srate_t srate, unsigned chN, unsigned maxBinN, unsigned binN, unsigned hopSmpN, const fd_sample_t** magV=nullptr, const fd_sample_t** phsV=nullptr, const fd_sample_t** hzV=nullptr );
void fbuf_destroy( fbuf_t*& buf ); void fbuf_destroy( fbuf_t*& buf );
fbuf_t* fbuf_duplicate( const fbuf_t* src ); fbuf_t* fbuf_duplicate( const fbuf_t* src );
@ -332,8 +331,12 @@ namespace cw
// `value_cfg` is optional. Set it to NULL to ignore // `value_cfg` is optional. Set it to NULL to ignore
rc_t var_register( instance_t* inst, const char* var_label, unsigned sfx_id, unsigned vid, unsigned chIdx, const object_t* value_cfg, variable_t*& varRef ); rc_t var_register( instance_t* inst, const char* var_label, unsigned sfx_id, unsigned vid, unsigned chIdx, const object_t* value_cfg, variable_t*& varRef );
// Returns true if this var is connected to an external proc variable // Returns true if this var is connected to an source proc variable
bool is_connected_to_external_proc( const variable_t* var ); bool is_connected_to_source_proc( const variable_t* var );
// Return true if this var is acting as a source for another var.
bool is_a_source_var( const variable_t* var );
//----------------- //-----------------
// //
@ -411,8 +414,8 @@ namespace cw
rc_t var_register_and_set( instance_t* inst, const char* var_label, unsigned sfx_id, unsigned vid, unsigned chIdx, srate_t srate, unsigned chN, unsigned frameN ); rc_t var_register_and_set( instance_t* inst, const char* var_label, unsigned sfx_id, unsigned vid, unsigned chIdx, srate_t srate, unsigned chN, unsigned frameN );
rc_t var_register_and_set( instance_t* inst, const char* var_label, unsigned sfx_id, unsigned vid, unsigned chIdx, midi::ch_msg_t* midiA, unsigned midiN ); rc_t var_register_and_set( instance_t* inst, const char* var_label, unsigned sfx_id, unsigned vid, unsigned chIdx, midi::ch_msg_t* midiA, unsigned midiN );
rc_t var_register_and_set( instance_t* inst, const char* var_label, unsigned sfx_id, unsigned vid, unsigned chIdx, srate_t srate, unsigned chN, const unsigned* maxBinN_V, const unsigned* binN_V, const unsigned* hopSmpN_V, const fd_real_t** magV=nullptr, const fd_real_t** phsV=nullptr, const fd_real_t** hzV=nullptr ); rc_t var_register_and_set( instance_t* inst, const char* var_label, unsigned sfx_id, unsigned vid, unsigned chIdx, srate_t srate, unsigned chN, const unsigned* maxBinN_V, const unsigned* binN_V, const unsigned* hopSmpN_V, const fd_sample_t** magV=nullptr, const fd_sample_t** phsV=nullptr, const fd_sample_t** hzV=nullptr );
rc_t var_register_and_set( instance_t* inst, const char* var_label, unsigned sfx_id, unsigned vid, unsigned chIdx, srate_t srate, unsigned chN, unsigned maxBinN, unsigned binN, unsigned hopSmpN, const fd_real_t** magV=nullptr, const fd_real_t** phsV=nullptr, const fd_real_t** hzV=nullptr ); rc_t var_register_and_set( instance_t* inst, const char* var_label, unsigned sfx_id, unsigned vid, unsigned chIdx, srate_t srate, unsigned chN, unsigned maxBinN, unsigned binN, unsigned hopSmpN, const fd_sample_t** magV=nullptr, const fd_sample_t** phsV=nullptr, const fd_sample_t** hzV=nullptr );
inline rc_t _var_register_and_set(cw::flow::instance_t*, unsigned int ) { return kOkRC; } inline rc_t _var_register_and_set(cw::flow::instance_t*, unsigned int ) { return kOkRC; }
@ -424,7 +427,8 @@ namespace cw
variable_t* var = nullptr; variable_t* var = nullptr;
if((rc = var_register_and_set( inst, var_label, sfx_id, vid, chIdx, var)) == kOkRC ) if((rc = var_register_and_set( inst, var_label, sfx_id, vid, chIdx, var)) == kOkRC )
{ {
var_set( inst, vid, chIdx, val ); if((rc = var_set( inst, vid, chIdx, val )) != kOkRC )
return rc;
if((rc = _var_register_and_set( inst, chIdx, std::forward<ARGS>(args)...)) != kOkRC ) if((rc = _var_register_and_set( inst, chIdx, std::forward<ARGS>(args)...)) != kOkRC )
return rc; return rc;
@ -444,6 +448,8 @@ namespace cw
bool var_exists( instance_t* inst, const char* label, unsigned sfx_id, unsigned chIdx ); bool var_exists( instance_t* inst, const char* label, unsigned sfx_id, unsigned chIdx );
bool var_has_value( instance_t* inst, const char* label, unsigned sfx_id, unsigned chIdx ); bool var_has_value( instance_t* inst, const char* label, unsigned sfx_id, unsigned chIdx );
bool var_is_a_source( instance_t* inst, const char* label, unsigned sfx_id, unsigned chIdx );
bool var_is_a_source( instance_t* inst, unsigned vid, unsigned chIdx );
rc_t var_find( instance_t* inst, const char* var_label, unsigned sfx_id, unsigned chIdx, const variable_t*& varRef ); rc_t var_find( instance_t* inst, const char* var_label, unsigned sfx_id, unsigned chIdx, const variable_t*& varRef );
rc_t var_find( instance_t* inst, const char* var_label, unsigned sfx_id, unsigned chIdx, variable_t*& varRef ); rc_t var_find( instance_t* inst, const char* var_label, unsigned sfx_id, unsigned chIdx, variable_t*& varRef );