Class: HDLRuby::High::Binary
- Inherits:
-
Low::Binary
- Object
- Base::Expression
- Low::Expression
- Low::Operation
- Low::Binary
- HDLRuby::High::Binary
- Includes:
- HExpression
- Defined in:
- lib/HDLRuby/hruby_high.rb
Overview
Describes a high-level binary expression
Constant Summary
Constants included from Low::Low2Symbol
Low::Low2Symbol::Low2SymbolPrefix, Low::Low2Symbol::Low2SymbolTable, Low::Low2Symbol::Symbol2LowTable
Instance Attribute Summary
Attributes included from HExpression
Attributes inherited from Low::Binary
Attributes inherited from Low::Operation
Attributes inherited from Low::Expression
Attributes included from Low::Hparent
Instance Method Summary collapse
-
#to_expr ⇒ Object
Converts to a new expression.
-
#to_low ⇒ Object
Converts the binary expression to HDLRuby::Low.
Methods included from HExpression
#[], #as, #coerce, #constant?, #inout, #input, #ljust, #lr, #ls, #match_type, #mux, orig_operator, #orig_operator, #output, #rjust, #rr, #rs, #sext, #to_bit, #to_unsigned, #to_value, #to_value?, #zext
Methods inherited from Low::Binary
#boolean?, #boolean_in_assign2select, #casts_without_expression!, #clone, #each_deep, #each_node, #each_node_deep, #each_ref_deep, #eql?, #explicit_types, #hash, #immutable?, #initialize, #map_nodes!, #replace_expressions!, #set_left!, #set_right!, #to_c, #to_change, #to_hdr, #to_high, #to_verilog, #to_vhdl, #use_name?
Methods inherited from Low::Operation
#eql?, #explicit_types, #hash, #initialize, #set_operator!, #to_c, #to_hdr, #to_vhdl
Methods inherited from Low::Expression
#boolean?, #break_types!, #clone, #each_node, #each_node_deep, #each_ref_deep, #eql?, #explicit_types, #extract_selects_to!, #hash, #immutable?, #initialize, #leftvalue?, #map_nodes!, #replace_expressions!, #replace_names!, #rightvalue?, #set_type!, #statement, #to_c, #to_c_expr, #to_hdr, #to_high, #to_vhdl, #use_name?
Methods included from Low::Low2Symbol
Methods included from Low::Hparent
Constructor Details
This class inherits a constructor from HDLRuby::Low::Binary
Instance Method Details
#to_expr ⇒ Object
Converts to a new expression.
2845 2846 2847 2848 |
# File 'lib/HDLRuby/hruby_high.rb', line 2845 def to_expr return Binary.new(self.type, self.operator, self.left.to_expr, self.right.to_expr) end |
#to_low ⇒ Object
Converts the binary expression to HDLRuby::Low.
2851 2852 2853 2854 2855 2856 2857 2858 2859 2860 |
# File 'lib/HDLRuby/hruby_high.rb', line 2851 def to_low # return HDLRuby::Low::Binary.new(self.type.to_low, self.operator, # self.left.to_low, self.right.to_low) binaryL = HDLRuby::Low::Binary.new(self.type.to_low, self.operator, self.left.to_low, self.right.to_low) # # For debugging: set the source high object # binaryL.properties[:low2high] = self.hdr_id # self.properties[:high2low] = binaryL return binaryL end |