rltk 3.0.0 → 3.0.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (50) hide show
  1. checksums.yaml +4 -4
  2. data/Rakefile +21 -22
  3. data/lib/rltk/ast.rb +185 -118
  4. data/lib/rltk/cfg.rb +157 -103
  5. data/lib/rltk/cg/basic_block.rb +19 -19
  6. data/lib/rltk/cg/bindings.rb +16 -16
  7. data/lib/rltk/cg/builder.rb +129 -129
  8. data/lib/rltk/cg/context.rb +7 -7
  9. data/lib/rltk/cg/contractor.rb +7 -7
  10. data/lib/rltk/cg/execution_engine.rb +30 -30
  11. data/lib/rltk/cg/function.rb +37 -37
  12. data/lib/rltk/cg/generated_bindings.rb +3932 -3932
  13. data/lib/rltk/cg/generic_value.rb +17 -17
  14. data/lib/rltk/cg/instruction.rb +116 -116
  15. data/lib/rltk/cg/llvm.rb +22 -22
  16. data/lib/rltk/cg/memory_buffer.rb +7 -7
  17. data/lib/rltk/cg/module.rb +73 -73
  18. data/lib/rltk/cg/pass_manager.rb +35 -35
  19. data/lib/rltk/cg/target.rb +41 -41
  20. data/lib/rltk/cg/triple.rb +7 -7
  21. data/lib/rltk/cg/type.rb +75 -75
  22. data/lib/rltk/cg/value.rb +161 -161
  23. data/lib/rltk/lexer.rb +57 -57
  24. data/lib/rltk/lexers/calculator.rb +7 -7
  25. data/lib/rltk/lexers/ebnf.rb +5 -5
  26. data/lib/rltk/parser.rb +338 -295
  27. data/lib/rltk/parsers/infix_calc.rb +7 -7
  28. data/lib/rltk/parsers/postfix_calc.rb +3 -3
  29. data/lib/rltk/parsers/prefix_calc.rb +3 -3
  30. data/lib/rltk/token.rb +13 -13
  31. data/lib/rltk/version.rb +6 -6
  32. data/test/cg/tc_basic_block.rb +17 -17
  33. data/test/cg/tc_control_flow.rb +41 -41
  34. data/test/cg/tc_function.rb +4 -4
  35. data/test/cg/tc_generic_value.rb +3 -3
  36. data/test/cg/tc_instruction.rb +53 -53
  37. data/test/cg/tc_math.rb +12 -12
  38. data/test/cg/tc_module.rb +14 -14
  39. data/test/cg/tc_transforms.rb +11 -11
  40. data/test/cg/tc_type.rb +12 -12
  41. data/test/cg/tc_value.rb +35 -35
  42. data/test/cg/ts_cg.rb +5 -5
  43. data/test/tc_ast.rb +137 -60
  44. data/test/tc_cfg.rb +34 -34
  45. data/test/tc_lexer.rb +42 -42
  46. data/test/tc_parser.rb +250 -173
  47. data/test/tc_token.rb +2 -2
  48. data/test/ts_rltk.rb +8 -8
  49. metadata +84 -85
  50. data/lib/rltk/cg/old_generated_bindings.rb +0 -6152
@@ -15,15 +15,15 @@ require 'rltk/cg/bindings'
15
15
  #######################
16
16
 
17
17
  module RLTK::CG
18
-
18
+
19
19
  # A PassManager is responsible for scheduling and running optimization
20
20
  # passes on modules.
21
21
  class PassManager
22
22
  include BindingClass
23
-
23
+
24
24
  # The Proc object called by the garbage collector to free resources used by LLVM.
25
25
  CLASS_FINALIZER = Proc.new { |id| Bindings.dispose_pass_manager(ptr) if ptr = ObjectSpace._id2ref(id).ptr }
26
-
26
+
27
27
  # A list of passes that are available to be added to the pass
28
28
  # manager via the {PassManager#add} method.
29
29
  PASSES = {
@@ -75,7 +75,7 @@ module RLTK::CG
75
75
  :TBAA => :type_based_alias_analysis,
76
76
  :Verifier => :verifier
77
77
  }
78
-
78
+
79
79
  # Create a new pass manager. You should never have to do this as
80
80
  # {Module Modules} should create PassManagers for you whenever they
81
81
  # are requested.
@@ -87,18 +87,18 @@ module RLTK::CG
87
87
  # LLVM Initialization
88
88
  @ptr = Bindings.create_pass_manager
89
89
  @mod = mod
90
-
90
+
91
91
  # Set the target data if the module is associated with a execution engine.
92
92
  self.target_data = mod.engine.target_data if mod.engine
93
-
93
+
94
94
  # RLTK Initialization
95
95
  @enabled = Array.new
96
-
96
+
97
97
  # Define a finalizer to free the memory used by LLVM for this
