1453b576eSBram Moolenaar" test float functions 2453b576eSBram Moolenaar 3b46fecd3SBram Moolenaarsource check.vim 4b46fecd3SBram MoolenaarCheckFeature float 5453b576eSBram Moolenaar 6453b576eSBram Moolenaarfunc Test_abs() 762473611SBram Moolenaar call assert_equal('1.23', string(abs(1.23))) 862473611SBram Moolenaar call assert_equal('1.23', string(abs(-1.23))) 9*93cf85f9SBram Moolenaar eval -1.23->abs()->string()->assert_equal('1.23') 10*93cf85f9SBram Moolenaar 1162473611SBram Moolenaar call assert_equal('0.0', string(abs(0.0))) 1262473611SBram Moolenaar call assert_equal('0.0', string(abs(1.0/(1.0/0.0)))) 1362473611SBram Moolenaar call assert_equal('0.0', string(abs(-1.0/(1.0/0.0)))) 1462473611SBram Moolenaar call assert_equal('inf', string(abs(1.0/0.0))) 1562473611SBram Moolenaar call assert_equal('inf', string(abs(-1.0/0.0))) 1662473611SBram Moolenaar call assert_equal('nan', string(abs(0.0/0.0))) 1717aca707SBram Moolenaar call assert_equal('12', string(abs('12abc'))) 1887200413SBram Moolenaar call assert_equal('12', string(abs('-12abc'))) 1987200413SBram Moolenaar call assert_fails("call abs([])", 'E745:') 2087200413SBram Moolenaar call assert_fails("call abs({})", 'E728:') 2187200413SBram Moolenaar call assert_fails("call abs(function('string'))", 'E703:') 22453b576eSBram Moolenaarendfunc 23453b576eSBram Moolenaar 24453b576eSBram Moolenaarfunc Test_sqrt() 2562473611SBram Moolenaar call assert_equal('0.0', string(sqrt(0.0))) 2662473611SBram Moolenaar call assert_equal('1.414214', string(sqrt(2.0))) 27*93cf85f9SBram Moolenaar eval 2.0->sqrt()->string()->assert_equal('1.414214') 2862473611SBram Moolenaar call assert_equal('inf', string(sqrt(1.0/0.0))) 2962473611SBram Moolenaar call assert_equal('nan', string(sqrt(-1.0))) 3062473611SBram Moolenaar call assert_equal('nan', string(sqrt(0.0/0.0))) 3187200413SBram Moolenaar call assert_fails('call sqrt("")', 'E808:') 32453b576eSBram Moolenaarendfunc 33453b576eSBram Moolenaar 34453b576eSBram Moolenaarfunc Test_log() 3562473611SBram Moolenaar call assert_equal('0.0', string(log(1.0))) 3662473611SBram Moolenaar call assert_equal('-0.693147', string(log(0.5))) 37*93cf85f9SBram Moolenaar eval 0.5->log()->string()->assert_equal('-0.693147') 3862473611SBram Moolenaar call assert_equal('-inf', string(log(0.0))) 3962473611SBram Moolenaar call assert_equal('nan', string(log(-1.0))) 4062473611SBram Moolenaar call assert_equal('inf', string(log(1.0/0.0))) 4162473611SBram Moolenaar call assert_equal('nan', string(log(0.0/0.0))) 4287200413SBram Moolenaar call assert_fails('call log("")', 'E808:') 43453b576eSBram Moolenaarendfunc 44453b576eSBram Moolenaar 45453b576eSBram Moolenaarfunc Test_log10() 4662473611SBram Moolenaar call assert_equal('0.0', string(log10(1.0))) 4762473611SBram Moolenaar call assert_equal('2.0', string(log10(100.0))) 4862473611SBram Moolenaar call assert_equal('2.079181', string(log10(120.0))) 49*93cf85f9SBram Moolenaar eval 120.0->log10()->string()->assert_equal('2.079181') 5062473611SBram Moolenaar call assert_equal('-inf', string(log10(0.0))) 5162473611SBram Moolenaar call assert_equal('nan', string(log10(-1.0))) 5262473611SBram Moolenaar call assert_equal('inf', string(log10(1.0/0.0))) 5362473611SBram Moolenaar call assert_equal('nan', string(log10(0.0/0.0))) 5487200413SBram Moolenaar call assert_fails('call log10("")', 'E808:') 55453b576eSBram Moolenaarendfunc 56453b576eSBram Moolenaar 57453b576eSBram Moolenaarfunc Test_exp() 5862473611SBram Moolenaar call assert_equal('1.0', string(exp(0.0))) 5962473611SBram Moolenaar call assert_equal('7.389056', string(exp(2.0))) 6062473611SBram Moolenaar call assert_equal('0.367879', string(exp(-1.0))) 61*93cf85f9SBram Moolenaar eval -1.0->exp()->string()->assert_equal('0.367879') 6262473611SBram Moolenaar call assert_equal('inf', string(exp(1.0/0.0))) 6362473611SBram Moolenaar call assert_equal('0.0', string(exp(-1.0/0.0))) 6462473611SBram Moolenaar call assert_equal('nan', string(exp(0.0/0.0))) 6587200413SBram Moolenaar call assert_fails('call exp("")', 'E808:') 66453b576eSBram Moolenaarendfunc 67453b576eSBram Moolenaar 68453b576eSBram Moolenaarfunc Test_sin() 6962473611SBram Moolenaar call assert_equal('0.0', string(sin(0.0))) 7062473611SBram Moolenaar call assert_equal('0.841471', string(sin(1.0))) 7162473611SBram Moolenaar call assert_equal('-0.479426', string(sin(-0.5))) 72*93cf85f9SBram Moolenaar eval -0.5->sin()->string()->assert_equal('-0.479426') 7362473611SBram Moolenaar call assert_equal('nan', string(sin(0.0/0.0))) 7462473611SBram Moolenaar call assert_equal('nan', string(sin(1.0/0.0))) 7562473611SBram Moolenaar call assert_equal('0.0', string(sin(1.0/(1.0/0.0)))) 7662473611SBram Moolenaar call assert_equal('-0.0', string(sin(-1.0/(1.0/0.0)))) 7787200413SBram Moolenaar call assert_fails('call sin("")', 'E808:') 78453b576eSBram Moolenaarendfunc 79453b576eSBram Moolenaar 80453b576eSBram Moolenaarfunc Test_asin() 8162473611SBram Moolenaar call assert_equal('0.0', string(asin(0.0))) 8262473611SBram Moolenaar call assert_equal('1.570796', string(asin(1.0))) 83*93cf85f9SBram Moolenaar eval 1.0->asin()->string()->assert_equal('1.570796') 84*93cf85f9SBram Moolenaar 8562473611SBram Moolenaar call assert_equal('-0.523599', string(asin(-0.5))) 8662473611SBram Moolenaar call assert_equal('nan', string(asin(1.1))) 8762473611SBram Moolenaar call assert_equal('nan', string(asin(1.0/0.0))) 8862473611SBram Moolenaar call assert_equal('nan', string(asin(0.0/0.0))) 8987200413SBram Moolenaar call assert_fails('call asin("")', 'E808:') 90453b576eSBram Moolenaarendfunc 91453b576eSBram Moolenaar 92453b576eSBram Moolenaarfunc Test_sinh() 9362473611SBram Moolenaar call assert_equal('0.0', string(sinh(0.0))) 9462473611SBram Moolenaar call assert_equal('0.521095', string(sinh(0.5))) 9562473611SBram Moolenaar call assert_equal('-1.026517', string(sinh(-0.9))) 96*93cf85f9SBram Moolenaar eval -0.9->sinh()->string()->assert_equal('-1.026517') 9762473611SBram Moolenaar call assert_equal('inf', string(sinh(1.0/0.0))) 9862473611SBram Moolenaar call assert_equal('-inf', string(sinh(-1.0/0.0))) 9962473611SBram Moolenaar call assert_equal('nan', string(sinh(0.0/0.0))) 10087200413SBram Moolenaar call assert_fails('call sinh("")', 'E808:') 101453b576eSBram Moolenaarendfunc 102453b576eSBram Moolenaar 103453b576eSBram Moolenaarfunc Test_cos() 10462473611SBram Moolenaar call assert_equal('1.0', string(cos(0.0))) 10562473611SBram Moolenaar call assert_equal('0.540302', string(cos(1.0))) 10662473611SBram Moolenaar call assert_equal('0.877583', string(cos(-0.5))) 107*93cf85f9SBram Moolenaar eval -0.5->cos()->string()->assert_equal('0.877583') 10862473611SBram Moolenaar call assert_equal('nan', string(cos(0.0/0.0))) 10962473611SBram Moolenaar call assert_equal('nan', string(cos(1.0/0.0))) 11087200413SBram Moolenaar call assert_fails('call cos("")', 'E808:') 111453b576eSBram Moolenaarendfunc 112453b576eSBram Moolenaar 113453b576eSBram Moolenaarfunc Test_acos() 11462473611SBram Moolenaar call assert_equal('1.570796', string(acos(0.0))) 11562473611SBram Moolenaar call assert_equal('0.0', string(acos(1.0))) 11662473611SBram Moolenaar call assert_equal('3.141593', string(acos(-1.0))) 117*93cf85f9SBram Moolenaar eval -1.0->acos()->string()->assert_equal('3.141593') 11862473611SBram Moolenaar call assert_equal('2.094395', string(acos(-0.5))) 11962473611SBram Moolenaar call assert_equal('nan', string(acos(1.1))) 12062473611SBram Moolenaar call assert_equal('nan', string(acos(1.0/0.0))) 12162473611SBram Moolenaar call assert_equal('nan', string(acos(0.0/0.0))) 12287200413SBram Moolenaar call assert_fails('call acos("")', 'E808:') 123453b576eSBram Moolenaarendfunc 124453b576eSBram Moolenaar 125453b576eSBram Moolenaarfunc Test_cosh() 12662473611SBram Moolenaar call assert_equal('1.0', string(cosh(0.0))) 12762473611SBram Moolenaar call assert_equal('1.127626', string(cosh(0.5))) 128*93cf85f9SBram Moolenaar eval 0.5->cosh()->string()->assert_equal('1.127626') 12962473611SBram Moolenaar call assert_equal('inf', string(cosh(1.0/0.0))) 13062473611SBram Moolenaar call assert_equal('inf', string(cosh(-1.0/0.0))) 13162473611SBram Moolenaar call assert_equal('nan', string(cosh(0.0/0.0))) 13287200413SBram Moolenaar call assert_fails('call cosh("")', 'E808:') 133453b576eSBram Moolenaarendfunc 134453b576eSBram Moolenaar 135453b576eSBram Moolenaarfunc Test_tan() 13662473611SBram Moolenaar call assert_equal('0.0', string(tan(0.0))) 13762473611SBram Moolenaar call assert_equal('0.546302', string(tan(0.5))) 13862473611SBram Moolenaar call assert_equal('-0.546302', string(tan(-0.5))) 139*93cf85f9SBram Moolenaar eval -0.5->tan()->string()->assert_equal('-0.546302') 14062473611SBram Moolenaar call assert_equal('nan', string(tan(1.0/0.0))) 14162473611SBram Moolenaar call assert_equal('nan', string(cos(0.0/0.0))) 14262473611SBram Moolenaar call assert_equal('0.0', string(tan(1.0/(1.0/0.0)))) 14362473611SBram Moolenaar call assert_equal('-0.0', string(tan(-1.0/(1.0/0.0)))) 14487200413SBram Moolenaar call assert_fails('call tan("")', 'E808:') 145453b576eSBram Moolenaarendfunc 146453b576eSBram Moolenaar 147453b576eSBram Moolenaarfunc Test_atan() 14862473611SBram Moolenaar call assert_equal('0.0', string(atan(0.0))) 14962473611SBram Moolenaar call assert_equal('0.463648', string(atan(0.5))) 15062473611SBram Moolenaar call assert_equal('-0.785398', string(atan(-1.0))) 151*93cf85f9SBram Moolenaar eval -1.0->atan()->string()->assert_equal('-0.785398') 15262473611SBram Moolenaar call assert_equal('1.570796', string(atan(1.0/0.0))) 15362473611SBram Moolenaar call assert_equal('-1.570796', string(atan(-1.0/0.0))) 15462473611SBram Moolenaar call assert_equal('nan', string(atan(0.0/0.0))) 15587200413SBram Moolenaar call assert_fails('call atan("")', 'E808:') 156453b576eSBram Moolenaarendfunc 157453b576eSBram Moolenaar 158453b576eSBram Moolenaarfunc Test_atan2() 15962473611SBram Moolenaar call assert_equal('-2.356194', string(atan2(-1, -1))) 16062473611SBram Moolenaar call assert_equal('2.356194', string(atan2(1, -1))) 16162473611SBram Moolenaar call assert_equal('0.0', string(atan2(1.0, 1.0/0.0))) 162*93cf85f9SBram Moolenaar eval 1.0->atan2(1.0/0.0)->string()->assert_equal('0.0') 16362473611SBram Moolenaar call assert_equal('1.570796', string(atan2(1.0/0.0, 1.0))) 16462473611SBram Moolenaar call assert_equal('nan', string(atan2(0.0/0.0, 1.0))) 16587200413SBram Moolenaar call assert_fails('call atan2("", -1)', 'E808:') 16687200413SBram Moolenaar call assert_fails('call atan2(-1, "")', 'E808:') 167453b576eSBram Moolenaarendfunc 168453b576eSBram Moolenaar 169453b576eSBram Moolenaarfunc Test_tanh() 17062473611SBram Moolenaar call assert_equal('0.0', string(tanh(0.0))) 17162473611SBram Moolenaar call assert_equal('0.462117', string(tanh(0.5))) 17262473611SBram Moolenaar call assert_equal('-0.761594', string(tanh(-1.0))) 173*93cf85f9SBram Moolenaar eval -1.0->tanh()->string()->assert_equal('-0.761594') 17462473611SBram Moolenaar call assert_equal('1.0', string(tanh(1.0/0.0))) 17562473611SBram Moolenaar call assert_equal('-1.0', string(tanh(-1.0/0.0))) 17662473611SBram Moolenaar call assert_equal('nan', string(tanh(0.0/0.0))) 17787200413SBram Moolenaar call assert_fails('call tanh("")', 'E808:') 178453b576eSBram Moolenaarendfunc 179453b576eSBram Moolenaar 180453b576eSBram Moolenaarfunc Test_fmod() 18162473611SBram Moolenaar call assert_equal('0.13', string(fmod(12.33, 1.22))) 18262473611SBram Moolenaar call assert_equal('-0.13', string(fmod(-12.33, 1.22))) 18362473611SBram Moolenaar call assert_equal('nan', string(fmod(1.0/0.0, 1.0))) 184*93cf85f9SBram Moolenaar eval (1.0/0.0)->fmod(1.0)->string()->assert_equal('nan') 18562473611SBram Moolenaar " On Windows we get "nan" instead of 1.0, accept both. 18662473611SBram Moolenaar let res = string(fmod(1.0, 1.0/0.0)) 18762473611SBram Moolenaar if res != 'nan' 18862473611SBram Moolenaar call assert_equal('1.0', res) 18962473611SBram Moolenaar endif 19062473611SBram Moolenaar call assert_equal('nan', string(fmod(1.0, 0.0))) 19187200413SBram Moolenaar call assert_fails("call fmod('', 1.22)", 'E808:') 19287200413SBram Moolenaar call assert_fails("call fmod(12.33, '')", 'E808:') 193453b576eSBram Moolenaarendfunc 194453b576eSBram Moolenaar 195453b576eSBram Moolenaarfunc Test_pow() 19662473611SBram Moolenaar call assert_equal('1.0', string(pow(0.0, 0.0))) 19762473611SBram Moolenaar call assert_equal('8.0', string(pow(2.0, 3.0))) 198*93cf85f9SBram Moolenaar eval 2.0->pow(3.0)->string()->assert_equal('8.0') 19962473611SBram Moolenaar call assert_equal('nan', string(pow(2.0, 0.0/0.0))) 20062473611SBram Moolenaar call assert_equal('nan', string(pow(0.0/0.0, 3.0))) 20162473611SBram Moolenaar call assert_equal('nan', string(pow(0.0/0.0, 3.0))) 20262473611SBram Moolenaar call assert_equal('inf', string(pow(2.0, 1.0/0.0))) 20362473611SBram Moolenaar call assert_equal('inf', string(pow(1.0/0.0, 3.0))) 20487200413SBram Moolenaar call assert_fails("call pow('', 2.0)", 'E808:') 20587200413SBram Moolenaar call assert_fails("call pow(2.0, '')", 'E808:') 206453b576eSBram Moolenaarendfunc 207453b576eSBram Moolenaar 208453b576eSBram Moolenaarfunc Test_str2float() 20962473611SBram Moolenaar call assert_equal('1.0', string(str2float('1'))) 21008243d26SBram Moolenaar call assert_equal('1.0', string(str2float(' 1 '))) 21108243d26SBram Moolenaar call assert_equal('1.0', string(str2float(' 1.0 '))) 21262473611SBram Moolenaar call assert_equal('1.23', string(str2float('1.23'))) 21362473611SBram Moolenaar call assert_equal('1.23', string(str2float('1.23abc'))) 214*93cf85f9SBram Moolenaar eval '1.23abc'->str2float()->string()->assert_equal('1.23') 21562473611SBram Moolenaar call assert_equal('1.0e40', string(str2float('1e40'))) 21687200413SBram Moolenaar call assert_equal('-1.23', string(str2float('-1.23'))) 21787200413SBram Moolenaar call assert_equal('1.23', string(str2float(' + 1.23 '))) 21808243d26SBram Moolenaar 21908243d26SBram Moolenaar call assert_equal('1.0', string(str2float('+1'))) 22008243d26SBram Moolenaar call assert_equal('1.0', string(str2float('+1'))) 22108243d26SBram Moolenaar call assert_equal('1.0', string(str2float(' +1 '))) 22208243d26SBram Moolenaar call assert_equal('1.0', string(str2float(' + 1 '))) 22308243d26SBram Moolenaar 22408243d26SBram Moolenaar call assert_equal('-1.0', string(str2float('-1'))) 22508243d26SBram Moolenaar call assert_equal('-1.0', string(str2float('-1'))) 22608243d26SBram Moolenaar call assert_equal('-1.0', string(str2float(' -1 '))) 22708243d26SBram Moolenaar call assert_equal('-1.0', string(str2float(' - 1 '))) 22808243d26SBram Moolenaar 22987200413SBram Moolenaar call assert_equal('0.0', string(str2float('+0.0'))) 23087200413SBram Moolenaar call assert_equal('-0.0', string(str2float('-0.0'))) 23162473611SBram Moolenaar call assert_equal('inf', string(str2float('1e1000'))) 23262473611SBram Moolenaar call assert_equal('inf', string(str2float('inf'))) 23362473611SBram Moolenaar call assert_equal('-inf', string(str2float('-inf'))) 23487200413SBram Moolenaar call assert_equal('inf', string(str2float('+inf'))) 23562473611SBram Moolenaar call assert_equal('inf', string(str2float('Inf'))) 23687200413SBram Moolenaar call assert_equal('inf', string(str2float(' +inf '))) 23762473611SBram Moolenaar call assert_equal('nan', string(str2float('nan'))) 23862473611SBram Moolenaar call assert_equal('nan', string(str2float('NaN'))) 23987200413SBram Moolenaar call assert_equal('nan', string(str2float(' nan '))) 24087200413SBram Moolenaar 24187200413SBram Moolenaar call assert_fails("call str2float(1.2)", 'E806:') 24287200413SBram Moolenaar call assert_fails("call str2float([])", 'E730:') 24387200413SBram Moolenaar call assert_fails("call str2float({})", 'E731:') 24487200413SBram Moolenaar call assert_fails("call str2float(function('string'))", 'E729:') 245453b576eSBram Moolenaarendfunc 246453b576eSBram Moolenaar 247863e80b4SBram Moolenaarfunc Test_float2nr() 248863e80b4SBram Moolenaar call assert_equal(1, float2nr(1.234)) 249863e80b4SBram Moolenaar call assert_equal(123, float2nr(1.234e2)) 250863e80b4SBram Moolenaar call assert_equal(12, float2nr(123.4e-1)) 251*93cf85f9SBram Moolenaar eval 123.4e-1->float2nr()->assert_equal(12) 252863e80b4SBram Moolenaar let max_number = 1/0 253863e80b4SBram Moolenaar let min_number = -max_number 254863e80b4SBram Moolenaar call assert_equal(max_number/2+1, float2nr(pow(2, 62))) 255863e80b4SBram Moolenaar call assert_equal(max_number, float2nr(pow(2, 63))) 256863e80b4SBram Moolenaar call assert_equal(max_number, float2nr(pow(2, 64))) 257863e80b4SBram Moolenaar call assert_equal(min_number/2-1, float2nr(-pow(2, 62))) 258863e80b4SBram Moolenaar call assert_equal(min_number, float2nr(-pow(2, 63))) 259863e80b4SBram Moolenaar call assert_equal(min_number, float2nr(-pow(2, 64))) 260863e80b4SBram Moolenaarendfunc 261863e80b4SBram Moolenaar 262453b576eSBram Moolenaarfunc Test_floor() 26362473611SBram Moolenaar call assert_equal('2.0', string(floor(2.0))) 26462473611SBram Moolenaar call assert_equal('2.0', string(floor(2.11))) 26562473611SBram Moolenaar call assert_equal('2.0', string(floor(2.99))) 266*93cf85f9SBram Moolenaar eval 2.99->floor()->string()->assert_equal('2.0') 26762473611SBram Moolenaar call assert_equal('-3.0', string(floor(-2.11))) 26862473611SBram Moolenaar call assert_equal('-3.0', string(floor(-2.99))) 26962473611SBram Moolenaar call assert_equal('nan', string(floor(0.0/0.0))) 27062473611SBram Moolenaar call assert_equal('inf', string(floor(1.0/0.0))) 27162473611SBram Moolenaar call assert_equal('-inf', string(floor(-1.0/0.0))) 27287200413SBram Moolenaar call assert_fails("call floor('')", 'E808:') 273453b576eSBram Moolenaarendfunc 274453b576eSBram Moolenaar 275453b576eSBram Moolenaarfunc Test_ceil() 27662473611SBram Moolenaar call assert_equal('2.0', string(ceil(2.0))) 27762473611SBram Moolenaar call assert_equal('3.0', string(ceil(2.11))) 27862473611SBram Moolenaar call assert_equal('3.0', string(ceil(2.99))) 27962473611SBram Moolenaar call assert_equal('-2.0', string(ceil(-2.11))) 280*93cf85f9SBram Moolenaar eval -2.11->ceil()->string()->assert_equal('-2.0') 28162473611SBram Moolenaar call assert_equal('-2.0', string(ceil(-2.99))) 28262473611SBram Moolenaar call assert_equal('nan', string(ceil(0.0/0.0))) 28362473611SBram Moolenaar call assert_equal('inf', string(ceil(1.0/0.0))) 28462473611SBram Moolenaar call assert_equal('-inf', string(ceil(-1.0/0.0))) 28587200413SBram Moolenaar call assert_fails("call ceil('')", 'E808:') 286453b576eSBram Moolenaarendfunc 287453b576eSBram Moolenaar 288453b576eSBram Moolenaarfunc Test_round() 28962473611SBram Moolenaar call assert_equal('2.0', string(round(2.1))) 29062473611SBram Moolenaar call assert_equal('3.0', string(round(2.5))) 29162473611SBram Moolenaar call assert_equal('3.0', string(round(2.9))) 292*93cf85f9SBram Moolenaar eval 2.9->round()->string()->assert_equal('3.0') 29362473611SBram Moolenaar call assert_equal('-2.0', string(round(-2.1))) 29462473611SBram Moolenaar call assert_equal('-3.0', string(round(-2.5))) 29562473611SBram Moolenaar call assert_equal('-3.0', string(round(-2.9))) 29662473611SBram Moolenaar call assert_equal('nan', string(round(0.0/0.0))) 29762473611SBram Moolenaar call assert_equal('inf', string(round(1.0/0.0))) 29862473611SBram Moolenaar call assert_equal('-inf', string(round(-1.0/0.0))) 29987200413SBram Moolenaar call assert_fails("call round('')", 'E808:') 300453b576eSBram Moolenaarendfunc 301453b576eSBram Moolenaar 302453b576eSBram Moolenaarfunc Test_trunc() 30362473611SBram Moolenaar call assert_equal('2.0', string(trunc(2.1))) 30462473611SBram Moolenaar call assert_equal('2.0', string(trunc(2.5))) 30562473611SBram Moolenaar call assert_equal('2.0', string(trunc(2.9))) 306*93cf85f9SBram Moolenaar eval 2.9->trunc()->string()->assert_equal('2.0') 30762473611SBram Moolenaar call assert_equal('-2.0', string(trunc(-2.1))) 30862473611SBram Moolenaar call assert_equal('-2.0', string(trunc(-2.5))) 30962473611SBram Moolenaar call assert_equal('-2.0', string(trunc(-2.9))) 31062473611SBram Moolenaar call assert_equal('nan', string(trunc(0.0/0.0))) 31162473611SBram Moolenaar call assert_equal('inf', string(trunc(1.0/0.0))) 31262473611SBram Moolenaar call assert_equal('-inf', string(trunc(-1.0/0.0))) 31387200413SBram Moolenaar call assert_fails("call trunc('')", 'E808:') 314453b576eSBram Moolenaarendfunc 315453b576eSBram Moolenaar 316fda1bff3SBram Moolenaarfunc Test_isinf() 317fda1bff3SBram Moolenaar call assert_equal(1, isinf(1.0/0.0)) 318fda1bff3SBram Moolenaar call assert_equal(-1, isinf(-1.0/0.0)) 319*93cf85f9SBram Moolenaar eval (-1.0/0.0)->isinf()->assert_equal(-1) 320fda1bff3SBram Moolenaar call assert_false(isinf(1.0)) 321fda1bff3SBram Moolenaar call assert_false(isinf(0.0/0.0)) 322fda1bff3SBram Moolenaar call assert_false(isinf('a')) 323fda1bff3SBram Moolenaar call assert_false(isinf([])) 324fda1bff3SBram Moolenaar call assert_false(isinf({})) 325fda1bff3SBram Moolenaarendfunc 326fda1bff3SBram Moolenaar 327453b576eSBram Moolenaarfunc Test_isnan() 328fda1bff3SBram Moolenaar call assert_true(isnan(0.0/0.0)) 329fda1bff3SBram Moolenaar call assert_false(isnan(1.0)) 330fda1bff3SBram Moolenaar call assert_false(isnan(1.0/0.0)) 331*93cf85f9SBram Moolenaar eval (1.0/0.0)->isnan()->assert_false() 332fda1bff3SBram Moolenaar call assert_false(isnan(-1.0/0.0)) 333fda1bff3SBram Moolenaar call assert_false(isnan('a')) 334fda1bff3SBram Moolenaar call assert_false(isnan([])) 335fda1bff3SBram Moolenaar call assert_false(isnan({})) 336453b576eSBram Moolenaarendfunc 337863e80b4SBram Moolenaar 338863e80b4SBram Moolenaar" This was converted from test65 339863e80b4SBram Moolenaarfunc Test_float_misc() 340863e80b4SBram Moolenaar call assert_equal('123.456000', printf('%f', 123.456)) 341863e80b4SBram Moolenaar call assert_equal('1.234560e+02', printf('%e', 123.456)) 342863e80b4SBram Moolenaar call assert_equal('123.456', printf('%g', 123.456)) 343863e80b4SBram Moolenaar " += 344863e80b4SBram Moolenaar let v = 1.234 345863e80b4SBram Moolenaar let v += 6.543 346863e80b4SBram Moolenaar call assert_equal('7.777', printf('%g', v)) 347863e80b4SBram Moolenaar let v = 1.234 348863e80b4SBram Moolenaar let v += 5 349863e80b4SBram Moolenaar call assert_equal('6.234', printf('%g', v)) 350863e80b4SBram Moolenaar let v = 5 351863e80b4SBram Moolenaar let v += 3.333 352863e80b4SBram Moolenaar call assert_equal('8.333', string(v)) 353863e80b4SBram Moolenaar " == 354863e80b4SBram Moolenaar let v = 1.234 355863e80b4SBram Moolenaar call assert_true(v == 1.234) 356863e80b4SBram Moolenaar call assert_false(v == 1.2341) 357863e80b4SBram Moolenaar " add-subtract 358863e80b4SBram Moolenaar call assert_equal('5.234', printf('%g', 4 + 1.234)) 359863e80b4SBram Moolenaar call assert_equal('-6.766', printf('%g', 1.234 - 8)) 360863e80b4SBram Moolenaar " mult-div 361863e80b4SBram Moolenaar call assert_equal('4.936', printf('%g', 4 * 1.234)) 362863e80b4SBram Moolenaar call assert_equal('0.003241', printf('%g', 4.0 / 1234)) 363863e80b4SBram Moolenaar " dict 364863e80b4SBram Moolenaar call assert_equal("{'x': 1.234, 'y': -2.0e20}", string({'x': 1.234, 'y': -2.0e20})) 365863e80b4SBram Moolenaar " list 366863e80b4SBram Moolenaar call assert_equal('[-123.4, 2.0e-20]', string([-123.4, 2.0e-20])) 367863e80b4SBram Moolenaarendfunc 368863e80b4SBram Moolenaar 369863e80b4SBram Moolenaar" vim: shiftwidth=2 sts=2 expandtab 370