mirror of
https://github.com/ruby/ruby.git
synced 2022-11-09 12:17:21 -05:00
* lib/rdoc/parser.rb: Parse files with a -*- rdoc -*- modeline
* test/rdoc/test_rdoc_parser.rb: Test for above git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@38135 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
parent
2ba9cdcee6
commit
f242cefc68
3 changed files with 67 additions and 1 deletions
|
@ -1,3 +1,8 @@
|
|||
Sun Dec 2 07:24:23 2012 Eric Hodel <drbrain@segment7.net>
|
||||
|
||||
* lib/rdoc/parser.rb: Parse files with a -*- rdoc -*- modeline
|
||||
* test/rdoc/test_rdoc_parser.rb: Test for above
|
||||
|
||||
Sun Dec 2 06:02:00 2012 KOSAKI Motohiro <kosaki.motohiro@gmail.com>
|
||||
|
||||
* gc.h (SET_MACHINE_STACK_END): add volatile for preventing
|
||||
|
|
|
@ -138,12 +138,33 @@ class RDoc::Parser
|
|||
# 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/
|
||||
if parser == RDoc::Parser::Simple and ext_name !~ /txt|rdoc/ then
|
||||
case check_modeline file_name
|
||||
when 'rdoc' then # continue
|
||||
else return nil
|
||||
end
|
||||
end
|
||||
|
||||
parser
|
||||
rescue Errno::EACCES
|
||||
end
|
||||
|
||||
##
|
||||
# Returns the file type from the modeline in +file_name+
|
||||
|
||||
def self.check_modeline file_name
|
||||
line = open file_name do |io|
|
||||
io.gets
|
||||
end
|
||||
|
||||
line =~ /-\*-(.*?)-\*-/
|
||||
|
||||
return nil unless type = $1
|
||||
|
||||
type.strip.downcase
|
||||
rescue ArgumentError # invalid byte sequence, etc.
|
||||
end
|
||||
|
||||
##
|
||||
# Finds and instantiates the correct parser for the given +file_name+ and
|
||||
# +content+.
|
||||
|
|
|
@ -75,6 +75,20 @@ class TestRDocParser < RDoc::TestCase
|
|||
end
|
||||
end
|
||||
|
||||
def test_can_parse_modeline
|
||||
readme_ext = File.join Dir.tmpdir, "README.EXT.#{$$}"
|
||||
|
||||
open readme_ext, 'w' do |io|
|
||||
io.puts "# README.EXT - -*- rdoc -*- created at: Mon Aug 7 16:45:54 JST 1995"
|
||||
io.puts
|
||||
io.puts "This document explains how to make extension libraries for Ruby."
|
||||
end
|
||||
|
||||
assert_equal RDoc::Parser::Simple, @RP.can_parse(readme_ext)
|
||||
ensure
|
||||
File.unlink readme_ext
|
||||
end
|
||||
|
||||
##
|
||||
# Selenium hides a .jar file using a .txt extension.
|
||||
|
||||
|
@ -83,6 +97,32 @@ class TestRDocParser < RDoc::TestCase
|
|||
assert_nil @RP.can_parse(hidden_zip)
|
||||
end
|
||||
|
||||
def test_check_modeline
|
||||
readme_ext = File.join Dir.tmpdir, "README.EXT.#{$$}"
|
||||
|
||||
open readme_ext, 'w' do |io|
|
||||
io.puts "# README.EXT - -*- RDoc -*- created at: Mon Aug 7 16:45:54 JST 1995"
|
||||
io.puts
|
||||
io.puts "This document explains how to make extension libraries for Ruby."
|
||||
end
|
||||
|
||||
assert_equal 'rdoc', @RP.check_modeline(readme_ext)
|
||||
ensure
|
||||
File.unlink readme_ext
|
||||
end
|
||||
|
||||
def test_check_modeline_no_modeline
|
||||
readme_ext = File.join Dir.tmpdir, "README.EXT.#{$$}"
|
||||
|
||||
open readme_ext, 'w' do |io|
|
||||
io.puts "This document explains how to make extension libraries for Ruby."
|
||||
end
|
||||
|
||||
assert_nil @RP.check_modeline(readme_ext)
|
||||
ensure
|
||||
File.unlink readme_ext
|
||||
end
|
||||
|
||||
def test_class_for_binary
|
||||
rp = @RP.dup
|
||||
|
||||
|
|
Loading…
Reference in a new issue