Bug #6392 ยป 0001-rdoc-extension-option-fix.patch
lib/rdoc/parser.rb | ||
---|---|---|
old_ext = old_ext.sub(/^\.(.*)/, '\1')
|
||
new_ext = new_ext.sub(/^\.(.*)/, '\1')
|
||
parser = can_parse "xxx.#{old_ext}"
|
||
parser = can_parse_by_name "xxx.#{old_ext}"
|
||
return false unless parser
|
||
RDoc::Parser.parsers.unshift [/\.#{new_ext}$/, parser]
|
||
... | ... | |
zip_signature == "PK\x03\x04" or
|
||
zip_signature == "PK\x05\x06" or
|
||
zip_signature == "PK\x07\x08"
|
||
rescue
|
||
false
|
||
end
|
||
##
|
||
# Return a parser that can handle a particular extension
|
||
def self.can_parse(file_name)
|
||
parser = RDoc::Parser.parsers.find { |regexp,| regexp =~ file_name }.last
|
||
parser = can_parse_by_name(file_name)
|
||
# HACK Selenium hides a jar file using a .txt extension
|
||
return if parser == RDoc::Parser::Simple and zip? file_name
|
||
parser
|
||
end
|
||
def self.can_parse_by_name(file_name)
|
||
pattern, parser = RDoc::Parser.parsers.find { |regexp,| regexp =~ file_name }
|
||
# The default parser must not parse binary files
|
||
ext_name = File.extname file_name
|
||
return parser if ext_name.empty?
|
||
return if parser == RDoc::Parser::Simple and ext_name !~ /txt|rdoc/
|
||
return if parser == RDoc::Parser::Simple and ext_name !~ /txt|rdoc/ and file_name[pattern].empty?
|
||
parser
|
||
end
|