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 'package:pathos/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 new Future.sync(() { | |
24 var readme = entrypoint.root.readmePath; | |
25 if (readme == null) return; | |
26 var bytes = readBinaryFile(readme); | |
27 try { | |
28 // The second and third arguments here are the default values. The | |
29 // fourth tells [decodeUtf8] to throw an ArgumentError if `bytes` isn't | |
30 // valid utf-8. | |
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 | |
OLD | NEW |