2014-04-28 21:21:12 +03:00
|
|
|
# ast classes
|
|
|
|
module Parser
|
2014-04-24 17:38:06 +03:00
|
|
|
class Expression
|
|
|
|
def eval
|
|
|
|
raise "abstract"
|
|
|
|
end
|
2014-04-28 16:07:34 +03:00
|
|
|
def compare other , attributes
|
|
|
|
attributes.each do |a|
|
|
|
|
left = send(a)
|
|
|
|
right = other.send( a)
|
|
|
|
return false unless left.class == right.class
|
|
|
|
return false unless left == right
|
|
|
|
end
|
|
|
|
return true
|
|
|
|
end
|
2014-04-24 17:38:06 +03:00
|
|
|
end
|
|
|
|
|
2014-04-27 18:13:34 +03:00
|
|
|
class IntegerExpression < Expression
|
2014-04-24 17:38:06 +03:00
|
|
|
attr_reader :value
|
|
|
|
def initialize val
|
|
|
|
@value = val
|
|
|
|
end
|
2014-04-28 16:07:34 +03:00
|
|
|
def == other
|
|
|
|
compare other , [:value]
|
|
|
|
end
|
2014-04-24 15:43:20 +03:00
|
|
|
end
|
|
|
|
|
2014-04-24 17:38:06 +03:00
|
|
|
class NameExpression < Expression
|
|
|
|
attr_reader :name
|
|
|
|
def initialize name
|
|
|
|
@name = name
|
|
|
|
end
|
2014-04-28 16:07:34 +03:00
|
|
|
def == other
|
|
|
|
compare other , [:name]
|
|
|
|
end
|
2014-04-24 15:43:20 +03:00
|
|
|
end
|
|
|
|
|
2014-04-24 17:38:06 +03:00
|
|
|
class FuncallExpression < Expression
|
|
|
|
attr_reader :name, :args
|
|
|
|
def initialize name, args
|
|
|
|
@name , @args = name , args
|
|
|
|
end
|
2014-04-28 16:07:34 +03:00
|
|
|
def == other
|
|
|
|
compare other , [:name , :args]
|
|
|
|
end
|
2014-04-24 15:43:20 +03:00
|
|
|
end
|
|
|
|
|
2014-04-24 17:38:06 +03:00
|
|
|
class ConditionalExpression < Expression
|
|
|
|
attr_reader :cond, :if_true, :if_false
|
|
|
|
def initialize cond, if_true, if_false
|
|
|
|
@cond, @if_true, @if_false = cond, if_true, if_false
|
|
|
|
end
|
2014-04-28 16:07:34 +03:00
|
|
|
def == other
|
|
|
|
compare other , [:cond, :if_true, :if_false]
|
|
|
|
end
|
2014-04-28 21:21:12 +03:00
|
|
|
end
|
2014-04-24 15:43:20 +03:00
|
|
|
|
2014-04-28 21:21:12 +03:00
|
|
|
class AssignmentExpression < Expression
|
|
|
|
attr_reader :assignee, :assigned
|
|
|
|
def initialize assignee, assigned
|
|
|
|
@assignee, @assigned = assignee, assigned
|
|
|
|
end
|
|
|
|
def == other
|
|
|
|
compare other , [:assignee, :assigned]
|
2014-04-24 15:43:20 +03:00
|
|
|
end
|
|
|
|
end
|
2014-04-24 17:38:06 +03:00
|
|
|
class FunctionExpression < Expression
|
2014-04-27 21:12:42 +03:00
|
|
|
attr_reader :name, :params, :block
|
|
|
|
def initialize name, params, block
|
|
|
|
@name, @params, @block = name, params, block
|
2014-04-24 17:38:06 +03:00
|
|
|
end
|
2014-04-28 16:07:34 +03:00
|
|
|
def == other
|
|
|
|
compare other , [:name, :params, :block]
|
|
|
|
end
|
2014-04-24 15:43:20 +03:00
|
|
|
end
|
|
|
|
end
|