symbolic pointer dereference API similar to Expression
length in bytes of data referenced
address of the instruction who generated the indirection
Expression (the pointer)
Expression (the pointer)
Expression (the pointer)
# File metasm/decode.rb, line 54 def self.[](t, l, o=nil) new(Expression[*t], l, o) end
# File metasm/decode.rb, line 24 def initialize(target, len, origin) @target, @len, @origin = target, len, origin end
# File metasm/decode.rb, line 33 def bind(h) h[self] || Indirection.new(@target.bind(h), @len, @origin) end
returns the complexity of the expression (number of externals +1 per indirection)
# File metasm/decode.rb, line 50 def complexity 1+@target.complexity end
# File metasm/decode.rb, line 38 def eql?(o) o.class == self.class and [o.target, o.len] == [@target, @len] end
# File metasm/decode.rb, line 62 def externals @target.externals end
# File metasm/decode.rb, line 37 def hash ; @target.hash^@len.to_i end
# File metasm/decode.rb, line 58 def inspect "Indirection[#{@target.inspect.sub(/^Expression/, '')}, #{@len.inspect}#{', '+@origin.inspect if @origin}]" end
# File metasm/decode.rb, line 66 def match_rec(pattern, vars) return false if not pattern.kind_of? Indirection pt = pattern.target if vars[pt] return false if @target != vars[pt] elsif vars.has_key? pt vars[pt] = @target elsif pt.kind_of? ExpressionType return false if not @target.match_rec(pt, vars) else return false if pt != @target end pl = pattern.len if vars[pl] return false if @len != vars[pl] elsif vars.has_key? pl vars[pl] = @len else return false if pl != @len end vars end
# File metasm/decode.rb, line 28 def reduce_rec ptr = Expression[@target.reduce] (ptr == Expression::Unknown) ? ptr : Indirection.new(ptr, @len, @origin) end
# File metasm/decode.rb, line 42 def render ret = [] qual = {1 => 'byte', 2 => 'word', 4 => 'dword', 8 => 'qword'}[len] || "_#{len*8}bits" if len ret << "#{qual} ptr " if qual ret << '[' << @target << ']' end