2008-01-08 05:18:41 -05:00
|
|
|
require 'rdoc/ri'
|
|
|
|
|
|
|
|
##
|
|
|
|
# Encapsulate all the strangeness to do with finding out where to find RDoc
|
|
|
|
# files
|
|
|
|
#
|
|
|
|
# We basically deal with three directories:
|
|
|
|
#
|
|
|
|
# 1. The 'system' documentation directory, which holds the documentation
|
|
|
|
# distributed with Ruby, and which is managed by the Ruby install process
|
|
|
|
# 2. The 'site' directory, which contains site-wide documentation added
|
|
|
|
# locally.
|
|
|
|
# 3. The 'user' documentation directory, stored under the user's own home
|
|
|
|
# directory.
|
|
|
|
#
|
|
|
|
# There's contention about all this, but for now:
|
|
|
|
#
|
|
|
|
# system:: $datadir/ri/<ver>/system/...
|
|
|
|
# site:: $datadir/ri/<ver>/site/...
|
|
|
|
# user:: ~/.rdoc
|
|
|
|
|
|
|
|
module RDoc::RI::Paths
|
|
|
|
|
|
|
|
#:stopdoc:
|
|
|
|
require 'rbconfig'
|
|
|
|
|
|
|
|
DOC_DIR = "doc/rdoc"
|
|
|
|
|
2008-09-24 22:43:03 -04:00
|
|
|
VERSION = RbConfig::CONFIG['ruby_version']
|
2008-01-08 05:18:41 -05:00
|
|
|
|
2009-05-23 12:07:46 -04:00
|
|
|
if VERSION > '1.9.1'
|
|
|
|
if m = /ruby/.match(RbConfig::CONFIG['RUBY_INSTALL_NAME'])
|
|
|
|
m = [m.pre_match, m.post_match]
|
|
|
|
else
|
|
|
|
m = [""] * 2
|
|
|
|
end
|
|
|
|
ri = "#{m[0]}ri#{m[1]}"
|
|
|
|
rdoc = "#{m[0]}rdoc#{m[1]}"
|
|
|
|
base = File.join(RbConfig::CONFIG['datadir'], ri, VERSION)
|
2009-03-25 22:33:16 -04:00
|
|
|
else
|
2009-05-23 12:07:46 -04:00
|
|
|
if m = /ruby/.match(RbConfig::CONFIG['RUBY_BASE_NAME'])
|
|
|
|
m = [m.pre_match, m.post_match]
|
|
|
|
else
|
|
|
|
m = [""] * 2
|
|
|
|
end
|
|
|
|
ri = "#{m[0]}ri#{m[1]}"
|
|
|
|
rdoc = "#{m[0]}rdoc#{m[1]}"
|
|
|
|
base = File.join(RbConfig::CONFIG['ridir'], VERSION)
|
2009-03-25 22:33:16 -04:00
|
|
|
end
|
2008-01-08 05:18:41 -05:00
|
|
|
SYSDIR = File.join(base, "system")
|
|
|
|
SITEDIR = File.join(base, "site")
|
2009-03-25 22:33:16 -04:00
|
|
|
HOMEDIR = (File.expand_path("~/.#{rdoc}") rescue nil)
|
2008-01-08 05:18:41 -05:00
|
|
|
|
2009-08-20 18:25:52 -04:00
|
|
|
autoload(:GEMDIRS, File.expand_path('../gemdirs.rb', __FILE__))
|
2008-01-08 05:18:41 -05:00
|
|
|
|
|
|
|
# Returns the selected documentation directories as an Array, or PATH if no
|
|
|
|
# overriding directories were given.
|
|
|
|
|
|
|
|
def self.path(use_system, use_site, use_home, use_gems, *extra_dirs)
|
|
|
|
path = raw_path(use_system, use_site, use_home, use_gems, *extra_dirs)
|
|
|
|
return path.select { |directory| File.directory? directory }
|
|
|
|
end
|
|
|
|
|
|
|
|
# Returns the selected documentation directories including nonexistent
|
|
|
|
# directories. Used to print out what paths were searched if no ri was
|
|
|
|
# found.
|
|
|
|
|
|
|
|
def self.raw_path(use_system, use_site, use_home, use_gems, *extra_dirs)
|
|
|
|
path = []
|
|
|
|
path << extra_dirs unless extra_dirs.empty?
|
|
|
|
path << SYSDIR if use_system
|
|
|
|
path << SITEDIR if use_site
|
|
|
|
path << HOMEDIR if use_home
|
|
|
|
path << GEMDIRS if use_gems
|
|
|
|
|
|
|
|
return path.flatten.compact
|
|
|
|
end
|
|
|
|
end
|