From 312d5ea58d1597698c9f38271f5dbe465088a8b1 Mon Sep 17 00:00:00 2001 From: Ge Wang Date: Thu, 21 Nov 2024 13:10:24 -0800 Subject: [PATCH] add implicit float->int conversion for setParamFloat() --- src/core/chuck.cpp | 13 ++++++++++++- 1 file changed, 12 insertions(+), 1 deletion(-) diff --git a/src/core/chuck.cpp b/src/core/chuck.cpp index 06661dba1..f2491fb47 100644 --- a/src/core/chuck.cpp +++ b/src/core/chuck.cpp @@ -338,13 +338,19 @@ t_CKBOOL ChucK::setParamFloat( const std::string & name, t_CKFLOAT value ) std::string key = tolower(name); // check read-only if( readOnlyParam(key) ) return FALSE; - // check + // check param type if( m_params.count( key ) > 0 && m_param_types[key] == ck_param_float ) { // insert into map m_params[key] = ck_ftoa( value, 32 ); return TRUE; } + // if param is an int, e.g., sample rate | 1.5.4.2 (ge) + else if( m_params.count( key ) > 0 && m_param_types[key] == ck_param_int ) + { + // round and redirect to setParam() as int + return setParam( name, (t_CKINT)(value+.05) ); + } else { return FALSE; @@ -441,6 +447,11 @@ t_CKFLOAT ChucK::getParamFloat( const std::string & name ) std::istringstream s( m_params[key] ); s >> result; } + else if( m_params.count( key ) > 0 && m_param_types[key] == ck_param_int ) + { + // get int and return as float | 1.5.4.2 (ge) + return (t_CKFLOAT)getParamInt(name); + } return result; }