2018-07-19 14:46:51 +03:00
|
|
|
module Ruby
|
|
|
|
|
|
|
|
# Base class for all statements in the tree. Derived classes correspond to known language
|
|
|
|
# constructs
|
|
|
|
#
|
|
|
|
# Compilers or compiler passes are written by implementing methods.
|
|
|
|
#
|
|
|
|
class Statement
|
|
|
|
|
2019-10-04 00:36:49 +03:00
|
|
|
# Many statements exist in the sol layer in quite a similar arrangement
|
2018-09-01 15:54:25 +03:00
|
|
|
# Especially for different types of assignment we can abstract the creation
|
2019-10-04 00:36:49 +03:00
|
|
|
# of the sol, by using the right class to instantiate, the "sol_brother"
|
|
|
|
# Ie same class_name, but in the Sol module
|
|
|
|
def sol_brother
|
|
|
|
eval "Sol::#{class_name}"
|
2018-07-19 20:59:15 +03:00
|
|
|
end
|
2018-09-01 15:54:25 +03:00
|
|
|
|
|
|
|
# return the class name without the module
|
2019-10-04 00:36:49 +03:00
|
|
|
# used to evaluate the sol_brother
|
2018-07-19 20:59:15 +03:00
|
|
|
def class_name
|
|
|
|
self.class.name.split("::").last
|
|
|
|
end
|
2018-07-19 14:46:51 +03:00
|
|
|
|
2018-09-01 15:54:25 +03:00
|
|
|
# helper method for formatting source code
|
|
|
|
# depth is the depth in the tree (os the ast)
|
|
|
|
# and the string are the ones to be indented (2 spaces)
|
2019-09-19 20:48:21 +03:00
|
|
|
def at_depth(depth , lines)
|
2018-09-01 15:54:25 +03:00
|
|
|
prefix = " " * 2 * depth
|
2019-09-19 20:48:21 +03:00
|
|
|
strings = lines.split("\n")
|
2018-09-01 15:54:25 +03:00
|
|
|
strings.collect{|str| prefix + str}.join("\n")
|
|
|
|
end
|
|
|
|
end
|
2018-07-19 14:46:51 +03:00
|
|
|
end
|