Class: RuboCop::MagicComment::VimComment

Inherits:
EditorComment show all
Defined in:
lib/rubocop/magic_comment.rb

Overview

Wrapper for Vim style magic comments.

Examples:

Vim style comment

comment = RuboCop::MagicComment.parse(
  '# vim: filetype=ruby, fileencoding=ascii-8bit'
)

comment.encoding # => 'ascii-8bit'

Constant Summary collapse

FORMAT =
/#\s*vim:\s*(.+)/.freeze
SEPARATOR =
', '
OPERATOR =
'='

Constants inherited from RuboCop::MagicComment

TOKEN

Instance Method Summary collapse

Methods inherited from RuboCop::MagicComment

#any?, #encoding_specified?, #frozen_string_literal?, #frozen_string_literal_specified?, #initialize, parse, #valid_literal_value?

Constructor Details

This class inherits a constructor from RuboCop::MagicComment

Instance Method Details

#encodingObject

For some reason the fileencoding keyword only works if there is at least one other token included in the string. For example

# works
  # vim: foo=bar, fileencoding=ascii-8bit

# does nothing
  # vim: foo=bar, fileencoding=ascii-8bit


173
174
175
# File 'lib/rubocop/magic_comment.rb', line 173

def encoding
  match('fileencoding') if tokens.size > 1
end

#frozen_string_literalObject

Vim comments cannot specify frozen string literal behavior.



178
# File 'lib/rubocop/magic_comment.rb', line 178

def frozen_string_literal; end