RDoc Project Guide for AI Agents
Project Overview
RDoc is Ruby's default documentation generation tool that produces HTML and command-line documentation for Ruby projects. It parses Ruby source code, C extensions, and markup files to generate documentation.
- Repository: https://github.com/ruby/rdoc
- Homepage: https://ruby.github.io/rdoc
- Required Ruby: See the version specified in gemspec
- Main Executables:
rdocandri
Key Development Commands
Testing
# Run all tests (default task)
bundle exec rake
# Run unit tests only (excludes RubyGems integration)
bundle exec rake normal_test
# Run RubyGems integration tests only
bundle exec rake rubygems_test
# Verify generated parser files are current (CI check)
bundle exec rake verify_generated
Test Framework: Test::Unit with test-unit gem
Test Location: test/ directory
Test Helper: test/lib/helper.rb
Linting
RuboCop (Ruby Linting)
# Check Ruby code style
bundle exec rubocop
# Auto-fix style issues
bundle exec rubocop -A
Configuration: .rubocop.yml
- Target Ruby: 3.0
- Minimal cop set (opt-in approach)
- Excludes generated parser files
Herb Linter (ERB/RHTML Files)
# Lint ERB template files
npx @herb-tools/linter "**/*.rhtml"
# Lint specific directory
npx @herb-tools/linter "lib/**/*.rhtml"
Template Location: lib/rdoc/generator/template/**/*.rhtml
CI Workflow: .github/workflows/lint.yml
Stylelint (CSS Files)
# Lint CSS files
npm run lint:css
# Auto-fix style issues
npm run lint:css -- --fix
# Lint specific file
npx stylelint "lib/rdoc/generator/template/aliki/css/rdoc.css"
Configuration: .stylelintrc.json
Features:
- Detects undefined CSS custom properties (variables)
- Detects missing
var()function for custom properties - Style and formatting checks
- Many issues auto-fixable with
--fix
Type annotations
Annotate method types using Sorbet flavored RBS in inline comments. For more information about RBS syntax, see the [documentation]).
A few examples:
# Method that receives an integer and doesn't return anything
#: (Integer) -> void
def foo(something); end
# Method that receives a string and returns an integer
#: (String) -> Integer
def (something)
123
end
# Method that doesn't accept arguments and returns a hash of symbol to string
#: () -> Hash[Symbol, String]
def
{ key: "value" }
end
# Method that accepts a block, which yields a single integer argument and returns whatever the block returns
#: [T] () { (Integer) -> T } -> T
def
yield(5)
end
Documentation Generation
# Generate documentation (creates _site directory)
bundle exec rake rdoc
# Force regenerate documentation
bundle exec rake rerdoc
# Show documentation coverage
bundle exec rake rdoc:coverage
bundle exec rake coverage
Output Directory: _site/ (GitHub Pages compatible)
Configuration: .rdoc_options
Parser Generation
RDoc uses generated parsers for Markdown and RD formats:
# Generate all parser files from sources
bundle exec rake generate
# Remove generated parser files
bundle exec rake clean
Generated Files:
lib/rdoc/rd/block_parser.rb(from.ryvia racc)lib/rdoc/rd/inline_parser.rb(from.ryvia racc)lib/rdoc/markdown.rb(from.kpegvia kpeg)lib/rdoc/markdown/literals.rb(from.kpegvia kpeg)
Note: These files are auto-generated and should not be edited manually. Always regenerate after modifying source .ry or .kpeg files.
Building and Releasing
# Build gem package
bundle exec rake build
# Install gem locally
bundle exec rake install
# Create tag and push to rubygems.org
bundle exec rake release
Project Structure
lib/rdoc/
├── rdoc.rb # Main entry point (RDoc::RDoc class)
├── version.rb # Version constant
├── task.rb # Rake task integration
├── parser/ # Source code parsers (Ruby, C, Markdown, RD)
│ ├── ruby.rb # Ruby code parser
│ ├── c.rb # C extension parser
│ ├── prism_ruby.rb # Prism-based Ruby parser
│ └── ...
├── generator/ # Documentation generators
│ ├── aliki.rb # HTML generator (default theme)
│ ├── darkfish.rb # HTML generator (deprecated, will be removed in v8.0)
│ ├── markup.rb # Markup format generator
│ ├── ri.rb # RI command generator
│ └── template/ # ERB templates (.rhtml files)
│ ├── aliki/ # Aliki theme (default)
│ └── darkfish/ # Darkfish theme (deprecated)
├── markup/ # Markup parsing and formatting
├── code_object/ # AST objects for documented items
├── markdown/ # Markdown parsing
├── rd/ # RD format parsing
└── ri/ # RI (Ruby Info) tool
test/ # 79 test files
├── lib/helper.rb # Test helpers
└── rdoc/ # Main test directory
exe/
├── rdoc # rdoc command executable
└── ri # ri command executable
Important Files
Configuration
.rubocop.yml- RuboCop configuration (main).generated_files_rubocop.yml- RuboCop config for generated files.rdoc_options- RDoc generation options.document- File list for documentationRakefile- Task definitionslib/rdoc/task.rb- Task definitions provided by RDocrdoc.gemspec- Gem specificationGemfile- Development dependencies
CI/CD
.github/workflows/test.yml- Test execution across Ruby versions/platforms.github/workflows/lint.yml- Linting (RuboCop + Herb).github/workflows/push_gem.yml- Gem publishing
Documentation
README.md- Basic usage guideExampleRDoc.rdoc- RDoc markup examplesdoc/rdoc/markup_reference.rb- RDoc markup referencesExampleMarkdown.md- Markdown examples
Architecture Notes
Pluggable System
- Parsers: Ruby, C, Markdown, RD, Prism-based Ruby (experimental)
- Generators: HTML/Aliki (default), HTML/Darkfish (deprecated), RI, POT (gettext), JSON, Markup
Common Workflows
Do NOT commit anything. Ask the developer to review the changes after tasks are finished.
NEVER pushes code to any repositories.
Making Code Changes
Use Red, Green, Refactor approach:
- Ensure Ruby version: Verify you're using Ruby 3.3.0+ (prepend
chruby <ruby version>if needed) - Red - Write failing tests: Add tests that fail for the new behavior
- Verify failure: Run
bundle exec raketo confirm tests fail as expected - Green - Make it work: Implement the minimum code to make tests pass
- Refactor - Make it right: Improve code quality while keeping tests green
- Run
bundle exec rakeafter each refactor to ensure tests still pass - Iterate on steps 4-5 as needed
- Run
- Lint your changes:
- Ruby code:
bundle exec rubocop -A(auto-fix when possible) - ERB templates:
npx @herb-tools/linter "**/*.rhtml"(if modified) - CSS files:
npm run lint:css -- --fix(if modified)
- Ruby code:
Modifying Parsers
- Edit source files (
.ryor.kpeg) - Regenerate:
bundle exec rake generate - Verify:
bundle exec rake verify_generated - Run tests:
bundle exec rake
Updating Documentation
- Modify documentation comments in source
- Regenerate:
bundle exec rake rerdoc - Check output in
_site/directory - Check coverage:
bundle exec rake coverage
Modifying Themes/Styling
When making changes to theme CSS or templates (e.g., Darkfish or Aliki themes):
- Generate documentation: Run
bundle exec rake rerdocto create baseline - Start HTTP server: Run
cd _site && python3 -m http.server 8000(use different port if 8000 is in use) - Investigate with sub-agent: Use Task tool to launch a general-purpose agent to inspect the documentation with Browser MCP
- The agent will connect browser to
http://localhost:8000, navigate pages, and take screenshots - Agent reports findings back (styling issues, layout problems, etc.)
- This saves context in main conversation
- The agent will connect browser to
- Make changes: Edit files in
lib/rdoc/generator/template/<theme>/as needed - Regenerate: Run
bundle exec rake rerdocto rebuild documentation with changes - Verify with sub-agent: Use Task tool again to launch agent that uses Browser MCP to verify fixes
- Agent takes screenshots and compares to original issues
- Agent reports back whether issues are resolved
- Lint changes (if modified):
- ERB templates:
npx @herb-tools/linter "lib/rdoc/generator/template/**/*.rhtml" - CSS files:
npm run lint:css -- --fix
- ERB templates:
- Stop server: Kill the HTTP server process when done
Tip: Keep HTTP server running during iteration. Just regenerate with bundle exec rake rerdoc between changes.
Notes for AI Agents
- Always run tests after making changes:
bundle exec rake - Lint your changes:
- RuboCop for Ruby:
bundle exec rubocop -A - Herb for ERB templates:
npx @herb-tools/linter "**/*.rhtml" - Stylelint for CSS:
npm run lint:css -- --fix
- RuboCop for Ruby:
- Regenerate parsers if you modify
.ryor.kpegfiles - Use
rake rerdocto regenerate documentation (not justrdoc) - Verify generated files with
rake verify_generated - Don't edit generated files directly (in
lib/rdoc/markdown/andlib/rdoc/rd/)
Browser MCP for Testing Generated Documentation
Browser MCP allows AI agents to visually inspect and interact with the generated HTML documentation. This is useful for verifying CSS styling, layout issues, and overall appearance.
Repository: https://github.com/BrowserMCP/mcp
Setup
If Browser MCP is not already installed, users should:
- Install the BrowserMCP Chrome extension from the Chrome Web Store
- Run:
claude mcp add --scope user browsermcp npx @browsermcp/mcp@latest - Connect a browser tab by clicking the BrowserMCP extension icon and selecting "Connect"
Testing Generated Documentation
To test the generated documentation with Browser MCP:
# Generate documentation
bundle exec rake rerdoc
# Start a simple HTTP server in the _site directory (use an available port)
cd _site && python3 -m http.server 8000
If port 8000 is already in use, try another port (e.g., python3 -m http.server 9000).
Then navigate to the appropriate URL (e.g., http://localhost:8000) in your connected browser tab and ask Claude to use browser MCP tools (e.g., "use browser MCP to navigate to http://localhost:8000 and take a screenshot").
Note: Browser MCP requires a proper HTTP server (not file:// URLs) for full functionality. The generated documentation must be served via HTTP/HTTPS.