cwFlowNet : network_apply_???_presets() now all optionally use 'proc_label_sfx_id'
This commit is contained in:
parent
760ab68d4f
commit
d1ba6f76d7
@ -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 );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -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 );
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user