Class: RuboCop::CommentConfig
- Inherits:
-
Object
- Object
- RuboCop::CommentConfig
- Defined in:
- lib/rubocop/comment_config.rb
Overview
This class parses the special rubocop:disable
comments in a source
and provides a way to check if each cop is enabled at arbitrary line.
Constant Summary collapse
- UNNEEDED_DISABLE =
'Lint/UnneededDisable'
- COMMENT_DIRECTIVE_REGEXP =
Regexp.new( '\A# rubocop : ((?:dis|en)able)\b ((?:[\w/]+,? )+)'.gsub(' ', '\s*') )
Instance Attribute Summary collapse
-
#processed_source ⇒ Object
readonly
Returns the value of attribute processed_source.
Instance Method Summary collapse
- #cop_disabled_line_ranges ⇒ Object
- #cop_enabled_at_line?(cop, line_number) ⇒ Boolean
-
#initialize(processed_source) ⇒ CommentConfig
constructor
A new instance of CommentConfig.
Constructor Details
#initialize(processed_source) ⇒ CommentConfig
Returns a new instance of CommentConfig.
14 15 16 |
# File 'lib/rubocop/comment_config.rb', line 14 def initialize(processed_source) @processed_source = processed_source end |
Instance Attribute Details
#processed_source ⇒ Object (readonly)
Returns the value of attribute processed_source.
12 13 14 |
# File 'lib/rubocop/comment_config.rb', line 12 def processed_source @processed_source end |
Instance Method Details
#cop_disabled_line_ranges ⇒ Object
24 25 26 |
# File 'lib/rubocop/comment_config.rb', line 24 def cop_disabled_line_ranges @cop_disabled_line_ranges ||= analyze end |
#cop_enabled_at_line?(cop, line_number) ⇒ Boolean
18 19 20 21 22 |
# File 'lib/rubocop/comment_config.rb', line 18 def cop_enabled_at_line?(cop, line_number) cop = cop.cop_name if cop.respond_to?(:cop_name) disabled_line_ranges = cop_disabled_line_ranges[cop] disabled_line_ranges.none? { |range| range.include?(line_number) } end |