Flutter Engine
The Flutter Engine
|
A tool to validate the documentation comments for the dart:
libraries.
To validate all the dart:
libraries, run:
Or to validate an individual library (async, collection, js_util, ...), run either of:
The tool should be run from the root of the sdk repository.
This tool will walk all DartDoc API docs looking for code samples in doc comments. It will analyze any code sample in a dart
code fence. For example:
`
dart ///
dart /// print('hello world!'); /// ```</blockquote>By default, an import for that library is added to the sample being analyzed, e.g., `import 'dart:async";`.### Excluding code samples from analysisIn order to exclude a code sample from analysis, change it to a plain code fence style:<blockquote>‍````dart/// ```/// print("I'm not analyzed :(");/// ```
The analysis tool can inject the code sample into a template before analyzing the sample. This allows the author to focus on the important parts of the API being documented with less boilerplate in the generated docs.
The template includes an automatic import of the library containing the example, so an example in, say, the documentation of StreamController.add
would have dart:async
imported automatically.
The tool will try and automatically detect the right template to use based on code patterns within the sample itself. In order to explicitly indicate which template to use, you can specify it as part of the code fence line. For example:
dart ///
dart template:main /// print('hello world ${Timer()}'); /// ```</blockquote>The current templates are:- `none`: Do not wrap the code sample in any template, including no imports.- `top`: The code sample is top level code, preceded only by imports.- `main`: The code sample is one or more statements in a simple asynchronous `main()` function.- `expression`: The code sample is an expression within a simple asynchronous `main()` method.For most code samples, the auto-detection code will select `template:main` or`template:expression`.If the example contains any `library` declarations, the template becomes `none`.### Specifying additional importsIf your example contains any `library`, the default import of the current library is omitted. To avoid that, you can declare extra automatic imports in the code fence like:<blockquote>‍````dart/// ```dart import:async/// print('hello world ${Timer()}');///</blockquote>Multiple imports can be specified like this if desired, e.g., "```` ```dart import:async import:convert````".Does not work if combined with `template:none`, whether the `none` template is specified explicitly or auto-detected.### Splitting examplesSome examples may be split into separate code blocks, but should be seenas continuing the same running example.If the following code blocks are marked as `continued` as shown below, theyare included into the previous code block instead of being treated as a newexample.<blockquote>‍````dart/// ```dart/// var list = [1, 2, 3];/// ```/// And then you can also do the following:/// ```dart continued/// list.forEach(print);/// ```
A continued
code block cannot have any other flags in the fence.
You can declare code that should be included in the analysis but not shown in the API docs by adding a comment "// Examples can assume:" to the file (usually at the top of the file, after the imports), following by one or more commented-out lines of code. That code is included verbatim in the analysis, at top-level after the automatic imports. Does not work with template:none
.
For example: