1453b576eSBram Moolenaar" test float functions 2453b576eSBram Moolenaar 3b46fecd3SBram Moolenaarsource check.vim 4b46fecd3SBram MoolenaarCheckFeature float 53cfa5b16SBram Moolenaarsource vim9.vim 6453b576eSBram Moolenaar 7453b576eSBram Moolenaarfunc Test_abs() 862473611SBram Moolenaar call assert_equal('1.23', string(abs(1.23))) 962473611SBram Moolenaar call assert_equal('1.23', string(abs(-1.23))) 1093cf85f9SBram Moolenaar eval -1.23->abs()->string()->assert_equal('1.23') 1193cf85f9SBram Moolenaar 1262473611SBram Moolenaar call assert_equal('0.0', string(abs(0.0))) 1362473611SBram Moolenaar call assert_equal('0.0', string(abs(1.0/(1.0/0.0)))) 1462473611SBram Moolenaar call assert_equal('0.0', string(abs(-1.0/(1.0/0.0)))) 1562473611SBram Moolenaar call assert_equal('inf', string(abs(1.0/0.0))) 1662473611SBram Moolenaar call assert_equal('inf', string(abs(-1.0/0.0))) 1762473611SBram Moolenaar call assert_equal('nan', string(abs(0.0/0.0))) 1817aca707SBram Moolenaar call assert_equal('12', string(abs('12abc'))) 1987200413SBram Moolenaar call assert_equal('12', string(abs('-12abc'))) 2087200413SBram Moolenaar call assert_fails("call abs([])", 'E745:') 2187200413SBram Moolenaar call assert_fails("call abs({})", 'E728:') 2287200413SBram Moolenaar call assert_fails("call abs(function('string'))", 'E703:') 23453b576eSBram Moolenaarendfunc 24453b576eSBram Moolenaar 25453b576eSBram Moolenaarfunc Test_sqrt() 2662473611SBram Moolenaar call assert_equal('0.0', string(sqrt(0.0))) 2762473611SBram Moolenaar call assert_equal('1.414214', string(sqrt(2.0))) 2893cf85f9SBram Moolenaar eval 2.0->sqrt()->string()->assert_equal('1.414214') 2962473611SBram Moolenaar call assert_equal('inf', string(sqrt(1.0/0.0))) 3062473611SBram Moolenaar call assert_equal('nan', string(sqrt(-1.0))) 3162473611SBram Moolenaar call assert_equal('nan', string(sqrt(0.0/0.0))) 3287200413SBram Moolenaar call assert_fails('call sqrt("")', 'E808:') 33453b576eSBram Moolenaarendfunc 34453b576eSBram Moolenaar 35453b576eSBram Moolenaarfunc Test_log() 3662473611SBram Moolenaar call assert_equal('0.0', string(log(1.0))) 3762473611SBram Moolenaar call assert_equal('-0.693147', string(log(0.5))) 3893cf85f9SBram Moolenaar eval 0.5->log()->string()->assert_equal('-0.693147') 3962473611SBram Moolenaar call assert_equal('-inf', string(log(0.0))) 4062473611SBram Moolenaar call assert_equal('nan', string(log(-1.0))) 4162473611SBram Moolenaar call assert_equal('inf', string(log(1.0/0.0))) 4262473611SBram Moolenaar call assert_equal('nan', string(log(0.0/0.0))) 4387200413SBram Moolenaar call assert_fails('call log("")', 'E808:') 44453b576eSBram Moolenaarendfunc 45453b576eSBram Moolenaar 46453b576eSBram Moolenaarfunc Test_log10() 4762473611SBram Moolenaar call assert_equal('0.0', string(log10(1.0))) 4862473611SBram Moolenaar call assert_equal('2.0', string(log10(100.0))) 4962473611SBram Moolenaar call assert_equal('2.079181', string(log10(120.0))) 5093cf85f9SBram Moolenaar eval 120.0->log10()->string()->assert_equal('2.079181') 5162473611SBram Moolenaar call assert_equal('-inf', string(log10(0.0))) 5262473611SBram Moolenaar call assert_equal('nan', string(log10(-1.0))) 5362473611SBram Moolenaar call assert_equal('inf', string(log10(1.0/0.0))) 5462473611SBram Moolenaar call assert_equal('nan', string(log10(0.0/0.0))) 5587200413SBram Moolenaar call assert_fails('call log10("")', 'E808:') 56453b576eSBram Moolenaarendfunc 57453b576eSBram Moolenaar 58453b576eSBram Moolenaarfunc Test_exp() 5962473611SBram Moolenaar call assert_equal('1.0', string(exp(0.0))) 6062473611SBram Moolenaar call assert_equal('7.389056', string(exp(2.0))) 6162473611SBram Moolenaar call assert_equal('0.367879', string(exp(-1.0))) 6293cf85f9SBram Moolenaar eval -1.0->exp()->string()->assert_equal('0.367879') 6362473611SBram Moolenaar call assert_equal('inf', string(exp(1.0/0.0))) 6462473611SBram Moolenaar call assert_equal('0.0', string(exp(-1.0/0.0))) 6562473611SBram Moolenaar call assert_equal('nan', string(exp(0.0/0.0))) 6687200413SBram Moolenaar call assert_fails('call exp("")', 'E808:') 67453b576eSBram Moolenaarendfunc 68453b576eSBram Moolenaar 69453b576eSBram Moolenaarfunc Test_sin() 7062473611SBram Moolenaar call assert_equal('0.0', string(sin(0.0))) 7162473611SBram Moolenaar call assert_equal('0.841471', string(sin(1.0))) 7262473611SBram Moolenaar call assert_equal('-0.479426', string(sin(-0.5))) 7393cf85f9SBram Moolenaar eval -0.5->sin()->string()->assert_equal('-0.479426') 7462473611SBram Moolenaar call assert_equal('nan', string(sin(0.0/0.0))) 7562473611SBram Moolenaar call assert_equal('nan', string(sin(1.0/0.0))) 7662473611SBram Moolenaar call assert_equal('0.0', string(sin(1.0/(1.0/0.0)))) 7762473611SBram Moolenaar call assert_equal('-0.0', string(sin(-1.0/(1.0/0.0)))) 7887200413SBram Moolenaar call assert_fails('call sin("")', 'E808:') 79453b576eSBram Moolenaarendfunc 80453b576eSBram Moolenaar 81453b576eSBram Moolenaarfunc Test_asin() 8262473611SBram Moolenaar call assert_equal('0.0', string(asin(0.0))) 8362473611SBram Moolenaar call assert_equal('1.570796', string(asin(1.0))) 8493cf85f9SBram Moolenaar eval 1.0->asin()->string()->assert_equal('1.570796') 8593cf85f9SBram Moolenaar 8662473611SBram Moolenaar call assert_equal('-0.523599', string(asin(-0.5))) 8762473611SBram Moolenaar call assert_equal('nan', string(asin(1.1))) 8862473611SBram Moolenaar call assert_equal('nan', string(asin(1.0/0.0))) 8962473611SBram Moolenaar call assert_equal('nan', string(asin(0.0/0.0))) 9087200413SBram Moolenaar call assert_fails('call asin("")', 'E808:') 91453b576eSBram Moolenaarendfunc 92453b576eSBram Moolenaar 93453b576eSBram Moolenaarfunc Test_sinh() 9462473611SBram Moolenaar call assert_equal('0.0', string(sinh(0.0))) 9562473611SBram Moolenaar call assert_equal('0.521095', string(sinh(0.5))) 9662473611SBram Moolenaar call assert_equal('-1.026517', string(sinh(-0.9))) 9793cf85f9SBram Moolenaar eval -0.9->sinh()->string()->assert_equal('-1.026517') 9862473611SBram Moolenaar call assert_equal('inf', string(sinh(1.0/0.0))) 9962473611SBram Moolenaar call assert_equal('-inf', string(sinh(-1.0/0.0))) 10062473611SBram Moolenaar call assert_equal('nan', string(sinh(0.0/0.0))) 10187200413SBram Moolenaar call assert_fails('call sinh("")', 'E808:') 102453b576eSBram Moolenaarendfunc 103453b576eSBram Moolenaar 104453b576eSBram Moolenaarfunc Test_cos() 10562473611SBram Moolenaar call assert_equal('1.0', string(cos(0.0))) 10662473611SBram Moolenaar call assert_equal('0.540302', string(cos(1.0))) 10762473611SBram Moolenaar call assert_equal('0.877583', string(cos(-0.5))) 10893cf85f9SBram Moolenaar eval -0.5->cos()->string()->assert_equal('0.877583') 10962473611SBram Moolenaar call assert_equal('nan', string(cos(0.0/0.0))) 11062473611SBram Moolenaar call assert_equal('nan', string(cos(1.0/0.0))) 11187200413SBram Moolenaar call assert_fails('call cos("")', 'E808:') 112453b576eSBram Moolenaarendfunc 113453b576eSBram Moolenaar 114453b576eSBram Moolenaarfunc Test_acos() 11562473611SBram Moolenaar call assert_equal('1.570796', string(acos(0.0))) 11662473611SBram Moolenaar call assert_equal('0.0', string(acos(1.0))) 11762473611SBram Moolenaar call assert_equal('3.141593', string(acos(-1.0))) 11893cf85f9SBram Moolenaar eval -1.0->acos()->string()->assert_equal('3.141593') 11962473611SBram Moolenaar call assert_equal('2.094395', string(acos(-0.5))) 12062473611SBram Moolenaar call assert_equal('nan', string(acos(1.1))) 12162473611SBram Moolenaar call assert_equal('nan', string(acos(1.0/0.0))) 12262473611SBram Moolenaar call assert_equal('nan', string(acos(0.0/0.0))) 12387200413SBram Moolenaar call assert_fails('call acos("")', 'E808:') 124453b576eSBram Moolenaarendfunc 125453b576eSBram Moolenaar 126453b576eSBram Moolenaarfunc Test_cosh() 12762473611SBram Moolenaar call assert_equal('1.0', string(cosh(0.0))) 12862473611SBram Moolenaar call assert_equal('1.127626', string(cosh(0.5))) 12993cf85f9SBram Moolenaar eval 0.5->cosh()->string()->assert_equal('1.127626') 13062473611SBram Moolenaar call assert_equal('inf', string(cosh(1.0/0.0))) 13162473611SBram Moolenaar call assert_equal('inf', string(cosh(-1.0/0.0))) 13262473611SBram Moolenaar call assert_equal('nan', string(cosh(0.0/0.0))) 13387200413SBram Moolenaar call assert_fails('call cosh("")', 'E808:') 134453b576eSBram Moolenaarendfunc 135453b576eSBram Moolenaar 136453b576eSBram Moolenaarfunc Test_tan() 13762473611SBram Moolenaar call assert_equal('0.0', string(tan(0.0))) 13862473611SBram Moolenaar call assert_equal('0.546302', string(tan(0.5))) 13962473611SBram Moolenaar call assert_equal('-0.546302', string(tan(-0.5))) 14093cf85f9SBram Moolenaar eval -0.5->tan()->string()->assert_equal('-0.546302') 14162473611SBram Moolenaar call assert_equal('nan', string(tan(1.0/0.0))) 14262473611SBram Moolenaar call assert_equal('nan', string(cos(0.0/0.0))) 14362473611SBram Moolenaar call assert_equal('0.0', string(tan(1.0/(1.0/0.0)))) 14462473611SBram Moolenaar call assert_equal('-0.0', string(tan(-1.0/(1.0/0.0)))) 14587200413SBram Moolenaar call assert_fails('call tan("")', 'E808:') 146453b576eSBram Moolenaarendfunc 147453b576eSBram Moolenaar 148453b576eSBram Moolenaarfunc Test_atan() 14962473611SBram Moolenaar call assert_equal('0.0', string(atan(0.0))) 15062473611SBram Moolenaar call assert_equal('0.463648', string(atan(0.5))) 15162473611SBram Moolenaar call assert_equal('-0.785398', string(atan(-1.0))) 15293cf85f9SBram Moolenaar eval -1.0->atan()->string()->assert_equal('-0.785398') 15362473611SBram Moolenaar call assert_equal('1.570796', string(atan(1.0/0.0))) 15462473611SBram Moolenaar call assert_equal('-1.570796', string(atan(-1.0/0.0))) 15562473611SBram Moolenaar call assert_equal('nan', string(atan(0.0/0.0))) 15687200413SBram Moolenaar call assert_fails('call atan("")', 'E808:') 157453b576eSBram Moolenaarendfunc 158453b576eSBram Moolenaar 159453b576eSBram Moolenaarfunc Test_atan2() 16062473611SBram Moolenaar call assert_equal('-2.356194', string(atan2(-1, -1))) 16162473611SBram Moolenaar call assert_equal('2.356194', string(atan2(1, -1))) 16262473611SBram Moolenaar call assert_equal('0.0', string(atan2(1.0, 1.0/0.0))) 16393cf85f9SBram Moolenaar eval 1.0->atan2(1.0/0.0)->string()->assert_equal('0.0') 16462473611SBram Moolenaar call assert_equal('1.570796', string(atan2(1.0/0.0, 1.0))) 16562473611SBram Moolenaar call assert_equal('nan', string(atan2(0.0/0.0, 1.0))) 16687200413SBram Moolenaar call assert_fails('call atan2("", -1)', 'E808:') 16787200413SBram Moolenaar call assert_fails('call atan2(-1, "")', 'E808:') 168453b576eSBram Moolenaarendfunc 169453b576eSBram Moolenaar 170453b576eSBram Moolenaarfunc Test_tanh() 17162473611SBram Moolenaar call assert_equal('0.0', string(tanh(0.0))) 17262473611SBram Moolenaar call assert_equal('0.462117', string(tanh(0.5))) 17362473611SBram Moolenaar call assert_equal('-0.761594', string(tanh(-1.0))) 17493cf85f9SBram Moolenaar eval -1.0->tanh()->string()->assert_equal('-0.761594') 17562473611SBram Moolenaar call assert_equal('1.0', string(tanh(1.0/0.0))) 17662473611SBram Moolenaar call assert_equal('-1.0', string(tanh(-1.0/0.0))) 17762473611SBram Moolenaar call assert_equal('nan', string(tanh(0.0/0.0))) 17887200413SBram Moolenaar call assert_fails('call tanh("")', 'E808:') 179453b576eSBram Moolenaarendfunc 180453b576eSBram Moolenaar 181453b576eSBram Moolenaarfunc Test_fmod() 18262473611SBram Moolenaar call assert_equal('0.13', string(fmod(12.33, 1.22))) 18362473611SBram Moolenaar call assert_equal('-0.13', string(fmod(-12.33, 1.22))) 18462473611SBram Moolenaar call assert_equal('nan', string(fmod(1.0/0.0, 1.0))) 18593cf85f9SBram Moolenaar eval (1.0/0.0)->fmod(1.0)->string()->assert_equal('nan') 18662473611SBram Moolenaar " On Windows we get "nan" instead of 1.0, accept both. 18762473611SBram Moolenaar let res = string(fmod(1.0, 1.0/0.0)) 18862473611SBram Moolenaar if res != 'nan' 18962473611SBram Moolenaar call assert_equal('1.0', res) 19062473611SBram Moolenaar endif 19162473611SBram Moolenaar call assert_equal('nan', string(fmod(1.0, 0.0))) 19287200413SBram Moolenaar call assert_fails("call fmod('', 1.22)", 'E808:') 19387200413SBram Moolenaar call assert_fails("call fmod(12.33, '')", 'E808:') 194453b576eSBram Moolenaarendfunc 195453b576eSBram Moolenaar 196453b576eSBram Moolenaarfunc Test_pow() 19762473611SBram Moolenaar call assert_equal('1.0', string(pow(0.0, 0.0))) 19862473611SBram Moolenaar call assert_equal('8.0', string(pow(2.0, 3.0))) 19993cf85f9SBram Moolenaar eval 2.0->pow(3.0)->string()->assert_equal('8.0') 20062473611SBram Moolenaar call assert_equal('nan', string(pow(2.0, 0.0/0.0))) 20162473611SBram Moolenaar call assert_equal('nan', string(pow(0.0/0.0, 3.0))) 20262473611SBram Moolenaar call assert_equal('nan', string(pow(0.0/0.0, 3.0))) 20362473611SBram Moolenaar call assert_equal('inf', string(pow(2.0, 1.0/0.0))) 20462473611SBram Moolenaar call assert_equal('inf', string(pow(1.0/0.0, 3.0))) 20587200413SBram Moolenaar call assert_fails("call pow('', 2.0)", 'E808:') 20687200413SBram Moolenaar call assert_fails("call pow(2.0, '')", 'E808:') 207453b576eSBram Moolenaarendfunc 208453b576eSBram Moolenaar 209453b576eSBram Moolenaarfunc Test_str2float() 21062473611SBram Moolenaar call assert_equal('1.0', string(str2float('1'))) 21108243d26SBram Moolenaar call assert_equal('1.0', string(str2float(' 1 '))) 21208243d26SBram Moolenaar call assert_equal('1.0', string(str2float(' 1.0 '))) 21362473611SBram Moolenaar call assert_equal('1.23', string(str2float('1.23'))) 21462473611SBram Moolenaar call assert_equal('1.23', string(str2float('1.23abc'))) 21593cf85f9SBram Moolenaar eval '1.23abc'->str2float()->string()->assert_equal('1.23') 21662473611SBram Moolenaar call assert_equal('1.0e40', string(str2float('1e40'))) 21787200413SBram Moolenaar call assert_equal('-1.23', string(str2float('-1.23'))) 21887200413SBram Moolenaar call assert_equal('1.23', string(str2float(' + 1.23 '))) 21908243d26SBram Moolenaar 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 call assert_equal('1.0', string(str2float(' + 1 '))) 22408243d26SBram Moolenaar 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 call assert_equal('-1.0', string(str2float(' - 1 '))) 22908243d26SBram Moolenaar 23087200413SBram Moolenaar call assert_equal('0.0', string(str2float('+0.0'))) 23187200413SBram Moolenaar call assert_equal('-0.0', string(str2float('-0.0'))) 23262473611SBram Moolenaar call assert_equal('inf', string(str2float('1e1000'))) 23362473611SBram Moolenaar call assert_equal('inf', string(str2float('inf'))) 23462473611SBram Moolenaar call assert_equal('-inf', string(str2float('-inf'))) 23587200413SBram Moolenaar call assert_equal('inf', string(str2float('+inf'))) 23662473611SBram Moolenaar call assert_equal('inf', string(str2float('Inf'))) 23787200413SBram Moolenaar call assert_equal('inf', string(str2float(' +inf '))) 23862473611SBram Moolenaar call assert_equal('nan', string(str2float('nan'))) 23962473611SBram Moolenaar call assert_equal('nan', string(str2float('NaN'))) 24087200413SBram Moolenaar call assert_equal('nan', string(str2float(' nan '))) 24187200413SBram Moolenaar 2423cfa5b16SBram Moolenaar call assert_equal(1.2, str2float(1.2)) 243*4490ec4eSYegappan Lakshmanan call CheckDefAndScriptFailure2(['str2float(1.2)'], 'E1013: Argument 1: type mismatch, expected string but got float', 'E1174: String required for argument 1') 24487200413SBram Moolenaar call assert_fails("call str2float([])", 'E730:') 24587200413SBram Moolenaar call assert_fails("call str2float({})", 'E731:') 24687200413SBram Moolenaar call assert_fails("call str2float(function('string'))", 'E729:') 247453b576eSBram Moolenaarendfunc 248453b576eSBram Moolenaar 249863e80b4SBram Moolenaarfunc Test_float2nr() 250863e80b4SBram Moolenaar call assert_equal(1, float2nr(1.234)) 251863e80b4SBram Moolenaar call assert_equal(123, float2nr(1.234e2)) 252863e80b4SBram Moolenaar call assert_equal(12, float2nr(123.4e-1)) 25393cf85f9SBram Moolenaar eval 123.4e-1->float2nr()->assert_equal(12) 254863e80b4SBram Moolenaar let max_number = 1/0 255863e80b4SBram Moolenaar let min_number = -max_number 256863e80b4SBram Moolenaar call assert_equal(max_number/2+1, float2nr(pow(2, 62))) 257863e80b4SBram Moolenaar call assert_equal(max_number, float2nr(pow(2, 63))) 258863e80b4SBram Moolenaar call assert_equal(max_number, float2nr(pow(2, 64))) 259863e80b4SBram Moolenaar call assert_equal(min_number/2-1, float2nr(-pow(2, 62))) 260863e80b4SBram Moolenaar call assert_equal(min_number, float2nr(-pow(2, 63))) 261863e80b4SBram Moolenaar call assert_equal(min_number, float2nr(-pow(2, 64))) 262863e80b4SBram Moolenaarendfunc 263863e80b4SBram Moolenaar 264453b576eSBram Moolenaarfunc Test_floor() 26562473611SBram Moolenaar call assert_equal('2.0', string(floor(2.0))) 26662473611SBram Moolenaar call assert_equal('2.0', string(floor(2.11))) 26762473611SBram Moolenaar call assert_equal('2.0', string(floor(2.99))) 26893cf85f9SBram Moolenaar eval 2.99->floor()->string()->assert_equal('2.0') 26962473611SBram Moolenaar call assert_equal('-3.0', string(floor(-2.11))) 27062473611SBram Moolenaar call assert_equal('-3.0', string(floor(-2.99))) 27162473611SBram Moolenaar call assert_equal('nan', string(floor(0.0/0.0))) 27262473611SBram Moolenaar call assert_equal('inf', string(floor(1.0/0.0))) 27362473611SBram Moolenaar call assert_equal('-inf', string(floor(-1.0/0.0))) 27487200413SBram Moolenaar call assert_fails("call floor('')", 'E808:') 275453b576eSBram Moolenaarendfunc 276453b576eSBram Moolenaar 277453b576eSBram Moolenaarfunc Test_ceil() 27862473611SBram Moolenaar call assert_equal('2.0', string(ceil(2.0))) 27962473611SBram Moolenaar call assert_equal('3.0', string(ceil(2.11))) 28062473611SBram Moolenaar call assert_equal('3.0', string(ceil(2.99))) 28162473611SBram Moolenaar call assert_equal('-2.0', string(ceil(-2.11))) 28293cf85f9SBram Moolenaar eval -2.11->ceil()->string()->assert_equal('-2.0') 28362473611SBram Moolenaar call assert_equal('-2.0', string(ceil(-2.99))) 28462473611SBram Moolenaar call assert_equal('nan', string(ceil(0.0/0.0))) 28562473611SBram Moolenaar call assert_equal('inf', string(ceil(1.0/0.0))) 28662473611SBram Moolenaar call assert_equal('-inf', string(ceil(-1.0/0.0))) 28787200413SBram Moolenaar call assert_fails("call ceil('')", 'E808:') 288453b576eSBram Moolenaarendfunc 289453b576eSBram Moolenaar 290453b576eSBram Moolenaarfunc Test_round() 29162473611SBram Moolenaar call assert_equal('2.0', string(round(2.1))) 29262473611SBram Moolenaar call assert_equal('3.0', string(round(2.5))) 29362473611SBram Moolenaar call assert_equal('3.0', string(round(2.9))) 29493cf85f9SBram Moolenaar eval 2.9->round()->string()->assert_equal('3.0') 29562473611SBram Moolenaar call assert_equal('-2.0', string(round(-2.1))) 29662473611SBram Moolenaar call assert_equal('-3.0', string(round(-2.5))) 29762473611SBram Moolenaar call assert_equal('-3.0', string(round(-2.9))) 29862473611SBram Moolenaar call assert_equal('nan', string(round(0.0/0.0))) 29962473611SBram Moolenaar call assert_equal('inf', string(round(1.0/0.0))) 30062473611SBram Moolenaar call assert_equal('-inf', string(round(-1.0/0.0))) 30187200413SBram Moolenaar call assert_fails("call round('')", 'E808:') 302453b576eSBram Moolenaarendfunc 303453b576eSBram Moolenaar 304453b576eSBram Moolenaarfunc Test_trunc() 30562473611SBram Moolenaar call assert_equal('2.0', string(trunc(2.1))) 30662473611SBram Moolenaar call assert_equal('2.0', string(trunc(2.5))) 30762473611SBram Moolenaar call assert_equal('2.0', string(trunc(2.9))) 30893cf85f9SBram Moolenaar eval 2.9->trunc()->string()->assert_equal('2.0') 30962473611SBram Moolenaar call assert_equal('-2.0', string(trunc(-2.1))) 31062473611SBram Moolenaar call assert_equal('-2.0', string(trunc(-2.5))) 31162473611SBram Moolenaar call assert_equal('-2.0', string(trunc(-2.9))) 31262473611SBram Moolenaar call assert_equal('nan', string(trunc(0.0/0.0))) 31362473611SBram Moolenaar call assert_equal('inf', string(trunc(1.0/0.0))) 31462473611SBram Moolenaar call assert_equal('-inf', string(trunc(-1.0/0.0))) 31587200413SBram Moolenaar call assert_fails("call trunc('')", 'E808:') 316453b576eSBram Moolenaarendfunc 317453b576eSBram Moolenaar 318fda1bff3SBram Moolenaarfunc Test_isinf() 319fda1bff3SBram Moolenaar call assert_equal(1, isinf(1.0/0.0)) 320fda1bff3SBram Moolenaar call assert_equal(-1, isinf(-1.0/0.0)) 32193cf85f9SBram Moolenaar eval (-1.0/0.0)->isinf()->assert_equal(-1) 322fda1bff3SBram Moolenaar call assert_false(isinf(1.0)) 323fda1bff3SBram Moolenaar call assert_false(isinf(0.0/0.0)) 324fda1bff3SBram Moolenaar call assert_false(isinf('a')) 325fda1bff3SBram Moolenaar call assert_false(isinf([])) 326fda1bff3SBram Moolenaar call assert_false(isinf({})) 327fda1bff3SBram Moolenaarendfunc 328fda1bff3SBram Moolenaar 329453b576eSBram Moolenaarfunc Test_isnan() 330fda1bff3SBram Moolenaar call assert_true(isnan(0.0/0.0)) 331fda1bff3SBram Moolenaar call assert_false(isnan(1.0)) 332fda1bff3SBram Moolenaar call assert_false(isnan(1.0/0.0)) 33393cf85f9SBram Moolenaar eval (1.0/0.0)->isnan()->assert_false() 334fda1bff3SBram Moolenaar call assert_false(isnan(-1.0/0.0)) 335fda1bff3SBram Moolenaar call assert_false(isnan('a')) 336fda1bff3SBram Moolenaar call assert_false(isnan([])) 337fda1bff3SBram Moolenaar call assert_false(isnan({})) 338453b576eSBram Moolenaarendfunc 339863e80b4SBram Moolenaar 340863e80b4SBram Moolenaar" This was converted from test65 341863e80b4SBram Moolenaarfunc Test_float_misc() 342863e80b4SBram Moolenaar call assert_equal('123.456000', printf('%f', 123.456)) 343863e80b4SBram Moolenaar call assert_equal('1.234560e+02', printf('%e', 123.456)) 344863e80b4SBram Moolenaar call assert_equal('123.456', printf('%g', 123.456)) 345863e80b4SBram Moolenaar " += 346863e80b4SBram Moolenaar let v = 1.234 347863e80b4SBram Moolenaar let v += 6.543 348863e80b4SBram Moolenaar call assert_equal('7.777', printf('%g', v)) 349863e80b4SBram Moolenaar let v = 1.234 350863e80b4SBram Moolenaar let v += 5 351863e80b4SBram Moolenaar call assert_equal('6.234', printf('%g', v)) 352863e80b4SBram Moolenaar let v = 5 353863e80b4SBram Moolenaar let v += 3.333 354863e80b4SBram Moolenaar call assert_equal('8.333', string(v)) 355863e80b4SBram Moolenaar " == 356863e80b4SBram Moolenaar let v = 1.234 357863e80b4SBram Moolenaar call assert_true(v == 1.234) 358863e80b4SBram Moolenaar call assert_false(v == 1.2341) 359863e80b4SBram Moolenaar " add-subtract 360863e80b4SBram Moolenaar call assert_equal('5.234', printf('%g', 4 + 1.234)) 361863e80b4SBram Moolenaar call assert_equal('-6.766', printf('%g', 1.234 - 8)) 362863e80b4SBram Moolenaar " mult-div 363863e80b4SBram Moolenaar call assert_equal('4.936', printf('%g', 4 * 1.234)) 364863e80b4SBram Moolenaar call assert_equal('0.003241', printf('%g', 4.0 / 1234)) 365863e80b4SBram Moolenaar " dict 366863e80b4SBram Moolenaar call assert_equal("{'x': 1.234, 'y': -2.0e20}", string({'x': 1.234, 'y': -2.0e20})) 367863e80b4SBram Moolenaar " list 368863e80b4SBram Moolenaar call assert_equal('[-123.4, 2.0e-20]', string([-123.4, 2.0e-20])) 369863e80b4SBram Moolenaarendfunc 370863e80b4SBram Moolenaar 371863e80b4SBram Moolenaar" vim: shiftwidth=2 sts=2 expandtab 372