Class: LLVM::Module::FunctionCollection
- Inherits:
-
Object
- Object
- LLVM::Module::FunctionCollection
- Includes:
- Enumerable
- Defined in:
- lib/llvm/core/module.rb
Instance Method Summary collapse
-
#[](key) ⇒ Object
Returns the Function with a name equal to key (symbol or string) or at key (integer).
-
#add(name, *args) ⇒ Object
Adds a Function with the given name (symbol or string) and args (Types).
-
#delete(function) ⇒ Object
Deletes the Function from the collection.
-
#each ⇒ Object
Iterates through each Function in the collection.
-
#first ⇒ Object
Returns the first Function in the collection.
-
#initialize(mod) ⇒ FunctionCollection
constructor
A new instance of FunctionCollection.
-
#last ⇒ Object
Returns the last Function in the collection.
-
#named(name) ⇒ Object
Returns the Function with the given name (symbol or string).
-
#next(function) ⇒ Object
Returns the next Function in the collection after function.
-
#previous(function) ⇒ Object
Returns the previous Function in the collection before function.
Constructor Details
#initialize(mod) ⇒ FunctionCollection
Returns a new instance of FunctionCollection.
169 170 171 |
# File 'lib/llvm/core/module.rb', line 169 def initialize(mod) @module = mod end |
Instance Method Details
#[](key) ⇒ Object
Returns the Function with a name equal to key (symbol or string) or at key (integer).
221 222 223 224 225 226 227 228 229 230 231 232 233 |
# File 'lib/llvm/core/module.rb', line 221 def [](key) case key when String, Symbol then named(key) when Integer i = 0 f = first until i >= key || f.nil? f = self.next(f) i += 1 end f end end |
#add(name, *args) ⇒ Object
Adds a Function with the given name (symbol or string) and args (Types).
174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 |
# File 'lib/llvm/core/module.rb', line 174 def add(name, *args) if args.first.kind_of? FunctionType type = args.first else type = Type.function(*args) end function = Function.from_ptr(C.add_function(@module, name.to_s, type)) if block_given? params = (0...function.params.size).map { |i| function.params[i] } yield function, *params end function end |
#delete(function) ⇒ Object
Deletes the Function from the collection.
216 217 218 |
# File 'lib/llvm/core/module.rb', line 216 def delete(function) C.delete_function(function) end |
#each ⇒ Object
Iterates through each Function in the collection.
236 237 238 239 240 241 242 |
# File 'lib/llvm/core/module.rb', line 236 def each f = first until f.nil? yield f f = self.next(f) end end |
#first ⇒ Object
Returns the first Function in the collection.
196 197 198 |
# File 'lib/llvm/core/module.rb', line 196 def first Function.from_ptr(C.get_first_function(@module)) end |
#last ⇒ Object
Returns the last Function in the collection.
201 202 203 |
# File 'lib/llvm/core/module.rb', line 201 def last Function.from_ptr(C.get_last_function(@module)) end |
#named(name) ⇒ Object
Returns the Function with the given name (symbol or string).
191 192 193 |
# File 'lib/llvm/core/module.rb', line 191 def named(name) Function.from_ptr(C.get_named_function(@module, name.to_s)) end |
#next(function) ⇒ Object
Returns the next Function in the collection after function.
206 207 208 |
# File 'lib/llvm/core/module.rb', line 206 def next(function) Function.from_ptr(C.get_next_function(function)) end |
#previous(function) ⇒ Object
Returns the previous Function in the collection before function.
211 212 213 |
# File 'lib/llvm/core/module.rb', line 211 def previous(function) Function.from_ptr(C.get_previous_function(function)) end |