AmberVM 0.0.19
Sign up to get free protection for your applications and to get access to all the features.
- data/README +38 -0
- data/bin/ambervm +278 -0
- data/lib/amber/acts_as_rvm_type.rb +157 -0
- data/lib/amber/classes/association.rb +36 -0
- data/lib/amber/classes/block.rb +52 -0
- data/lib/amber/classes/boolean.rb +40 -0
- data/lib/amber/classes/class.rb +50 -0
- data/lib/amber/classes/error.rb +22 -0
- data/lib/amber/classes/list.rb +96 -0
- data/lib/amber/classes/null.rb +35 -0
- data/lib/amber/classes/number.rb +95 -0
- data/lib/amber/classes/object.rb +56 -0
- data/lib/amber/classes/string.rb +79 -0
- data/lib/amber/classes.rb +113 -0
- data/lib/amber/environment.rb +251 -0
- data/lib/amber/fukubukuro/ecma_core.rb +409 -0
- data/lib/amber/fukubukuro.rb +866 -0
- data/lib/amber/functions/all.rb +3 -0
- data/lib/amber/functions/array/append.rb +50 -0
- data/lib/amber/functions/array/at.rb +50 -0
- data/lib/amber/functions/array/set_at.rb +50 -0
- data/lib/amber/functions/array.rb +30 -0
- data/lib/amber/functions/association/assoc_get.rb +55 -0
- data/lib/amber/functions/association/assoc_set.rb +56 -0
- data/lib/amber/functions/bitwise/bitwise_and.rb +41 -0
- data/lib/amber/functions/bitwise/bitwise_not.rb +41 -0
- data/lib/amber/functions/bitwise/bitwise_or.rb +41 -0
- data/lib/amber/functions/bitwise/bitwise_xor.rb +41 -0
- data/lib/amber/functions/bitwise.rb +3 -0
- data/lib/amber/functions/collection/get.rb +66 -0
- data/lib/amber/functions/collection/set.rb +67 -0
- data/lib/amber/functions/collection/size.rb +54 -0
- data/lib/amber/functions/general/cmp.rb +43 -0
- data/lib/amber/functions/general/eq.rb +45 -0
- data/lib/amber/functions/general/gt.rb +45 -0
- data/lib/amber/functions/general/gte.rb +45 -0
- data/lib/amber/functions/general/lt.rb +45 -0
- data/lib/amber/functions/general/lte.rb +45 -0
- data/lib/amber/functions/general/neq.rb +45 -0
- data/lib/amber/functions/general/type.rb +43 -0
- data/lib/amber/functions/general.rb +3 -0
- data/lib/amber/functions/io/print.rb +45 -0
- data/lib/amber/functions/io.rb +3 -0
- data/lib/amber/functions/list/align.rb +73 -0
- data/lib/amber/functions/list/join.rb +45 -0
- data/lib/amber/functions/list/map.rb +58 -0
- data/lib/amber/functions/list/split.rb +55 -0
- data/lib/amber/functions/list.rb +3 -0
- data/lib/amber/functions/logic/and.rb +55 -0
- data/lib/amber/functions/logic/not.rb +40 -0
- data/lib/amber/functions/logic/or.rb +50 -0
- data/lib/amber/functions/logic.rb +3 -0
- data/lib/amber/functions/math/abs.rb +39 -0
- data/lib/amber/functions/math/acos.rb +39 -0
- data/lib/amber/functions/math/add.rb +40 -0
- data/lib/amber/functions/math/asin.rb +39 -0
- data/lib/amber/functions/math/atan.rb +39 -0
- data/lib/amber/functions/math/ceil.rb +39 -0
- data/lib/amber/functions/math/cos.rb +39 -0
- data/lib/amber/functions/math/dec.rb +39 -0
- data/lib/amber/functions/math/div.rb +44 -0
- data/lib/amber/functions/math/exp.rb +39 -0
- data/lib/amber/functions/math/floor.rb +39 -0
- data/lib/amber/functions/math/inc.rb +39 -0
- data/lib/amber/functions/math/log.rb +39 -0
- data/lib/amber/functions/math/mod.rb +41 -0
- data/lib/amber/functions/math/mul.rb +43 -0
- data/lib/amber/functions/math/neg.rb +43 -0
- data/lib/amber/functions/math/power.rb +43 -0
- data/lib/amber/functions/math/rand.rb +36 -0
- data/lib/amber/functions/math/round.rb +39 -0
- data/lib/amber/functions/math/shl.rb +41 -0
- data/lib/amber/functions/math/shr.rb +41 -0
- data/lib/amber/functions/math/sin.rb +39 -0
- data/lib/amber/functions/math/sub.rb +43 -0
- data/lib/amber/functions/math/tan.rb +39 -0
- data/lib/amber/functions/math.rb +3 -0
- data/lib/amber/functions/objects/send.rb +22 -0
- data/lib/amber/functions/rails/print.rb +44 -0
- data/lib/amber/functions/rails.rb +3 -0
- data/lib/amber/functions/string/ansi.rb +24 -0
- data/lib/amber/functions/string/capstr.rb +23 -0
- data/lib/amber/functions/string/center.rb +25 -0
- data/lib/amber/functions/string/chr.rb +16 -0
- data/lib/amber/functions/string/ljust.rb +26 -0
- data/lib/amber/functions/string/regmatch.rb +34 -0
- data/lib/amber/functions/string/rjust.rb +26 -0
- data/lib/amber/functions/string.rb +3 -0
- data/lib/amber/functions.rb +103 -0
- data/lib/amber/interpreter.rb +1380 -0
- data/lib/amber/languages/brainfuck.rb +153 -0
- data/lib/amber/languages/ecma/compiler.rb +1661 -0
- data/lib/amber/languages/ecma/core-math.js +67 -0
- data/lib/amber/languages/ecma/core-objects.js +57 -0
- data/lib/amber/languages/ecma.rb +9 -0
- data/lib/amber/languages/ecma_fuku/compiler.rb +1622 -0
- data/lib/amber/languages/ecma_fuku/core-math.js +67 -0
- data/lib/amber/languages/ecma_fuku/core-objects.js +56 -0
- data/lib/amber/languages/ecma_fuku.rb +13 -0
- data/lib/amber/languages/math/compiler.rb +70 -0
- data/lib/amber/languages/math/tokenizer.rb +69 -0
- data/lib/amber/languages/math/tree.rb +110 -0
- data/lib/amber/languages/math.rb +26 -0
- data/lib/amber/languages.rb +99 -0
- data/lib/amber/library.rb +79 -0
- data/lib/amber/optimisation.rb +299 -0
- data/lib/amber/plugin.rb +337 -0
- data/lib/amber/rails.rb +90 -0
- data/lib/amber.rb +106 -0
- data/spec/amber/class_spec.rb +27 -0
- data/spec/amber/enviroment_spec.rb +61 -0
- data/spec/amber/function_spec.rb +25 -0
- data/spec/amber/functions/association/assoc_get_spec.rb +41 -0
- data/spec/amber/functions/association/assoc_set_spec.rb +43 -0
- data/spec/amber/functions/collection/get_spec.rb +12 -0
- data/spec/amber/functions/collection/set_spec.rb +10 -0
- data/spec/amber/functions/collection/size_spec.rb +10 -0
- data/spec/amber/functions/list/split_spec.rb +47 -0
- data/spec/amber/functions/string/ansi_spec.rb +44 -0
- data/spec/amber/functions/string/capstr_spec.rb +42 -0
- data/spec/amber/functions/string/center_spec.rb +49 -0
- data/spec/amber/functions/string/ljust_spec.rb +49 -0
- data/spec/amber/functions/string/regmatch_spec.rb +52 -0
- data/spec/amber/functions/string/rjust_spec.rb +49 -0
- data/spec/amber/interpreter/assignment_spec.rb +22 -0
- data/spec/amber/interpreter/condition_spec.rb +103 -0
- data/spec/amber/interpreter/constant_spec.rb +31 -0
- data/spec/amber/interpreter/core_call_spec.rb +72 -0
- data/spec/amber/interpreter/interpreter_spec.rb +11 -0
- data/spec/amber/interpreter/parameter_spec.rb +24 -0
- data/spec/amber/interpreter/sequence_spec.rb +47 -0
- data/spec/amber/interpreter/variable_spec.rb +24 -0
- data/spec/amber/plugin_spec.rb +10 -0
- data/spec/classes/atom/association_spec.rb +39 -0
- data/spec/classes/atom/block_spec.rb +25 -0
- data/spec/classes/atom/boolean_spec.rb +67 -0
- data/spec/classes/atom/error_spec.rb +43 -0
- data/spec/classes/atom/list_spec.rb +68 -0
- data/spec/classes/atom/number_spec.rb +132 -0
- data/spec/classes/atom/string_spec.rb +175 -0
- data/spec/languages/ecma/ecma_array_spec.rb +79 -0
- data/spec/languages/ecma/ecma_closure_spec.rb +38 -0
- data/spec/languages/ecma/ecma_literals_spec.rb +71 -0
- data/spec/languages/ecma/ecma_objects_spec.rb +165 -0
- data/spec/languages/ecma/ecma_old_spec.rb +540 -0
- data/spec/languages/ecma/ecma_spec.rb +64 -0
- data/spec/languages/ecma_fuku/ecma_array_spec.rb +61 -0
- data/spec/languages/ecma_fuku/ecma_closure_spec.rb +33 -0
- data/spec/languages/ecma_fuku/ecma_function_spec.rb +84 -0
- data/spec/languages/ecma_fuku/ecma_literals_spec.rb +55 -0
- data/spec/languages/ecma_fuku/ecma_objects_spec.rb +133 -0
- data/spec/languages/ecma_fuku/ecma_old_spec.rb +415 -0
- data/spec/languages/ecma_fuku/ecma_operator_spec.rb +33 -0
- data/spec/languages/ecma_fuku/ecma_spec.rb +52 -0
- data/spec/languages/math/compiler_spec.rb +49 -0
- data/spec/languages/math/tokenizer_spec.rb +73 -0
- data/spec/languages/math/tree_spec.rb +153 -0
- metadata +225 -0
@@ -0,0 +1,153 @@
|
|
1
|
+
require 'strscan'
|
2
|
+
require 'amber/functions/math/add'
|
3
|
+
require 'amber/functions/math/sub'
|
4
|
+
require 'amber/functions/io/print'
|
5
|
+
|
6
|
+
module AmberVM
|
7
|
+
module Languages
|
8
|
+
# This is a brainfuck compiler for the VM.
|
9
|
+
# It covers the compleat BF syntax and allows you to write files that are executed.
|
10
|
+
#
|
11
|
+
# Mostly a gimick I admit but it's a nice demonstration of how rVM works.
|
12
|
+
class Brainfuck < AmberVM::Languages::Language
|
13
|
+
|
14
|
+
def Brainfuck.bfpp str
|
15
|
+
str.gsub!(/\/\/.*?\n/,'')
|
16
|
+
str.gsub!(/[^<>+\[\].,\dv-]/,'')
|
17
|
+
str.gsub!('v','[-]')
|
18
|
+
str.gsub!(/(.)(\d+)/) do |s|
|
19
|
+
s[0].chr * s.gsub(/^./,'').to_i
|
20
|
+
end
|
21
|
+
str
|
22
|
+
end
|
23
|
+
|
24
|
+
# This function compiles a string of BF code and returns the equivalent for the
|
25
|
+
# rVM.
|
26
|
+
def compile code
|
27
|
+
make_vmcode(make_tree(code))
|
28
|
+
end
|
29
|
+
|
30
|
+
private
|
31
|
+
def make_tree str
|
32
|
+
str.gsub!(/\/\/.*?\n/,'') #delete comments
|
33
|
+
str.gsub!(/[^<>+\[\].,\d-]/,'')
|
34
|
+
s = StringScanner.new(str)
|
35
|
+
tree = []
|
36
|
+
cur = tree
|
37
|
+
stack = []
|
38
|
+
while (!s.eos?)
|
39
|
+
c = s.scan(/./)
|
40
|
+
case (c)
|
41
|
+
when '+'
|
42
|
+
if cur.last and cur.last[0] == :inc
|
43
|
+
cur.last[1] += 1
|
44
|
+
else
|
45
|
+
cur << [:inc, 1]
|
46
|
+
end
|
47
|
+
when '-'
|
48
|
+
if cur.last and cur.last[0] == :dec
|
49
|
+
cur.last[1] += 1
|
50
|
+
else
|
51
|
+
cur << [:dec, 1]
|
52
|
+
end
|
53
|
+
when '<'
|
54
|
+
if cur.last and cur.last[0] == :left
|
55
|
+
cur.last[1] += 1
|
56
|
+
else
|
57
|
+
cur << [:left, 1]
|
58
|
+
end
|
59
|
+
when '>'
|
60
|
+
if cur.last and cur.last[0] == :right
|
61
|
+
cur.last[1] += 1
|
62
|
+
else
|
63
|
+
cur << [:right, 1]
|
64
|
+
end
|
65
|
+
when '['
|
66
|
+
tmp = []
|
67
|
+
cur << [:loop, tmp]
|
68
|
+
stack << cur
|
69
|
+
cur = tmp
|
70
|
+
when '.'
|
71
|
+
cur << [:print]
|
72
|
+
when ','
|
73
|
+
cur << [:read]
|
74
|
+
when ']'
|
75
|
+
cur = stack.pop
|
76
|
+
end
|
77
|
+
end
|
78
|
+
tree
|
79
|
+
end
|
80
|
+
|
81
|
+
def make_vmcode tree
|
82
|
+
root = AmberVM::Interpreter::Sequence.new();
|
83
|
+
ptr = Interpreter::Variable.new(Interpreter.const(:string,'ptr'))
|
84
|
+
val = Interpreter::Variable.new(ptr)
|
85
|
+
tree.each do |item|
|
86
|
+
case item[0]
|
87
|
+
when :inc
|
88
|
+
root << Interpreter::Assignment.new(
|
89
|
+
ptr,
|
90
|
+
Interpreter::CoreCall.new(
|
91
|
+
:add,
|
92
|
+
[
|
93
|
+
Interpreter::Condition.new(
|
94
|
+
val,
|
95
|
+
val,
|
96
|
+
Interpreter.const(:number,0)
|
97
|
+
),
|
98
|
+
Interpreter.const(:number,item[1])
|
99
|
+
]
|
100
|
+
)
|
101
|
+
)
|
102
|
+
when :dec
|
103
|
+
root << Interpreter::Assignment.new(
|
104
|
+
ptr,
|
105
|
+
Interpreter::CoreCall.new(
|
106
|
+
:sub,
|
107
|
+
[
|
108
|
+
Interpreter::Condition.new(
|
109
|
+
val,
|
110
|
+
val,
|
111
|
+
Interpreter.const(:number,0)
|
112
|
+
),
|
113
|
+
Interpreter.const(:number,item[1])
|
114
|
+
]
|
115
|
+
)
|
116
|
+
)
|
117
|
+
when :left
|
118
|
+
root << Interpreter::Assignment.new(
|
119
|
+
Interpreter.const(:string,'ptr'),
|
120
|
+
Interpreter::CoreCall.new(
|
121
|
+
:sub,
|
122
|
+
[
|
123
|
+
ptr,
|
124
|
+
Interpreter.const(:number,item[1])
|
125
|
+
]
|
126
|
+
)
|
127
|
+
)
|
128
|
+
when :right
|
129
|
+
root << Interpreter::Assignment.new(
|
130
|
+
Interpreter.const(:string,'ptr'),
|
131
|
+
Interpreter::CoreCall.new(
|
132
|
+
:add,
|
133
|
+
[
|
134
|
+
ptr,
|
135
|
+
Interpreter.const(:number,item[1])
|
136
|
+
]
|
137
|
+
)
|
138
|
+
)
|
139
|
+
when :print
|
140
|
+
root << Interpreter::CoreCall.new(:print, [Interpreter::CoreCall.new(:chr,[val])])
|
141
|
+
when :read
|
142
|
+
when :loop
|
143
|
+
body = make_vmcode(item[1])
|
144
|
+
root << Interpreter::Loop.new(val, body)
|
145
|
+
end
|
146
|
+
end
|
147
|
+
root
|
148
|
+
end
|
149
|
+
|
150
|
+
register_for :brainfuck
|
151
|
+
end
|
152
|
+
end
|
153
|
+
end
|