Fix potential for double path on grep. Fixed broken generators check. Better regex to check for commented out lines when grep returns path name first

This commit is contained in:
Aaron Hurley 2010-08-06 03:31:23 +08:00 committed by Jeremy McAnally
parent fcf23ffecf
commit 22ce8cab63

View File

@ -221,8 +221,8 @@ module Rails
generators = Dir.glob(base_path + "vendor/plugins/**/generators/**/") generators = Dir.glob(base_path + "vendor/plugins/**/generators/**/")
unless generators.empty? unless generators.empty?
files = generators.map do |g| files = generators.reject do |g|
grep_for("def manifest", g).empty? ? g : nil grep_for("def manifest", g).empty?
end.compact end.compact
if !files.empty? if !files.empty?
@ -347,6 +347,9 @@ module Rails
def grep_for(text, where = "./", double_quote = false, perl_regex = false) def grep_for(text, where = "./", double_quote = false, perl_regex = false)
# If they're on Windows, they probably don't have grep. # If they're on Windows, they probably don't have grep.
@probably_has_grep ||= (Config::CONFIG['host_os'].downcase =~ /mswin|windows|mingw/).nil? @probably_has_grep ||= (Config::CONFIG['host_os'].downcase =~ /mswin|windows|mingw/).nil?
# protect against double root paths in Rails 3
where.gsub!(Regexp.new(base_path),'')
lines = if @probably_has_grep lines = if @probably_has_grep
find_with_grep(text, base_path + where, double_quote, perl_regex) find_with_grep(text, base_path + where, double_quote, perl_regex)
@ -355,9 +358,7 @@ module Rails
end end
# ignore comments # ignore comments
lines.gsub! /^\s*#.+$/m, "" lines.gsub /^(\/[^:]+:)?\s*#.+$/m, ""
lines
end end
# Sets a base path for finding files; mostly for testing # Sets a base path for finding files; mostly for testing
@ -374,22 +375,19 @@ module Rails
else else
"grep -r #{"-P" if perl_regex} --exclude=\*.svn\* '#{text}' #{where}" "grep -r #{"-P" if perl_regex} --exclude=\*.svn\* '#{text}' #{where}"
end end
Open3.popen3(command) do |stdin, stdout, stderr| Open3.popen3(command) do |stdin, stdout, stderr|
value = stdout.read value = stdout.read
end end
value value
end end
# Use the rak gem to grep the files (not yet implemented) # Use the rak gem to grep the files (not yet implemented)
def find_with_rak(text, where, double_quote) def find_with_rak(text, where, double_quote)
value = "" value = ""
Open3.popen3("rak --nogroup -l '#{Regexp.escape(text)}' #{where}") do |stdin, stdout, stderr| Open3.popen3("rak --nogroup -l '#{Regexp.escape(text)}' #{where}") do |stdin, stdout, stderr|
value = stdout.read value = stdout.read
end end
value value
end end
@ -405,13 +403,11 @@ module Rails
def extract_filenames_from_grep(output) def extract_filenames_from_grep(output)
return nil if output.empty? return nil if output.empty?
fnames = output.split("\n").map do |fn| output.split("\n").map do |fn|
if m = fn.match(/^(.+?):/) if m = fn.match(/^(.+?):/)
m[1] m[1]
end end
end.compact end.compact.uniq
fnames.uniq
end end
def extract_filenames_from_rak(output) def extract_filenames_from_rak(output)