<a> tags are added for the parents and members of records and return type and params of functions.
The link redirects to the reference's info file.
The directory path where each info file will be saved is now generated in the serialization phase and stored as an attribute in each Info.
Bitcode writer and reader were modified to handle the new attributes.
Details
Diff Detail
Event Timeline
General design thought: could we move the path name construction to Serialize.cpp? Essentially, move the logic that builds the path name from the namespaces and name to the serialize step (you'll have to add the OutDirectory to the ClangDocContext so that you can access it in the mapper), and then the GetInfoOuputFile() function in ClangDocMain.cpp would take the Info.Path string as a parameter and do the directory construction and whatnot.
With that, you could then also add the Path field to References, so that you wouldn't need to pass a map around in the generation phase. What do you think?
clang-tools-extra/clang-doc/HTMLGenerator.cpp | ||
---|---|---|
21 | Anonymous namespace is used for functions when LLVM Coding Guidelines tells using static for same purpose. | |
31 | You don't need to assign empty string. See readability-redundant-string-init. |
Path name generation was moved to serialization phase as @juliehockett suggested.
Empty string declaration fixed.
Removed anonymous namespaces.
clang-tools-extra/clang-doc/HTMLGenerator.cpp | ||
---|---|---|
21 | Actually, since these aren't used outside of this file, please use the static keyword instead of wrapping them in a namespace. | |
58 | Use llvm::sys::path to allow for other platforms that use a different separator. | |
clang-tools-extra/clang-doc/MDGenerator.cpp | ||
21 | Same here, just use static. | |
clang-tools-extra/clang-doc/Serialize.cpp | ||
31 ↗ | (On Diff #206317) | <root>/A/B/C.<ext> |
230 ↗ | (On Diff #206317) | Also for members |
255 ↗ | (On Diff #206317) | Also for param references, if applicable |
308–310 ↗ | (On Diff #206317) | Can we do the path construction for virtual bases as well, so they can be linked too? |
341–350 ↗ | (On Diff #206317) | Add path information to these references as well |
clang-tools-extra/unittests/clang-doc/SerializeTest.cpp | ||
145–146 ↗ | (On Diff #206317) | formatting change? |
Links added for a function's return type and parameters' types and for a record's members' type.
Fixed path generation to support multiple platforms.
clang-tools-extra/unittests/clang-doc/SerializeTest.cpp | ||
---|---|---|
145–146 ↗ | (On Diff #206317) | Yes, clang-format did that change. |
clang-tools-extra/clang-doc/HTMLGenerator.cpp | ||
---|---|---|
35 | You shouldn't need the prefixed :: | |
clang-tools-extra/clang-doc/Serialize.cpp | ||
466 ↗ | (On Diff #208463) | While you're here, can you update this error to something like "Invalid reference type for parent namespace"? |
567 ↗ | (On Diff #208463) | nit: use ++Enum.Namespace.begin() |
clang-tools-extra/clang-doc/tool/ClangDocMain.cpp | ||
231–232 | Could it add the OutDirectory here, and just store the relative path in I->Path? Since OutDirectory is constant throughout. You also wouldn't have to plumb it through all the serialize functions. |
The info path generated in serialization was the composite of the out directory and the parent namespaces. Now it's only the parent namespaces; the out directory path is appended until the directory is actually created in the doc generation phase.
clang-tools-extra/clang-doc/Serialize.cpp | ||
---|---|---|
567 ↗ | (On Diff #208463) | ++ operator cannot be used in that expression because it's not assignable. |
I've also just noticed that the YAML generator is missing from this -- could you add the Path fields to hat output as well?
clang-tools-extra/clang-doc/HTMLGenerator.cpp | ||
---|---|---|
35 | Now that the paths aren't absolute, you'll need to make this relative to the current path (something like https://github.com/llvm/llvm-project/blob/master/clang/lib/Lex/PPLexerChange.cpp#L201) |
Use relative paths for references/links within files.
Don't fill namespaces of parentInfo in serialization and path is only generated when the parent is the global namespace.
Add new fields (Path in Reference and Path in Info) to YAML output and tests.
In tag nodes with children that are not inline, two text nodes that are adjacent won't have a new line between them. Tag nodes are still rendered in their own line.
<p> A B <a>C<a> D </p>
is now rendered as
<p> A B <a>C<a> D </p>
Anonymous namespace is used for functions when LLVM Coding Guidelines tells using static for same purpose.