module Sprockets::Mime
def mime_exts
value - MIME Type String
key - MIME extension String
mime_exts['.js'] #=> 'application/javascript'
Examples:
Used for internal fast lookup purposes.
Internal: Mapping of MIME extension Strings to MIME type Strings.
def mime_exts config[:mime_exts] end
def mime_type_charset_detecter(mime_type)
mime_type - String MIME type
Internal: Get detecter function for MIME type.
def mime_type_charset_detecter(mime_type) if type = config[:mime_types][mime_type] if detect = type[:charset] return detect end end end
def mime_types
charset - Default Encoding or function to detect encoding
extensions - Array of extnames
value - Hash
key - MIME Type String
Public: Mapping of MIME type Strings to properties Hash.
def mime_types config[:mime_types] end
def read_file(filename, content_type = nil)
Returns String file contents transcoded to UTF-8 or in its external
content_type - String MIME type
filename - String path
Public: Read file on disk with MIME type specific encoding.
def read_file(filename, content_type = nil) data = File.binread(filename) if detect = mime_type_charset_detecter(content_type) detect.call(data).encode(Encoding::UTF_8, universal_newline: true) else data end end
def register_mime_type(mime_type, extensions: [], charset: nil)
See EncodingUtils.
charset - Proc/Method that detects the charset of a file.
extensions - Array of String extnames
mime_type - String MIME Type
Public: Register a new mime type.
def register_mime_type(mime_type, extensions: [], charset: nil) extnames = Array(extensions) charset ||= :default if mime_type.start_with?('text/') charset = EncodingUtils::CHARSET_DETECT[charset] if charset.is_a?(Symbol) self.config = hash_reassoc(config, :mime_exts) do |mime_exts| extnames.each do |extname| mime_exts[extname] = mime_type end mime_exts end self.config = hash_reassoc(config, :mime_types) do |mime_types| type = { extensions: extnames } type[:charset] = charset if charset mime_types.merge(mime_type => type) end end