| OLD | NEW |
| (Empty) |
| 1 /// This library adds `dart:io` support to the HTML5 parser. Call | |
| 2 /// [initDartIOSupport] before calling the [parse] methods and they will accept | |
| 3 /// a [RandomAccessFile] as input, in addition to the other input types. | |
| 4 library parser_console; | |
| 5 | |
| 6 import 'dart:io'; | |
| 7 import 'parser.dart'; | |
| 8 import 'src/inputstream.dart' as inputstream; | |
| 9 | |
| 10 /// Adds support to the [HtmlParser] for running on a console VM. In particular | |
| 11 /// this means it will be able to handle `dart:io` and [RandomAccessFile]s as | |
| 12 /// input to the various [parse] methods. | |
| 13 void useConsole() { | |
| 14 inputstream.consoleSupport = new _ConsoleSupport(); | |
| 15 } | |
| 16 | |
| 17 class _ConsoleSupport extends inputstream.ConsoleSupport { | |
| 18 List<int> bytesFromFile(source) { | |
| 19 if (source is! RandomAccessFile) return null; | |
| 20 return readAllBytesFromFile(source); | |
| 21 } | |
| 22 } | |
| 23 | |
| 24 // TODO(jmesserly): this should be `RandomAccessFile.readAllBytes`. | |
| 25 /// Synchronously reads all bytes from the [file]. | |
| 26 List<int> readAllBytesFromFile(RandomAccessFile file) { | |
| 27 int length = file.lengthSync(); | |
| 28 var bytes = new List<int>(length); | |
| 29 | |
| 30 int bytesRead = 0; | |
| 31 while (bytesRead < length) { | |
| 32 int read = file.readIntoSync(bytes, bytesRead, length - bytesRead); | |
| 33 if (read <= 0) { | |
| 34 // This could happen if, for example, the file was resized while | |
| 35 // we're reading. Just shrink the bytes array and move on. | |
| 36 bytes = bytes.sublist(0, bytesRead); | |
| 37 break; | |
| 38 } | |
| 39 bytesRead += read; | |
| 40 } | |
| 41 return bytes; | |
| 42 } | |
| OLD | NEW |