OLD | NEW |
1 // Copyright (c) 2012, the Dart project authors. Please see the AUTHORS file | 1 // Copyright (c) 2012, the Dart project authors. Please see the AUTHORS file |
2 // for details. All rights reserved. Use of this source code is governed by a | 2 // for details. All rights reserved. Use of this source code is governed by a |
3 // BSD-style license that can be found in the LICENSE file. | 3 // BSD-style license that can be found in the LICENSE file. |
4 | 4 |
5 /** | 5 /** |
6 * To generate docs for a library, run this script with the path to an | 6 * To generate docs for a library, run this script with the path to an |
7 * entrypoint .dart file, like: | 7 * entrypoint .dart file, like: |
8 * | 8 * |
9 * $ dart dartdoc.dart foo.dart | 9 * $ dart dartdoc.dart foo.dart |
10 * | 10 * |
11 * This will create a "docs" directory with the docs for your libraries. To | 11 * This will create a "docs" directory with the docs for your libraries. To |
12 * create these beautiful docs, dartdoc parses your library and every library | 12 * create these beautiful docs, dartdoc parses your library and every library |
13 * it imports (recursively). From each library, it parses all classes and | 13 * it imports (recursively). From each library, it parses all classes and |
14 * members, finds the associated doc comments and builds crosslinked docs from | 14 * members, finds the associated doc comments and builds crosslinked docs from |
15 * them. | 15 * them. |
16 */ | 16 */ |
17 library dartdoc; | 17 library dartdoc; |
18 | 18 |
19 import 'dart:async'; | 19 import 'dart:async'; |
20 import 'dart:io'; | 20 import 'dart:io'; |
21 import 'dart:uri'; | |
22 | 21 |
23 // TODO(rnystrom): Use "package:" URL (#4968). | 22 // TODO(rnystrom): Use "package:" URL (#4968). |
24 import '../lib/dartdoc.dart'; | 23 import '../lib/dartdoc.dart'; |
25 import '../lib/src/dartdoc/utils.dart'; | 24 import '../lib/src/dartdoc/utils.dart'; |
26 import 'package:args/args.dart'; | 25 import 'package:args/args.dart'; |
27 import 'package:pathos/path.dart' as path; | 26 import 'package:pathos/path.dart' as path; |
28 | 27 |
29 /** | 28 /** |
30 * Run this from the `lib/_internal/dartdoc` directory. | 29 * Run this from the `lib/_internal/dartdoc` directory. |
31 */ | 30 */ |
(...skipping 241 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
273 // If there is not, then check if the entrypoint is somewhere in a `lib` | 272 // If there is not, then check if the entrypoint is somewhere in a `lib` |
274 // directory. | 273 // directory. |
275 var parts = path.split(path.dirname(script)); | 274 var parts = path.split(path.dirname(script)); |
276 var libDir = parts.lastIndexOf('lib'); | 275 var libDir = parts.lastIndexOf('lib'); |
277 if (libDir > 0) { | 276 if (libDir > 0) { |
278 return path.join(path.joinAll(parts.take(libDir)), 'packages'); | 277 return path.join(path.joinAll(parts.take(libDir)), 'packages'); |
279 } else { | 278 } else { |
280 return null; | 279 return null; |
281 } | 280 } |
282 } | 281 } |
OLD | NEW |