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 /// Validates that a package's README is valid utf-8. |
| 18 class Utf8ReadmeValidator extends Validator { |
| 19 Utf8ReadmeValidator(Entrypoint entrypoint) |
| 20 : super(entrypoint); |
| 21 |
| 22 Future validate() { |
| 23 return entrypoint.root.readmePath.then((readme) { |
| 24 if (readme == null) return; |
| 25 var bytes = readBinaryFile(readme); |
| 26 try { |
| 27 // The second and third arguments here are the default values. The |
| 28 // fourth tells [decodeUtf8] to throw an ArgumentError if `bytes` isn't |
| 29 // valid utf-8. |
| 30 decodeUtf8(bytes, 0, null, null); |
| 31 } on ArgumentError catch (_) { |
| 32 warnings.add("$readme contains invalid UTF-8.\n" |
| 33 "This will cause it to be displayed incorrectly on " |
| 34 "pub.dartlang.org."); |
| 35 } |
| 36 }); |
| 37 } |
| 38 } |
| 39 |
OLD | NEW |