2003-12-16 00:44:25 -05:00
|
|
|
module 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:
|
|
|
|
#
|
2003-12-18 16:08:25 -05:00
|
|
|
# system:: $datadir/ri/<ver>/system/...
|
|
|
|
# site:: $datadir/ri/<ver>/site/...
|
2003-12-16 00:44:25 -05:00
|
|
|
# user:: ~/.rdoc
|
|
|
|
|
|
|
|
module Paths
|
|
|
|
|
|
|
|
#:stopdoc:
|
|
|
|
require 'rbconfig'
|
|
|
|
|
|
|
|
DOC_DIR = "doc/rdoc"
|
|
|
|
|
2003-12-18 16:08:25 -05:00
|
|
|
version = Config::CONFIG['ruby_version']
|
|
|
|
|
|
|
|
base = File.join(Config::CONFIG['datadir'], "ri", version)
|
2004-01-12 11:10:52 -05:00
|
|
|
|
|
|
|
if ENV["DESTDIR"]
|
|
|
|
SYSDIR = File.join(ENV["DESTDIR"], base, "system")
|
|
|
|
else
|
|
|
|
SYSDIR = File.join(base, "system")
|
|
|
|
end
|
|
|
|
|
2003-12-18 16:08:25 -05:00
|
|
|
SITEDIR = File.join(base, "site")
|
2003-12-16 00:44:25 -05:00
|
|
|
homedir = ENV['HOME'] || ENV['USERPROFILE'] || ENV['HOMEPATH']
|
|
|
|
|
|
|
|
if homedir
|
|
|
|
HOMEDIR = File.join(homedir, ".rdoc")
|
|
|
|
else
|
|
|
|
HOMEDIR = nil
|
|
|
|
end
|
|
|
|
|
2003-12-18 16:08:25 -05:00
|
|
|
# This is the search path for 'ri'
|
2003-12-16 00:44:25 -05:00
|
|
|
PATH = [ SYSDIR, SITEDIR, HOMEDIR ].find_all {|p| p && File.directory?(p)}
|
|
|
|
end
|
|
|
|
end
|