-
Notifications
You must be signed in to change notification settings - Fork 481
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
At-ref proposal with InterSphinx compatibility #2366
Comments
The prototype for this proposal is starting to shape up nicely at https://github.com/JuliaDocs/DocInventories.jl and https://github.com/JuliaDocs/DocumenterInterLinks.jl. I will expand this issue with further points for discussion once we get the documentation for these two new packages deployed. |
The A few updates on the original proposal and further points of discussion for the next community meeting.
|
👋 I'd like to point out one technical detail that might affect your implementation of lookup of an
It's not strictly true that
In most cases, it's safe to assume that the inventory will live at |
@bskinn Thanks for checking in, and thanks for You are absolutely correct about the relative URLs; that was badly phrased in the original #2366 (comment). In DocumenterInterLinks, the URLs are indeed relative to an explicit root URL, independent of where the inventory file is read from. The |
Terrific, sounds like you had it firmly in hand already. Thanks for the kind words, very glad it was helpful, and thanks for all you & the team do! |
@goerz Apologies for the delay. But I finally found the bandwidth to go through this and #2424. And, actually, I don't have much to say -- LGTM! The immediate necessary changes to Documenter (#2424) are pretty minimal and don't change any behavior. I think I have some opinions / question marks on the link resolving side (what DocumenterInterLinks does), but the writing of the inventory side of things seems very straightforward. My two cents on the inventory files: we should probably pick one. I'm somewhat partial to the existing InterSphinx format, simply because it's some sort of an existing "standard" (even though I like TOML better as the syntax). But maybe let's discuss the pros and cons in more detail at the community call, and make a decision there. |
I would propose that we add support for external
@ref
references in a way that is fully compatible with InterSphinx (part of the Sphinx framework that is the Python-equivalent ofDocumenter
). Sphinx is used by virtually all Python projects (including Python itself), as well as some C/C++/Fortran projects.This provides a solution for #688 and #425.
It may also address #319 and #1343.
The proposal has two parts:
Every call of
makedocs
creates anobjects.inv
file in thebuild
folder that contains a mapping of all symbols in the project to a relative URL. This "inventory" file gets deployed alongside the rest of thebuild
folder. Thus, it will be downloadable as, e.g.,https://documenter.juliadocs.org/stable/objects.inv
,https://documenter.juliadocs.org/v1.1/objects.inv
, etc. See below for the format of theobjects.inv
file.A plugin,
DocumenterInterlinks
(or some other name) provides the ability for a project to link to any other documentation. For example,DocumenterCitations
might want to link to the main Julia docs and theDocumenter
docs. It would set that up as follows indocs/make.jl
:Assuming that both the Julia documentation and the Documenter documentation were built such that
https://docs.julialang.org/en/v1.9/objects.inv
andhttps://documenter.juliadocs.org/stable/objects.inv
exists, this would enable to write Markdown like the following theDocumenterCitations
documentation:When building
DocumenterCitations
' documentation, these two references would ordinarily not be resolvable. With theDocumenterInterlinks
plugin, for any reference that cannot be resolved locally, the plugin would go through all the external references ("julia"
,"Documenter"
) that were set up above, download theobjects.inv
file, and resolve to the link defined here. See below for details.In principle, all of the above would work independent of the format of the
objects.inv
file (orinventory.toml
, or any other name). I would propose though to adopt the exact format defined by InterSphinx, as detailed below. First, the format is fundamentally suitable (not surprisingly, since Sphinx and Documenter are quite similar). Second, it would allow interoperability with Sphinx: Julia projects could link to Python projects (including the Python manual). For example, the PythonPlot.jl documentation could link directly to the matplotlib documentation. I've also used Sphinx for a large Fortran project of whichQuantumControl.jl
is a continuation, and I would certainly be interested in being able to link from theQuantumControl.jl
documentation to the Fortran QDYN documentation. The other way around would work too, of course: Python projects (or anything using Sphinx) could link directly to Julia documentation.All of this is a bit gratuitous for the original problem #688 of just linking between Julia projects, but since we have to design some kind of inventory file anyway, simply adopting the InterSphinx format would give us a lot of interoperability basically "for free".
The
links
set up in the configuration may choose to link to something like astable
target, to a specific version. The former runs the risk of links breaking when a new version of the target package is released, but it's up to the user what they want. In any case, this is strictly better than the current solution of explicit URLs:Now, if Documenter 2.0 came out without a
makedocs
function, I'd no longer have to manually fix all the links. Instead, I could just change thestable
tov1
in a single location in mymake.jl
file.Lastly, I would stress that creating and deploying the
objects.inv
should be part of Documenter itself, not of theDocumenterInterlinks
plugin: We'd want to be able to link to any Documenter-based documentation, without the authors having to opt-in via a plugin. Anobjects.inv
file (in any format) would also solve other problems. For example, there has been some discussion (@pfitzseb) about VS Code indexing the docstrings of all installed packages. If these docstrings link to other parts of the documentation, anobjects.inv
could be used to resolve these links without VS Code needing to ingest every package's full documentation.Creating an Inventory File
Documenter already keeps track of all reference targets (docstrings, headers) in a project. It would simply have to dump these into an
objects.inv
file in a format compatible with InterSphinx. This format has been reverse-engineered here: https://sphobjinv.readthedocs.io/en/stable/syntax.htmlBasically, the
objects.inv
is a compressed list of plain text lines with the structure (parsed by a regex)Documenter would set the individual fields as follows:
name
: For a docstring, this would be the fully qualified name, e.g.Documenter.makedocs
. For headers, it should be the header ID, as described in "Duplicate Headers", or an auto-generated ID (the "slug") if there is no specified ID.domain
would always bejl
. This matches the choice in the Sphinx-Julia domain. While that project seems to be inactive, their choices are sensible, and we should adopt them.role
should be one oftype
,abstract
,mod
,func
for docstrings, depending on what kind of object the docstring is for. Again, this is taken from the Sphinx-Julia domain. This isn't really relevant for linking between Julia projects, since Documenter doesn't differentiate betweenbut for Sphinx projects linking to a Documenter project, this would come into play, and the relevant reStructuredText syntax would be
For headers,
role
would always beref
.priority
would be1
(not relevant to Documenter/InterSphinx)uri
would be the URL to access the resource, relative to theobjects.inv
file. For example, forname=makedocs
in Documenter'sobjects.inv
it would belib/public/#Documenter.makedocs
dispname
would be the same asname
for docstrings, and the full string of the section title for sectionsThe
DocumenterInterlinks
extensionThe extension would be opt-in, enabling a project to link out to any other Documenter or Sphinx project. At a minimum, this would handle all references that cannot be resolved locally, and go through all the external resources defined when instantiating the plugin to find one that can resolve the reference.
If we want to go further, we could also extend Documenter's
@ref
syntax to enable some features comparable to that of InterSphinx, see theexternal
role in SphinxAll of the following would be valid links in Documenter:
I'd consider these features optional, although without them, there may be a risk for "collisions" of different packages having references for the same
name
. The first one found wins, but that may make it impossible to generate certain links. Nonetheless, I would start any implementation of aDocumenterInterlinks
plugin to just handle otherwise unresolved references and add fancy new features only later.I would also be open to the possibility of all external links having to use
@extref
instead of@ref
. That is, theDocumenterInterlinks
could provide an entirely new command instead of overloading the existing@ref
.The text was updated successfully, but these errors were encountered: