Skip to Content Skip to Search
Methods
#
A
C
E
H
L
N
P
T
Included Modules

Class Public methods

new(initializers = nil)

# File railties/lib/rails/initializable.rb, line 43
def initialize(initializers = nil)
  @order = Hash.new { |hash, key| hash[key] = Set.new }
  @resolve = Hash.new { |hash, key| hash[key] = Set.new }
  @collection = []
  concat(initializers) if initializers
end

Instance Public methods

+(other)

# File railties/lib/rails/initializable.rb, line 69
def +(other)
  dup.concat(other.to_a)
end

<<(initializer)

# File railties/lib/rails/initializable.rb, line 73
def <<(initializer)
  @collection << initializer
  @order[initializer.before] << initializer.name if initializer.before
  @order[initializer.name] << initializer.after if initializer.after
  @resolve[initializer.name] << initializer
  self
end

append(*initializers)

Alias for: push

concat(*initializer_collections)

# File railties/lib/rails/initializable.rb, line 88
def concat(*initializer_collections)
  initializer_collections.each do |initializers|
    initializers.each(&method(:<<))
  end
  self
end

each(&block)

Also aliased as: tsort_each_node
# File railties/lib/rails/initializable.rb, line 58
def each(&block)
  @collection.each(&block)
end

has?(name)

# File railties/lib/rails/initializable.rb, line 95
def has?(name)
  @resolve.key?(name)
end

last()

# File railties/lib/rails/initializable.rb, line 54
def last
  @collection.last
end

push(*initializers)

Also aliased as: append
# File railties/lib/rails/initializable.rb, line 81
def push(*initializers)
  initializers.each(&method(:<<))
  self
end

to_a()

# File railties/lib/rails/initializable.rb, line 50
def to_a
  @collection
end

tsort_each_child(initializer, &block)

# File railties/lib/rails/initializable.rb, line 63
def tsort_each_child(initializer, &block)
  @order[initializer.name].each do |name|
    @resolve[name].each(&block)
  end
end

tsort_each_node(&block)

Alias for: each