Module: RplLang::Words::Store

Includes:
Types
Included in:
Rpl
Defined in:
lib/rpl/words/store.rb

Instance Method Summary collapse

Methods included from Types

new_object

Instance Method Details

#populate_dictionaryObject



8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
# File 'lib/rpl/words/store.rb', line 8

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