cwFlowNet : network_apply_???_presets() now all optionally use 'proc_label_sfx_id'

This commit is contained in:
kevin 2024-05-24 16:36:43 -04:00
parent 760ab68d4f
commit d1ba6f76d7
2 changed files with 39 additions and 36 deletions

View File

@ -90,7 +90,7 @@ namespace cw
{ {
bool is_var_cfg_type_fl = (vd = var_desc_find( proc->class_desc, var_label ))!=nullptr && cwIsFlag(vd->type,kCfgTFl); bool is_var_cfg_type_fl = (vd = var_desc_find( proc->class_desc, var_label ))!=nullptr && cwIsFlag(vd->type,kCfgTFl);
bool is_list_fl = value->is_list(); bool is_list_fl = value->is_list();
bool is_list_of_list_fl = is_list_fl && value->child_count() > 0 && value->child_ele(0)->is_list(); bool is_list_of_list_fl = is_list_fl && value->child_count() > 0 && value->child_ele(0)->is_container();
bool parse_list_fl = (is_list_fl && !is_var_cfg_type_fl) || (is_list_of_list_fl && is_var_cfg_type_fl); bool parse_list_fl = (is_list_fl && !is_var_cfg_type_fl) || (is_list_of_list_fl && is_var_cfg_type_fl);
// if a list of values was given and the var type is not a 'cfg' type or if a list of lists was given // if a list of values was given and the var type is not a 'cfg' type or if a list of lists was given
@ -2209,7 +2209,7 @@ namespace cw
proc->class_desc = class_desc; proc->class_desc = class_desc;
proc->net = &net; proc->net = &net;
// parse the in-list ,fill in pstate.in_array, and create var proc instances for var's referenced by in-list // parse the in-list ,fill in pstate.in_array, and create var instances for var's referenced by in-list
if((rc = _in_stmt_parse_in_list( net, proc, proxyVarL, pstate )) != kOkRC ) if((rc = _in_stmt_parse_in_list( net, proc, proxyVarL, pstate )) != kOkRC )
{ {
rc = cwLogError(rc,"in-list parse failed on proc inst instance '%s:%i'.",cwStringNullGuard(proc->label),pstate.proc_label_sfx_id); rc = cwLogError(rc,"in-list parse failed on proc inst instance '%s:%i'.",cwStringNullGuard(proc->label),pstate.proc_label_sfx_id);
@ -3038,7 +3038,7 @@ namespace cw
for(preset_value=vlist->value_head; preset_value!=nullptr; preset_value=preset_value->link) for(preset_value=vlist->value_head; preset_value!=nullptr; preset_value=preset_value->link)
{ {
if( preset_value->proc->label_sfx_id == proc_label_sfx_id ) if( proc_label_sfx_id==kInvalidId || preset_value->proc->label_sfx_id == proc_label_sfx_id )
if((rc = var_set( preset_value->var, &preset_value->value )) != kOkRC ) if((rc = var_set( preset_value->var, &preset_value->value )) != kOkRC )
{ {
rc = cwLogError(rc,"Preset value apply failed on '%s:%i'-'%s:%i'.", rc = cwLogError(rc,"Preset value apply failed on '%s:%i'-'%s:%i'.",
@ -3052,7 +3052,7 @@ namespace cw
return rc; return rc;
} }
rc_t _network_apply_dual_preset( network_t& net, const network_preset_t* net_ps0, const network_preset_t* net_ps1, double coeff ) rc_t _network_apply_dual_preset( network_t& net, const network_preset_t* net_ps0, const network_preset_t* net_ps1, double coeff, unsigned proc_label_sfx_id )
{ {
rc_t rc = kOkRC; rc_t rc = kOkRC;
@ -3062,6 +3062,7 @@ namespace cw
// set the value pointer in each of the preset-pair records referenced by preset-1 // set the value pointer in each of the preset-pair records referenced by preset-1
for(const preset_value_t* pv1=net_ps1->u.vlist.value_head; pv1!=nullptr; pv1=pv1->link) for(const preset_value_t* pv1=net_ps1->u.vlist.value_head; pv1!=nullptr; pv1=pv1->link)
if( proc_label_sfx_id == kInvalidId || pv1->proc->label_sfx_id == proc_label_sfx_id )
{ {
if( pv1->var->chIdx != kAnyChIdx ) if( pv1->var->chIdx != kAnyChIdx )
net.preset_pairA[ pv1->pairTblIdx ].value = &pv1->value; net.preset_pairA[ pv1->pairTblIdx ].value = &pv1->value;
@ -3077,6 +3078,7 @@ namespace cw
// //
for(const preset_value_t* pv0=net_ps0->u.vlist.value_head; pv0!=nullptr; pv0=pv0->link) for(const preset_value_t* pv0=net_ps0->u.vlist.value_head; pv0!=nullptr; pv0=pv0->link)
if( proc_label_sfx_id == kInvalidId || pv0->proc->label_sfx_id == proc_label_sfx_id )
{ {
if( pv0->var->chIdx != kAnyChIdx ) if( pv0->var->chIdx != kAnyChIdx )
{ {
@ -3267,7 +3269,7 @@ cw::rc_t cw::flow::network_apply_preset( network_t& net, const char* preset_labe
break; break;
case kPresetDualTId: case kPresetDualTId:
if((rc = _network_apply_dual_preset(net, network_preset->u.dual.pri, network_preset->u.dual.sec, network_preset->u.dual.coeff )) != kOkRC ) if((rc = _network_apply_dual_preset(net, network_preset->u.dual.pri, network_preset->u.dual.sec, network_preset->u.dual.coeff, proc_label_sfx_id )) != kOkRC )
goto errLabel; goto errLabel;
break; break;
@ -3287,7 +3289,7 @@ errLabel:
} }
cw::rc_t cw::flow::network_apply_dual_preset( network_t& net, const char* preset_label_0, const char* preset_label_1, double coeff ) cw::rc_t cw::flow::network_apply_dual_preset( network_t& net, const char* preset_label_0, const char* preset_label_1, double coeff, unsigned proc_label_sfx_id )
{ {
rc_t rc = kOkRC; rc_t rc = kOkRC;
const network_preset_t* net_ps0 = nullptr; const network_preset_t* net_ps0 = nullptr;
@ -3305,7 +3307,7 @@ cw::rc_t cw::flow::network_apply_dual_preset( network_t& net, const char* preset
goto errLabel; goto errLabel;
} }
if((rc = _network_apply_dual_preset(net, net_ps0, net_ps1, coeff )) != kOkRC ) if((rc = _network_apply_dual_preset(net, net_ps0, net_ps1, coeff, proc_label_sfx_id )) != kOkRC )
goto errLabel; goto errLabel;
errLabel: errLabel:
@ -3483,7 +3485,7 @@ errLabel:
#endif #endif
cw::rc_t cw::flow::network_apply_preset( network_t& net, const multi_preset_selector_t& mps ) cw::rc_t cw::flow::network_apply_preset( network_t& net, const multi_preset_selector_t& mps, unsigned proc_label_sfx_id )
{ {
rc_t rc = kOkRC; rc_t rc = kOkRC;
const char* label0 = nullptr; const char* label0 = nullptr;
@ -3574,12 +3576,12 @@ cw::rc_t cw::flow::network_apply_preset( network_t& net, const multi_preset_sele
if( label1 == nullptr ) if( label1 == nullptr )
{ {
rc = network_apply_preset( net, label0 ); rc = network_apply_preset( net, label0, proc_label_sfx_id );
} }
else else
{ {
double coeff = _calc_multi_preset_dual_coeff(mps); double coeff = _calc_multi_preset_dual_coeff(mps);
rc = network_apply_dual_preset( net, label0, label1, coeff ); rc = network_apply_dual_preset( net, label0, label1, coeff, proc_label_sfx_id );
} }

View File

@ -74,9 +74,10 @@ namespace cw
// 'proc_label_sfx_id' is the proc label_sfx_id to be used to identify all proc's which will // 'proc_label_sfx_id' is the proc label_sfx_id to be used to identify all proc's which will
// be updated by the preset application. This is used to identify the set of procs to be updated // be updated by the preset application. This is used to identify the set of procs to be updated
// for 'poly' networks. // for 'poly' networks.
rc_t network_apply_preset( network_t& net, const char* presetLabel, unsigned proc_label_sfx_id=kBaseSfxId ); // If 'proc_label_sfx_id' is set to 'kInvalidId' then the preset will be applied to all proc's.
rc_t network_apply_dual_preset( network_t& net, const char* presetLabel_0, const char* presetLabel_1, double coeff ); rc_t network_apply_preset( network_t& net, const char* presetLabel, unsigned proc_label_sfx_id=kInvalidId );
rc_t network_apply_preset( network_t& net, const multi_preset_selector_t& mps ); rc_t network_apply_dual_preset( network_t& net, const char* presetLabel_0, const char* presetLabel_1, double coeff, unsigned proc_label_sfx_id=kInvalidId );
rc_t network_apply_preset( network_t& net, const multi_preset_selector_t& mps, unsigned proc_label_sfx_id=kInvalidId );
} }