90 lines
3.8 KiB
Ruby
90 lines
3.8 KiB
Ruby
# frozen_string_literal: true
|
||
|
||
module RplLang
|
||
module Words
|
||
module Store
|
||
include Types
|
||
|
||
def populate_dictionary
|
||
super
|
||
|
||
category = 'Store'
|
||
|
||
@dictionary.add_word!( ['▶', 'sto'],
|
||
category,
|
||
'( content name -- ) store to variable',
|
||
proc do
|
||
args = stack_extract( [[RplName], :any] )
|
||
|
||
@dictionary.add_var!( args[0].value,
|
||
args[1] )
|
||
end )
|
||
|
||
@dictionary.add_word!( ['rcl'],
|
||
category,
|
||
'( name -- … ) push content of variable name onto stack',
|
||
proc do
|
||
args = stack_extract( [[RplName]] )
|
||
|
||
content = @dictionary.lookup( args[0].value )
|
||
|
||
@stack << content unless content.nil?
|
||
end )
|
||
|
||
@dictionary.add_word!( ['purge'],
|
||
category,
|
||
'( name -- ) delete variable',
|
||
proc do
|
||
args = stack_extract( [[RplName]] )
|
||
|
||
@dictionary.remove_var!( args[0].value )
|
||
end )
|
||
|
||
@dictionary.add_word!( ['vars'],
|
||
category,
|
||
'( -- […] ) list variables',
|
||
proc do
|
||
@stack << Types.new_object( RplList, (@dictionary.vars.keys + @dictionary.local_vars_layers.reduce([]) { |memo, layer| memo + layer.keys })
|
||
.map { |name| Types.new_object( RplName, name ) } )
|
||
end )
|
||
|
||
@dictionary.add_word!( ['clusr'],
|
||
category,
|
||
'( -- ) delete all variables',
|
||
proc do
|
||
@dictionary.remove_all_vars!
|
||
end )
|
||
|
||
@dictionary.add_word!( ['sto+'],
|
||
category,
|
||
'( a n -- ) add content to variable\'s value',
|
||
Types.new_object( RplProgram, '« swap over rcl + swap sto »' ) )
|
||
|
||
@dictionary.add_word!( ['sto-'],
|
||
category,
|
||
'( a n -- ) subtract content to variable\'s value',
|
||
Types.new_object( RplProgram, '« swap over rcl swap - swap sto »' ) )
|
||
|
||
@dictionary.add_word!( ['sto×', 'sto*'],
|
||
category,
|
||
'( a n -- ) multiply content of variable\'s value',
|
||
Types.new_object( RplProgram, '« swap over rcl * swap sto »' ) )
|
||
|
||
@dictionary.add_word!( ['sto÷', 'sto/'],
|
||
category,
|
||
'( a n -- ) divide content of variable\'s value',
|
||
Types.new_object( RplProgram, '« swap over rcl swap / swap sto »' ) )
|
||
|
||
@dictionary.add_word!( ['sneg'],
|
||
category,
|
||
'( a n -- ) negate content of variable\'s value',
|
||
Types.new_object( RplProgram, '« dup rcl chs swap sto »' ) )
|
||
|
||
@dictionary.add_word!( ['sinv'],
|
||
category,
|
||
'( a n -- ) invert content of variable\'s value',
|
||
Types.new_object( RplProgram, '« dup rcl inv swap sto »' ) )
|
||
end
|
||
end
|
||
end
|
||
end
|