Chromium Code Reviews| OLD | NEW |
|---|---|
| (Empty) | |
| 1 // Copyright (c) 2013, the Dart project authors. Please see the AUTHORS file | |
| 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. | |
| 4 | |
| 5 library utf8_readme_validator; | |
| 6 | |
| 7 import 'dart:async'; | |
| 8 import 'dart:utf'; | |
| 9 | |
| 10 import '../../../pkg/path/lib/path.dart' as path; | |
| 11 | |
| 12 import '../entrypoint.dart'; | |
| 13 import '../io.dart'; | |
| 14 import '../utils.dart'; | |
| 15 import '../validator.dart'; | |
| 16 | |
| 17 /// A validator that validates that a package doesn't contain compiled Dartdoc | |
| 18 /// output. | |
|
Bob Nystrom
2013/01/31 19:08:29
Fix doc comment.
nweiz
2013/01/31 21:39:10
Done.
| |
| 19 class Utf8ReadmeValidator extends Validator { | |
| 20 Utf8ReadmeValidator(Entrypoint entrypoint) | |
| 21 : super(entrypoint); | |
| 22 | |
| 23 Future validate() { | |
| 24 return entrypoint.readmePath.then((readme) { | |
| 25 if (readme == null) return; | |
| 26 return readByteFile(readme).then((bytes) { | |
| 27 try { | |
| 28 // The second and third arguments here are the default values. The | |
| 29 // fourth tells [decodeUtf8] to throw an ArgumentError if `bytes` | |
| 30 // isn't valid utf-8. | |
|
Bob Nystrom
2013/01/31 19:08:29
Good God, that's a bad API.
nweiz
2013/01/31 21:39:10
It would be a little better if it used keyword arg
| |
| 31 decodeUtf8(bytes, 0, null, null); | |
| 32 } on ArgumentError catch (_) { | |
| 33 warnings.add("$readme contains invalid UTF-8.\n" | |
| 34 "This will cause it to be displayed incorrectly on " | |
| 35 "pub.dartlang.org."); | |
| 36 } | |
| 37 }); | |
| 38 }); | |
| 39 } | |
| 40 } | |
| 41 | |
| OLD | NEW |