Skip to content

Conversation

@st0012
Copy link
Member

@st0012 st0012 commented Aug 5, 2024

Currently, rdoc doesn't support server mode, which makes both using it and developing it extremely inconvenient.

(ri --server is RI's web interface, which lets users read indexed RI documents in the browser. It does NOT run current project's RDoc documentation in server mode. To avoid confusion, I moved RDoc::Servlet to RDoc::RI::Servlet.)

So in this PR, I want to introduce a very rough server support to RDoc:

  • Can be used with rdoc --server or rdoc -s
    • It's marked as experimental for now as it's very slow (see below)
    • The port defaults to 4000 but can be assigned with --port=PORT
  • Will use a tmpdir to temporarily host the generated files so they don't override the original doc folder
  • It reparses and regenerates files on EVERY SINGLE REQUEST, which is pretty slow, but still faster than running rdoc or rake rdoc repeatedly
    • We can add smarter reparsing/regenerating support, but it will first take some refactoring as the current design doesn't account for those

@st0012 st0012 requested a review from colby-swandale August 19, 2024 11:38
@st0012 st0012 force-pushed the rdoc-server branch 2 times, most recently from 0435544 to 27a8909 Compare August 24, 2024 11:09
@st0012 st0012 mentioned this pull request Aug 27, 2024
opt.on(
"--server[=PORT]",
Integer,
"[Experimental] Run WEBrick server with generated documentation.",
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I feel we can remove the [Experiment] flag, we're not shipping something we're not expecting will work or introduce any breaking changes.

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

My interpretation of "experimental" is: the feature works but may not live up to expectation at the moment and has a slight chance to be removed if it's proven problematic.

In this case, I don't expect it to be removed later but it doesn't have the maturity to work like yard server or some static site generators' server mode.

lib/rdoc/rdoc.rb Outdated
end

# Change the output directory to tmp so it doesn't overwrite the current documentation
Dir.chdir "tmp" do
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Discussed this in Slack. Let's look at utilizing mktmpdir instead of $CWD/test

st0012 and others added 3 commits August 31, 2024 21:44
This class is used as a server for the ri command, not as a rdoc server.
So putting it under RDoc::RI will make its purpose clearer.
Co-authored-by: Colby Swandale <996377+colby-swandale@users.noreply.github.com>
@generator.update_data_from_store

# Regenerate the documentation and asserts
@generator.generate(server_mode: true)
Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Through implementing this feature I learned a lot about how data are passed around, which sometimes simply duplicate in multiple classes. And I plan to do some refactor around them.

@st0012 st0012 added this to the v6.8.0 milestone Oct 17, 2024
@st0012 st0012 modified the milestones: v6.8.0, v7.0.0 Nov 12, 2024
@faustind
Copy link

faustind commented May 17, 2025

Hi @st0012

Please tell me: Will your work here allow one to consult the standard library's documentation locally using rdoc?

ri's server mode seems to require the installation of webrick. Will rdoc --server have the same dependency?


edit

Never mind 😅 I saw the requirement on webrick in the Gemfile. And ri's server mode already allows consulting the Ruby docs locally 👍🏾

end

# Don't need to run stats for server mode
return if @options.server_port
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Can we instead do this above?

if @options.server_port
  start_server
  return
end

Comment on lines +533 to +534
trap 'INT' do server.shutdown end
trap 'TERM' do server.shutdown end
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Nit

Suggested change
trap 'INT' do server.shutdown end
trap 'TERM' do server.shutdown end
trap 'INT' { server.shutdown }
trap 'TERM' { server.shutdown }

Comment on lines +32 to +33
:darkfish => darkfish_dir,
:json_index => json_index_dir,
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Nit

Suggested change
:darkfish => darkfish_dir,
:json_index => json_index_dir,
darkfish: darkfish_dir,
json_index: json_index_dir,


res.content_type = 'text/html'
res.status = 500
res.body = <<-BODY
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Would it be possible to move this to an ERB file?

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Projects

None yet

Development

Successfully merging this pull request may close these issues.

4 participants