return (line !~ '^[=-#]' || s:is_mkdCode(a:lnum)) ? '' : line
endfunc
-func! Foldexpr_markdown(lnum)
- let l2 = s:effective_line(a:lnum+1)
- if l2 =~ '^==\+\s*'
- " next line is underlined (level 1)
- return '>1'
- elseif l2 =~ '^--\+\s*'
- " next line is underlined (level 2)
- return '>2'
- endif
+if get(g:, "vim_markdown_folding_style_pythonic", 0)
+ func! Foldexpr_markdown(lnum)
+ let l2 = s:effective_line(a:lnum+1)
+ if l2 =~ '^==\+\s*'
+ " next line is underlined (level 1)
+ return '>0'
+ elseif l2 =~ '^--\+\s*'
+ " next line is underlined (level 2)
+ return '>1'
+ endif
- let l1 = s:effective_line(a:lnum)
- if l1 =~ '^#'
- " don't include the section title in the fold
- return '-1'
- endif
+ let l1 = s:effective_line(a:lnum)
+ if l1 =~ '^#'
+ " current line starts with hashes
+ return '>'.(matchend(l1, '^#\+') - 1)
+ elseif a:lnum == 1
+ " fold any 'preamble'
+ return '>1'
+ else
+ " keep previous foldlevel
+ return '='
+ endif
+ endfunc
- if (a:lnum == 1)
- let l0 = ''
- else
- let l0 = s:effective_line(a:lnum-1)
- endif
- if l0 =~ '^#'
- " current line starts with hashes
- return '>'.matchend(l0, '^#\+')
- else
- " keep previous foldlevel
- return '='
- endif
-endfunc
+ fun! Foldtext_markdown()
+ let line = getline(v:foldstart)
+ let has_numbers = &number || &relativenumber
+ let nucolwidth = &fdc + has_numbers * &numberwidth
+ let windowwidth = winwidth(0) - nucolwidth - 6
+ let foldedlinecount = v:foldend - v:foldstart
+ let line = strpart(line, 0, windowwidth - 2 -len(foldedlinecount))
+ let line = substitute(line, '\%("""\|''''''\)', '', '')
+ let fillcharcount = windowwidth - len(line) - len(foldedlinecount) + 1
+ return line . ' ' . repeat("-", fillcharcount) . ' ' . foldedlinecount
+ endfunc
+else
+ func! Foldexpr_markdown(lnum)
+ let l2 = s:effective_line(a:lnum+1)
+ if l2 =~ '^==\+\s*'
+ " next line is underlined (level 1)
+ return '>1'
+ elseif l2 =~ '^--\+\s*'
+ " next line is underlined (level 2)
+ return '>2'
+ endif
+
+ let l1 = s:effective_line(a:lnum)
+ if l1 =~ '^#'
+ " don't include the section title in the fold
+ return '-1'
+ endif
+ if (a:lnum == 1)
+ let l0 = ''
+ else
+ let l0 = s:effective_line(a:lnum-1)
+ endif
+ if l0 =~ '^#'
+ " current line starts with hashes
+ return '>'.matchend(l0, '^#\+')
+ else
+ " keep previous foldlevel
+ return '='
+ endif
+ endfunc
+endif
if !get(g:, "vim_markdown_folding_disabled", 0)
- setlocal foldexpr=Foldexpr_markdown(v:lnum)
- setlocal foldmethod=expr
+ setlocal foldexpr=Foldexpr_markdown(v:lnum)
+ setlocal foldmethod=expr
+ if get(g:, "vim_markdown_folding_style_pythonic", 0)
+ setlocal foldtext=Foldtext_markdown()
+ endif
endif
--- /dev/null
+Before:
+ let g:vim_markdown_folding_style_pythonic = 1
+ source ../after/ftplugin/markdown.vim
+
+After:
+ setlocal foldexpr=0
+ setlocal foldmethod=manual
+
+Given markdown;
+# Title
+
+## Chapter 1
+
+```
+This is code block
+# This is just a comment
+```
+
+## Chapter 2
+
+foobar
+
+Execute (fold level # in code block):
+ AssertEqual foldlevel(1), 0, '# Title'
+ AssertEqual foldlevel(3), 1, '## Chapter 1'
+ AssertEqual foldlevel(7), 1, '# This is just a comment'
+ AssertEqual foldlevel(8), 1, '```'
+ AssertEqual foldlevel(10), 1, '## Chapter 2'
+ AssertEqual foldlevel(12), 1, 'foobar'
+
+Given markdown;
+
+==+ Fold Level 1
+
+--+ Fold Level 2
+
+Execute (fold level ==+, --+):
+ AssertEqual foldlevel(2), 0, '==+'
+ AssertEqual foldlevel(4), 1, '--+'