ruby/lib/rubygems/resolver/stats.rb
nagachika 996b1bfa95 merge revision(s) 53707,53708,53709,53712,53777,53781: [Backport #12326]
* lib/rubygems.rb, lib/rubygems/*, test/rubygems/*: Update rubygems-2.5.2.
	  It supports to enable frozen string literal and add `--norc` option for
	  disable to `.gemrc` configuration.
	  See 2.5.2 release notes for other fixes and enhancements.
	  a8aa3bac72/History.txt (L3)

	* lib/rubygems/specification.rb: `coding` is affect only first line except
	  shebang.

	* lib/rubygems/package.rb, lib/rubygems/package/*: ditto.


git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/branches/ruby_2_3@56003 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
2016-08-24 15:28:23 +00:00

45 lines
950 B
Ruby

# frozen_string_literal: true
class Gem::Resolver::Stats
def initialize
@max_depth = 0
@max_requirements = 0
@requirements = 0
@backtracking = 0
@iterations = 0
end
def record_depth(stack)
if stack.size > @max_depth
@max_depth = stack.size
end
end
def record_requirements(reqs)
if reqs.size > @max_requirements
@max_requirements = reqs.size
end
end
def requirement!
@requirements += 1
end
def backtracking!
@backtracking += 1
end
def iteration!
@iterations += 1
end
PATTERN = "%20s: %d\n"
def display
$stdout.puts "=== Resolver Statistics ==="
$stdout.printf PATTERN, "Max Depth", @max_depth
$stdout.printf PATTERN, "Total Requirements", @requirements
$stdout.printf PATTERN, "Max Requirements", @max_requirements
$stdout.printf PATTERN, "Backtracking #", @backtracking
$stdout.printf PATTERN, "Iteration #", @iterations
end
end