Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(100)

Side by Side Diff: utils/pub/validator/utf8_readme.dart

Issue 12090081: Add a Pub validator for READMEs that are invalid utf-8. (Closed) Base URL: https://dart.googlecode.com/svn/branches/bleeding_edge/dart
Patch Set: Actually use the validator. Created 7 years, 10 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
OLDNEW
(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
OLDNEW
« utils/pub/io.dart ('K') | « utils/pub/validator.dart ('k') | utils/tests/pub/test_pub.dart » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698