98
98
  # pass manager.
99
99
  ObjectSpace.define_finalizer(self, CLASS_FINALIZER)
100
100
  end
101
-
101
+
102
102
  # Add a pass or passes to this pass manager. Passes may either be
103
103
  # specified via the keys for the PASSES hash or any string that will
104
104
  # be turned into a string (via the {Bindings.get_bname} method)
@@ -112,47 +112,47 @@ module RLTK::CG
112
112
  def add(*names)
113
113
  names.each do |name|
114
114
  name = name.to_sym
115
-
115
+
116
116
  if PASSES.has_key?(name)
117
117
  next if @enabled.include?(name)
118
-
118
+
119
119
  Bindings.send("add_#{PASSES[name]}_pass", @ptr)
120
-
120
+
121
121
  @enabled << name
122
-
122
+
123
123
  elsif PASSES.has_value?(bname = Bindings.get_bname(name))
124
124
  next if @enabled.include?(PASSES.key(bname))
125
-
125
+
126
126
  Bindings.send("add_#{bname}_pass", @ptr)
127
-
127
+
128
128
  @enabled << PASSES.key(bname)
129
-
129
+
130
130
  else
131
131
  raise "Unknown pass: #{name}"
132
132
  end
133
133
  end
134
-
134
+
135
135
  self
136
136
  end
137
137
  alias :<< :add
138
-
138
+
139
139
  # @return [Array<Symbol>] List of passes that have been enabled.
140
140
  def enabled
141
141
  @enabled.clone
142
142
  end
143
-
143
+
144
144
  # @return [Boolean] Weather the pass has been enabled or not.
145
145
  def enabled?(name)
146
146
  @enabled.include?(name) or @enabled.include?(PASSES.key(Bindings.get_bname(name)))
147
147
  end
148
-
148
+
149
149
  # Run the enabled passes on the execution engine's module.
150
150
  #
151
151
  # @return [void]
152
152
  def run
153
153
  Bindings.run_pass_manager(@ptr, @mod).to_bool
154
154
  end
155
-
155
+
156
156
  # Set the target data for this pass manager.
157
157
  #
158
158
  # @param [TargetData] data
@@ -161,13 +161,13 @@ module RLTK::CG
161
161
  def target_data=(data)
162
162
  Bindings.add_target_data(check_type(data, TargetData, 'data'), @ptr)
163
163
  end
164
-
164
+
165
165
  protected
166
166
  # Empty method used by {FunctionPassManager} to clean up resources.
167
167
  def finalize
168
168
  end
169
169
  end
170
-
170
+
171
171
  # A FunctionPassManager is responsible for scheduling and running optimization
172
172
  # passes on individual functions inside the context of a module.
173
173
  class FunctionPassManager < PassManager
@@ -181,16 +181,16 @@ module RLTK::CG
181
181
  def initialize(mod)
182
182
  # LLVM Initialization
183
183
  @ptr = Bindings.create_function_pass_manager_for_module(mod)
184
-
184
+
185
185
  # Set the target data if the module is associated with a execution engine.
186
186
  self.target_data = mod.engine.target_data if mod.engine
187
-
187
+
188
188
  Bindings.initialize_function_pass_manager(@ptr)
189
-
189
+
190
190
  # RLTK Initialization
191
191
  @enabled = Array.new
192
192
  end
193
-
193
+
194
194
  # Run the enabled passes on the given function inside the execution
195
195
  # engine's module.
196
196
  #
@@ -200,7 +200,7 @@ module RLTK::CG
200
200
  def run(fun)
201
201
  Bindings.run_function_pass_manager(@ptr, fun).to_bool
202
202
  end
203
-
203
+
204
204
  protected
205
205
  # Called by {#dispose} to finalize any operations of the function
206
206
  # pass manager.
@@ -210,7 +210,7 @@ module RLTK::CG
210
210
  Bindings.finalize_function_pass_manager(@ptr).to_bool
211
211
  end
212
212
  end
213
-
213
+
214
214
  PASS_GROUPS = [
215
215
  :analysis,
216
216
  :core,
@@ -224,29 +224,29 @@ module RLTK::CG
224
224
  :transform_utils,
225
225
  :vectorization
226
226
  ]
227
-
227
+
228
228
  class PassRegistry
229
229
  include BindingClass
230
-
230
+
231
231
  def self.global
232
232
  PassRegistry.allocate.tap { |pr| pr.ptr = Bindings.get_global_pass_registry }
233
233
  end
234
-
234
+
235
235
  def initialize
236
236
  @ptr = Bindings::OpaquePassRegistry.new
237
237
  end
238
-
238
+
239
239
  def init(pass_group = :all)
240
240
  if pass_group == :all
241
241
  PASS_GROUPS.each { |pg| Bindings.send("initialize_#{pg}", @ptr) }
