Class: RubyCritic::AnalysedModulesCollection

Inherits:
Object
  • Object
show all
Includes:
Enumerable
Defined in:
lib/rubycritic/core/analysed_modules_collection.rb

Constant Summary collapse

COST_LIMIT =

Limit used to prevent very bad modules to have excessive impact in the overall result. See #limited_cost_for

32
MAX_SCORE =

Score goes from 0 (worst) to 100 (perfect)

100
ZERO_SCORE_COST =

Projects with an average cost of 16 (or above) will score 0, since 16 is where the worst possible rating (F) starts

16
COST_MULTIPLIER =
MAX_SCORE.to_f / ZERO_SCORE_COST

Instance Method Summary collapse

Constructor Details

#initialize(paths) ⇒ AnalysedModulesCollection

Returns a new instance of AnalysedModulesCollection.



20
21
22
23
24
# File 'lib/rubycritic/core/analysed_modules_collection.rb', line 20

def initialize(paths)
  @modules = SourceLocator.new(paths).pathnames.map do |pathname|
    AnalysedModule.new(pathname: pathname)
  end
end

Instance Method Details

#each(&block) ⇒ Object



26
27
28
# File 'lib/rubycritic/core/analysed_modules_collection.rb', line 26

def each(&block)
  @modules.each(&block)
end

#for_rating(rating) ⇒ Object



46
47
48
# File 'lib/rubycritic/core/analysed_modules_collection.rb', line 46

def for_rating(rating)
  find_all { |mod| mod.rating.to_s == rating }
end

#scoreObject



34
35
36
37
38
39
40
# File 'lib/rubycritic/core/analysed_modules_collection.rb', line 34

def score
  if @modules.any?
    MAX_SCORE - average_limited_cost * COST_MULTIPLIER
  else
    0.0
  end
end

#summaryObject



42
43
44
# File 'lib/rubycritic/core/analysed_modules_collection.rb', line 42

def summary
  AnalysisSummary.generate(self)
end

#to_json(*options) ⇒ Object



30
31
32
# File 'lib/rubycritic/core/analysed_modules_collection.rb', line 30

def to_json(*options)
  @modules.to_json(*options)
end