A summary of data about the Ruby ecosystem.

https://github.com/ruby/rdoc

RDoc produces HTML and online documentation for Ruby projects.
https://github.com/ruby/rdoc

Keywords

documentation-tool hacktoberfest ruby

Keywords from Contributors

rubygems activerecord activejob mvc rack json-parser repl ruby-gem rspec rubocop

Last synced: about 21 hours ago
JSON representation

Repository metadata

RDoc produces HTML and online documentation for Ruby projects.

README.md

RDoc - Ruby Documentation System

Description

RDoc produces HTML and command-line documentation for Ruby projects. RDoc includes the rdoc and ri tools for generating and displaying documentation from the command-line.

Generating Documentation

Once installed, you can create documentation using the rdoc command

rdoc [options] [names...]

For an up-to-date option summary, type

rdoc --help

A typical use might be to generate documentation for a package of Ruby source (such as RDoc itself).

rdoc

This command generates documentation for all the Ruby and C source files in and below the current directory. These will be stored in a documentation tree starting in the subdirectory doc.

You can make this slightly more useful for your readers by having the index page contain the documentation for the primary file. In our case, we could type

rdoc --main README.md

You'll find information on the various formatting tricks you can use in comment blocks in the documentation this generates.

RDoc uses file extensions to determine how to process each file. File names ending .rb and .rbw are assumed to be Ruby source. Files ending .c are parsed as C files. All other files are assumed to contain just Markup-style markup (with or without leading # comment markers). If directory names are passed to RDoc, they are scanned recursively for C and Ruby source files only.

To generate documentation using rake see RDoc::Task.

To generate documentation programmatically:

require 'rdoc/rdoc'

options = RDoc::Options.new
options.files = ['a.rb', 'b.rb']
options.setup_generator 'aliki'
# see RDoc::Options

rdoc = RDoc::RDoc.new
rdoc.document options
# see RDoc::RDoc

You can specify the target files for document generation with .document file in the project root directory. .document file contains a list of file and directory names including comment lines starting with #. See https://github.com/ruby/rdoc/blob/master/.document as an example.

Writing Documentation

To write documentation for RDoc, place a comment above the class, module, method, constant, or attribute you want documented:

##
# This class represents an arbitrary shape by a series of points.
class Shape
  ##
  # Creates a new shape described by a +polyline+.
  #
  # If the +polyline+ does not end at the same point it started at the
  # first pointed is copied and placed at the end of the line.
  #
  # An ArgumentError is raised if the line crosses itself, but shapes may
  # be concave.
  def initialize polyline
    # ...
  end
end

Markup Formats

RDoc supports multiple markup formats:

Format File Extensions Default For
RDoc .rdoc .rb, .c files
Markdown .md None
RD .rd None
TomDoc N/A None

RDoc markup is currently the default format for Ruby and C files. However, we plan to retire it in favor of Markdown in the future.

Markdown support is actively being improved. Once it reaches feature parity with RDoc markup, it will become the default format.

For standalone documentation files, we recommend writing .md files instead of .rdoc files.

RD and TomDoc are legacy formats. We highly discourage their use in new projects.

Specifying Markup Format

Per-file: Add a :markup: directive at the top of a Ruby file:

# :markup: markdown

# This class uses **Markdown** for documentation.
class MyClass
end

Per-project: Create a .rdoc_options file in your project root:

markup: markdown

Command line:

rdoc --markup markdown

Feature Differences

Feature RDoc Markup Markdown
Headings = Heading # Heading
Bold *word* **word**
Italic _word_ *word*
Monospace +word+ `word`
Links {text}[url] [text](url)
Code blocks Indent 2 spaces Fenced with ```
Cross-references Automatic Automatic
Directives (:nodoc:, etc.) Supported Supported
Tables Not supported Supported
Strikethrough <del>text</del> ~~text~~
Footnotes Not supported Supported

For complete syntax documentation, see:

Directives

Comments can contain directives that tell RDoc information that it cannot otherwise discover through parsing. See RDoc::Markup@Directives to control what is or is not documented, to define method arguments or to break up methods in a class by topic. See RDoc::Parser::Ruby for directives used to teach RDoc about metaprogrammed methods.

See RDoc::Parser::C for documenting C extensions with RDoc.

Documentation Coverage

To determine how well your project is documented run rdoc -C lib to get a documentation coverage report. rdoc -C1 lib includes parameter names in the documentation coverage report.

Theme Options

RDoc ships with two built-in themes:

  • Aliki (default) - A modern, clean theme with improved navigation and search
  • Darkfish (deprecated) - The classic theme, will be removed in v8.0

To use the Darkfish theme instead of the default Aliki theme:

rdoc --format darkfish

Or in your .rdoc_options file:

generator_name: darkfish

There are also a few community-maintained themes for RDoc:

Please follow the theme's README for usage instructions.

Bugs

See CONTRIBUTING.md for information on filing a bug report. It's OK to file a bug report for anything you're having a problem with. If you can't figure out how to make RDoc produce the output you like that is probably a documentation bug.

License

RDoc is Copyright (c) 2001-2003 Dave Thomas, The Pragmatic Programmers. Portions (c) 2007-2011 Eric Hodel. Portions copyright others, see individual files and LEGAL.rdoc for details.

RDoc is free software, and may be redistributed under the terms specified in LICENSE.rdoc.

Warranty

This software is provided "as is" and without any express or implied warranties, including, without limitation, the implied warranties of merchantability and fitness for a particular purpose.


Owner metadata


GitHub Events

Total
Last Year

Committers metadata

Last synced: 8 days ago

Total Commits: 3,521
Total Committers: 139
Avg Commits per committer: 25.331
Development Distribution Score (DDS): 0.527

Commits in past year: 240
Committers in past year: 20
Avg Commits per committer in past year: 12.0
Development Distribution Score (DDS) in past year: 0.588

Name Email Commits
Eric Hodel d****n@s****t 1667
Code Ass a****a@g****m 474
SHIBATA Hiroshi h****t@r****g 256
Nobuyoshi Nakada n****u@r****g 245
Stan Lo s****2@g****m 150
dependabot[bot] 4****] 104
Designing Patterns t****s@d****m 62
Zachary Scott e@z****o 49
tomoya ishida t****n@g****m 46
Zachary Scott z****y@z****t 27
Burdette Lamar B****r@Y****m 26
Tom Copeland t****m@i****m 25
Kouhei Sutou k****u@c****m 18
Yusuke Endoh m****e@r****g 18
Vinicius Stock v****k 15
Kazuhiro NISHIYAMA zn@m****m 15
Phil Hagelberg p****l@h****g 13
Mike Dalessio m****o@g****m 12
Erik Hollensbe e****b@h****g 11
Jeremy Evans c****e@j****t 11
Benoit Daloze e****p@g****m 9
Masafumi Koba 4****s 9
Earlopain 1****n 8
Petrik p****k@d****t 8
Ryan Davis r****y@z****m 8
Yusuke Nakamura y****5@g****m 8
Marcus Stollsteimer s****r@w****e 7
toshimaru me@t****t 6
Amauri Bizerra 1****c 6
Peter Zhu p****r@p****a 6
and 109 more...

Committer domains:


Issue and Pull Request metadata

Last synced: about 1 month ago

Total issues: 112
Total pull requests: 697
Average time to close issues: about 1 year
Average time to close pull requests: about 1 month
Total issue authors: 57
Total pull request authors: 65
Average comments per issue: 1.04
Average comments per pull request: 1.09
Merged pull request: 524
Bot issues: 0
Bot pull requests: 131

Past year issues: 37
Past year pull requests: 251
Past year average time to close issues: 16 days
Past year average time to close pull requests: 4 days
Past year issue authors: 23
Past year pull request authors: 25
Past year average comments per issue: 0.76
Past year average comments per pull request: 1.26
Past year merged pull request: 174
Past year bot issues: 0
Past year bot pull requests: 48

More stats: https://issues.ecosyste.ms/repositories/lookup?url=https://github.com/ruby/rdoc

Top Issue Authors

  • st0012 (12)
  • BurdetteLamar (12)
  • okuramasafumi (7)
  • nobu (6)
  • hsbt (6)
  • gemmaro (3)
  • halostatue (3)
  • zenspider (3)
  • kou (2)
  • tompng (2)
  • headius (2)
  • ioquatix (2)
  • Earlopain (2)
  • flavorjones (2)
  • p8 (2)

Top Pull Request Authors

  • st0012 (159)
  • dependabot[bot] (131)
  • nobu (70)
  • tompng (43)
  • BurdetteLamar (32)
  • hsbt (25)
  • okuramasafumi (19)
  • p8 (18)
  • flavorjones (15)
  • vinistock (15)
  • zzak (14)
  • ybiquitous (12)
  • nevans (11)
  • sunblaze (11)
  • adam12 (8)

Top Issue Labels

  • bug (12)
  • enhancement (6)
  • Feature Request (4)
  • markup-markdown (3)
  • Bug (2)
  • Non-Bug (1)
  • documentation (1)

Top Pull Request Labels

  • dependencies (131)
  • enhancement (74)
  • bug (57)
  • github_actions (38)
  • documentation (33)
  • Documentation (7)
  • Feature Request (6)
  • experimental (2)
  • refactor (2)
  • integration_testng (2)
  • Bug (1)
  • Performance (1)

Package metadata

gem.coop: rdoc

RDoc produces HTML and command-line documentation for Ruby projects. RDoc includes the +rdoc+ and +ri+ tools for generating and displaying documentation from the command-line.

rubygems.org: rdoc

RDoc produces HTML and command-line documentation for Ruby projects. RDoc includes the +rdoc+ and +ri+ tools for generating and displaying documentation from the command-line.

proxy.golang.org: github.com/ruby/rdoc

  • Homepage:
  • Documentation: https://pkg.go.dev/github.com/ruby/rdoc#section-documentation
  • Licenses: other
  • Latest release: v7.2.0+incompatible (published 22 days ago)
  • Last Synced: 2026-02-22T20:21:06.332Z (9 days ago)
  • Versions: 70
  • Dependent Packages: 0
  • Dependent Repositories: 0
  • Rankings:
    • Forks count: 1.352%
    • Stargazers count: 2.208%
    • Average: 5.984%
    • Dependent packages count: 9.576%
    • Dependent repos count: 10.802%

Dependencies

Gemfile rubygems
  • gettext >= 0 development
  • kpeg >= 0 development
  • racc > 1.4.10 development
  • rake >= 0 development
  • rubocop >= 0 development
  • test-unit >= 0 development
rdoc.gemspec rubygems
  • psych >= 4.0.0
.github/workflows/test.yml actions
  • actions/checkout ac593985615ec2ede58e132d2e21d2b1cbd6127c composite
  • ruby/setup-ruby 319066216501fbd5e2d568f14b7d68c19fb67a5d composite
.github/workflows/gh-pages.yml actions
  • actions/checkout v3 composite
  • actions/configure-pages v3 composite
  • actions/deploy-pages v2 composite
  • actions/upload-pages-artifact v1 composite
  • ruby/setup-ruby 250fcd6a742febb1123a77a841497ccaa8b9e939 composite
.github/workflows/push_gem.yml actions
  • actions/checkout 8e8c483db84b4bee98b60c0593521ed34d9990e8 composite
  • ruby/setup-ruby eaecf785f6a34567a6d97f686bbb7bccc1ac1e5c composite
  • rubygems/release-gem 1c162a739e8b4cb21a676e97b087e8268d8fc40b composite
  • step-security/harden-runner df199fb7be9f65074067a9eb93f12bb4c5547cf2 composite
package-lock.json npm
  • 124 dependencies
.github/workflows/ruby-core.yml actions
  • actions/checkout 8e8c483db84b4bee98b60c0593521ed34d9990e8 composite
  • ruby/setup-ruby eaecf785f6a34567a6d97f686bbb7bccc1ac1e5c composite
.github/workflows/fork-preview-deploy.yml actions
  • actions/download-artifact v6 composite
  • actions/github-script v8 composite
.github/workflows/cloudflare-preview.yml actions
  • actions/checkout v6.0.1 composite
  • actions/github-script v8 composite
  • cloudflare/wrangler-action v3 composite
  • ruby/setup-ruby v1 composite
.github/workflows/lint.yml actions
  • actions/checkout v6.0.1 composite
  • ruby/setup-ruby master composite
package.json npm
  • stylelint ^16.25.0 development
  • stylelint-config-standard ^39.0.1 development
  • stylelint-value-no-unknown-custom-properties ^6.0.1 development
.github/workflows/pr-preview-check.yml actions
  • actions/github-script v8 composite
  • actions/upload-artifact v5 composite

Score: 34.95724718007144