From 3d215b3c8e6238147a1fc7906076f7714fa4d39c Mon Sep 17 00:00:00 2001 From: mitchell Date: Sun, 2 Jun 2019 17:59:16 -0400 Subject: lexlua: Updated Markdown lexer. Thanks to Alexander Misel. --- lexlua/markdown.lua | 30 ++++++++++++++++++++++++------ 1 file changed, 24 insertions(+), 6 deletions(-) (limited to 'lexlua/markdown.lua') diff --git a/lexlua/markdown.lua b/lexlua/markdown.lua index d9f69d5f5..c6236c226 100644 --- a/lexlua/markdown.lua +++ b/lexlua/markdown.lua @@ -88,13 +88,31 @@ lex:add_rule('link', (lexer.any - lexer.space)^1)) lex:add_style('link', 'underlined') -lex:add_rule('strong', token('strong', P('**') * (lexer.any - '**')^0 * - P('**')^-1 + - P('__') * (lexer.any - '__')^0 * - P('__')^-1)) +local punct_space = lexer.punct + lexer.space + +-- Handles flanking delimiters as described in +-- https://github.github.com/gfm/#emphasis-and-strong-emphasis in the cases +-- where simple delimited ranges are not sufficient. +local function flanked_range(s, not_inword) + local fl_char = lexer.any - s - lexer.space + local left_fl = lpeg.B(punct_space - s) * s * #fl_char + + s * #(fl_char - lexer.punct) + local right_fl = lpeg.B(lexer.punct) * s * #(punct_space - s) + + lpeg.B(fl_char) * s + return left_fl * (lexer.any - (not_inword and s * #punct_space or s))^0 * + right_fl +end + +lex:add_rule('strong', + token('strong', flanked_range('**') + + (lpeg.B(punct_space) + #lexer.starts_line('_')) * + flanked_range('__', true) * #(punct_space + -1))) lex:add_style('strong', 'bold') -lex:add_rule('em', token('em', lexer.delimited_range('*', true, true) + - lexer.delimited_range('_', true, true))) + +lex:add_rule('em', + token('em', flanked_range('*') + + (lpeg.B(punct_space) + #lexer.starts_line('_')) * + flanked_range('_', true) * #(punct_space + -1))) lex:add_style('em', 'italics') -- Embedded HTML. -- cgit v1.2.3