# frozen_string_literal: true require 'minitest/autorun' require 'rpl' class TestLanguageStore < MiniTest::Test include Types def test_sto interpreter = Rpl.new interpreter.run '« 2 dup * » \'quatre\' sto' assert_empty interpreter.stack interpreter.run 'quatre' assert_equal [Types.new_object( RplNumeric, 4 )], interpreter.stack end def test_lsto interpreter = Rpl.new interpreter.run "« 2 'deux' lsto deux dup * » eval 'deux' rcl" assert_empty interpreter.dictionary.local_vars_layers assert_equal [Types.new_object( RplNumeric, 4 )], interpreter.stack interpreter = Rpl.new interpreter.run "« 2 'deux' lsto « 3 'trois' lsto trois drop » eval deux dup * » eval 'deux' rcl 'trois' rcl" assert_empty interpreter.dictionary.local_vars_layers assert_equal [Types.new_object( RplNumeric, 4 )], interpreter.stack end def test_rcl interpreter = Rpl.new interpreter.run '« 2 dup * » \'quatre\' sto \'quatre\' rcl' assert_equal [Types.new_object( RplProgram, '« 2 dup * »' )], interpreter.stack end def test_purge interpreter = Rpl.new interpreter.run '« 2 dup * » \'quatre\' sto \'quatre\' purge' assert_nil interpreter.dictionary.lookup( 'quatre' ) end def test_vars interpreter = Rpl.new interpreter.run '« 2 dup * » \'quatre\' sto 1 \'un\' sto vars' assert_equal [Types.new_object( RplList, [Types.new_object( RplName, 'quatre' ), Types.new_object( RplName, 'un' )] )], interpreter.stack end def test_clusr interpreter = Rpl.new interpreter.run '« 2 dup * » \'quatre\' sto 1 \'un\' sto clusr' assert_empty interpreter.dictionary.vars end def test_sto_add interpreter = Rpl.new interpreter.run '1 \'test\' sto 3 \'test\' sto+ \'test\' rcl' assert_equal [Types.new_object( RplNumeric, 4 )], interpreter.stack end def test_sto_subtract interpreter = Rpl.new interpreter.run '1 \'test\' sto 3 \'test\' sto- \'test\' rcl' assert_equal [Types.new_object( RplNumeric, -2 )], interpreter.stack end def test_sto_multiply interpreter = Rpl.new interpreter.run '2 \'test\' sto 3 \'test\' sto* \'test\' rcl' assert_equal [Types.new_object( RplNumeric, 6 )], interpreter.stack end def test_sto_divide interpreter = Rpl.new interpreter.run '3 \'test\' sto 2.0 \'test\' sto÷ \'test\' rcl' assert_equal [Types.new_object( RplNumeric, 1.5 )], interpreter.stack end def test_sto_negate interpreter = Rpl.new interpreter.run '3 \'test\' sto \'test\' sneg \'test\' rcl' assert_equal [Types.new_object( RplNumeric, -3 )], interpreter.stack end def test_sto_inverse interpreter = Rpl.new interpreter.run '2 \'test\' sto \'test\' sinv \'test\' rcl' assert_equal [Types.new_object( RplNumeric, 0.5 )], interpreter.stack end end