-
Notifications
You must be signed in to change notification settings - Fork 118
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
Incompatibility with @macro
/@template
and @docImport
#3757
Comments
One possible solution would be to move During parsing, when the analyzer sees a Presumably that macro/template-replaced text will be considered as the element's doc comment, even in the IDE. Design decisions:
|
This would have been my naive expectation of how references in templates/macros are resolved. |
Will this enable us to improve the doc experience in the IDE by virtually inserting the |
Yes I do think this is generally desirable, as part of moving dartdoc features into analyzer. |
I would also have expected that to be the approach. The imports in the library containing the template should be the ones used to resolve the identifier.
We already do that, at least for hovers. (I don't think we currently do for code completion because of performance issues, but this change might enable that to work too.) I don't think we'd be able to "replace" the |
@kallentu found this issue.
Background
Dartdoc currently supports a snippets system (
@macro
/@template
) where a block of text from one doc comment can be re-used in other doc comments:foo.dart:
bar.dart:
When dartdoc generates the docs for this code, it builds a database of all of the
@template
names and contents, and then replaces each@macro
with the corresponding@template
text. So for theBar
class's documentation, dartdoc builds a String that looks like:After this textual replacement, we resolve comment references. In this step, dartdoc determines what code element is being referenced by
[Widget]
.Resolution tomorrow
Before we get into how dartdoc performs resolution today, I'll mention that the goal is that dartdoc will always go to the analyzer for resolution. In taking that step, we hit this problem: When resolving comment references on
class Bar
, we encounter[Widget]
, and have no idea what it could be referring to. There is noWidget
in the local file, nor in the import namespace. Even if we went to the "doc import" namespace (including elements imported via@docImport
), we don't find aWidget
.Resolution today
So how do macro/template snippets work today?
Today, dartdoc doesn't even ask analyzer what the comment references are. Dartdoc looks at each doc comment (after macro/template replacement), and parses it manually for square brackets. Dartdoc has its own determination of what a comment reference even is. Because of this custom resolution, dartdoc specifically allows for comment references in macro/template-replaced text.
Secondly, today we have the "universal scope reference" system, which allows far-flung elements to be referenced in a doc comment. If
Widget
is not found by analyzer's Scope APIs, then dartdoc seeks it out in non-imported code.A little deeper
At first glance, it seems like the second issue above could be solved with doc imports. We can add a doc import for 'package:flutter/widgets.dart'.
The first issue is trickier though: If dartdoc stops parsing comments, looking for comment references, and just asks the analyzer, then all comment references in macro/template-replaced code will be missed. Comment references are resolved by the analyzer, made available on Comment.references. This list of references will not include macro/template-replaced code.
The text was updated successfully, but these errors were encountered: