From df89eae40b56ceb326930d6aaea80fac4cdcd61c Mon Sep 17 00:00:00 2001 From: Sean Lang Date: Thu, 26 Mar 2015 21:43:27 -0400 Subject: [PATCH] fix issue with loose_item_end detection breaking and add previously failing text case for it --- lib/index.coffee | 27 ++++++--------------------- test/index.coffee | 22 ++++++++++++++++++++++ 2 files changed, 28 insertions(+), 21 deletions(-) diff --git a/lib/index.coffee b/lib/index.coffee index 5910602..55d9d30 100644 --- a/lib/index.coffee +++ b/lib/index.coffee @@ -88,20 +88,19 @@ preprocessAST = (ast) -> # this is actually all we need the list start token for orderedList = currentToken.ordered else if currentToken.type in nestingStartTokens - nestingStartToken = currentToken.type - tokenIndex = nestingStartTokens.indexOf(nestingStartToken) - nestingEndToken = nestingEndTokens[tokenIndex] + tokenIndex = nestingStartTokens.indexOf(currentToken.type) currentToken.type = nestContainingTokens[tokenIndex] i++ - # if other nestingStartTokens of the same type open while looking for the - # end of this subAST, make sure not to steal their nestingEndToken + # there is no `loose_item_end` token, so we don't actually check the type + # of the token that's closing a given nesting level... we just assume it's + # correct. nestingLevel = 1 subAST = [] loop - if ast[i].type is nestingEndToken + if ast[i].type in nestingEndTokens nestingLevel-- - if ast[i].type is nestingStartToken + else if ast[i].type in nestingStartTokens nestingLevel++ if nestingLevel is 0 @@ -285,20 +284,6 @@ module.exports = (dirtyMarkdown, options = {}) -> # remove all the `space` and `list_end` tokens - they're useless ast = ast.filter (token) -> token.type not in ['space', 'list_end'] - - # there is no `loose_item_end` token, so we need to make it. thankfully, it's - # pretty easy to determine where they go, by finding `list_item_end` wherever - # there's an unclosed `loose_item` - openLooseItem = false - ast = ast.map (token) -> - if token.type is 'loose_item_start' - openLooseItem = true - else if token.type is 'list_item_end' and openLooseItem - openLooseItem = false - # replace the list_item_end with loose_item_end - token = type: 'loose_item_end' - return token - ast = preprocessAST(ast) ast = fixHeaders(ast, options.ensureFirstHeaderIsH1) diff --git a/test/index.coffee b/test/index.coffee index 2119e04..fd3d8e1 100644 --- a/test/index.coffee +++ b/test/index.coffee @@ -187,6 +187,28 @@ describe 'lists', -> - last item ''') + it 'should normalize unordered nested lists (2)', -> + tidyMdSnippet(''' + + adas + - asdas + - sdas + + + sdfsdas + - sddfasdfdfs + - sdfafasdfsa + + asdfads + ''').should.equal(''' + - adas + - asdas + - sdas + + - sdfsdas + - sddfasdfdfs + - sdfafasdfsa + + - asdfads + ''') + it 'should normalize ordered lists', -> tidyMdSnippet(''' # H1 header