Sha256: 4186d6834654bfe9ece5ee1d47aea935118922d67460f2d05e3e8aba291ed1b2

Contents?: true

Size: 438 Bytes

Versions: 8

Compression:

Stored size: 438 Bytes

Contents

$n = 100

puts "Generating #{$n} cascading modules..."

$m = []
(1..$n).each { |i|
  $m[i] = Module.new
  $m[i].class_eval {
    define_method( "_#{i}" ) { puts "Called method in module #{i}." }
    include $m[i-1] if $m[i-1]
  }
}

class ManyIncludes
  include $m[$n]
end

mm = ManyIncludes.new
mn = "_#{$n/2}"

t0 = Time.now
mm.send(mn)
t1 = Time.now
puts "Time to call a single method among #{$n} modules: #{(t1 - t0).to_f} seconds."

Version data entries

8 entries across 8 versions & 1 rubygems

Version Path
facets-2.9.2 work/bench/general/bench_includes.rb
facets-2.3.0 demo/bench/general/bench_includes.rb
facets-2.4.0 demo/bench/general/bench_includes.rb
facets-2.4.1 demo/bench/general/bench_includes.rb
facets-2.4.3 demo/bench/general/bench_includes.rb
facets-2.4.2 demo/bench/general/bench_includes.rb
facets-2.4.4 demo/bench/general/bench_includes.rb
facets-2.4.5 demo/bench/general/bench_includes.rb