Mitigate major perf regression caused by the Middleman::Util#binary? method

This commit is contained in:
Ben Hollis 2013-01-22 00:59:54 -08:00 committed by Thomas Reynolds
parent c34b425f45
commit da39484767

View file

@ -10,8 +10,6 @@ require "thor"
# Core Pathname library used for traversal # Core Pathname library used for traversal
require "pathname" require "pathname"
require 'win32/file' if File::ALT_SEPARATOR
module Middleman module Middleman
module Util module Util
@ -21,8 +19,17 @@ module Middleman
# @param [String] filename The file to check. # @param [String] filename The file to check.
# @return [Boolean] # @return [Boolean]
def self.binary?(filename) def self.binary?(filename)
s = (File.read(filename, File.stat(filename).blksize) || "").split(//) ext = File.extname(filename)
((s.size - s.grep(" ".."~").size) / s.size.to_f) > 0.30 return false if Tilt.registered?(ext.sub('.',''))
ext = ".#{ext}" unless ext.to_s[0] == ?.
mime = ::Rack::Mime.mime_type(ext, nil)
return false unless mime
return false if mime.start_with?('text/')
return false if mime.include?('xml')
return false if mime.include?('json')
return false if mime.include?('javascript')
true
end end
# The logger # The logger