242
-
242
+
243
243
  elsif PASS_GROUPS.include?(pass_group)
244
244
  Bindings.send("initialize_#{pass_group}", @ptr)
245
245
  end
246
246
  end
247
-
247
+
248
248
  def init(pass_group)
249
-
249
+
250
250
  end
251
251
  end
252
252
  end
@@ -20,100 +20,100 @@ module RLTK::CG
20
20
  # Class binding for the LLVM Triple class.
21
21
  class Target
22
22
  include BindingClass
23
-
23
+
24
24
  #################
25
25
  # Class Methods #
26
26
  #################
27
-
27
+
28
28
  # @return [Target] First target in the target list
29
29
  def self.first
30
30
  @first ||= self.new(Bindings.get_first_target)
31
31
  end
32
-
32
+
33
33
  # @return [Target] Target object for the host architecture.
34
34
  def self.host
35
35
  @host ||= self.new(Triple.host)
36
36
  end
37
-
37
+
38
38
  # @return [Target] Next target in the target list
39
39
  def self.next_target(target)
40
40
  self.new(Bindings.get_next_target(target))
41
41
  end
42
-
42
+
43
43
  ####################
44
44
  # Instance Methods #
45
45
  ####################
46
-
46
+
47
47
  # Create an object representing a particular code generation target.
48
48
  # You can create a target either from a string or a Triple.
49
49
  #
50
50
  # @param [Triple, String] overloaded Object describing the target.
51
51
  def initialize(overloaded)
52
- @ptr, @triple =
52
+ @ptr, @triple =
53
53
  case overloaded
54
54
  when String
55
55
  [Bindings.get_target_from_name(overloaded), Triple.new(overloaded)]
56
-
56
+
57
57
  when RLTK::CG::Triple
58
58
  ptr = FFI::MemoryPointer.new(:pointer)
59
59
  error = FFI::MemoryPointer.new(:pointer)
60
60
  status = Bindings.get_target_from_triple(overloaded.to_s, ptr, error)
61
-
61
+
62
62
  if status.zero?
63
63
  [ptr, overloaded]
64
-
64
+
65
65
  else
66
66
  errorp = error.read_pointer
67
67
  message = errorp.null? ? 'Unknown' : errorp.read_string
68
-
68
+
69
69
  error.autorelease = false
70
-
70
+
71
71
  Bindings.dispose_message(error)
72
-
72
+
73
73
  raise "Error creating target: #{message}"
74
74
  end
75
-
75
+
76
76
  when RLTK::CG::Bindings::Triple
77
77
  [overloaded, nil]
78
78
  end
79
79
  end
80
-
80
+
81
81
  # @return [Boolean] Whether or not the target has an ASM backend
82
82
  def asm_backend?
83
83
  Bindings.target_has_asm_backend(@ptr).to_bool
84
84
  end
85
-
85
+
86
86
  # @return [Boolean] Whether or not the target has a JIT
87
87
  def jit?
88
88
  Bindings.target_has_jit(@ptr).to_bool
89
89
  end
90
-
90
+
91
91
  # @return [Boolean] Whether or not the target has a TargetMachine
92
92
  def target_machine?
93
93
  Bindings.target_has_target_machine(@ptr).to_bool
94
94
  end
95
-
95
+
96
96
  # @return [String] Description of the target
97
97
  def describe
98
98
  Bindings.get_target_description(@ptr)
99
99
  end
100
-
100
+
101
101
  # @return [Triple] Triple object for this target
102
102
  def triple
103
103
  @triple ||= Triple.new(Bindings.get_target_name(@ptr))
104
104
  end
105
105
  end
106
-
106
+
107
107
  # This class represents data about a specific architecture. Currently it
108
108
  # is for internal use only and should not be instantiated by users.
109
109
  class TargetData
110
110
  include BindingClass
111
-
111
+
112
112
  # @param [FFI::Pointer] ptr
113
113
  def initialize(ptr)
114
114
  @ptr = ptr
115
115
  end
116
-
116
+
117
117
  # Gets the pointer size for this target machine and address space
118
118
  # combination.
119
119
  #
@@ -124,20 +124,20 @@ module RLTK::CG
124
124
  Bindings.pointer_size_for_as(@ptr, as)
125
125
  end
126
126
  end
127
-
127
+
128
128
  # This class represents a specific architecture that wil be targeted by
129
129
  # LLVM's compilation process.
130
130
  class TargetMachine
131
131
  include BindingClass
132
-
132
+
133
133
  # The Proc object called by the garbage collector to free resources used by LLVM.
134
134
  CLASS_FINALIZER = Proc.new { |id| Bindings.dispose_target_machine(ptr) if ptr = ObjectSpace._id2ref(id).ptr }
135
-
135
+
136
136
  # @return [TargetMachine] TargetMachine representation of the host machine.
