| OLD | NEW |
| 1 // Copyright (c) 2011, the Dart project authors. Please see the AUTHORS file | 1 // Copyright (c) 2011, the Dart project authors. Please see the AUTHORS file |
| 2 // for details. All rights reserved. Use of this source code is governed by a | 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. | 3 // BSD-style license that can be found in the LICENSE file. |
| 4 | 4 |
| 5 /// Parses text in markdown format. Use this entrypoint if you want to parse | 5 /// Parses text in markdown format. Use this entrypoint if you want to parse |
| 6 /// markdown from your own Dart code. To parse markdown by running the script | 6 /// markdown from your own Dart code. To parse markdown by running the script |
| 7 /// directly from the command line, see markdown.dart. | 7 /// directly from the command line, see markdown.dart. |
| 8 #library('markdown'); | 8 #library('markdown'); |
| 9 | 9 |
| 10 #source('ast.dart'); | 10 #source('ast.dart'); |
| (...skipping 22 matching lines...) Expand all Loading... |
| 33 | 33 |
| 34 Node setImplicitLinkResolver(Node resolver(String text)) { | 34 Node setImplicitLinkResolver(Node resolver(String text)) { |
| 35 _implicitLinkResolver = resolver; | 35 _implicitLinkResolver = resolver; |
| 36 } | 36 } |
| 37 | 37 |
| 38 /// Maintains the context needed to parse a markdown document. | 38 /// Maintains the context needed to parse a markdown document. |
| 39 class Document { | 39 class Document { |
| 40 final Map<String, Link> refLinks; | 40 final Map<String, Link> refLinks; |
| 41 | 41 |
| 42 Document() | 42 Document() |
| 43 : refLinks = <Link>{}; | 43 : refLinks = <String, Link>{}; |
| 44 | 44 |
| 45 parseRefLinks(List<String> lines) { | 45 parseRefLinks(List<String> lines) { |
| 46 // This is a hideous regex. It matches: | 46 // This is a hideous regex. It matches: |
| 47 // [id]: http:foo.com "some title" | 47 // [id]: http:foo.com "some title" |
| 48 // Where there may whitespace in there, and where the title may be in | 48 // Where there may whitespace in there, and where the title may be in |
| 49 // single quotes, double quotes, or parentheses. | 49 // single quotes, double quotes, or parentheses. |
| 50 final indent = @'^[ ]{0,3}'; // Leading indentation. | 50 final indent = @'^[ ]{0,3}'; // Leading indentation. |
| 51 final id = @'\[([^\]]+)\]'; // Reference id in [brackets]. | 51 final id = @'\[([^\]]+)\]'; // Reference id in [brackets]. |
| 52 final quote = @'"[^"]+"'; // Title in "double quotes". | 52 final quote = @'"[^"]+"'; // Title in "double quotes". |
| 53 final apos = @"'[^']+'"; // Title in 'single quotes'. | 53 final apos = @"'[^']+'"; // Title in 'single quotes'. |
| (...skipping 53 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 107 /// `<em>this <strong>is</strong> a</em> <code>markdown</code>`. | 107 /// `<em>this <strong>is</strong> a</em> <code>markdown</code>`. |
| 108 List<Node> parseInline(String text) => new InlineParser(text, this).parse(); | 108 List<Node> parseInline(String text) => new InlineParser(text, this).parse(); |
| 109 } | 109 } |
| 110 | 110 |
| 111 class Link { | 111 class Link { |
| 112 final String id; | 112 final String id; |
| 113 final String url; | 113 final String url; |
| 114 final String title; | 114 final String title; |
| 115 Link(this.id, this.url, this.title); | 115 Link(this.id, this.url, this.title); |
| 116 } | 116 } |
| OLD | NEW |