Class: RubyCritic::AnalysedModulesCollection
- Inherits:
-
Object
- Object
- RubyCritic::AnalysedModulesCollection
- 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
- #each(&block) ⇒ Object
- #for_rating(rating) ⇒ Object
-
#initialize(paths) ⇒ AnalysedModulesCollection
constructor
A new instance of AnalysedModulesCollection.
- #score ⇒ Object
- #summary ⇒ Object
- #to_json(*options) ⇒ Object
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
44 45 46 |
# File 'lib/rubycritic/core/analysed_modules_collection.rb', line 44 def () find_all { |mod| mod..to_s == } end |
#score ⇒ Object
34 35 36 37 38 |
# File 'lib/rubycritic/core/analysed_modules_collection.rb', line 34 def score MAX_SCORE - average_limited_cost * COST_MULTIPLIER rescue 0.0 end |
#summary ⇒ Object
40 41 42 |
# File 'lib/rubycritic/core/analysed_modules_collection.rb', line 40 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(*) @modules.to_json(*) end |