137
137
  def self.host
138
138
  @host ||= self.new(Target.host)
139
139
  end
140
-
140
+
141
141
  # Create a new object describing a target machine.
142
142
  #
143
143
  # @see Bindings._enum_reloc_model_
@@ -152,24 +152,24 @@ module RLTK::CG
152
152
  def initialize(target, mcpu = '', features = '', opt_level = :none, reloc_mode = :default, code_model = :default)
153
153
  # Convert the features parameter if necessary.
154
154
  features = TargetMachine.build_feature_string(features) if features.is_a?(Array)
155
-
155
+
156
156
  @ptr = Bindings.create_target_machine(target, target.triple.to_s, mcpu, features, opt_level, reloc_mode, code_model)
157
-
157
+
158
158
  # Define a finalizer to free the memory used by LLVM for
159
159
  # this target machine.
160
160
  ObjectSpace.define_finalizer(self, CLASS_FINALIZER)
161
161
  end
162
-
162
+
163
163
  # @return [String] Name of the target machine's CPU
164
164
  def cpu
165
165
  Bindings.get_target_machine_cpu(@ptr)
166
166
  end
167
-
167
+
168
168
  # @return [TargetData]
169
169
  def data
170
170
  TargetData.new(Bindings.get_target_machine_data(@pt))
171
171
  end
172
-
172
+
173
173
  # Emit assembly or object code for the given module to the file
174
174
  # specified.
175
175
  #
@@ -183,34 +183,34 @@ module RLTK::CG
183
183
  def emit_module(mod, file_name, emit_type)
184
184
  error = FFI::MemoryPointer.new(:pointer)
185
185
  status = Bindings.target_machine_emit_to_file(@ptr, mod, file_name, emit_type, error)
186
-
186
+
187
187
  if not status.zero?
188
188
  errorp = error.read_pointer
189
189
  message = errorp.null? ? 'Unknown' : errorp.read_string
190
-
190
+
191
191
  error.autorelease = false
192
-
192
+
193
193
  Bindings.dispose_message(error)
194
-
194
+
195
195
  raise "Error emiting code for module: #{message}"
196
196
  end
197
197
  end
198
-
198
+
199
199
  # @return [String] Feature string for this target machine
200
200
  def feature_string
201
201
  Bindings.get_target_machine_feature_string(@ptr)
202
202
  end
203
-
203
+
204
204
  # @return [Target]
205
205
  def target
206
206
  Target.new(Bindings.get_target_machine_target(@ptr))
207
207
  end
208
-
208
+
209
209
  # @return [Triple]
210
210
  def triple
211
211
  Triple.new(Bindings.get_target_machine_triple(@ptr))
212
212
  end
213
-
213
+
214
214
  # Set verbose ASM property.
215
215
  #
216
216
  # @param [Boolean] bool Verbose ASM or not
@@ -218,10 +218,10 @@ module RLTK::CG
218
218
  # @return [void]
219
219
  def verbose_asm=(bool)
220
220
  @verbose_asm = bool
221
-
221
+
222
222
  Bindings.set_target_machine_asm_verbosity(@ptr, bool.to_i)
223
223
  end
224
-
224
+
225
225
  # @return [Boolean] If this target machine should print verbose ASM
226
226
  def verbose_asm?
227
227
  @verbose_asm ||= false
@@ -19,37 +19,37 @@ module RLTK::CG
19
19
  # Class binding for the LLVM Triple class.
20
20
  class Triple
21
21
  include BindingClass
22
-
22
+
23
23
  #################
24
24
  # Class Methods #
25
25
  #################
26
-
26
+
27
27
  # @return [Triple] Object representing the host architecture, vendor, OS, and environment.
28
28
  def self.host
29
29
  @host ||= Triple.new(host_string)
30
30
  end
31
-
31
+
32
32
  # @return [String] String representation of the host architecture, vendor, OS, and environment.
33
33
  def self.host_string
34
34
  @host_string ||= Bindings.get_default_target_triple
35
35
  end
36
-
36
+
37
37
  ####################
38
38
  # Instance Methods #
39
39
  ####################
40
-
40
+
41
41
  # Create a new triple describing the host architecture, vendor, OS,
42
42
  # and (optionally) environment.
43
43
  #
44
44
  # @param [FFI::Pointer, String] overloaded
45
45
  def initialize(overloaded)
46
- @ptr, @str =
46
+ @ptr, @str =
47
47
  case overloaded
48
48
  when FFI::Pointer then [overloaded, nil]
49
49
  when String then [Bindings.triple_create(overloaded), overloaded]
50
50
  end
51
51
  end
52
-
52
+
53
53
  # @return [String] String representation of this triple.
54
54
  def to_s
55
55
  @str ||= Bindings.get_triple_string(@ptr)