2017-11-27 13:45:24 +03:00
|
|
|
# frozen_string_literal: true
|
2008-04-26 20:14:19 +04:00
|
|
|
$DEBUG_RDOC = nil
|
|
|
|
|
2012-11-27 08:28:14 +04:00
|
|
|
# :main: README.rdoc
|
2010-04-01 11:45:16 +04:00
|
|
|
|
2008-01-08 12:07:31 +03:00
|
|
|
##
|
2012-11-27 08:28:14 +04:00
|
|
|
# RDoc produces documentation for Ruby source files by parsing the source and
|
|
|
|
# extracting the definition for classes, modules, methods, includes and
|
|
|
|
# requires. It associates these with optional documentation contained in an
|
|
|
|
# immediately preceding comment block then renders the result using an output
|
|
|
|
# formatter.
|
2011-05-14 04:39:16 +04:00
|
|
|
#
|
2012-11-27 08:28:14 +04:00
|
|
|
# For a simple introduction to writing or generating documentation using RDoc
|
|
|
|
# see the README.
|
2008-07-18 04:46:16 +04:00
|
|
|
#
|
2008-04-26 20:14:19 +04:00
|
|
|
# == Roadmap
|
2008-07-18 04:46:16 +04:00
|
|
|
#
|
2013-09-19 03:33:36 +04:00
|
|
|
# If you think you found a bug in RDoc see CONTRIBUTING@Bugs
|
2008-07-18 04:46:16 +04:00
|
|
|
#
|
2012-11-27 08:28:14 +04:00
|
|
|
# If you want to use RDoc to create documentation for your Ruby source files,
|
|
|
|
# see RDoc::Markup and refer to <tt>rdoc --help</tt> for command line usage.
|
2008-07-18 04:46:16 +04:00
|
|
|
#
|
2012-11-27 08:28:14 +04:00
|
|
|
# If you want to set the default markup format see
|
|
|
|
# RDoc::Markup@Supported+Formats
|
2008-07-18 04:46:16 +04:00
|
|
|
#
|
2012-11-27 08:28:14 +04:00
|
|
|
# If you want to store rdoc configuration in your gem (such as the default
|
|
|
|
# markup format) see RDoc::Options@Saved+Options
|
2010-04-01 11:45:16 +04:00
|
|
|
#
|
2012-11-27 08:28:14 +04:00
|
|
|
# If you want to write documentation for Ruby files see RDoc::Parser::Ruby
|
2008-07-18 04:46:16 +04:00
|
|
|
#
|
2012-11-27 08:28:14 +04:00
|
|
|
# If you want to write documentation for extensions written in C see
|
|
|
|
# RDoc::Parser::C
|
2008-07-18 04:46:16 +04:00
|
|
|
#
|
2012-11-27 08:28:14 +04:00
|
|
|
# If you want to generate documentation using <tt>rake</tt> see RDoc::Task.
|
2008-07-18 04:46:16 +04:00
|
|
|
#
|
2012-11-27 08:28:14 +04:00
|
|
|
# If you want to drive RDoc programmatically, see RDoc::RDoc.
|
2008-07-18 04:46:16 +04:00
|
|
|
#
|
2012-11-27 08:28:14 +04:00
|
|
|
# If you want to use the library to format text blocks into HTML or other
|
|
|
|
# formats, look at RDoc::Markup.
|
2008-07-18 04:46:16 +04:00
|
|
|
#
|
2012-11-27 08:28:14 +04:00
|
|
|
# If you want to make an RDoc plugin such as a generator or directive handler
|
|
|
|
# see RDoc::RDoc.
|
2008-07-18 04:46:16 +04:00
|
|
|
#
|
2012-11-27 08:28:14 +04:00
|
|
|
# If you want to write your own output generator see RDoc::Generator.
|
2008-07-18 04:46:16 +04:00
|
|
|
#
|
2013-09-19 03:33:36 +04:00
|
|
|
# If you want an overview of how RDoc works see CONTRIBUTING
|
2008-07-18 04:46:16 +04:00
|
|
|
#
|
2012-11-27 08:28:14 +04:00
|
|
|
# == Credits
|
2008-07-18 04:46:16 +04:00
|
|
|
#
|
2010-12-20 06:22:49 +03:00
|
|
|
# RDoc is currently being maintained by Eric Hodel <drbrain@segment7.net>.
|
2008-04-26 20:14:19 +04:00
|
|
|
#
|
|
|
|
# Dave Thomas <dave@pragmaticprogrammer.com> is the original author of RDoc.
|
2008-07-18 04:46:16 +04:00
|
|
|
#
|
2008-04-26 20:14:19 +04:00
|
|
|
# * The Ruby parser in rdoc/parse.rb is based heavily on the outstanding
|
|
|
|
# work of Keiju ISHITSUKA of Nippon Rational Inc, who produced the Ruby
|
|
|
|
# parser for irb and the rtags package.
|
2008-01-08 12:07:31 +03:00
|
|
|
|
|
|
|
module RDoc
|
|
|
|
|
2008-01-14 06:34:05 +03:00
|
|
|
##
|
|
|
|
# Exception thrown by any rdoc error.
|
|
|
|
|
|
|
|
class Error < RuntimeError; end
|
|
|
|
|
2022-02-10 05:31:06 +03:00
|
|
|
require_relative 'rdoc/version'
|
2010-12-20 06:22:49 +03:00
|
|
|
|
|
|
|
##
|
|
|
|
# Method visibilities
|
|
|
|
|
|
|
|
VISIBILITIES = [:public, :protected, :private]
|
2008-01-08 12:07:31 +03:00
|
|
|
|
|
|
|
##
|
|
|
|
# Name of the dotfile that contains the description of files to be processed
|
|
|
|
# in the current directory
|
|
|
|
|
|
|
|
DOT_DOC_FILENAME = ".document"
|
|
|
|
|
2010-04-01 11:45:16 +04:00
|
|
|
##
|
|
|
|
# General RDoc modifiers
|
|
|
|
|
2008-01-14 06:34:05 +03:00
|
|
|
GENERAL_MODIFIERS = %w[nodoc].freeze
|
|
|
|
|
2010-04-01 11:45:16 +04:00
|
|
|
##
|
|
|
|
# RDoc modifiers for classes
|
|
|
|
|
2008-01-14 06:34:05 +03:00
|
|
|
CLASS_MODIFIERS = GENERAL_MODIFIERS
|
|
|
|
|
2010-04-01 11:45:16 +04:00
|
|
|
##
|
|
|
|
# RDoc modifiers for attributes
|
|
|
|
|
|
|
|
ATTR_MODIFIERS = GENERAL_MODIFIERS
|
|
|
|
|
|
|
|
##
|
|
|
|
# RDoc modifiers for constants
|
2008-01-14 06:34:05 +03:00
|
|
|
|
|
|
|
CONSTANT_MODIFIERS = GENERAL_MODIFIERS
|
|
|
|
|
2010-04-01 11:45:16 +04:00
|
|
|
##
|
|
|
|
# RDoc modifiers for methods
|
|
|
|
|
2008-01-14 06:34:05 +03:00
|
|
|
METHOD_MODIFIERS = GENERAL_MODIFIERS +
|
|
|
|
%w[arg args yield yields notnew not-new not_new doc]
|
|
|
|
|
2012-11-27 08:28:14 +04:00
|
|
|
##
|
|
|
|
# Loads the best available YAML library.
|
|
|
|
|
|
|
|
def self.load_yaml
|
|
|
|
begin
|
|
|
|
gem 'psych'
|
2015-12-22 15:08:13 +03:00
|
|
|
rescue NameError => e # --disable-gems
|
|
|
|
raise unless e.name == :gem
|
2012-11-27 08:28:14 +04:00
|
|
|
rescue Gem::LoadError
|
|
|
|
end
|
|
|
|
|
|
|
|
begin
|
|
|
|
require 'psych'
|
|
|
|
rescue ::LoadError
|
|
|
|
ensure
|
|
|
|
require 'yaml'
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2023-12-15 13:35:16 +03:00
|
|
|
##
|
2023-12-25 07:43:11 +03:00
|
|
|
# Searches and returns the directory for settings.
|
2023-12-15 13:35:16 +03:00
|
|
|
#
|
|
|
|
# 1. <tt>$HOME/.rdoc</tt> directory, if it exists.
|
|
|
|
# 2. The +rdoc+ directory under the path specified by the
|
|
|
|
# +XDG_DATA_HOME+ environment variable, if it is set.
|
|
|
|
# 3. <tt>$HOME/.local/share/rdoc</tt> directory.
|
|
|
|
#
|
|
|
|
# Other than the home directory, the containing directory will be
|
|
|
|
# created automatically.
|
|
|
|
|
2020-04-23 13:16:06 +03:00
|
|
|
def self.home
|
|
|
|
rdoc_dir = begin
|
|
|
|
File.expand_path('~/.rdoc')
|
|
|
|
rescue ArgumentError
|
|
|
|
end
|
|
|
|
|
|
|
|
if File.directory?(rdoc_dir)
|
|
|
|
rdoc_dir
|
|
|
|
else
|
2023-12-15 13:26:46 +03:00
|
|
|
require 'fileutils'
|
2020-04-23 15:11:21 +03:00
|
|
|
begin
|
|
|
|
# XDG
|
|
|
|
xdg_data_home = ENV["XDG_DATA_HOME"] || File.join(File.expand_path("~"), '.local', 'share')
|
|
|
|
unless File.exist?(xdg_data_home)
|
|
|
|
FileUtils.mkdir_p xdg_data_home
|
|
|
|
end
|
|
|
|
File.join xdg_data_home, "rdoc"
|
|
|
|
rescue Errno::EACCES
|
2020-04-23 13:16:06 +03:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2022-02-10 05:31:06 +03:00
|
|
|
autoload :RDoc, "#{__dir__}/rdoc/rdoc"
|
2012-11-27 08:28:14 +04:00
|
|
|
|
2022-02-10 05:31:06 +03:00
|
|
|
autoload :CrossReference, "#{__dir__}/rdoc/cross_reference"
|
|
|
|
autoload :ERBIO, "#{__dir__}/rdoc/erbio"
|
|
|
|
autoload :ERBPartial, "#{__dir__}/rdoc/erb_partial"
|
|
|
|
autoload :Encoding, "#{__dir__}/rdoc/encoding"
|
|
|
|
autoload :Generator, "#{__dir__}/rdoc/generator"
|
|
|
|
autoload :Options, "#{__dir__}/rdoc/options"
|
|
|
|
autoload :Parser, "#{__dir__}/rdoc/parser"
|
|
|
|
autoload :Servlet, "#{__dir__}/rdoc/servlet"
|
|
|
|
autoload :RI, "#{__dir__}/rdoc/ri"
|
|
|
|
autoload :Stats, "#{__dir__}/rdoc/stats"
|
|
|
|
autoload :Store, "#{__dir__}/rdoc/store"
|
|
|
|
autoload :Task, "#{__dir__}/rdoc/task"
|
|
|
|
autoload :Text, "#{__dir__}/rdoc/text"
|
2012-11-27 08:28:14 +04:00
|
|
|
|
2022-02-10 05:31:06 +03:00
|
|
|
autoload :Markdown, "#{__dir__}/rdoc/markdown"
|
|
|
|
autoload :Markup, "#{__dir__}/rdoc/markup"
|
|
|
|
autoload :RD, "#{__dir__}/rdoc/rd"
|
|
|
|
autoload :TomDoc, "#{__dir__}/rdoc/tom_doc"
|
2012-11-27 08:28:14 +04:00
|
|
|
|
2022-02-10 05:31:06 +03:00
|
|
|
autoload :KNOWN_CLASSES, "#{__dir__}/rdoc/known_classes"
|
2012-11-27 08:28:14 +04:00
|
|
|
|
2022-02-10 05:31:06 +03:00
|
|
|
autoload :TokenStream, "#{__dir__}/rdoc/token_stream"
|
2012-11-27 08:28:14 +04:00
|
|
|
|
2022-02-10 05:31:06 +03:00
|
|
|
autoload :Comment, "#{__dir__}/rdoc/comment"
|
2012-11-27 08:28:14 +04:00
|
|
|
|
2022-02-10 05:31:06 +03:00
|
|
|
require_relative 'rdoc/i18n'
|
2014-09-05 05:41:25 +04:00
|
|
|
|
2012-11-27 08:28:14 +04:00
|
|
|
# code objects
|
|
|
|
#
|
|
|
|
# We represent the various high-level code constructs that appear in Ruby
|
|
|
|
# programs: classes, modules, methods, and so on.
|
2022-02-10 05:31:06 +03:00
|
|
|
autoload :CodeObject, "#{__dir__}/rdoc/code_object"
|
|
|
|
|
|
|
|
autoload :Context, "#{__dir__}/rdoc/context"
|
|
|
|
autoload :TopLevel, "#{__dir__}/rdoc/top_level"
|
|
|
|
|
|
|
|
autoload :AnonClass, "#{__dir__}/rdoc/anon_class"
|
|
|
|
autoload :ClassModule, "#{__dir__}/rdoc/class_module"
|
|
|
|
autoload :NormalClass, "#{__dir__}/rdoc/normal_class"
|
|
|
|
autoload :NormalModule, "#{__dir__}/rdoc/normal_module"
|
|
|
|
autoload :SingleClass, "#{__dir__}/rdoc/single_class"
|
|
|
|
|
|
|
|
autoload :Alias, "#{__dir__}/rdoc/alias"
|
|
|
|
autoload :AnyMethod, "#{__dir__}/rdoc/any_method"
|
|
|
|
autoload :MethodAttr, "#{__dir__}/rdoc/method_attr"
|
|
|
|
autoload :GhostMethod, "#{__dir__}/rdoc/ghost_method"
|
|
|
|
autoload :MetaMethod, "#{__dir__}/rdoc/meta_method"
|
|
|
|
autoload :Attr, "#{__dir__}/rdoc/attr"
|
|
|
|
|
|
|
|
autoload :Constant, "#{__dir__}/rdoc/constant"
|
|
|
|
autoload :Mixin, "#{__dir__}/rdoc/mixin"
|
|
|
|
autoload :Include, "#{__dir__}/rdoc/include"
|
|
|
|
autoload :Extend, "#{__dir__}/rdoc/extend"
|
|
|
|
autoload :Require, "#{__dir__}/rdoc/require"
|
2012-11-27 08:28:14 +04:00
|
|
|
|
2008-01-08 12:07:31 +03:00
|
|
|
end
|