Sha256: 05596afef65a07ea3a99aeaa2008018914ba3529e2fcd824b7d7d120f2e57389
Contents?: true
Size: 1.77 KB
Versions: 4
Compression:
Stored size: 1.77 KB
Contents
# encoding: utf-8 module RuboCop module Cop module Style # This cop checks whether the source file has a utf-8 encoding # comment or not. This check makes sense only for code that # should support Ruby 1.9, since in 2.0+ utf-8 is the default # source file encoding. There are two style: # # when_needed - only enforce an encoding comment if there are non ASCII # characters, otherwise report an offense # always - enforce encoding comment in all files class Encoding < Cop include ConfigurableEnforcedStyle MSG_MISSING = 'Missing utf-8 encoding comment.' MSG_UNNECESSARY = 'Unnecessary utf-8 encoding comment.' def investigate(processed_source) return if processed_source.buffer.source.empty? line_number = encoding_line_number(processed_source) message = offense(processed_source, line_number) return unless message range = source_range(processed_source.buffer, line_number + 1, 0) add_offense(nil, range, message) end private def offense(processed_source, line_number) line = processed_source[line_number] encoding_present = line =~ /#.*coding\s?[:=]\s?(UTF|utf)-8/ ascii_only = processed_source.buffer.source.ascii_only? always_encode = style == :always if !encoding_present && (always_encode || !ascii_only) MSG_MISSING elsif !always_encode && ascii_only && encoding_present MSG_UNNECESSARY end end def encoding_line_number(processed_source) line_number = 0 line_number += 1 if processed_source[line_number] =~ /^#!/ line_number end end end end end
Version data entries
4 entries across 4 versions & 2 rubygems