Don't look for frontmatter on binary files. Fixes #728

This commit is contained in:
Thomas Reynolds 2013-01-11 16:58:02 -08:00
parent 7231f9dfe2
commit a76b02a55b
3 changed files with 29 additions and 15 deletions

View file

@ -130,8 +130,11 @@ module Middleman::CoreExtensions
# @return [Array<Thor::CoreExt::HashWithIndifferentAccess, String>] # @return [Array<Thor::CoreExt::HashWithIndifferentAccess, String>]
def frontmatter_and_content(path) def frontmatter_and_content(path)
full_path = File.expand_path(File.join(@app.source_dir, path)) full_path = File.expand_path(File.join(@app.source_dir, path))
content = File.read(full_path)
data = {} data = {}
content = nil
if !::Middleman::Util.binary?(full_path)
content = File.read(full_path)
begin begin
if content =~ /\A.*coding:/ if content =~ /\A.*coding:/
@ -148,6 +151,7 @@ module Middleman::CoreExtensions
rescue => e rescue => e
# Probably a binary file, move on # Probably a binary file, move on
end end
end
[data, content] [data, content]
end end

View file

@ -151,8 +151,7 @@ module Middleman
# #
# @retrun [Boolean] # @retrun [Boolean]
def binary? def binary?
s = (File.read(source_file, File.stat(source_file).blksize) || "").split(//) ::Middleman::Util.binary?(source_file)
((s.size - s.grep(" ".."~").size) / s.size.to_f) > 0.30
end end
end end
end end

View file

@ -10,10 +10,21 @@ 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
# Whether the source file is binary.
#
# @param [String] filename The file to check.
# @return [Boolean]
def self.binary?(filename)
s = (File.read(filename, File.stat(filename).blksize) || "").split(//)
((s.size - s.grep(" ".."~").size) / s.size.to_f) > 0.30
end
# The logger # The logger
# #
# @return [Middleman::Logger] The logger # @return [Middleman::Logger] The logger