| OLD | NEW |
| (Empty) |
| 1 // Copyright (c) 2014, 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 import 'package:barback/barback.dart'; | |
| 6 import 'package:markdown/markdown.dart'; | |
| 7 | |
| 8 import 'dart:async'; | |
| 9 | |
| 10 class ConvertMarkdown extends Transformer { | |
| 11 | |
| 12 // A constructor named "asPlugin" is required. It can be empty, but | |
| 13 // it must be present. It is how pub determines that you want this | |
| 14 // class to be publicly available as a loadable transformer plugin. | |
| 15 ConvertMarkdown.asPlugin(); | |
| 16 | |
| 17 // Any markdown file with one of the following extensions is | |
| 18 // converted to HTML. | |
| 19 String get allowedExtensions => ".md .markdown .mdown"; | |
| 20 | |
| 21 Future apply(Transform transform) { | |
| 22 return transform.primaryInput.readAsString().then((content) { | |
| 23 | |
| 24 // The extension of the output is changed to ".html". | |
| 25 var id = transform.primaryInput.id.changeExtension(".html"); | |
| 26 | |
| 27 String newContent = "<html><body>" | |
| 28 + markdownToHtml(content) | |
| 29 + "</body></html>"; | |
| 30 transform.addOutput(new Asset.fromString(id, newContent)); | |
| 31 }); | |
| 32 } | |
| 33 } | |
| OLD | NEW |