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

Side by Side Diff: lib/src/inline_parser.dart

Issue 1274753003: Allow resolving links that contain inline syntax. (Closed) Base URL: https://github.com/dart-lang/markdown.git@master
Patch Set: Created 5 years, 4 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
« no previous file with comments | « lib/src/html_renderer.dart ('k') | pubspec.yaml » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright (c) 2012, the Dart project authors. Please see the AUTHORS file 1 // Copyright (c) 2012, 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 library markdown.inline_parser; 5 library markdown.inline_parser;
6 6
7 import 'ast.dart'; 7 import 'ast.dart';
8 import 'document.dart'; 8 import 'document.dart';
9 import 'util.dart'; 9 import 'util.dart';
10 10
(...skipping 262 matching lines...) Expand 10 before | Expand all | Expand 10 after
273 273
274 Node createNode(InlineParser parser, Match match, TagState state) { 274 Node createNode(InlineParser parser, Match match, TagState state) {
275 // If we didn't match refLink or inlineLink, then it means there was 275 // If we didn't match refLink or inlineLink, then it means there was
276 // nothing after the first square bracket, so it isn't a normal markdown 276 // nothing after the first square bracket, so it isn't a normal markdown
277 // link at all. Instead, we allow users of the library to specify a special 277 // link at all. Instead, we allow users of the library to specify a special
278 // resolver function ([linkResolver]) that may choose to handle 278 // resolver function ([linkResolver]) that may choose to handle
279 // this. Otherwise, it's just treated as plain text. 279 // this. Otherwise, it's just treated as plain text.
280 if (isNullOrEmpty(match[1])) { 280 if (isNullOrEmpty(match[1])) {
281 if (linkResolver == null) return null; 281 if (linkResolver == null) return null;
282 282
283 // Only allow implicit links if the content is just text. 283 // Treat the contents as unparsed text even if they happen to match. This
284 // TODO(rnystrom): Do we want to relax this? 284 // way, we can handle things like [LINK_WITH_UNDERSCORES] as a link and
285 if (state.children.any((child) => child is! Text)) return null; 285 // not get confused by the emphasis.
286 // If there are multiple children, but they are all text, send the 286 var textToResolve = parser.source.substring(state.endPos, parser.pos);
287 // combined text to linkResolver.
288 var textToResolve =
289 state.children.fold('', (oldVal, child) => oldVal + child.text);
290 287
291 // See if we have a resolver that will generate a link for us. 288 // See if we have a resolver that will generate a link for us.
292 resolved = true; 289 resolved = true;
293 return linkResolver(textToResolve); 290 return linkResolver(textToResolve);
294 } else { 291 } else {
295 Link link = getLink(parser, match, state); 292 Link link = getLink(parser, match, state);
296 if (link == null) return null; 293 if (link == null) return null;
297 294
298 final Element node = new Element('a', state.children) 295 final Element node = new Element('a', state.children)
299 ..attributes["href"] = escapeHtml(link.url) 296 ..attributes["href"] = escapeHtml(link.url)
(...skipping 141 matching lines...) Expand 10 before | Expand all | Expand 10 after
441 parser.consume(endMatch[0].length); 438 parser.consume(endMatch[0].length);
442 } else { 439 } else {
443 // Didn't close correctly so revert to text. 440 // Didn't close correctly so revert to text.
444 parser.start = startPos; 441 parser.start = startPos;
445 parser.advanceBy(endMatch[0].length); 442 parser.advanceBy(endMatch[0].length);
446 } 443 }
447 444
448 return null; 445 return null;
449 } 446 }
450 } 447 }
OLDNEW
« no previous file with comments | « lib/src/html_renderer.dart ('k') | pubspec.yaml » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698