Class: RuboCop::DirectiveComment
Relationships & Source Files | |
Inherits: | Object |
Defined in: | lib/rubocop/directive_comment.rb |
Overview
This class wraps the Parser::Source::Comment
object that represents a
special rubocop:disable
and rubocop:enable
comment and exposes what
cops it contains.
Constant Summary
-
COPS_PATTERN =
Internal use only
# File 'lib/rubocop/directive_comment.rb', line 19"(all|#{COP_NAMES_PATTERN})"
-
COP_NAMES_PATTERN =
Internal use only
# File 'lib/rubocop/directive_comment.rb', line 17"(?:#{COP_NAME_PATTERN} , )*#{COP_NAME_PATTERN}"
-
COP_NAME_PATTERN =
Internal use only
# File 'lib/rubocop/directive_comment.rb', line 15'([A-Z]\w+/)*(?:[A-Z]\w+)'
-
DIRECTIVE_COMMENT_REGEXP =
Internal use only
# File 'lib/rubocop/directive_comment.rb', line 21Regexp.new( "# rubocop : ((?:disable|enable|todo))\\b #{COPS_PATTERN}" .gsub(' ', '\s*') )
-
LINT_DEPARTMENT =
Internal use only
# File 'lib/rubocop/directive_comment.rb', line 9'Lint'
-
LINT_REDUNDANT_DIRECTIVE_COP =
Internal use only
# File 'lib/rubocop/directive_comment.rb', line 11"#{LINT_DEPARTMENT}/RedundantCopDisableDirective"
-
LINT_SYNTAX_COP =
Internal use only
# File 'lib/rubocop/directive_comment.rb', line 13"#{LINT_DEPARTMENT}/Syntax"
Class Method Summary
Instance Attribute Summary
-
#all_cops? ⇒ Boolean
readonly
Checks if all cops specified in this directive.
- #comment readonly
- #cop_registry readonly
- #cops readonly
-
#disabled? ⇒ Boolean
readonly
Checks if this directive disables cops.
-
#disabled_all? ⇒ Boolean
readonly
Checks if this directive disables all cops.
-
#enabled? ⇒ Boolean
readonly
Checks if this directive enables cops.
-
#enabled_all? ⇒ Boolean
readonly
Checks if this directive enables all cops.
- #mode readonly
-
#single_line? ⇒ Boolean
readonly
Checks if this directive relates to single line.
Instance Method Summary
-
#cop_names
Returns array of specified in this directive cop names.
-
#department_names
Returns array of specified in this directive department names when all department disabled.
- #directive_count
-
#in_directive_department?(cop) ⇒ Boolean
Checks if directive departments include cop.
-
#line_number
Returns line number for directive.
-
#match?(cop_names) ⇒ Boolean
Checks if this directive contains all the given cop names.
-
#match_captures
Returns match captures to directive comment pattern.
-
#overridden_by_department?(cop) ⇒ Boolean
Checks if cop department has already used in directive comment.
- #range
-
#raw_cop_names
Returns an array of cops for this directive comment, without resolving departments.
- #all_cop_names private
- #cop_names_for_department(department) private
- #department?(name) ⇒ Boolean private
- #exclude_lint_department_cops(cops) private
- #parsed_cop_names private
Constructor Details
.new(comment, cop_registry = Cop::Registry.global) ⇒ DirectiveComment
# File 'lib/rubocop/directive_comment.rb', line 32
def initialize(comment, cop_registry = Cop::Registry.global) @comment = comment @cop_registry = cop_registry @mode, @cops = match_captures end
Class Method Details
.before_comment(line)
[ GitHub ]# File 'lib/rubocop/directive_comment.rb', line 26
def self.before_comment(line) line.split(DIRECTIVE_COMMENT_REGEXP).first end
Instance Attribute Details
#all_cops? ⇒ Boolean
(readonly)
Checks if all cops specified in this directive
# File 'lib/rubocop/directive_comment.rb', line 82
def all_cops? cops == 'all' end
#comment (readonly)
[ GitHub ]# File 'lib/rubocop/directive_comment.rb', line 30
attr_reader :comment, :cop_registry, :mode, :cops
#cop_registry (readonly)
[ GitHub ]#cops (readonly)
[ GitHub ]# File 'lib/rubocop/directive_comment.rb', line 30
attr_reader :comment, :cop_registry, :mode, :cops
#disabled? ⇒ Boolean
(readonly)
Checks if this directive disables cops
# File 'lib/rubocop/directive_comment.rb', line 62
def disabled? %w[disable todo].include?(mode) end
#disabled_all? ⇒ Boolean
(readonly)
Checks if this directive disables all cops
#enabled? ⇒ Boolean
(readonly)
Checks if this directive enables cops
# File 'lib/rubocop/directive_comment.rb', line 67
def enabled? mode == 'enable' end
#enabled_all? ⇒ Boolean
(readonly)
Checks if this directive enables all cops
#mode (readonly)
[ GitHub ]# File 'lib/rubocop/directive_comment.rb', line 30
attr_reader :comment, :cop_registry, :mode, :cops
#single_line? ⇒ Boolean
(readonly)
Checks if this directive relates to single line
# File 'lib/rubocop/directive_comment.rb', line 39
def single_line? !comment.text.start_with?(DIRECTIVE_COMMENT_REGEXP) end
Instance Method Details
#all_cop_names (private)
[ GitHub ]# File 'lib/rubocop/directive_comment.rb', line 134
def all_cop_names exclude_lint_department_cops(cop_registry.names) end
#cop_names
Returns array of specified in this directive cop names
# File 'lib/rubocop/directive_comment.rb', line 87
def cop_names @cop_names ||= all_cops? ? all_cop_names : parsed_cop_names end
#cop_names_for_department(department) (private)
[ GitHub ]# File 'lib/rubocop/directive_comment.rb', line 138
def cop_names_for_department(department) names = cop_registry.names_for_department(department) department == LINT_DEPARTMENT ? exclude_lint_department_cops(names) : names end
#department?(name) ⇒ Boolean
(private)
# File 'lib/rubocop/directive_comment.rb', line 130
def department?(name) cop_registry.department?(name) end
#department_names
Returns array of specified in this directive department names when all department disabled
# File 'lib/rubocop/directive_comment.rb', line 98
def department_names raw_cop_names.select { |cop| department?(cop) } end
#directive_count
[ GitHub ]# File 'lib/rubocop/directive_comment.rb', line 112
def directive_count raw_cop_names.count end
#exclude_lint_department_cops(cops) (private)
[ GitHub ]# File 'lib/rubocop/directive_comment.rb', line 143
def exclude_lint_department_cops(cops) cops - [LINT_REDUNDANT_DIRECTIVE_COP, LINT_SYNTAX_COP] end
#in_directive_department?(cop) ⇒ Boolean
Checks if directive departments include cop
# File 'lib/rubocop/directive_comment.rb', line 103
def in_directive_department?(cop) department_names.any? { |department| cop.start_with?(department) } end
#line_number
Returns line number for directive
# File 'lib/rubocop/directive_comment.rb', line 117
def line_number comment.source_range.line end
#match?(cop_names) ⇒ Boolean
Checks if this directive contains all the given cop names
# File 'lib/rubocop/directive_comment.rb', line 44
def match?(cop_names) parsed_cop_names.uniq.sort == cop_names.uniq.sort end
#match_captures
Returns match captures to directive comment pattern
# File 'lib/rubocop/directive_comment.rb', line 57
def match_captures @match_captures ||= comment.text.match(DIRECTIVE_COMMENT_REGEXP)&.captures end
#overridden_by_department?(cop) ⇒ Boolean
Checks if cop department has already used in directive comment
# File 'lib/rubocop/directive_comment.rb', line 108
def overridden_by_department?(cop) in_directive_department?(cop) && raw_cop_names.include?(cop) end
#parsed_cop_names (private)
[ GitHub ]# File 'lib/rubocop/directive_comment.rb', line 123
def parsed_cop_names cops = raw_cop_names.map do |name| department?(name) ? cop_names_for_department(name) : name end.flatten cops - [LINT_SYNTAX_COP] end
#range
[ GitHub ]# File 'lib/rubocop/directive_comment.rb', line 48
def range match = comment.text.match(DIRECTIVE_COMMENT_REGEXP) begin_pos = comment.source_range.begin_pos Parser::Source::Range.new( comment.source_range.source_buffer, begin_pos + match.begin(0), begin_pos + match.end(0) ) end
#raw_cop_names
Returns an array of cops for this directive comment, without resolving departments
# File 'lib/rubocop/directive_comment.rb', line 92
def raw_cop_names @raw_cop_names ||= (cops || '').split(/,\s*/) end