commit 830f62d7c539b45c2bacfb068c8cf3fcaae5e98a
parent 8d9cf471d63f4cf7a57e3c077f06277a7bcddb0d
Author: Hayden Hamilton <haydenh@sdf.org>
Date: Sun, 19 Jul 2020 15:48:32 +0100
moving from newsboat to sfeed_curses
Diffstat:
34 files changed, 108 insertions(+), 8736 deletions(-)
diff --git a/.config/alias b/.config/alias
@@ -41,10 +41,11 @@ irc-us.oscss.eu ssh -p 222 hayden@140.82.11.69
freebsd.oscss ssh -p 22122 hayden@freebsd.oscss.eu
sdf ssh haydenh@tty.sdf.org
localserve ssh void@192.168.1.20
+sfeed_curses sfeed_update $XDG_CONFIG_HOME/sfeed/config && SFEED_PLUMBER=urlhand2 \sfeed_curses $XDG_CACHE_HOME/sfeed/*
irc ssh -p 15551 hayden@77.68.91.186
vps2 ssh -p 15552 hayden@vps2.haydenvh.com
dd echo PLEASE TRIPLE CHECK, THEN RUN ddd
-ddd dd
+ddd \dd
diff colordiff
~d cd ~/general/downloads; ls
~do cd ~/general/documents; ls
diff --git a/.config/mpv/mpv.conf b/.config/mpv/mpv.conf
@@ -1,3 +1,2 @@
-vo=xv
ytdl-format="(bestvideo[height<=720]+bestaudio)[ext=webm]/bestvideo[height<=720]+bestaudio/best[height<=720]/bestvideo+bestaudio/best"
diff --git a/.config/newsboat/config b/.config/newsboat/config
@@ -1,31 +0,0 @@
-#show-read-feeds no
-auto-reload yes
-
-browser "nohup vimb --no-maximize"
-external-url-viewer "nohup urlhand"
-
-bind-key j down
-bind-key k up
-bind-key j next articlelist
-bind-key k prev articlelist
-bind-key J next-feed articlelist
-bind-key K prev-feed articlelist
-bind-key G end
-bind-key g home
-bind-key d pagedown
-bind-key u pageup
-bind-key l open
-bind-key h quit
-bind-key a toggle-article-read
-bind-key n next-unread
-bind-key N prev-unread
-bind-key D pb-download
-bind-key U show-urls
-bind-key x pb-delete
-
-color listnormal white black
-color listfocus white red bold
-color listnormal_unread magenta black
-color listfocus_unread magenta red bold
-color info black blue bold
-color article white black
diff --git a/.config/nvim/autoload/vimwiki/base.vim b/.config/nvim/autoload/vimwiki/base.vim
@@ -1,2096 +0,0 @@
-" vim:tabstop=2:shiftwidth=2:expandtab:textwidth=99
-" Vimwiki autoload plugin file
-" Desc: Basic functionality
-" Home: https://github.com/vimwiki/vimwiki/
-
-if exists("g:loaded_vimwiki_auto") || &cp
- finish
-endif
-let g:loaded_vimwiki_auto = 1
-
-
-function! s:safesubstitute(text, search, replace, mode)
- " Substitute regexp but do not interpret replace
- let escaped = escape(a:replace, '\&')
- return substitute(a:text, a:search, escaped, a:mode)
-endfunction
-
-
-function! s:vimwiki_get_known_syntaxes()
- " Getting all syntaxes that different wikis could have
- let syntaxes = {}
- let syntaxes['default'] = 1
- for wiki_nr in range(vimwiki#vars#number_of_wikis())
- let wiki_syntax = vimwiki#vars#get_wikilocal('syntax', wiki_nr)
- let syntaxes[wiki_syntax] = 1
- endfor
- " also consider the syntaxes from g:vimwiki_ext2syntax
- for syn in values(vimwiki#vars#get_global('ext2syntax'))
- let syntaxes[syn] = 1
- endfor
- return keys(syntaxes)
-endfunction
-
-
-function! vimwiki#base#file_pattern(files)
- " Get search regex from glob()
- " string. Aim to support *all* special characters, forcing the user to choose
- " names that are compatible with any external restrictions that they
- " encounter (e.g. filesystem, wiki conventions, other syntaxes, ...).
- " See: https://github.com/vimwiki-backup/vimwiki/issues/316
- " Change / to [/\\] to allow "Windows paths"
- return '\V\%('.join(a:files, '\|').'\)\m'
-endfunction
-
-
-"FIXME TODO slow and faulty
-function! vimwiki#base#subdir(path, filename)
- let path = a:path
- " ensure that we are not fooled by a symbolic link
- "FIXME if we are not "fooled", we end up in a completely different wiki?
- if a:filename !~# '^scp:'
- let filename = resolve(a:filename)
- else
- let filename = a:filename
- endif
- let idx = 0
- "FIXME this can terminate in the middle of a path component!
- while path[idx] ==? filename[idx]
- let idx = idx + 1
- endwhile
-
- let p = split(strpart(filename, idx), '[/\\]')
- let res = join(p[:-2], '/')
- if len(res) > 0
- let res = res.'/'
- endif
- return res
-endfunction
-
-
-function! vimwiki#base#current_subdir()
- return vimwiki#base#subdir(vimwiki#vars#get_wikilocal('path'), expand('%:p'))
-endfunction
-
-
-function! vimwiki#base#invsubdir(subdir)
- return substitute(a:subdir, '[^/\.]\+/', '../', 'g')
-endfunction
-
-
-" Returns: the number of the wiki a file belongs to or -1 if it doesn't belong
-" to any registered wiki.
-" The path can be the full path or just the directory of the file
-function! vimwiki#base#find_wiki(path)
- let bestmatch = -1
- let bestlen = 0
- let path = vimwiki#path#path_norm(vimwiki#path#chomp_slash(a:path))
- for idx in range(vimwiki#vars#number_of_wikis())
- let idx_path = expand(vimwiki#vars#get_wikilocal('path', idx))
- let idx_path = vimwiki#path#path_norm(vimwiki#path#chomp_slash(idx_path))
- let common_pfx = vimwiki#path#path_common_pfx(idx_path, path)
- if vimwiki#path#is_equal(common_pfx, idx_path)
- if len(common_pfx) > bestlen
- let bestlen = len(common_pfx)
- let bestmatch = idx
- endif
- endif
- endfor
-
- return bestmatch
-endfunction
-
-
-" THE central function of Vimwiki. Extract infos about the target from a link.
-" If the second parameter is present, which should be an absolute file path, it
-" is assumed that the link appears in that file. Without it, the current file
-" is used.
-function! vimwiki#base#resolve_link(link_text, ...)
- if a:0
- let source_wiki = vimwiki#base#find_wiki(a:1)
- let source_file = a:1
- else
- let source_wiki = vimwiki#vars#get_bufferlocal('wiki_nr')
- let source_file = vimwiki#path#current_wiki_file()
- endif
-
- let link_text = a:link_text
-
-
- let link_infos = {
- \ 'index': -1,
- \ 'scheme': '',
- \ 'filename': '',
- \ 'anchor': '',
- \ }
-
- if link_text == ''
- return link_infos
- endif
-
- let scheme = matchstr(link_text, '^\zs'.vimwiki#vars#get_global('rxSchemes').'\ze:')
- if scheme == ''
- let link_infos.scheme = 'wiki'.source_wiki
- else
- let link_infos.scheme = scheme
-
- if link_infos.scheme !~# '\mwiki\d\+\|diary\|local\|file'
- let link_infos.filename = link_text " unknown scheme, may be a weblink
- return link_infos
- endif
-
- let link_text = matchstr(link_text, '^'.vimwiki#vars#get_global('rxSchemes').':\zs.*\ze')
- endif
-
- let is_wiki_link = link_infos.scheme =~# '\mwiki\d\+' || link_infos.scheme ==# 'diary'
-
- " extract anchor
- if is_wiki_link
- let split_lnk = split(link_text, '#', 1)
- let link_text = split_lnk[0]
- if len(split_lnk) > 1 && split_lnk[-1] != ''
- let link_infos.anchor = join(split_lnk[1:], '#')
- endif
- if link_text == '' " because the link was of the form '#anchor'
- let expected_ext = vimwiki#u#escape(vimwiki#vars#get_wikilocal('ext')).'$'
- if source_file =~# expected_ext
- " Source file has expected extension. Remove it, it will be added later on
- let ext_len = strlen(vimwiki#vars#get_wikilocal('ext'))
- let link_text = fnamemodify(source_file, ':p:t')[:-ext_len-1]
- endif
-
- endif
- endif
-
- " check if absolute or relative path
- if is_wiki_link && link_text[0] == '/'
- if link_text != '/'
- let link_text = link_text[1:]
- endif
- let is_relative = 0
- elseif !is_wiki_link && vimwiki#path#is_absolute(link_text)
- let is_relative = 0
- else
- let is_relative = 1
- let root_dir = fnamemodify(source_file, ':p:h') . '/'
- endif
-
-
- " extract the other items depending on the scheme
- if link_infos.scheme =~# '\mwiki\d\+'
- let link_infos.index = eval(matchstr(link_infos.scheme, '\D\+\zs\d\+\ze'))
- if link_infos.index < 0 || link_infos.index >= vimwiki#vars#number_of_wikis()
- let link_infos.index = -1
- let link_infos.filename = ''
- return link_infos
- endif
-
- if !is_relative || link_infos.index != source_wiki
- let root_dir = vimwiki#vars#get_wikilocal('path', link_infos.index)
- endif
-
- let link_infos.filename = root_dir . link_text
-
- if vimwiki#path#is_link_to_dir(link_text)
- if vimwiki#vars#get_global('dir_link') != ''
- let link_infos.filename .= vimwiki#vars#get_global('dir_link') .
- \ vimwiki#vars#get_wikilocal('ext', link_infos.index)
- endif
- else
- let link_infos.filename .= vimwiki#vars#get_wikilocal('ext', link_infos.index)
- endif
-
- elseif link_infos.scheme ==# 'diary'
- let link_infos.index = source_wiki
-
- let link_infos.filename =
- \ vimwiki#vars#get_wikilocal('path', link_infos.index) .
- \ vimwiki#vars#get_wikilocal('diary_rel_path', link_infos.index) .
- \ link_text .
- \ vimwiki#vars#get_wikilocal('ext', link_infos.index)
- elseif (link_infos.scheme ==# 'file' || link_infos.scheme ==# 'local') && is_relative
- let link_infos.filename = simplify(root_dir . link_text)
- else " absolute file link
- " collapse repeated leading "/"'s within a link
- let link_text = substitute(link_text, '\m^/\+', '/', '')
- " expand ~/
- let link_text = fnamemodify(link_text, ':p')
- let link_infos.filename = simplify(link_text)
- endif
-
- let link_infos.filename = vimwiki#path#normalize(link_infos.filename)
- return link_infos
-endfunction
-
-
-function! vimwiki#base#system_open_link(url)
- " handlers
- function! s:win32_handler(url)
- "Disable shellslash for cmd and command.com, but enable for all other shells
- "See Issue #560
- if (&shell =~? "cmd") || (&shell =~? "command.com")
-
- if exists('+shellslash')
- let old_ssl = &shellslash
- set noshellslash
- let url = shellescape(a:url, 1)
- let &shellslash = old_ssl
- else
- let url = shellescape(a:url, 1)
- endif
- execute 'silent ! start "Title" /B ' . url
-
- else
-
- if exists('+shellslash')
- let old_ssl = &shellslash
- set shellslash
- let url = shellescape(a:url, 1)
- let &shellslash = old_ssl
- else
- let url = shellescape(a:url, 1)
- endif
- execute 'silent ! start ' . url
-
- endif
- endfunction
- function! s:macunix_handler(url)
- call system('open ' . shellescape(a:url).' &')
- endfunction
- function! s:linux_handler(url)
- call system('xdg-open ' . shellescape(a:url).' &')
- endfunction
- try
- if vimwiki#u#is_windows()
- call s:win32_handler(a:url)
- return
- elseif vimwiki#u#is_macos()
- call s:macunix_handler(a:url)
- return
- else
- call s:linux_handler(a:url)
- return
- endif
- endtry
- echomsg 'Vimwiki Error: Default Vimwiki link handler was unable to open the HTML file!'
-endfunction
-
-
-function! vimwiki#base#open_link(cmd, link, ...)
- let link_infos = {}
- if a:0
- let link_infos = vimwiki#base#resolve_link(a:link, a:1)
- else
- let link_infos = vimwiki#base#resolve_link(a:link)
- endif
-
- if link_infos.filename == ''
- if link_infos.index == -1
- echomsg 'Vimwiki Error: No registered wiki ''' . link_infos.scheme . '''.'
- else
- echomsg 'Vimwiki Error: Unable to resolve link!'
- endif
- return
- endif
-
- let is_wiki_link = link_infos.scheme =~# '\mwiki\d\+' || link_infos.scheme =~# 'diary'
-
- let update_prev_link = is_wiki_link &&
- \ !vimwiki#path#is_equal(link_infos.filename, vimwiki#path#current_wiki_file())
-
- let vimwiki_prev_link = []
- " update previous link for wiki pages
- if update_prev_link
- if a:0
- let vimwiki_prev_link = [a:1, []]
- elseif &ft ==# 'vimwiki'
- let vimwiki_prev_link = [vimwiki#path#current_wiki_file(), getpos('.')]
- endif
- endif
-
- " open/edit
- if is_wiki_link
- call vimwiki#base#edit_file(a:cmd, link_infos.filename, link_infos.anchor,
- \ vimwiki_prev_link, update_prev_link)
- else
- call vimwiki#base#system_open_link(link_infos.filename)
- endif
-endfunction
-
-
-function! vimwiki#base#get_globlinks_escaped() abort
- " only get links from the current dir
- " change to the directory of the current file
- let orig_pwd = getcwd()
- lcd! %:h
- " all path are relative to the current file's location
- let globlinks = glob('*'.vimwiki#vars#get_wikilocal('ext'), 1)."\n"
- " remove extensions
- let globlinks = substitute(globlinks, '\'.vimwiki#vars#get_wikilocal('ext').'\ze\n', '', 'g')
- " restore the original working directory
- exe 'lcd! '.orig_pwd
- " convert to a List
- let lst = split(globlinks, '\n')
- " Apply fnameescape() to each item
- call map(lst, 'fnameescape(v:val)')
- " Convert back to newline-separated list
- let globlinks = join(lst, "\n")
- " return all escaped links as a single newline-separated string
- return globlinks
-endfunction
-
-
-function! vimwiki#base#generate_links()
- let lines = []
-
- let links = vimwiki#base#get_wikilinks(vimwiki#vars#get_bufferlocal('wiki_nr'), 0)
- call sort(links)
-
- let bullet = repeat(' ', vimwiki#lst#get_list_margin()) . vimwiki#lst#default_symbol().' '
- for link in links
- let abs_filepath = vimwiki#path#abs_path_of_link(link)
- if !s:is_diary_file(abs_filepath)
- call add(lines, bullet.
- \ s:safesubstitute(vimwiki#vars#get_global('WikiLinkTemplate1'),
- \ '__LinkUrl__', link, ''))
- endif
- endfor
-
- let links_rx = '\m^\s*'.vimwiki#u#escape(vimwiki#lst#default_symbol()).' '
-
- call vimwiki#base#update_listing_in_buffer(lines, 'Generated Links', links_rx, line('$')+1, 1)
-endfunction
-
-
-function! vimwiki#base#goto(...)
- let key = a:1
- let anchor = a:0 > 1 ? a:2 : ''
-
- call vimwiki#base#edit_file(':e',
- \ vimwiki#vars#get_wikilocal('path') . key . vimwiki#vars#get_wikilocal('ext'),
- \ anchor)
-endfunction
-
-
-function! vimwiki#base#backlinks()
- let current_filename = expand("%:p")
- let locations = []
- for idx in range(vimwiki#vars#number_of_wikis())
- let syntax = vimwiki#vars#get_wikilocal('syntax', idx)
- let wikifiles = vimwiki#base#find_files(idx, 0)
- for source_file in wikifiles
- let links = s:get_links(source_file, idx)
- for [target_file, _, lnum, col] in links
- " don't include links from the current file to itself
- if vimwiki#path#is_equal(target_file, current_filename) &&
- \ !vimwiki#path#is_equal(target_file, source_file)
- call add(locations, {'filename':source_file, 'lnum':lnum, 'col':col})
- endif
- endfor
- endfor
- endfor
-
- if empty(locations)
- echomsg 'Vimwiki: No other file links to this file'
- else
- call setloclist(0, locations, 'r')
- lopen
- endif
-endfunction
-
-
-" Returns: a list containing all files of the given wiki as absolute file path.
-" If the given wiki number is negative, the diary of the current wiki is used
-" If the second argument is not zero, only directories are found
-function! vimwiki#base#find_files(wiki_nr, directories_only)
- let wiki_nr = a:wiki_nr
- if wiki_nr >= 0
- let root_directory = vimwiki#vars#get_wikilocal('path', wiki_nr)
- else
- let root_directory = vimwiki#vars#get_wikilocal('path') .
- \ vimwiki#vars#get_wikilocal('diary_rel_path')
- let wiki_nr = vimwiki#vars#get_bufferlocal('wiki_nr')
- endif
- if a:directories_only
- let ext = '/'
- else
- let ext = vimwiki#vars#get_wikilocal('ext', wiki_nr)
- endif
- " if current wiki is temporary -- was added by an arbitrary wiki file then do
- " not search wiki files in subdirectories. Or it would hang the system if
- " wiki file was created in $HOME or C:/ dirs.
- if vimwiki#vars#get_wikilocal('is_temporary_wiki', wiki_nr)
- let pattern = '*'.ext
- else
- let pattern = '**/*'.ext
- endif
- return split(globpath(root_directory, pattern), '\n')
-endfunction
-
-
-" Returns: a list containing the links to get from the current file to all wiki
-" files in the given wiki.
-" If the given wiki number is negative, the diary of the current wiki is used.
-" If also_absolute_links is nonzero, also return links of the form /file
-function! vimwiki#base#get_wikilinks(wiki_nr, also_absolute_links)
- let files = vimwiki#base#find_files(a:wiki_nr, 0)
- if a:wiki_nr == vimwiki#vars#get_bufferlocal('wiki_nr')
- let cwd = vimwiki#path#wikify_path(expand('%:p:h'))
- elseif a:wiki_nr < 0
- let cwd = vimwiki#vars#get_wikilocal('path') . vimwiki#vars#get_wikilocal('diary_rel_path')
- else
- let cwd = vimwiki#vars#get_wikilocal('path', a:wiki_nr)
- endif
- let result = []
- for wikifile in files
- let wikifile = fnamemodify(wikifile, ':r') " strip extension
- let wikifile = vimwiki#path#relpath(cwd, wikifile)
- call add(result, wikifile)
- endfor
- if a:also_absolute_links
- for wikifile in files
- if a:wiki_nr == vimwiki#vars#get_bufferlocal('wiki_nr')
- let cwd = vimwiki#vars#get_wikilocal('path')
- elseif a:wiki_nr < 0
- let cwd = vimwiki#vars#get_wikilocal('path') . vimwiki#vars#get_wikilocal('diary_rel_path')
- endif
- let wikifile = fnamemodify(wikifile, ':r') " strip extension
- let wikifile = '/'.vimwiki#path#relpath(cwd, wikifile)
- call add(result, wikifile)
- endfor
- endif
- return result
-endfunction
-
-
-" Returns: a list containing the links to all directories from the current file
-function! vimwiki#base#get_wiki_directories(wiki_nr)
- let dirs = vimwiki#base#find_files(a:wiki_nr, 1)
- if a:wiki_nr == vimwiki#vars#get_bufferlocal('wiki_nr')
- let cwd = vimwiki#path#wikify_path(expand('%:p:h'))
- let root_dir = vimwiki#vars#get_wikilocal('path')
- else
- let cwd = vimwiki#vars#get_wikilocal('path', a:wiki_nr)
- endif
- let result = ['./']
- for wikidir in dirs
- let wikidir_relative = vimwiki#path#relpath(cwd, wikidir)
- call add(result, wikidir_relative)
- if a:wiki_nr == vimwiki#vars#get_bufferlocal('wiki_nr')
- let wikidir_absolute = '/'.vimwiki#path#relpath(root_dir, wikidir)
- call add(result, wikidir_absolute)
- endif
- endfor
- return result
-endfunction
-
-
-function! vimwiki#base#get_anchors(filename, syntax)
- if !filereadable(a:filename)
- return []
- endif
-
- let rxheader = vimwiki#vars#get_syntaxlocal('header_search', a:syntax)
- let rxbold = vimwiki#vars#get_syntaxlocal('bold_search', a:syntax)
- let rxtag = vimwiki#vars#get_syntaxlocal('tag_search', a:syntax)
-
- let anchor_level = ['', '', '', '', '', '', '']
- let anchors = []
- let current_complete_anchor = ''
- for line in readfile(a:filename)
-
- " collect headers
- let h_match = matchlist(line, rxheader)
- if !empty(h_match)
- let header = vimwiki#u#trim(h_match[2])
- let level = len(h_match[1])
- call add(anchors, header)
- let anchor_level[level-1] = header
- for l in range(level, 6)
- let anchor_level[l] = ''
- endfor
- if level == 1
- let current_complete_anchor = header
- else
- let current_complete_anchor = ''
- for l in range(level-1)
- if anchor_level[l] != ''
- let current_complete_anchor .= anchor_level[l].'#'
- endif
- endfor
- let current_complete_anchor .= header
- call add(anchors, current_complete_anchor)
- endif
- endif
-
- " collect bold text (there can be several in one line)
- let bold_count = 1
- while 1
- let bold_text = matchstr(line, rxbold, 0, bold_count)
- if bold_text == ''
- break
- endif
- call add(anchors, bold_text)
- if current_complete_anchor != ''
- call add(anchors, current_complete_anchor.'#'.bold_text)
- endif
- let bold_count += 1
- endwhile
-
- " collect tags text (there can be several in one line)
- let tag_count = 1
- while 1
- let tag_group_text = matchstr(line, rxtag, 0, tag_count)
- if tag_group_text == ''
- break
- endif
- for tag_text in split(tag_group_text, ':')
- call add(anchors, tag_text)
- if current_complete_anchor != ''
- call add(anchors, current_complete_anchor.'#'.tag_text)
- endif
- endfor
- let tag_count += 1
- endwhile
-
- endfor
-
- return anchors
-endfunction
-
-
-function! s:jump_to_anchor(anchor)
- let oldpos = getpos('.')
- call cursor(1, 1)
-
- let anchor = vimwiki#u#escape(a:anchor)
-
- let segments = split(anchor, '#', 0)
-
- for segment in segments
-
- let anchor_header = s:safesubstitute(
- \ vimwiki#vars#get_syntaxlocal('header_match'),
- \ '__Header__', segment, '')
- let anchor_bold = s:safesubstitute(
- \ vimwiki#vars#get_syntaxlocal('bold_match'),
- \ '__Text__', segment, '')
- let anchor_tag = s:safesubstitute(
- \ vimwiki#vars#get_syntaxlocal('tag_match'),
- \ '__Tag__', segment, '')
-
- if !search(anchor_tag, 'Wc') && !search(anchor_header, 'Wc') && !search(anchor_bold, 'Wc')
- call setpos('.', oldpos)
- break
- endif
- let oldpos = getpos('.')
- endfor
-endfunction
-
-
-" Params: full path to a wiki file and its wiki number
-" Returns: a list of all links inside the wiki file
-" Every list item has the form
-" [target file, anchor, line number of the link in source file, column number]
-function! s:get_links(wikifile, idx)
- if !filereadable(a:wikifile)
- return []
- endif
-
- let syntax = vimwiki#vars#get_wikilocal('syntax', a:idx)
- let rx_link = vimwiki#vars#get_syntaxlocal('wikilink', syntax)
- let links = []
- let lnum = 0
-
- for line in readfile(a:wikifile)
- let lnum += 1
-
- let link_count = 1
- while 1
- let col = match(line, rx_link, 0, link_count)+1
- let link_text = matchstr(line, rx_link, 0, link_count)
- if link_text == ''
- break
- endif
- let link_count += 1
- let target = vimwiki#base#resolve_link(link_text, a:wikifile)
- if target.filename != '' && target.scheme =~# '\mwiki\d\+\|diary\|file\|local'
- call add(links, [target.filename, target.anchor, lnum, col])
- endif
- endwhile
- endfor
-
- return links
-endfunction
-
-
-function! vimwiki#base#check_links()
- let anchors_of_files = {}
- let links_of_files = {}
- let errors = []
- for idx in range(vimwiki#vars#number_of_wikis())
- let syntax = vimwiki#vars#get_wikilocal('syntax', idx)
- let wikifiles = vimwiki#base#find_files(idx, 0)
- for wikifile in wikifiles
- let links_of_files[wikifile] = s:get_links(wikifile, idx)
- let anchors_of_files[wikifile] = vimwiki#base#get_anchors(wikifile, syntax)
- endfor
- endfor
-
- for wikifile in keys(links_of_files)
- for [target_file, target_anchor, lnum, col] in links_of_files[wikifile]
- if target_file == '' && target_anchor == ''
- call add(errors, {'filename':wikifile, 'lnum':lnum, 'col':col,
- \ 'text': "numbered scheme refers to a non-existent wiki"})
- elseif has_key(anchors_of_files, target_file)
- if target_anchor != '' && index(anchors_of_files[target_file], target_anchor) < 0
- call add(errors, {'filename':wikifile, 'lnum':lnum, 'col':col,
- \'text': "there is no such anchor: ".target_anchor})
- endif
- else
- if target_file =~ '\m/$' " maybe it's a link to a directory
- if !isdirectory(target_file)
- call add(errors, {'filename':wikifile, 'lnum':lnum, 'col':col,
- \'text': "there is no such directory: ".target_file})
- endif
- else " maybe it's a non-wiki file
- if filereadable(target_file)
- let anchors_of_files[target_file] = []
- else
- call add(errors, {'filename':wikifile, 'lnum':lnum, 'col':col,
- \'text': "there is no such file: ".target_file})
- endif
- endif
- endif
- endfor
- endfor
-
-
- " Check which wiki files are reachable from at least one of the index files.
- " First, all index files are marked as reachable. Then, pick a reachable file
- " and mark all files to which it links as reachable, too. Repeat until the
- " links of all reachable files have been checked.
-
- " Map every wiki file to a number. 0 means not reachable from any index file,
- " 1 means reachable, but the outgoing links are not checked yet, 2 means
- " reachable and done.
- let reachable_wikifiles = {}
-
- " first, all files are considered not reachable
- for wikifile in keys(links_of_files)
- let reachable_wikifiles[wikifile] = 0
- endfor
-
- " mark every index file as reachable
- for idx in range(vimwiki#vars#number_of_wikis())
- let index_file = vimwiki#vars#get_wikilocal('path', idx) .
- \ vimwiki#vars#get_wikilocal('index', idx) . vimwiki#vars#get_wikilocal('ext', idx)
- if filereadable(index_file)
- let reachable_wikifiles[index_file] = 1
- endif
- endfor
-
- while 1
- let next_unvisited_wikifile = ''
- for wf in keys(reachable_wikifiles)
- if reachable_wikifiles[wf] == 1
- let next_unvisited_wikifile = wf
- let reachable_wikifiles[wf] = 2
- break
- endif
- endfor
- if next_unvisited_wikifile == ''
- break
- endif
- for [target_file, target_anchor, lnum, col] in links_of_files[next_unvisited_wikifile]
- if has_key(reachable_wikifiles, target_file) && reachable_wikifiles[target_file] == 0
- let reachable_wikifiles[target_file] = 1
- endif
- endfor
- endwhile
-
- for wf in keys(reachable_wikifiles)
- if reachable_wikifiles[wf] == 0
- call add(errors, {'text':wf." is not reachable from the index file"})
- endif
- endfor
-
- if empty(errors)
- echomsg 'Vimwiki: All links are OK'
- else
- call setqflist(errors, 'r')
- copen
- endif
-endfunction
-
-
-function! vimwiki#base#edit_file(command, filename, anchor, ...)
- let fname = escape(a:filename, '% *|#`')
- let dir = fnamemodify(a:filename, ":p:h")
-
- let ok = vimwiki#path#mkdir(dir, 1)
-
- if !ok
- echomsg ' '
- echomsg 'Vimwiki Error: Unable to edit file in non-existent directory: '.dir
- return
- endif
-
- " Check if the file we want to open is already the current file
- " which happens if we jump to an achor in the current file.
- " This hack is necessary because apparently Vim messes up the result of
- " getpos() directly after this command. Strange.
- if !(a:command ==# ':e ' && vimwiki#path#is_equal(a:filename, expand('%:p')))
- if &autowriteall && !&hidden " in this case, the file is saved before switching to the
- " new buffer. This causes Vim to show two messages in the command line which triggers
- " the annoying hit-enter prompt. Solution: show no messages at all.
- silent execute a:command fname
- else
- try
- execute a:command fname
- catch /E37:/
- echomsg 'Vimwiki: Can''t leave the current buffer, because it is modified. Hint: Take a look at'
- \ ''':h g:vimwiki_autowriteall'' to see how to save automatically.'
- return
- catch /E325:/
- echom 'Vimwiki: Vim couldn''t open the file, probably because a swapfile already exists. See :h E325.'
- return
- endtry
- endif
-
- " If the opened file was not already loaded by Vim, an autocommand is
- " triggered at this point
-
- " Make sure no other plugin takes ownership over the new file. Vimwiki
- " rules them all! Well, except for directories, which may be opened with
- " Netrw
- if &filetype != 'vimwiki' && fname !~ '\m/$'
- setfiletype vimwiki
- endif
- endif
- if a:anchor != ''
- call s:jump_to_anchor(a:anchor)
- endif
-
- " save previous link
- " a:1 -- previous vimwiki link to save
- " a:2 -- should we update previous link
- if a:0 && a:2 && len(a:1) > 0
- call vimwiki#vars#set_bufferlocal('prev_link', a:1)
- endif
-endfunction
-
-
-function! vimwiki#base#search_word(wikiRx, cmd)
- let match_line = search(a:wikiRx, 's'.a:cmd)
- if match_line == 0
- echomsg 'Vimwiki: Wiki link not found'
- endif
-endfunction
-
-
-" Returns part of the line that matches wikiRX at cursor
-function! vimwiki#base#matchstr_at_cursor(wikiRX)
- let col = col('.') - 1
- let line = getline('.')
- let ebeg = -1
- let cont = match(line, a:wikiRX, 0)
- while (ebeg >= 0 || (0 <= cont) && (cont <= col))
- let contn = matchend(line, a:wikiRX, cont)
- if (cont <= col) && (col < contn)
- let ebeg = match(line, a:wikiRX, cont)
- let elen = contn - ebeg
- break
- else
- let cont = match(line, a:wikiRX, contn)
- endif
- endwh
- if ebeg >= 0
- return strpart(line, ebeg, elen)
- else
- return ""
- endif
-endfunction
-
-
-function! vimwiki#base#replacestr_at_cursor(wikiRX, sub)
- let col = col('.') - 1
- let line = getline('.')
- let ebeg = -1
- let cont = match(line, a:wikiRX, 0)
- while (ebeg >= 0 || (0 <= cont) && (cont <= col))
- let contn = matchend(line, a:wikiRX, cont)
- if (cont <= col) && (col < contn)
- let ebeg = match(line, a:wikiRX, cont)
- let elen = contn - ebeg
- break
- else
- let cont = match(line, a:wikiRX, contn)
- endif
- endwh
- if ebeg >= 0
- " TODO: There might be problems with Unicode chars...
- let newline = strpart(line, 0, ebeg).a:sub.strpart(line, ebeg+elen)
- call setline(line('.'), newline)
- endif
-endfunction
-
-
-function! s:print_wiki_list()
- let idx = 0
- while idx < vimwiki#vars#number_of_wikis()
- if idx == vimwiki#vars#get_bufferlocal('wiki_nr')
- let sep = ' * '
- echohl PmenuSel
- else
- let sep = ' '
- echohl None
- endif
- echo (idx + 1) . sep . vimwiki#vars#get_wikilocal('path', idx)
- let idx += 1
- endwhile
- echohl None
-endfunction
-
-
-function! s:update_wiki_link(fname, old, new)
- echo "Updating links in ".a:fname
- let has_updates = 0
- let dest = []
- for line in readfile(a:fname)
- if !has_updates && match(line, a:old) != -1
- let has_updates = 1
- endif
- " XXX: any other characters to escape!?
- call add(dest, substitute(line, a:old, escape(a:new, "&"), "g"))
- endfor
- " add exception handling...
- if has_updates
- call rename(a:fname, a:fname.'#vimwiki_upd#')
- call writefile(dest, a:fname)
- call delete(a:fname.'#vimwiki_upd#')
- endif
-endfunction
-
-
-function! s:update_wiki_links_dir(wiki_nr, dir, old_fname, new_fname)
- let old_fname = substitute(a:old_fname, '[/\\]', '[/\\\\]', 'g')
- let new_fname = a:new_fname
-
- let old_fname_r = vimwiki#base#apply_template(
- \ vimwiki#vars#get_syntaxlocal('WikiLinkMatchUrlTemplate',
- \ vimwiki#vars#get_wikilocal('syntax', a:wiki_nr)), old_fname, '', '')
-
- let files = split(glob(vimwiki#vars#get_wikilocal('path', a:wiki_nr).a:dir.'*'.
- \ vimwiki#vars#get_wikilocal('ext', a:wiki_nr)), '\n')
- for fname in l:files
- call s:update_wiki_link(fname, old_fname_r, new_fname)
- endfor
-endfunction
-
-
-function! s:tail_name(fname)
- let result = substitute(a:fname, ":", "__colon__", "g")
- let result = fnamemodify(result, ":t:r")
- let result = substitute(result, "__colon__", ":", "g")
- return result
-endfunction
-
-
-function! s:update_wiki_links(wiki_nr, old_fname, new_fname,old_fname_relpath)
- let old_fname = a:old_fname
- let new_fname = a:new_fname
-
- let subdirs = split(a:old_fname_relpath, '[/\\]')[: -2]
-
- " TODO: Use Dictionary here...
- let dirs_keys = ['']
- let dirs_vals = ['']
- if len(subdirs) > 0
- let dirs_keys = ['']
- let dirs_vals = [join(subdirs, '/').'/']
- let idx = 0
- while idx < len(subdirs) - 1
- call add(dirs_keys, join(subdirs[: idx], '/').'/')
- call add(dirs_vals, join(subdirs[idx+1 :], '/').'/')
- let idx = idx + 1
- endwhile
- call add(dirs_keys,join(subdirs, '/').'/')
- call add(dirs_vals, '')
- endif
-
- let idx = 0
- while idx < len(dirs_keys)
- let dir = dirs_keys[idx]
- let new_dir = dirs_vals[idx]
- call s:update_wiki_links_dir(a:wiki_nr, dir, new_dir.old_fname, new_dir.new_fname)
- let idx = idx + 1
- endwhile
-endfunction
-
-
-function! s:get_wiki_buffers()
- let blist = []
- let bcount = 1
- while bcount<=bufnr("$")
- if bufexists(bcount)
- let bname = fnamemodify(bufname(bcount), ":p")
- " this may find buffers that are not part of the current wiki, but that
- " doesn't hurt
- if bname =~# vimwiki#vars#get_wikilocal('ext')."$"
- let bitem = [bname, vimwiki#vars#get_bufferlocal('prev_link', bcount)]
- call add(blist, bitem)
- endif
- endif
- let bcount = bcount + 1
- endwhile
- return blist
-endfunction
-
-
-function! s:open_wiki_buffer(item)
- call vimwiki#base#edit_file(':e', a:item[0], '')
- if !empty(a:item[1])
- call vimwiki#vars#set_bufferlocal('prev_link', a:item[1], a:item[0])
- endif
-endfunction
-
-
-function! vimwiki#base#nested_syntax(filetype, start, end, textSnipHl) abort
-" From http://vim.wikia.com/wiki/VimTip857
- let ft=toupper(a:filetype)
- let group='textGroup'.ft
- if exists('b:current_syntax')
- let s:current_syntax=b:current_syntax
- " Remove current syntax definition, as some syntax files (e.g. cpp.vim)
- " do nothing if b:current_syntax is defined.
- unlet b:current_syntax
- endif
-
- " Some syntax files set up iskeyword which might scratch vimwiki a bit.
- " Let us save and restore it later.
- " let b:skip_set_iskeyword = 1
- let is_keyword = &iskeyword
-
- try
- " keep going even if syntax file is not found
- execute 'syntax include @'.group.' syntax/'.a:filetype.'.vim'
- execute 'syntax include @'.group.' after/syntax/'.a:filetype.'.vim'
- catch
- endtry
-
- let &iskeyword = is_keyword
-
- if exists('s:current_syntax')
- let b:current_syntax=s:current_syntax
- else
- unlet b:current_syntax
- endif
-
- " Fix issue #236: tell Vimwiki to think in maths when encountering maths
- " blocks like {{$ }}$. Here, we don't want the tex highlight group, but the
- " group for tex math.
- if a:textSnipHl ==# 'VimwikiMath'
- let group='texMathZoneGroup'
- endif
-
- execute 'syntax region textSnip'.ft.
- \ ' matchgroup='.a:textSnipHl.
- \ ' start="'.a:start.'" end="'.a:end.'"'.
- \ ' contains=@'.group.' keepend'
-
- " A workaround to Issue 115: Nested Perl syntax highlighting differs from
- " regular one.
- " Perl syntax file has perlFunctionName which is usually has no effect due to
- " 'contained' flag. Now we have 'syntax include' that makes all the groups
- " included as 'contained' into specific group.
- " Here perlFunctionName (with quite an angry regexp "\h\w*[^:]") clashes with
- " the rest syntax rules as now it has effect being really 'contained'.
- " Clear it!
- if ft =~? 'perl'
- syntax clear perlFunctionName
- endif
-endfunction
-
-
-" creates or updates auto-generated listings in a wiki file, like TOC, diary
-" links, tags list etc.
-" - the listing consists of a level 1 header and a list of strings as content
-" - a:content_regex is used to determine how long a potentially existing list is
-" - a:default_lnum is the line number where the new listing should be placed if
-" it's not already present
-" - if a:create is true, it will be created if it doesn't exist, otherwise it
-" will only be updated if it already exists
-function! vimwiki#base#update_listing_in_buffer(strings, start_header,
- \ content_regex, default_lnum, create)
- " Vim behaves strangely when files change while in diff mode
- if &diff || &readonly
- return
- endif
-
- " check if the listing is already there
- let already_there = 0
-
- let header_rx = '\m^\s*'.substitute(vimwiki#vars#get_syntaxlocal('rxH1_Template'),
- \ '__Header__', a:start_header, '') .'\s*$'
-
- let start_lnum = 1
- while start_lnum <= line('$')
- if getline(start_lnum) =~# header_rx
- let already_there = 1
- break
- endif
- let start_lnum += 1
- endwhile
-
- if !already_there && !a:create
- return
- endif
-
- let winview_save = winsaveview()
- let cursor_line = winview_save.lnum
- let is_cursor_after_listing = 0
-
- let is_fold_closed = 1
-
- let lines_diff = 0
-
- if already_there
- let is_fold_closed = ( foldclosed(start_lnum) > -1 )
- " delete the old listing
- let whitespaces_in_first_line = matchstr(getline(start_lnum), '\m^\s*')
- let end_lnum = start_lnum + 1
- while end_lnum <= line('$') && getline(end_lnum) =~# a:content_regex
- let end_lnum += 1
- endwhile
- let is_cursor_after_listing = ( cursor_line >= end_lnum )
- " We'll be removing a range. But, apparently, if folds are enabled, Vim
- " won't let you remove a range that overlaps with closed fold -- the entire
- " fold gets deleted. So we temporarily disable folds, and then reenable
- " them right back.
- let foldenable_save = &l:foldenable
- setlocal nofoldenable
- silent exe 'keepjumps ' . start_lnum.','.string(end_lnum - 1).'delete _'
- let &l:foldenable = foldenable_save
- let lines_diff = 0 - (end_lnum - start_lnum)
- else
- let start_lnum = a:default_lnum
- let is_cursor_after_listing = ( cursor_line > a:default_lnum )
- let whitespaces_in_first_line = ''
- endif
-
- let start_of_listing = start_lnum
-
- " write new listing
- let new_header = whitespaces_in_first_line
- \ . s:safesubstitute(vimwiki#vars#get_syntaxlocal('rxH1_Template'),
- \ '__Header__', a:start_header, '')
- keepjumps call append(start_lnum - 1, new_header)
- let start_lnum += 1
- let lines_diff += 1 + len(a:strings)
- for string in a:strings
- keepjumps call append(start_lnum - 1, string)
- let start_lnum += 1
- endfor
- " append an empty line if there is not one
- if start_lnum <= line('$') && getline(start_lnum) !~# '\m^\s*$'
- keepjumps call append(start_lnum - 1, '')
- let lines_diff += 1
- endif
-
- " Open fold, if needed
- if !is_fold_closed && ( foldclosed(start_of_listing) > -1 )
- exe start_of_listing
- norm! zo
- endif
-
- if is_cursor_after_listing
- let winview_save.lnum += lines_diff
- endif
- call winrestview(winview_save)
-endfunction
-
-
-function! vimwiki#base#find_next_link()
- call vimwiki#base#search_word(vimwiki#vars#get_syntaxlocal('rxAnyLink'), '')
-endfunction
-
-
-function! vimwiki#base#find_prev_link()
- "Jump 2 times if the cursor is in the middle of a link
- if synIDattr(synID(line('.'), col('.'), 0), "name") =~# "VimwikiLink.*" &&
- \ synIDattr(synID(line('.'), col('.')-1, 0), "name") =~# "VimwikiLink.*"
- call vimwiki#base#search_word(vimwiki#vars#get_syntaxlocal('rxAnyLink'), 'b')
- endif
- call vimwiki#base#search_word(vimwiki#vars#get_syntaxlocal('rxAnyLink'), 'b')
-endfunction
-
-
-function! vimwiki#base#follow_link(split, ...)
- let reuse_other_split_window = a:0 >= 1 ? a:1 : 0
- let move_cursor_to_new_window = a:0 >= 2 ? a:2 : 1
-
- " Parse link at cursor and pass to VimwikiLinkHandler, or failing that, the
- " default open_link handler
-
- " try WikiLink
- let lnk = matchstr(vimwiki#base#matchstr_at_cursor(vimwiki#vars#get_syntaxlocal('rxWikiLink')),
- \ vimwiki#vars#get_syntaxlocal('rxWikiLinkMatchUrl'))
- " try WikiIncl
- if lnk == ""
- let lnk = matchstr(vimwiki#base#matchstr_at_cursor(vimwiki#vars#get_global('rxWikiIncl')),
- \ vimwiki#vars#get_global('rxWikiInclMatchUrl'))
- endif
- " try Weblink
- if lnk == ""
- let lnk = matchstr(vimwiki#base#matchstr_at_cursor(vimwiki#vars#get_syntaxlocal('rxWeblink')),
- \ vimwiki#vars#get_syntaxlocal('rxWeblinkMatchUrl'))
- endif
-
- if lnk != "" " cursor is indeed on a link
- let processed_by_user_defined_handler = VimwikiLinkHandler(lnk)
- if processed_by_user_defined_handler
- return
- endif
-
- if a:split ==# "hsplit"
- let cmd = ":split "
- elseif a:split ==# "vsplit"
- let cmd = ":vsplit "
- elseif a:split ==# "tab"
- let cmd = ":tabnew "
- else
- let cmd = ":e "
- endif
-
- " if we want to and can reuse a split window, jump to that window and open
- " the new file there
- if (a:split ==# 'hsplit' || a:split ==# 'vsplit') && reuse_other_split_window
- let previous_window_nr = winnr('#')
- if previous_window_nr > 0 && previous_window_nr != winnr()
- execute previous_window_nr . 'wincmd w'
- let cmd = ':e'
- endif
- endif
-
-
- if vimwiki#vars#get_wikilocal('syntax') == 'markdown'
- let processed_by_markdown_reflink = vimwiki#markdown_base#open_reflink(lnk)
- if processed_by_markdown_reflink
- return
- endif
-
- " remove the extension from the filename if exists, because non-vimwiki
- " markdown files usually include the extension in links
- let lnk = substitute(lnk, '\'.vimwiki#vars#get_wikilocal('ext').'$', '', '')
- endif
-
- let current_tab_page = tabpagenr()
-
- call vimwiki#base#open_link(cmd, lnk)
-
- if !move_cursor_to_new_window
- if (a:split ==# 'hsplit' || a:split ==# 'vsplit')
- execute 'wincmd p'
- elseif a:split ==# 'tab'
- execute 'tabnext ' . current_tab_page
- endif
- endif
-
- else
- if a:0 >= 3
- execute "normal! ".a:3
- else
- call vimwiki#base#normalize_link(0)
- endif
- endif
-endfunction
-
-
-function! vimwiki#base#go_back_link()
- let prev_link = vimwiki#vars#get_bufferlocal('prev_link')
- if !empty(prev_link)
- " go back to saved wiki link
- call vimwiki#base#edit_file(':e ', prev_link[0], '')
- call setpos('.', prev_link[1])
- else
- " maybe we came here by jumping to a tag -> pop from the tag stack
- silent! pop!
- endif
-endfunction
-
-
-function! vimwiki#base#goto_index(wnum, ...)
- if a:wnum > vimwiki#vars#number_of_wikis()
- echomsg 'Vimwiki Error: Wiki '.a:wnum.' is not registered in your Vimwiki settings!'
- return
- endif
-
- " usually a:wnum is greater then 0 but with the following command it is == 0:
- " vim -n -c ":VimwikiIndex"
- if a:wnum > 0
- let idx = a:wnum - 1
- else
- let idx = 0
- endif
-
- if a:0
- if a:1 == 1
- let cmd = 'tabedit'
- elseif a:1 == 2
- let cmd = 'split'
- elseif a:1 == 3
- let cmd = 'vsplit'
- endif
- else
- let cmd = 'edit'
- endif
-
- let index_file = vimwiki#vars#get_wikilocal('path', idx).
- \ vimwiki#vars#get_wikilocal('index', idx).
- \ vimwiki#vars#get_wikilocal('ext', idx)
-
- call vimwiki#base#edit_file(cmd, index_file, '')
-endfunction
-
-
-function! vimwiki#base#delete_link()
- " Delete wiki file you are in from filesystem
- let val = input('Delete "'.expand('%').'" [y]es/[N]o? ')
- if val !~? '^y'
- return
- endif
- let fname = expand('%:p')
- try
- call delete(fname)
- catch /.*/
- echomsg 'Vimwiki Error: Cannot delete "'.expand('%:t:r').'"!'
- return
- endtry
-
- call vimwiki#base#go_back_link()
- execute "bdelete! ".escape(fname, " ")
-
- " reread buffer => deleted wiki link should appear as non-existent
- if expand('%:p') != ""
- execute "e"
- endif
-endfunction
-
-
-" Rename current file, update all links to it
-function! vimwiki#base#rename_link()
- let subdir = vimwiki#vars#get_bufferlocal('subdir')
- let old_fname = subdir.expand('%:t')
-
- " there is no file (new one maybe)
- if glob(expand('%:p')) == ''
- echomsg 'Vimwiki Error: Cannot rename "'.expand('%:p').
- \'". It does not exist! (New file? Save it before renaming.)'
- return
- endif
-
- let val = input('Rename "'.expand('%:t:r').'" [y]es/[N]o? ')
- if val !~? '^y'
- return
- endif
-
- let new_link = input('Enter new name: ')
-
- if new_link =~# '[/\\]'
- echomsg 'Vimwiki Error: Cannot rename to a filename with path!'
- return
- endif
-
- if substitute(new_link, '\s', '', 'g') == ''
- echomsg 'Vimwiki Error: Cannot rename to an empty filename!'
- return
- endif
-
- let url = matchstr(new_link, vimwiki#vars#get_syntaxlocal('rxWikiLinkMatchUrl'))
- if url != ''
- let new_link = url
- endif
-
- let new_link = subdir.new_link
- let wiki_nr = vimwiki#vars#get_bufferlocal("wiki_nr")
- let new_fname = vimwiki#vars#get_wikilocal('path') . new_link . vimwiki#vars#get_wikilocal('ext')
-
- " do not rename if file with such name exists
- let fname = glob(new_fname)
- if fname != ''
- echomsg 'Vimwiki Error: Cannot rename to "'.new_fname.'". File with that name exist!'
- return
- endif
- " rename wiki link file
- try
- echomsg 'Vimwiki: Renaming '.vimwiki#vars#get_wikilocal('path').old_fname.' to '.new_fname
- let res = rename(expand('%:p'), expand(new_fname))
- if res != 0
- throw "Cannot rename!"
- end
- catch /.*/
- echomsg 'Vimwiki Error: Cannot rename "'.expand('%:t:r').'" to "'.new_fname.'"'
- return
- endtry
-
- let &buftype="nofile"
-
- let cur_buffer = [expand('%:p'), vimwiki#vars#get_bufferlocal('prev_link')]
-
- let blist = s:get_wiki_buffers()
-
- " save wiki buffers
- for bitem in blist
- execute ':b '.escape(bitem[0], ' ')
- execute ':update'
- endfor
-
- execute ':b '.escape(cur_buffer[0], ' ')
-
- " remove wiki buffers
- for bitem in blist
- execute 'bwipeout '.escape(bitem[0], ' ')
- endfor
-
- let setting_more = &more
- setlocal nomore
-
- " update links
- call s:update_wiki_links(wiki_nr, s:tail_name(old_fname), s:tail_name(new_link),old_fname)
-
- " restore wiki buffers
- for bitem in blist
- if !vimwiki#path#is_equal(bitem[0], cur_buffer[0])
- call s:open_wiki_buffer(bitem)
- endif
- endfor
-
- call s:open_wiki_buffer([new_fname, cur_buffer[1]])
- " execute 'bwipeout '.escape(cur_buffer[0], ' ')
-
- echomsg 'Vimwiki: '.old_fname.' is renamed to '.new_fname
-
- let &more = setting_more
-endfunction
-
-
-function! vimwiki#base#ui_select()
- call s:print_wiki_list()
- let idx = input("Select Wiki (specify number): ")
- if idx == ""
- return
- endif
- call vimwiki#base#goto_index(idx)
-endfunction
-
-
-function! vimwiki#base#TO_header(inner, including_subheaders, count)
- let headers = s:collect_headers()
- if empty(headers)
- return
- endif
-
- let current_line = line('.')
-
- let current_header_index = s:current_header(headers, current_line)
-
- if current_header_index < 0
- return
- endif
-
- " from which to which header
- if !a:including_subheaders && a:count <= 1
- let first_line = headers[current_header_index][0]
- let last_line = current_header_index == len(headers)-1 ? line('$') :
- \ headers[current_header_index + 1][0] - 1
- else
- let first_header_index = current_header_index
- for _ in range(a:count - 1)
- let parent = s:get_another_header(headers, first_header_index, -1, '<')
- if parent < 0
- break
- else
- let first_header_index = parent
- endif
- endfor
-
- let next_sibling_or_higher = s:get_another_header(headers, first_header_index, +1, '<=')
-
- let first_line = headers[first_header_index][0]
- let last_line =
- \ next_sibling_or_higher >= 0 ? headers[next_sibling_or_higher][0] - 1 : line('$')
- endif
-
- if a:inner
- let first_line += 1
- let last_line = prevnonblank(last_line)
- endif
-
- if first_line > last_line
- " this can happen e.g. when doing vih on a header with another header in the very next line
- return
- endif
-
- call cursor(first_line, 1)
- normal! V
- call cursor(last_line, 1)
-endfunction
-
-
-function! vimwiki#base#TO_table_cell(inner, visual)
- if col('.') == col('$')-1
- return
- endif
-
- if a:visual
- normal! `>
- let sel_end = getpos('.')
- normal! `<
- let sel_start = getpos('.')
-
- let firsttime = sel_start == sel_end
-
- if firsttime
- if !search('|\|\(-+-\)', 'cb', line('.'))
- return
- endif
- if getline('.')[virtcol('.')] == '+'
- normal! l
- endif
- if a:inner
- normal! 2l
- endif
- let sel_start = getpos('.')
- endif
-
- normal! `>
- call search('|\|\(-+-\)', '', line('.'))
- if getline('.')[virtcol('.')] == '+'
- normal! l
- endif
- if a:inner
- if firsttime || abs(sel_end[2] - getpos('.')[2]) != 2
- normal! 2h
- endif
- endif
- let sel_end = getpos('.')
-
- call setpos('.', sel_start)
- exe "normal! \<C-v>"
- call setpos('.', sel_end)
-
- " XXX: WORKAROUND.
- " if blockwise selection is ended at | character then pressing j to extend
- " selection further fails. But if we shake the cursor left and right then
- " it works.
- normal! hl
- else
- if !search('|\|\(-+-\)', 'cb', line('.'))
- return
- endif
- if a:inner
- normal! 2l
- endif
- normal! v
- call search('|\|\(-+-\)', '', line('.'))
- if !a:inner && getline('.')[virtcol('.')-1] == '|'
- normal! h
- elseif a:inner
- normal! 2h
- endif
- endif
-endfunction
-
-
-function! vimwiki#base#TO_table_col(inner, visual)
- let t_rows = vimwiki#tbl#get_rows(line('.'))
- if empty(t_rows)
- return
- endif
-
- " TODO: refactor it!
- if a:visual
- normal! `>
- let sel_end = getpos('.')
- normal! `<
- let sel_start = getpos('.')
-
- let firsttime = sel_start == sel_end
-
- if firsttime
- " place cursor to the top row of the table
- call vimwiki#u#cursor(t_rows[0][0], virtcol('.'))
- " do not accept the match at cursor position if cursor is next to column
- " separator of the table separator (^ is a cursor):
- " |-----^-+-------|
- " | bla | bla |
- " |-------+-------|
- " or it will select wrong column.
- if strpart(getline('.'), virtcol('.')-1) =~# '^-+'
- let s_flag = 'b'
- else
- let s_flag = 'cb'
- endif
- " search the column separator backwards
- if !search('|\|\(-+-\)', s_flag, line('.'))
- return
- endif
- " -+- column separator is matched --> move cursor to the + sign
- if getline('.')[virtcol('.')] == '+'
- normal! l
- endif
- " inner selection --> reduce selection
- if a:inner
- normal! 2l
- endif
- let sel_start = getpos('.')
- endif
-
- normal! `>
- if !firsttime && getline('.')[virtcol('.')] == '|'
- normal! l
- elseif a:inner && getline('.')[virtcol('.')+1] =~# '[|+]'
- normal! 2l
- endif
- " search for the next column separator
- call search('|\|\(-+-\)', '', line('.'))
- " Outer selection selects a column without border on the right. So we move
- " our cursor left if the previous search finds | border, not -+-.
- if getline('.')[virtcol('.')] != '+'
- normal! h
- endif
- if a:inner
- " reduce selection a bit more if inner.
- normal! h
- endif
- " expand selection to the bottom line of the table
- call vimwiki#u#cursor(t_rows[-1][0], virtcol('.'))
- let sel_end = getpos('.')
-
- call setpos('.', sel_start)
- exe "normal! \<C-v>"
- call setpos('.', sel_end)
-
- else
- " place cursor to the top row of the table
- call vimwiki#u#cursor(t_rows[0][0], virtcol('.'))
- " do not accept the match at cursor position if cursor is next to column
- " separator of the table separator (^ is a cursor):
- " |-----^-+-------|
- " | bla | bla |
- " |-------+-------|
- " or it will select wrong column.
- if strpart(getline('.'), virtcol('.')-1) =~# '^-+'
- let s_flag = 'b'
- else
- let s_flag = 'cb'
- endif
- " search the column separator backwards
- if !search('|\|\(-+-\)', s_flag, line('.'))
- return
- endif
- " -+- column separator is matched --> move cursor to the + sign
- if getline('.')[virtcol('.')] == '+'
- normal! l
- endif
- " inner selection --> reduce selection
- if a:inner
- normal! 2l
- endif
-
- exe "normal! \<C-V>"
-
- " search for the next column separator
- call search('|\|\(-+-\)', '', line('.'))
- " Outer selection selects a column without border on the right. So we move
- " our cursor left if the previous search finds | border, not -+-.
- if getline('.')[virtcol('.')] != '+'
- normal! h
- endif
- " reduce selection a bit more if inner.
- if a:inner
- normal! h
- endif
- " expand selection to the bottom line of the table
- call vimwiki#u#cursor(t_rows[-1][0], virtcol('.'))
- endif
-endfunction
-
-
-function! vimwiki#base#AddHeaderLevel()
- let lnum = line('.')
- let line = getline(lnum)
- let rxHdr = vimwiki#vars#get_syntaxlocal('rxH')
- if line =~# '^\s*$'
- return
- endif
-
- if line =~# vimwiki#vars#get_syntaxlocal('rxHeader')
- let level = vimwiki#u#count_first_sym(line)
- if level < 6
- if vimwiki#vars#get_syntaxlocal('symH')
- let line = substitute(line, '\('.rxHdr.'\+\).\+\1', rxHdr.'&'.rxHdr, '')
- else
- let line = substitute(line, '\('.rxHdr.'\+\).\+', rxHdr.'&', '')
- endif
- call setline(lnum, line)
- endif
- else
- let line = substitute(line, '^\s*', '&'.rxHdr.' ', '')
- if vimwiki#vars#get_syntaxlocal('symH')
- let line = substitute(line, '\s*$', ' '.rxHdr.'&', '')
- endif
- call setline(lnum, line)
- endif
-endfunction
-
-
-function! vimwiki#base#RemoveHeaderLevel()
- let lnum = line('.')
- let line = getline(lnum)
- let rxHdr = vimwiki#vars#get_syntaxlocal('rxH')
- if line =~# '^\s*$'
- return
- endif
-
- if line =~# vimwiki#vars#get_syntaxlocal('rxHeader')
- let level = vimwiki#u#count_first_sym(line)
- let old = repeat(rxHdr, level)
- let new = repeat(rxHdr, level - 1)
-
- let chomp = line =~# rxHdr.'\s'
-
- if vimwiki#vars#get_syntaxlocal('symH')
- let line = substitute(line, old, new, 'g')
- else
- let line = substitute(line, old, new, '')
- endif
-
- if level == 1 && chomp
- let line = substitute(line, '^\s', '', 'g')
- let line = substitute(line, '\s$', '', 'g')
- endif
-
- let line = substitute(line, '\s*$', '', '')
-
- call setline(lnum, line)
- endif
-endfunction
-
-
-
-" Returns all the headers in the current buffer as a list of the form
-" [[line_number, header_level, header_text], [...], [...], ...]
-function! s:collect_headers()
- let is_inside_pre_or_math = 0 " 1: inside pre, 2: inside math, 0: outside
- let headers = []
- for lnum in range(1, line('$'))
- let line_content = getline(lnum)
- if (is_inside_pre_or_math == 1 && line_content =~# vimwiki#vars#get_syntaxlocal('rxPreEnd')) ||
- \ (is_inside_pre_or_math == 2 && line_content =~# vimwiki#vars#get_syntaxlocal('rxMathEnd'))
- let is_inside_pre_or_math = 0
- continue
- endif
- if is_inside_pre_or_math > 0
- continue
- endif
- if line_content =~# vimwiki#vars#get_syntaxlocal('rxPreStart')
- let is_inside_pre_or_math = 1
- continue
- endif
- if line_content =~# vimwiki#vars#get_syntaxlocal('rxMathStart')
- let is_inside_pre_or_math = 2
- continue
- endif
- if line_content !~# vimwiki#vars#get_syntaxlocal('rxHeader')
- continue
- endif
- let header_level = vimwiki#u#count_first_sym(line_content)
- let header_text =
- \ vimwiki#u#trim(matchstr(line_content, vimwiki#vars#get_syntaxlocal('rxHeader')))
- call add(headers, [lnum, header_level, header_text])
- endfor
-
- return headers
-endfunction
-
-
-function! s:current_header(headers, line_number)
- if empty(a:headers)
- return -1
- endif
-
- if a:line_number >= a:headers[-1][0]
- return len(a:headers) - 1
- endif
-
- let current_header_index = -1
- while a:headers[current_header_index+1][0] <= a:line_number
- let current_header_index += 1
- endwhile
- return current_header_index
-endfunction
-
-
-function! s:get_another_header(headers, current_index, direction, operation)
- if empty(a:headers) || a:current_index < 0
- return -1
- endif
- let current_level = a:headers[a:current_index][1]
- let index = a:current_index + a:direction
-
- while 1
- if index < 0 || index >= len(a:headers)
- return -1
- endif
- if eval('a:headers[index][1] ' . a:operation . ' current_level')
- return index
- endif
- let index += a:direction
- endwhile
-endfunction
-
-
-function! vimwiki#base#goto_parent_header()
- let headers = s:collect_headers()
- let current_header_index = s:current_header(headers, line('.'))
- let parent_header = s:get_another_header(headers, current_header_index, -1, '<')
- if parent_header >= 0
- call cursor(headers[parent_header][0], 1)
- else
- echo 'Vimwiki: no parent header found'
- endif
-endfunction
-
-
-function! vimwiki#base#goto_next_header()
- let headers = s:collect_headers()
- let current_header_index = s:current_header(headers, line('.'))
- if current_header_index >= 0 && current_header_index < len(headers) - 1
- call cursor(headers[current_header_index + 1][0], 1)
- elseif current_header_index < 0 && !empty(headers) " we're above the first header
- call cursor(headers[0][0], 1)
- else
- echo 'Vimwiki: no next header found'
- endif
-endfunction
-
-
-function! vimwiki#base#goto_prev_header()
- let headers = s:collect_headers()
- let current_header_index = s:current_header(headers, line('.'))
- " if the cursor already was on a header, jump to the previous one
- if current_header_index >= 1 && headers[current_header_index][0] == line('.')
- let current_header_index -= 1
- endif
- if current_header_index >= 0
- call cursor(headers[current_header_index][0], 1)
- else
- echo 'Vimwiki: no previous header found'
- endif
-endfunction
-
-
-function! vimwiki#base#goto_sibling(direction)
- let headers = s:collect_headers()
- let current_header_index = s:current_header(headers, line('.'))
- let next_potential_sibling =
- \ s:get_another_header(headers, current_header_index, a:direction, '<=')
- if next_potential_sibling >= 0 && headers[next_potential_sibling][1] ==
- \ headers[current_header_index][1]
- call cursor(headers[next_potential_sibling][0], 1)
- else
- echo 'Vimwiki: no sibling header found'
- endif
-endfunction
-
-
-" a:create == 1: creates or updates TOC in current file
-" a:create == 0: update if TOC exists
-function! vimwiki#base#table_of_contents(create)
- let headers = s:collect_headers()
- let toc_header_text = vimwiki#vars#get_global('toc_header')
-
- if !a:create
- " Do nothing if there is no TOC to update. (This is a small performance optimization -- if
- " auto_toc == 1, but the current buffer has no TOC but is long, saving the buffer could
- " otherwise take a few seconds for nothing.)
- let toc_already_present = 0
- for entry in headers
- if entry[2] ==# toc_header_text
- let toc_already_present = 1
- break
- endif
- endfor
- if !toc_already_present
- return
- endif
- endif
-
- let numbering = vimwiki#vars#get_global('html_header_numbering')
- let headers_levels = [['', 0], ['', 0], ['', 0], ['', 0], ['', 0], ['', 0]]
- let complete_header_infos = []
- for header in headers
- let h_text = header[2]
- let h_level = header[1]
- if h_text ==# toc_header_text " don't include the TOC's header itself
- continue
- endif
- let headers_levels[h_level-1] = [h_text, headers_levels[h_level-1][1]+1]
- for idx in range(h_level, 5) | let headers_levels[idx] = ['', 0] | endfor
-
- let h_complete_id = ''
- for l in range(h_level-1)
- if headers_levels[l][0] != ''
- let h_complete_id .= headers_levels[l][0].'#'
- endif
- endfor
- let h_complete_id .= headers_levels[h_level-1][0]
-
- if numbering > 0 && numbering <= h_level
- let h_number = join(map(copy(headers_levels[numbering-1 : h_level-1]), 'v:val[1]'), '.')
- let h_number .= vimwiki#vars#get_global('html_header_numbering_sym')
- let h_text = h_number.' '.h_text
- endif
-
- call add(complete_header_infos, [h_level, h_complete_id, h_text])
- endfor
-
- let lines = []
- let startindent = repeat(' ', vimwiki#lst#get_list_margin())
- let indentstring = repeat(' ', vimwiki#u#sw())
- let bullet = vimwiki#lst#default_symbol().' '
- for [lvl, link, desc] in complete_header_infos
- if vimwiki#vars#get_wikilocal('syntax') == 'markdown'
- let link_tpl = vimwiki#vars#get_syntaxlocal('Weblink1Template')
- else
- let link_tpl = vimwiki#vars#get_global('WikiLinkTemplate2')
- endif
- let link = s:safesubstitute(link_tpl, '__LinkUrl__',
- \ '#'.link, '')
- let link = s:safesubstitute(link, '__LinkDescription__', desc, '')
- call add(lines, startindent.repeat(indentstring, lvl-1).bullet.link)
- endfor
-
- let links_rx = '\m^\s*'.vimwiki#u#escape(vimwiki#lst#default_symbol()).' '
-
- call vimwiki#base#update_listing_in_buffer(lines, toc_header_text, links_rx, 1, a:create)
-endfunction
-
-
-" Construct a regular expression matching from template (with special
-" characters properly escaped), by substituting rxUrl for __LinkUrl__, rxDesc
-" for __LinkDescription__, and rxStyle for __LinkStyle__. The three
-" arguments rxUrl, rxDesc, and rxStyle are copied verbatim, without any
-" special character escapes or substitutions.
-function! vimwiki#base#apply_template(template, rxUrl, rxDesc, rxStyle)
- let lnk = a:template
- if a:rxUrl != ""
- let lnk = s:safesubstitute(lnk, '__LinkUrl__', a:rxUrl, 'g')
- endif
- if a:rxDesc != ""
- let lnk = s:safesubstitute(lnk, '__LinkDescription__', a:rxDesc, 'g')
- endif
- if a:rxStyle != ""
- let lnk = s:safesubstitute(lnk, '__LinkStyle__', a:rxStyle, 'g')
- endif
- return lnk
-endfunction
-
-
-function! s:clean_url(url)
- " remove protocol and tld
- let url = substitute(a:url, '^\a\+\d*:', '', '')
- let url = substitute(url, '^//', '', '')
- let url = substitute(url, '^\([^/]\+\)\.\a\{2,4}/', '\1/', '')
- let url = split(url, '/\|=\|-\|&\|?\|\.')
- let url = filter(url, 'v:val !=# ""')
- if url[0] == "www"
- let url = url[1:]
- endif
- if url[-1] =~ '^\(htm\|html\|php\)$'
- let url = url[0:-2]
- endif
- " remove words consisting of only hexadecimal digits or non-word characters
- let url = filter(url, 'v:val !~ "^\\A\\{4,}$"')
- let url = filter(url, 'v:val !~ "^\\x\\{4,}$" || v:val !~ "\\d"')
- return join(url, " ")
-endfunction
-
-
-function! s:is_diary_file(filename)
- let file_path = vimwiki#path#path_norm(a:filename)
- let rel_path = vimwiki#vars#get_wikilocal('diary_rel_path')
- let diary_path = vimwiki#path#path_norm(vimwiki#vars#get_wikilocal('path') . rel_path)
- return rel_path != '' && file_path =~# '^'.vimwiki#u#escape(diary_path)
-endfunction
-
-
-function! vimwiki#base#normalize_link_helper(str, rxUrl, rxDesc, template)
- let url = matchstr(a:str, a:rxUrl)
- let descr = matchstr(a:str, a:rxDesc)
- if descr == ""
- let descr = s:clean_url(url)
- endif
- let lnk = s:safesubstitute(a:template, '__LinkDescription__', descr, '')
- let lnk = s:safesubstitute(lnk, '__LinkUrl__', url, '')
- return lnk
-endfunction
-
-
-function! vimwiki#base#normalize_imagelink_helper(str, rxUrl, rxDesc, rxStyle, template)
- let lnk = vimwiki#base#normalize_link_helper(a:str, a:rxUrl, a:rxDesc, a:template)
- let style = matchstr(a:str, a:rxStyle)
- let lnk = s:safesubstitute(lnk, '__LinkStyle__', style, '')
- return lnk
-endfunction
-
-
-function! s:normalize_link_in_diary(lnk)
- let link = a:lnk . vimwiki#vars#get_wikilocal('ext')
- let link_wiki = vimwiki#vars#get_wikilocal('path') . '/' . link
- let link_diary = vimwiki#vars#get_wikilocal('path') . '/'
- \ . vimwiki#vars#get_wikilocal('diary_rel_path') . '/' . link
- let link_exists_in_diary = filereadable(link_diary)
- let link_exists_in_wiki = filereadable(link_wiki)
- let link_is_date = a:lnk =~# '\d\d\d\d-\d\d-\d\d'
-
- if link_exists_in_diary || link_is_date
- let str = a:lnk
- let rxUrl = vimwiki#vars#get_global('rxWord')
- let rxDesc = ''
- let template = vimwiki#vars#get_global('WikiLinkTemplate1')
- elseif link_exists_in_wiki
- let depth = len(split(vimwiki#vars#get_wikilocal('diary_rel_path'), '/'))
- let str = repeat('../', depth) . a:lnk . '|' . a:lnk
- let rxUrl = '^.*\ze|'
- let rxDesc = '|\zs.*$'
- let template = vimwiki#vars#get_global('WikiLinkTemplate2')
- else
- let str = a:lnk
- let rxUrl = '.*'
- let rxDesc = ''
- let template = vimwiki#vars#get_global('WikiLinkTemplate1')
- endif
-
- return vimwiki#base#normalize_link_helper(str, rxUrl, rxDesc, template)
-endfunction
-
-
-function! s:normalize_link_syntax_n()
-
- " try WikiLink
- let lnk = vimwiki#base#matchstr_at_cursor(vimwiki#vars#get_syntaxlocal('rxWikiLink'))
- if !empty(lnk)
- let sub = vimwiki#base#normalize_link_helper(lnk,
- \ vimwiki#vars#get_syntaxlocal('rxWikiLinkMatchUrl'),
- \ vimwiki#vars#get_syntaxlocal('rxWikiLinkMatchDescr'),
- \ vimwiki#vars#get_global('WikiLinkTemplate2'))
- call vimwiki#base#replacestr_at_cursor(vimwiki#vars#get_syntaxlocal('rxWikiLink'), sub)
- return
- endif
-
- " try WikiIncl
- let lnk = vimwiki#base#matchstr_at_cursor(vimwiki#vars#get_global('rxWikiIncl'))
- if !empty(lnk)
- " NO-OP !!
- return
- endif
-
- " try Weblink
- let lnk = vimwiki#base#matchstr_at_cursor(vimwiki#vars#get_syntaxlocal('rxWeblink'))
- if !empty(lnk)
- let sub = vimwiki#base#normalize_link_helper(lnk,
- \ lnk, '', vimwiki#vars#get_global('WikiLinkTemplate2'))
- call vimwiki#base#replacestr_at_cursor(vimwiki#vars#get_syntaxlocal('rxWeblink'), sub)
- return
- endif
-
- " try Word (any characters except separators)
- " rxWord is less permissive than rxWikiLinkUrl which is used in
- " normalize_link_syntax_v
- let lnk = vimwiki#base#matchstr_at_cursor(vimwiki#vars#get_global('rxWord'))
- if !empty(lnk)
- if s:is_diary_file(expand("%:p"))
- let sub = s:normalize_link_in_diary(lnk)
- else
- let sub = s:safesubstitute(
- \ vimwiki#vars#get_global('WikiLinkTemplate1'), '__LinkUrl__', lnk, '')
- endif
- call vimwiki#base#replacestr_at_cursor('\V'.lnk, sub)
- return
- endif
-
-endfunction
-
-
-function! s:normalize_link_syntax_v()
- let sel_save = &selection
- let &selection = "old"
- let default_register_save = @"
- let registertype_save = getregtype('"')
-
- try
- " Save selected text to register "
- normal! gv""y
-
- " Set substitution
- if s:is_diary_file(expand("%:p"))
- let sub = s:normalize_link_in_diary(@")
- else
- let sub = s:safesubstitute(vimwiki#vars#get_global('WikiLinkTemplate1'),
- \ '__LinkUrl__', @", '')
- endif
-
- " Put substitution in register " and change text
- call setreg('"', substitute(sub, '\n', '', ''), visualmode())
- normal! `>""pgvd
- finally
- call setreg('"', default_register_save, registertype_save)
- let &selection = sel_save
- endtry
-endfunction
-
-
-function! vimwiki#base#normalize_link(is_visual_mode)
- if exists('*vimwiki#'.vimwiki#vars#get_wikilocal('syntax').'_base#normalize_link')
- " Syntax-specific links
- call vimwiki#{vimwiki#vars#get_wikilocal('syntax')}_base#normalize_link(a:is_visual_mode)
- else
- if !a:is_visual_mode
- call s:normalize_link_syntax_n()
- elseif line("'<") == line("'>")
- " action undefined for multi-line visual mode selections
- call s:normalize_link_syntax_v()
- endif
- endif
-endfunction
-
-
-function! vimwiki#base#detect_nested_syntax()
- let last_word = '\v.*<(\w+)\s*$'
- let lines = map(filter(getline(1, "$"), 'v:val =~ "\\%({{{\\|```\\)" && v:val =~ last_word'),
- \ 'substitute(v:val, last_word, "\\=submatch(1)", "")')
- let dict = {}
- for elem in lines
- let dict[elem] = elem
- endfor
- return dict
-endfunction
-
-
-function! vimwiki#base#complete_links_escaped(ArgLead, CmdLine, CursorPos) abort
- " We can safely ignore args if we use -custom=complete option, Vim engine
- " will do the job of filtering.
- return vimwiki#base#get_globlinks_escaped()
-endfunction
-
-
-" -------------------------------------------------------------------------
-" Load syntax-specific Wiki functionality
-for s:syn in s:vimwiki_get_known_syntaxes()
- execute 'runtime! autoload/vimwiki/'.s:syn.'_base.vim'
-endfor
-" -------------------------------------------------------------------------
-
diff --git a/.config/nvim/autoload/vimwiki/customwiki2html.sh b/.config/nvim/autoload/vimwiki/customwiki2html.sh
@@ -1,62 +0,0 @@
-#!/bin/bash
-
-#
-# This script converts markdown into html, to be used with vimwiki's
-# "customwiki2html" option. Experiment with the two proposed methods by
-# commenting / uncommenting the relevant lines below.
-#
-# NEW! An alternative converter was developed by Jason6Anderson, and can
-# be located at https://github.com/vimwiki-backup/vimwiki/issues/384
-#
-#
-# To use this script, you must have the Discount converter installed.
-#
-# http://www.pell.portland.or.us/~orc/Code/discount/
-#
-# To verify your installation, check that the commands markdown and mkd2text,
-# are on your path.
-#
-# Also verify that this file is executable.
-#
-# Then, in your .vimrc file, set:
-#
-# g:vimwiki_customwiki2html=$HOME.'/.vim/autoload/vimwiki/customwiki2html.sh'
-#
-# On your next restart, Vimwiki will run this script instead of using the
-# internal wiki2html converter.
-#
-
-MARKDOWN=markdown
-MKD2HTML=mkd2html
-
-
-FORCE="$1"
-SYNTAX="$2"
-EXTENSION="$3"
-OUTPUTDIR="$4"
-INPUT="$5"
-CSSFILE="$6"
-
-FORCEFLAG=
-
-[ $FORCE -eq 0 ] || { FORCEFLAG="-f"; };
-[ $SYNTAX = "markdown" ] || { echo "Error: Unsupported syntax"; exit -2; };
-
-OUTPUT="$OUTPUTDIR"/$(basename "$INPUT" .$EXTENSION).html
-
-# # Method 1:
-# # markdown [-d] [-T] [-V] [-b url-base] [-C prefix] [-F bitmap] [-f flags] [-o file] [-s text] [-t text] [textfile]
-#
-# URLBASE=http://example.com
-# $MARKDOWN -T -b $URLBASE -o $OUTPUT $INPUT
-
-
-# Method 2:
-# mkd2html [-css file] [-header string] [-footer string] [file]
-
-$MKD2HTML -css "$CSSFILE" "$INPUT"
-OUTPUTTMP=$(dirname "$INPUT")/$(basename "$INPUT" ."$EXTENSION").html
-mv -f "$OUTPUTTMP" "$OUTPUT"
-
-
-
diff --git a/.config/nvim/autoload/vimwiki/default.tpl b/.config/nvim/autoload/vimwiki/default.tpl
@@ -1,11 +0,0 @@
-<!DOCTYPE html>
-<html>
-<head>
-<link rel="Stylesheet" type="text/css" href="%root_path%%css%">
-<title>%title%</title>
-<meta http-equiv="Content-Type" content="text/html; charset=%encoding%">
-</head>
-<body>
-%content%
-</body>
-</html>
diff --git a/.config/nvim/autoload/vimwiki/diary.vim b/.config/nvim/autoload/vimwiki/diary.vim
@@ -1,327 +0,0 @@
-" vim:tabstop=2:shiftwidth=2:expandtab:textwidth=99
-" Vimwiki autoload plugin file
-" Description: Handle diary notes
-" Home: https://github.com/vimwiki/vimwiki/
-
-
-if exists("g:loaded_vimwiki_diary_auto") || &cp
- finish
-endif
-let g:loaded_vimwiki_diary_auto = 1
-
-
-let s:vimwiki_max_scan_for_caption = 5
-
-
-function! s:prefix_zero(num)
- if a:num < 10
- return '0'.a:num
- endif
- return a:num
-endfunction
-
-
-function! s:diary_path(...)
- let idx = a:0 == 0 ? vimwiki#vars#get_bufferlocal('wiki_nr') : a:1
- return vimwiki#vars#get_wikilocal('path', idx).vimwiki#vars#get_wikilocal('diary_rel_path', idx)
-endfunction
-
-
-function! s:diary_index(...)
- let idx = a:0 == 0 ? vimwiki#vars#get_bufferlocal('wiki_nr') : a:1
- return s:diary_path(idx).vimwiki#vars#get_wikilocal('diary_index', idx).
- \ vimwiki#vars#get_wikilocal('ext', idx)
-endfunction
-
-
-function! vimwiki#diary#diary_date_link(...)
- if a:0
- return strftime('%Y-%m-%d', a:1)
- else
- return strftime('%Y-%m-%d')
- endif
-endfunction
-
-
-function! s:get_position_links(link)
- let idx = -1
- let links = []
- if a:link =~# '^\d\{4}-\d\d-\d\d'
- let links = map(s:get_diary_files(), 'fnamemodify(v:val, ":t:r")')
- " include 'today' into links
- if index(links, vimwiki#diary#diary_date_link()) == -1
- call add(links, vimwiki#diary#diary_date_link())
- endif
- call sort(links)
- let idx = index(links, a:link)
- endif
- return [idx, links]
-endfunction
-
-
-function! s:get_month_name(month)
- return vimwiki#vars#get_global('diary_months')[str2nr(a:month)]
-endfunction
-
-
-function! s:read_captions(files)
- let result = {}
- let rx_header = vimwiki#vars#get_syntaxlocal('rxHeader')
- for fl in a:files
- " remove paths and extensions
- let fl_key = substitute(fnamemodify(fl, ':t'), vimwiki#vars#get_wikilocal('ext').'$', '', '')
-
- if filereadable(fl)
- for line in readfile(fl, '', s:vimwiki_max_scan_for_caption)
- if line =~# rx_header && !has_key(result, fl_key)
- let result[fl_key] = vimwiki#u#trim(matchstr(line, rx_header))
- endif
- endfor
- endif
-
- if !has_key(result, fl_key)
- let result[fl_key] = ''
- endif
-
- endfor
- return result
-endfunction
-
-
-function! s:get_diary_files()
- let rx = '^\d\{4}-\d\d-\d\d'
- let s_files = glob(vimwiki#vars#get_wikilocal('path').
- \ vimwiki#vars#get_wikilocal('diary_rel_path').'*'.vimwiki#vars#get_wikilocal('ext'))
- let files = split(s_files, '\n')
- call filter(files, 'fnamemodify(v:val, ":t") =~# "'.escape(rx, '\').'"')
-
- " remove backup files (.wiki~)
- call filter(files, 'v:val !~# ''.*\~$''')
-
- return files
-endfunction
-
-
-function! s:group_links(links)
- let result = {}
- let p_year = 0
- let p_month = 0
- for fl in sort(keys(a:links))
- let year = strpart(fl, 0, 4)
- let month = strpart(fl, 5, 2)
- if p_year != year
- let result[year] = {}
- let p_month = 0
- endif
- if p_month != month
- let result[year][month] = {}
- endif
- let result[year][month][fl] = a:links[fl]
- let p_year = year
- let p_month = month
- endfor
- return result
-endfunction
-
-
-function! s:sort(lst)
- if vimwiki#vars#get_wikilocal('diary_sort') ==? 'desc'
- return reverse(sort(a:lst))
- else
- return sort(a:lst)
- endif
-endfunction
-
-
-function! s:format_diary()
- let result = []
-
- let links_with_captions = s:read_captions(s:get_diary_files())
- let g_files = s:group_links(links_with_captions)
-
- for year in s:sort(keys(g_files))
- call add(result, '')
- call add(result,
- \ substitute(vimwiki#vars#get_syntaxlocal('rxH2_Template'), '__Header__', year , ''))
-
- for month in s:sort(keys(g_files[year]))
- call add(result, '')
- call add(result, substitute(vimwiki#vars#get_syntaxlocal('rxH3_Template'),
- \ '__Header__', s:get_month_name(month), ''))
-
- for [fl, cap] in s:sort(items(g_files[year][month]))
- let link_tpl = vimwiki#vars#get_global('WikiLinkTemplate2')
-
- if vimwiki#vars#get_wikilocal('syntax') == 'markdown'
- let link_tpl = vimwiki#vars#get_syntaxlocal('Weblink1Template')
-
- if empty(cap) " When using markdown syntax, we should ensure we always have a link description.
- let cap = fl
- endif
- elseif empty(cap)
- let link_tpl = vimwiki#vars#get_global('WikiLinkTemplate1')
- endif
-
- let entry = substitute(link_tpl, '__LinkUrl__', fl, '')
- let entry = substitute(entry, '__LinkDescription__', cap, '')
- call add(result, repeat(' ', vimwiki#lst#get_list_margin()).'* '.entry)
- endfor
-
- endfor
- endfor
-
- return result
-endfunction
-
-
-" The given wiki number a:wnum is 1 for the first wiki, 2 for the second and so on. This is in
-" contrast to most other places, where counting starts with 0. When a:wnum is 0, the current wiki
-" is used.
-function! vimwiki#diary#make_note(wnum, ...)
- if a:wnum == 0
- let wiki_nr = vimwiki#vars#get_bufferlocal('wiki_nr')
- if wiki_nr < 0 " this happens when e.g. VimwikiMakeDiaryNote was called outside a wiki buffer
- let wiki_nr = 0
- endif
- else
- let wiki_nr = a:wnum - 1
- endif
-
- if wiki_nr >= vimwiki#vars#number_of_wikis()
- echomsg 'Vimwiki Error: Wiki '.wiki_nr.' is not registered in g:vimwiki_list!'
- return
- endif
-
- " TODO: refactor it. base#goto_index uses the same
-
- call vimwiki#path#mkdir(vimwiki#vars#get_wikilocal('path', wiki_nr).
- \ vimwiki#vars#get_wikilocal('diary_rel_path', wiki_nr))
-
- let cmd = 'edit'
- if a:0
- if a:1 == 1
- let cmd = 'tabedit'
- elseif a:1 == 2
- let cmd = 'split'
- elseif a:1 == 3
- let cmd = 'vsplit'
- endif
- endif
- if a:0>1
- let link = 'diary:'.a:2
- else
- let link = 'diary:'.vimwiki#diary#diary_date_link()
- endif
-
- call vimwiki#base#open_link(cmd, link, s:diary_index(wiki_nr))
-endfunction
-
-
-function! vimwiki#diary#goto_diary_index(wnum)
- if a:wnum > vimwiki#vars#number_of_wikis()
- echomsg 'Vimwiki Error: Wiki '.a:wnum.' is not registered in g:vimwiki_list!'
- return
- endif
-
- " TODO: refactor it. base#goto_index uses the same
- if a:wnum > 0
- let idx = a:wnum - 1
- else
- let idx = 0
- endif
-
- call vimwiki#base#edit_file('e', s:diary_index(idx), '')
-
- if vimwiki#vars#get_wikilocal('auto_diary_index')
- call vimwiki#diary#generate_diary_section()
- write! " save changes
- endif
-endfunction
-
-
-function! vimwiki#diary#goto_next_day()
- let link = ''
- let [idx, links] = s:get_position_links(expand('%:t:r'))
-
- if idx == (len(links) - 1)
- return
- endif
-
- if idx != -1 && idx < len(links) - 1
- let link = 'diary:'.links[idx+1]
- else
- " goto today
- let link = 'diary:'.vimwiki#diary#diary_date_link()
- endif
-
- if len(link)
- call vimwiki#base#open_link(':e ', link)
- endif
-endfunction
-
-
-function! vimwiki#diary#goto_prev_day()
- let link = ''
- let [idx, links] = s:get_position_links(expand('%:t:r'))
-
- if idx == 0
- return
- endif
-
- if idx > 0
- let link = 'diary:'.links[idx-1]
- else
- " goto today
- let link = 'diary:'.vimwiki#diary#diary_date_link()
- endif
-
- if len(link)
- call vimwiki#base#open_link(':e ', link)
- endif
-endfunction
-
-
-function! vimwiki#diary#generate_diary_section()
- let current_file = vimwiki#path#path_norm(expand("%:p"))
- let diary_file = vimwiki#path#path_norm(s:diary_index())
- if vimwiki#path#is_equal(current_file, diary_file)
- let content_rx = '^\%(\s*\* \)\|\%(^\s*$\)\|\%('.vimwiki#vars#get_syntaxlocal('rxHeader').'\)'
- call vimwiki#base#update_listing_in_buffer(s:format_diary(),
- \ vimwiki#vars#get_wikilocal('diary_header'), content_rx, line('$')+1, 1)
- else
- echomsg 'Vimwiki Error: You can generate diary links only in a diary index page!'
- endif
-endfunction
-
-
-" Callback function for Calendar.vim
-function! vimwiki#diary#calendar_action(day, month, year, week, dir)
- let day = s:prefix_zero(a:day)
- let month = s:prefix_zero(a:month)
-
- let link = a:year.'-'.month.'-'.day
- if winnr('#') == 0
- if a:dir ==? 'V'
- vsplit
- else
- split
- endif
- else
- wincmd p
- if !&hidden && &modified
- new
- endif
- endif
-
- call vimwiki#diary#make_note(0, 0, link)
-endfunction
-
-
-function vimwiki#diary#calendar_sign(day, month, year)
- let day = s:prefix_zero(a:day)
- let month = s:prefix_zero(a:month)
- let sfile = vimwiki#vars#get_wikilocal('path').vimwiki#vars#get_wikilocal('diary_rel_path').
- \ a:year.'-'.month.'-'.day.vimwiki#vars#get_wikilocal('ext')
- return filereadable(expand(sfile))
-endfunction
-
diff --git a/.config/nvim/autoload/vimwiki/html.vim b/.config/nvim/autoload/vimwiki/html.vim
@@ -1,1664 +0,0 @@
-" vim:tabstop=2:shiftwidth=2:expandtab:textwidth=99
-" Vimwiki autoload plugin file
-" Description: HTML export
-" Home: https://github.com/vimwiki/vimwiki/
-
-
-if exists("g:loaded_vimwiki_html_auto") || &cp
- finish
-endif
-let g:loaded_vimwiki_html_auto = 1
-
-
-function! s:root_path(subdir)
- return repeat('../', len(split(a:subdir, '[/\\]')))
-endfunction
-
-
-function! s:syntax_supported()
- return vimwiki#vars#get_wikilocal('syntax') ==? "default"
-endfunction
-
-
-function! s:remove_blank_lines(lines)
- while !empty(a:lines) && a:lines[-1] =~# '^\s*$'
- call remove(a:lines, -1)
- endwhile
-endfunction
-
-
-function! s:is_web_link(lnk)
- if a:lnk =~# '^\%(https://\|http://\|www.\|ftp://\|file://\|mailto:\)'
- return 1
- endif
- return 0
-endfunction
-
-
-function! s:is_img_link(lnk)
- if tolower(a:lnk) =~# '\.\%(png\|jpg\|gif\|jpeg\)$'
- return 1
- endif
- return 0
-endfunction
-
-
-function! s:has_abs_path(fname)
- if a:fname =~# '\(^.:\)\|\(^/\)'
- return 1
- endif
- return 0
-endfunction
-
-
-function! s:find_autoload_file(name)
- for path in split(&runtimepath, ',')
- let fname = path.'/autoload/vimwiki/'.a:name
- if glob(fname) != ''
- return fname
- endif
- endfor
- return ''
-endfunction
-
-
-function! s:default_CSS_full_name(path)
- let path = expand(a:path)
- let css_full_name = path . vimwiki#vars#get_wikilocal('css_name')
- return css_full_name
-endfunction
-
-
-function! s:create_default_CSS(path)
- let css_full_name = s:default_CSS_full_name(a:path)
- if glob(css_full_name) == ""
- call vimwiki#path#mkdir(fnamemodify(css_full_name, ':p:h'))
- let default_css = s:find_autoload_file('style.css')
- if default_css != ''
- let lines = readfile(default_css)
- call writefile(lines, css_full_name)
- return 1
- endif
- endif
- return 0
-endfunction
-
-
-function! s:template_full_name(name)
- if a:name == ''
- let name = vimwiki#vars#get_wikilocal('template_default')
- else
- let name = a:name
- endif
-
- let fname = expand(vimwiki#vars#get_wikilocal('template_path').
- \ name . vimwiki#vars#get_wikilocal('template_ext'))
-
- if filereadable(fname)
- return fname
- else
- return ''
- endif
-endfunction
-
-
-function! s:get_html_template(template)
- " TODO: refactor it!!!
- let lines=[]
-
- if a:template != ''
- let template_name = s:template_full_name(a:template)
- try
- let lines = readfile(template_name)
- return lines
- catch /E484/
- echomsg 'Vimwiki: HTML template '.template_name. ' does not exist!'
- endtry
- endif
-
- let default_tpl = s:template_full_name('')
-
- if default_tpl == ''
- let default_tpl = s:find_autoload_file('default.tpl')
- endif
-
- let lines = readfile(default_tpl)
- return lines
-endfunction
-
-
-function! s:safe_html_preformatted(line)
- let line = substitute(a:line,'<','\<', 'g')
- let line = substitute(line,'>','\>', 'g')
- return line
-endfunction
-
-
-function! s:escape_html_attribute(string)
- return substitute(a:string, '"', '\"', 'g')
-endfunction
-
-
-function! s:safe_html_line(line)
- " escape & < > when producing HTML text
- " s:lt_pattern, s:gt_pattern depend on g:vimwiki_valid_html_tags
- " and are set in vimwiki#html#Wiki2HTML()
- let line = substitute(a:line, '&', '\&', 'g')
- let line = substitute(line,s:lt_pattern,'\<', 'g')
- let line = substitute(line,s:gt_pattern,'\>', 'g')
-
- return line
-endfunction
-
-
-function! s:delete_html_files(path)
- let htmlfiles = split(glob(a:path.'**/*.html'), '\n')
- for fname in htmlfiles
- " ignore user html files, e.g. search.html,404.html
- if stridx(vimwiki#vars#get_global('user_htmls'), fnamemodify(fname, ":t")) >= 0
- continue
- endif
-
- " delete if there is no corresponding wiki file
- let subdir = vimwiki#base#subdir(vimwiki#vars#get_wikilocal('path_html'), fname)
- let wikifile = vimwiki#vars#get_wikilocal('path').subdir.
- \fnamemodify(fname, ":t:r").vimwiki#vars#get_wikilocal('ext')
- if filereadable(wikifile)
- continue
- endif
-
- try
- call delete(fname)
- catch
- echomsg 'Vimwiki Error: Cannot delete '.fname
- endtry
- endfor
-endfunction
-
-
-function! s:mid(value, cnt)
- return strpart(a:value, a:cnt, len(a:value) - 2 * a:cnt)
-endfunction
-
-
-function! s:subst_func(line, regexp, func, ...)
- " Substitute text found by regexp with result of
- " func(matched) function.
-
- let pos = 0
- let lines = split(a:line, a:regexp, 1)
- let res_line = ""
- for line in lines
- let res_line = res_line.line
- let matched = matchstr(a:line, a:regexp, pos)
- if matched != ""
- if a:0
- let res_line = res_line.{a:func}(matched, a:1)
- else
- let res_line = res_line.{a:func}(matched)
- endif
- endif
- let pos = matchend(a:line, a:regexp, pos)
- endfor
- return res_line
-endfunction
-
-
-function! s:process_date(placeholders, default_date)
- if !empty(a:placeholders)
- for [placeholder, row, idx] in a:placeholders
- let [type, param] = placeholder
- if type ==# 'date' && !empty(param)
- return param
- endif
- endfor
- endif
- return a:default_date
-endfunction
-
-
-function! s:process_title(placeholders, default_title)
- if !empty(a:placeholders)
- for [placeholder, row, idx] in a:placeholders
- let [type, param] = placeholder
- if type ==# 'title' && !empty(param)
- return param
- endif
- endfor
- endif
- return a:default_title
-endfunction
-
-
-function! s:is_html_uptodate(wikifile)
- let tpl_time = -1
-
- let tpl_file = s:template_full_name('')
- if tpl_file != ''
- let tpl_time = getftime(tpl_file)
- endif
-
- let wikifile = fnamemodify(a:wikifile, ":p")
- let htmlfile = expand(vimwiki#vars#get_wikilocal('path_html') .
- \ vimwiki#vars#get_bufferlocal('subdir') . fnamemodify(wikifile, ":t:r").".html")
-
- if getftime(wikifile) <= getftime(htmlfile) && tpl_time <= getftime(htmlfile)
- return 1
- endif
- return 0
-endfunction
-
-
-function! s:html_insert_contents(html_lines, content)
- let lines = []
- for line in a:html_lines
- if line =~# '%content%'
- let parts = split(line, '%content%', 1)
- if empty(parts)
- call extend(lines, a:content)
- else
- for idx in range(len(parts))
- call add(lines, parts[idx])
- if idx < len(parts) - 1
- call extend(lines, a:content)
- endif
- endfor
- endif
- else
- call add(lines, line)
- endif
- endfor
- return lines
-endfunction
-
-
-function! s:tag_eqin(value)
- " mathJAX wants \( \) for inline maths
- return '\('.s:mid(a:value, 1).'\)'
-endfunction
-
-
-function! s:tag_em(value)
- return '<em>'.s:mid(a:value, 1).'</em>'
-endfunction
-
-
-function! s:tag_strong(value, header_ids)
- let text = s:mid(a:value, 1)
- let id = s:escape_html_attribute(text)
- let complete_id = ''
- for l in range(6)
- if a:header_ids[l][0] != ''
- let complete_id .= a:header_ids[l][0].'-'
- endif
- endfor
- if a:header_ids[5][0] == ''
- let complete_id = complete_id[:-2]
- endif
- let complete_id .= '-'.id
- return '<span id="'.s:escape_html_attribute(complete_id).'"></span><strong id="'
- \ .id.'">'.text.'</strong>'
-endfunction
-
-
-function! s:tag_tags(value, header_ids)
- let complete_id = ''
- for level in range(6)
- if a:header_ids[level][0] != ''
- let complete_id .= a:header_ids[level][0].'-'
- endif
- endfor
- if a:header_ids[5][0] == ''
- let complete_id = complete_id[:-2]
- endif
- let complete_id = s:escape_html_attribute(complete_id)
-
- let result = []
- for tag in split(a:value, ':')
- let id = s:escape_html_attribute(tag)
- call add(result, '<span id="'.complete_id.'-'.id.'"></span><span class="tag" id="'
- \ .id.'">'.tag.'</span>')
- endfor
- return join(result)
-endfunction
-
-
-function! s:tag_todo(value)
- return '<span class="todo">'.a:value.'</span>'
-endfunction
-
-
-function! s:tag_strike(value)
- return '<del>'.s:mid(a:value, 2).'</del>'
-endfunction
-
-
-function! s:tag_super(value)
- return '<sup><small>'.s:mid(a:value, 1).'</small></sup>'
-endfunction
-
-
-function! s:tag_sub(value)
- return '<sub><small>'.s:mid(a:value, 2).'</small></sub>'
-endfunction
-
-
-function! s:tag_code(value)
- return '<code>'.s:safe_html_preformatted(s:mid(a:value, 1)).'</code>'
-endfunction
-
-
-" match n-th ARG within {{URL[|ARG1|ARG2|...]}}
-" *c,d,e),...
-function! s:incl_match_arg(nn_index)
- let rx = vimwiki#vars#get_global('rxWikiInclPrefix'). vimwiki#vars#get_global('rxWikiInclUrl')
- let rx = rx . repeat(vimwiki#vars#get_global('rxWikiInclSeparator') .
- \ vimwiki#vars#get_global('rxWikiInclArg'), a:nn_index-1)
- if a:nn_index > 0
- let rx = rx. vimwiki#vars#get_global('rxWikiInclSeparator'). '\zs' .
- \ vimwiki#vars#get_global('rxWikiInclArg') . '\ze'
- endif
- let rx = rx . vimwiki#vars#get_global('rxWikiInclArgs') .
- \ vimwiki#vars#get_global('rxWikiInclSuffix')
- return rx
-endfunction
-
-
-function! s:linkify_link(src, descr)
- let src_str = ' href="'.s:escape_html_attribute(a:src).'"'
- let descr = vimwiki#u#trim(a:descr)
- let descr = (descr == "" ? a:src : descr)
- let descr_str = (descr =~# vimwiki#vars#get_global('rxWikiIncl')
- \ ? s:tag_wikiincl(descr)
- \ : descr)
- return '<a'.src_str.'>'.descr_str.'</a>'
-endfunction
-
-
-function! s:linkify_image(src, descr, verbatim_str)
- let src_str = ' src="'.a:src.'"'
- let descr_str = (a:descr != '' ? ' alt="'.a:descr.'"' : '')
- let verbatim_str = (a:verbatim_str != '' ? ' '.a:verbatim_str : '')
- return '<img'.src_str.descr_str.verbatim_str.' />'
-endfunction
-
-
-function! s:tag_weblink(value)
- " Weblink Template -> <a href="url">descr</a>
- let str = a:value
- let url = matchstr(str, vimwiki#vars#get_syntaxlocal('rxWeblinkMatchUrl'))
- let descr = matchstr(str, vimwiki#vars#get_syntaxlocal('rxWeblinkMatchDescr'))
- let line = s:linkify_link(url, descr)
- return line
-endfunction
-
-
-function! s:tag_wikiincl(value)
- " {{imgurl|arg1|arg2}} -> ???
- " {{imgurl}} -> <img src="imgurl"/>
- " {{imgurl|descr|style="A"}} -> <img src="imgurl" alt="descr" style="A" />
- " {{imgurl|descr|class="B"}} -> <img src="imgurl" alt="descr" class="B" />
- let str = a:value
- " custom transclusions
- let line = VimwikiWikiIncludeHandler(str)
- " otherwise, assume image transclusion
- if line == ''
- let url_0 = matchstr(str, vimwiki#vars#get_global('rxWikiInclMatchUrl'))
- let descr = matchstr(str, s:incl_match_arg(1))
- let verbatim_str = matchstr(str, s:incl_match_arg(2))
-
- let link_infos = vimwiki#base#resolve_link(url_0)
-
- if link_infos.scheme =~# '\mlocal\|wiki\d\+\|diary'
- let url = vimwiki#path#relpath(fnamemodify(s:current_html_file, ':h'), link_infos.filename)
- " strip the .html extension when we have wiki links, so that the user can
- " simply write {{image.png}} to include an image from the wiki directory
- if link_infos.scheme =~# '\mwiki\d\+\|diary'
- let url = fnamemodify(url, ':r')
- endif
- else
- let url = link_infos.filename
- endif
-
- let url = escape(url, '#')
- let line = s:linkify_image(url, descr, verbatim_str)
- endif
- return line
-endfunction
-
-
-function! s:tag_wikilink(value)
- " [[url]] -> <a href="url.html">url</a>
- " [[url|descr]] -> <a href="url.html">descr</a>
- " [[url|{{...}}]] -> <a href="url.html"> ... </a>
- " [[fileurl.ext|descr]] -> <a href="fileurl.ext">descr</a>
- " [[dirurl/|descr]] -> <a href="dirurl/index.html">descr</a>
- " [[url#a1#a2]] -> <a href="url.html#a1-a2">url#a1#a2</a>
- " [[#a1#a2]] -> <a href="#a1-a2">#a1#a2</a>
- let str = a:value
- let url = matchstr(str, vimwiki#vars#get_syntaxlocal('rxWikiLinkMatchUrl'))
- let descr = matchstr(str, vimwiki#vars#get_syntaxlocal('rxWikiLinkMatchDescr'))
- let descr = vimwiki#u#trim(descr)
- let descr = (descr != '' ? descr : url)
-
- let line = VimwikiLinkConverter(url, s:current_wiki_file, s:current_html_file)
- if line == ''
- let link_infos = vimwiki#base#resolve_link(url, s:current_wiki_file)
-
- if link_infos.scheme ==# 'file'
- " external file links are always absolute
- let html_link = link_infos.filename
- elseif link_infos.scheme ==# 'local'
- let html_link = vimwiki#path#relpath(fnamemodify(s:current_html_file, ':h'),
- \ link_infos.filename)
- elseif link_infos.scheme =~# '\mwiki\d\+\|diary'
- " wiki links are always relative to the current file
- let html_link = vimwiki#path#relpath(
- \ fnamemodify(s:current_wiki_file, ':h'),
- \ fnamemodify(link_infos.filename, ':r'))
- if html_link !~ '\m/$'
- let html_link .= '.html'
- endif
- else " other schemes, like http, are left untouched
- let html_link = link_infos.filename
- endif
-
- if link_infos.anchor != ''
- let anchor = substitute(link_infos.anchor, '#', '-', 'g')
- let html_link .= '#'.anchor
- endif
- let line = html_link
- endif
-
- let line = s:linkify_link(line, descr)
- return line
-endfunction
-
-
-function! s:tag_remove_internal_link(value)
- let value = s:mid(a:value, 2)
-
- let line = ''
- if value =~# '|'
- let link_parts = split(value, "|", 1)
- else
- let link_parts = split(value, "][", 1)
- endif
-
- if len(link_parts) > 1
- if len(link_parts) < 3
- let style = ""
- else
- let style = link_parts[2]
- endif
- let line = link_parts[1]
- else
- let line = value
- endif
- return line
-endfunction
-
-
-function! s:tag_remove_external_link(value)
- let value = s:mid(a:value, 1)
-
- let line = ''
- if s:is_web_link(value)
- let lnkElements = split(value)
- let head = lnkElements[0]
- let rest = join(lnkElements[1:])
- if rest == ""
- let rest = head
- endif
- let line = rest
- elseif s:is_img_link(value)
- let line = '<img src="'.value.'" />'
- else
- " [alskfj sfsf] shouldn't be a link. So return it as it was --
- " enclosed in [...]
- let line = '['.value.']'
- endif
- return line
-endfunction
-
-
-function! s:make_tag(line, regexp, func, ...)
- " Make tags for a given matched regexp.
- " Exclude preformatted text and href links.
- " FIXME
- let patt_splitter = '\(`[^`]\+`\)\|'.
- \ '\('.vimwiki#vars#get_syntaxlocal('rxPreStart').'.\+'.
- \ vimwiki#vars#get_syntaxlocal('rxPreEnd').'\)\|'.
- \ '\(<a href.\{-}</a>\)\|'.
- \ '\(<img src.\{-}/>\)\|'.
- \ '\(<pre.\{-}</pre>\)\|'.
- \ '\('.vimwiki#vars#get_syntaxlocal('rxEqIn').'\)'
-
- "FIXME FIXME !!! these can easily occur on the same line!
- "XXX {{{ }}} ??? obsolete
- if '`[^`]\+`' ==# a:regexp || '{{{.\+}}}' ==# a:regexp ||
- \ vimwiki#vars#get_syntaxlocal('rxEqIn') ==# a:regexp
- let res_line = s:subst_func(a:line, a:regexp, a:func)
- else
- let pos = 0
- " split line with patt_splitter to have parts of line before and after
- " href links, preformatted text
- " ie:
- " hello world `is just a` simple <a href="link.html">type of</a> prg.
- " result:
- " ['hello world ', ' simple ', 'type of', ' prg']
- let lines = split(a:line, patt_splitter, 1)
- let res_line = ""
- for line in lines
- if a:0
- let res_line = res_line.s:subst_func(line, a:regexp, a:func, a:1)
- else
- let res_line = res_line.s:subst_func(line, a:regexp, a:func)
- endif
- let res_line = res_line.matchstr(a:line, patt_splitter, pos)
- let pos = matchend(a:line, patt_splitter, pos)
- endfor
- endif
- return res_line
-endfunction
-
-
-function! s:process_tags_remove_links(line)
- let line = a:line
- let line = s:make_tag(line, '\[\[.\{-}\]\]', 's:tag_remove_internal_link')
- let line = s:make_tag(line, '\[.\{-}\]', 's:tag_remove_external_link')
- return line
-endfunction
-
-
-function! s:process_tags_typefaces(line, header_ids)
- let line = a:line
- let line = s:make_tag(line, vimwiki#vars#get_syntaxlocal('rxItalic'), 's:tag_em')
- let line = s:make_tag(line, vimwiki#vars#get_syntaxlocal('rxBold'), 's:tag_strong', a:header_ids)
- let line = s:make_tag(line, vimwiki#vars#get_global('rxTodo'), 's:tag_todo')
- let line = s:make_tag(line, vimwiki#vars#get_syntaxlocal('rxDelText'), 's:tag_strike')
- let line = s:make_tag(line, vimwiki#vars#get_syntaxlocal('rxSuperScript'), 's:tag_super')
- let line = s:make_tag(line, vimwiki#vars#get_syntaxlocal('rxSubScript'), 's:tag_sub')
- let line = s:make_tag(line, vimwiki#vars#get_syntaxlocal('rxCode'), 's:tag_code')
- let line = s:make_tag(line, vimwiki#vars#get_syntaxlocal('rxEqIn'), 's:tag_eqin')
- let line = s:make_tag(line, vimwiki#vars#get_syntaxlocal('rxTags'), 's:tag_tags', a:header_ids)
- return line
-endfunction
-
-
-function! s:process_tags_links(line)
- let line = a:line
- let line = s:make_tag(line, vimwiki#vars#get_syntaxlocal('rxWikiLink'), 's:tag_wikilink')
- let line = s:make_tag(line, vimwiki#vars#get_global('rxWikiIncl'), 's:tag_wikiincl')
- let line = s:make_tag(line, vimwiki#vars#get_syntaxlocal('rxWeblink'), 's:tag_weblink')
- return line
-endfunction
-
-
-function! s:process_inline_tags(line, header_ids)
- let line = s:process_tags_links(a:line)
- let line = s:process_tags_typefaces(line, a:header_ids)
- return line
-endfunction
-
-
-function! s:close_tag_pre(pre, ldest)
- if a:pre[0]
- call insert(a:ldest, "</pre>")
- return 0
- endif
- return a:pre
-endfunction
-
-
-function! s:close_tag_math(math, ldest)
- if a:math[0]
- call insert(a:ldest, "\\\]")
- return 0
- endif
- return a:math
-endfunction
-
-
-function! s:close_tag_quote(quote, ldest)
- if a:quote
- call insert(a:ldest, "</blockquote>")
- return 0
- endif
- return a:quote
-endfunction
-
-
-function! s:close_tag_para(para, ldest)
- if a:para
- call insert(a:ldest, "</p>")
- return 0
- endif
- return a:para
-endfunction
-
-
-function! s:close_tag_table(table, ldest, header_ids)
- " The first element of table list is a string which tells us if table should be centered.
- " The rest elements are rows which are lists of columns:
- " ['center',
- " [ CELL1, CELL2, CELL3 ],
- " [ CELL1, CELL2, CELL3 ],
- " [ CELL1, CELL2, CELL3 ],
- " ]
- " And CELLx is: { 'body': 'col_x', 'rowspan': r, 'colspan': c }
-
- function! s:sum_rowspan(table)
- let table = a:table
-
- " Get max cells
- let max_cells = 0
- for row in table[1:]
- let n_cells = len(row)
- if n_cells > max_cells
- let max_cells = n_cells
- end
- endfor
-
- " Sum rowspan
- for cell_idx in range(max_cells)
- let rows = 1
-
- for row_idx in range(len(table)-1, 1, -1)
- if cell_idx >= len(table[row_idx])
- let rows = 1
- continue
- endif
-
- if table[row_idx][cell_idx].rowspan == 0
- let rows += 1
- else " table[row_idx][cell_idx].rowspan == 1
- let table[row_idx][cell_idx].rowspan = rows
- let rows = 1
- endif
- endfor
- endfor
- endfunction
-
- function! s:sum_colspan(table)
- for row in a:table[1:]
- let cols = 1
-
- for cell_idx in range(len(row)-1, 0, -1)
- if row[cell_idx].colspan == 0
- let cols += 1
- else "row[cell_idx].colspan == 1
- let row[cell_idx].colspan = cols
- let cols = 1
- endif
- endfor
- endfor
- endfunction
-
- function! s:close_tag_row(row, header, ldest, header_ids)
- call add(a:ldest, '<tr>')
-
- " Set tag element of columns
- if a:header
- let tag_name = 'th'
- else
- let tag_name = 'td'
- end
-
- " Close tag of columns
- for cell in a:row
- if cell.rowspan == 0 || cell.colspan == 0
- continue
- endif
-
- if cell.rowspan > 1
- let rowspan_attr = ' rowspan="' . cell.rowspan . '"'
- else "cell.rowspan == 1
- let rowspan_attr = ''
- endif
- if cell.colspan > 1
- let colspan_attr = ' colspan="' . cell.colspan . '"'
- else "cell.colspan == 1
- let colspan_attr = ''
- endif
-
- call add(a:ldest, '<' . tag_name . rowspan_attr . colspan_attr .'>')
- call add(a:ldest, s:process_inline_tags(cell.body, a:header_ids))
- call add(a:ldest, '</'. tag_name . '>')
- endfor
-
- call add(a:ldest, '</tr>')
- endfunction
-
- let table = a:table
- let ldest = a:ldest
- if len(table)
- call s:sum_rowspan(table)
- call s:sum_colspan(table)
-
- if table[0] ==# 'center'
- call add(ldest, "<table class='center'>")
- else
- call add(ldest, "<table>")
- endif
-
- " Empty lists are table separators.
- " Search for the last empty list. All the above rows would be a table header.
- " We should exclude the first element of the table list as it is a text tag
- " that shows if table should be centered or not.
- let head = 0
- for idx in range(len(table)-1, 1, -1)
- if empty(table[idx])
- let head = idx
- break
- endif
- endfor
- if head > 0
- for row in table[1 : head-1]
- if !empty(filter(row, '!empty(v:val)'))
- call s:close_tag_row(row, 1, ldest, a:header_ids)
- endif
- endfor
- for row in table[head+1 :]
- call s:close_tag_row(row, 0, ldest, a:header_ids)
- endfor
- else
- for row in table[1 :]
- call s:close_tag_row(row, 0, ldest, a:header_ids)
- endfor
- endif
- call add(ldest, "</table>")
- let table = []
- endif
- return table
-endfunction
-
-
-function! s:close_tag_list(lists, ldest)
- while len(a:lists)
- let item = remove(a:lists, 0)
- call insert(a:ldest, item[0])
- endwhile
-endfunction
-
-
-function! s:close_tag_def_list(deflist, ldest)
- if a:deflist
- call insert(a:ldest, "</dl>")
- return 0
- endif
- return a:deflist
-endfunction
-
-
-function! s:process_tag_pre(line, pre)
- " pre is the list of [is_in_pre, indent_of_pre]
- "XXX always outputs a single line or empty list!
- let lines = []
- let pre = a:pre
- let processed = 0
- "XXX huh?
- "if !pre[0] && a:line =~# '^\s*{{{[^\(}}}\)]*\s*$'
- if !pre[0] && a:line =~# '^\s*{{{'
- let class = matchstr(a:line, '{{{\zs.*$')
- "FIXME class cannot contain arbitrary strings
- let class = substitute(class, '\s\+$', '', 'g')
- if class != ""
- call add(lines, "<pre ".class.">")
- else
- call add(lines, "<pre>")
- endif
- let pre = [1, len(matchstr(a:line, '^\s*\ze{{{'))]
- let processed = 1
- elseif pre[0] && a:line =~# '^\s*}}}\s*$'
- let pre = [0, 0]
- call add(lines, "</pre>")
- let processed = 1
- elseif pre[0]
- let processed = 1
- "XXX destroys indent in general!
- "call add(lines, substitute(a:line, '^\s\{'.pre[1].'}', '', ''))
- call add(lines, s:safe_html_preformatted(a:line))
- endif
- return [processed, lines, pre]
-endfunction
-
-
-function! s:process_tag_math(line, math)
- " math is the list of [is_in_math, indent_of_math]
- let lines = []
- let math = a:math
- let processed = 0
- if !math[0] && a:line =~# '^\s*{{\$[^\(}}$\)]*\s*$'
- let class = matchstr(a:line, '{{$\zs.*$')
- "FIXME class cannot be any string!
- let class = substitute(class, '\s\+$', '', 'g')
- " store the environment name in a global variable in order to close the
- " environment properly
- let s:current_math_env = matchstr(class, '^%\zs\S\+\ze%')
- if s:current_math_env != ""
- call add(lines, substitute(class, '^%\(\S\+\)%', '\\begin{\1}', ''))
- elseif class != ""
- call add(lines, "\\\[".class)
- else
- call add(lines, "\\\[")
- endif
- let math = [1, len(matchstr(a:line, '^\s*\ze{{\$'))]
- let processed = 1
- elseif math[0] && a:line =~# '^\s*}}\$\s*$'
- let math = [0, 0]
- if s:current_math_env != ""
- call add(lines, "\\end{".s:current_math_env."}")
- else
- call add(lines, "\\\]")
- endif
- let processed = 1
- elseif math[0]
- let processed = 1
- call add(lines, substitute(a:line, '^\s\{'.math[1].'}', '', ''))
- endif
- return [processed, lines, math]
-endfunction
-
-
-function! s:process_tag_quote(line, quote)
- let lines = []
- let quote = a:quote
- let processed = 0
- if a:line =~# '^\s\{4,}\S'
- if !quote
- call add(lines, "<blockquote>")
- let quote = 1
- endif
- let processed = 1
- call add(lines, substitute(a:line, '^\s*', '', ''))
- elseif quote
- call add(lines, "</blockquote>")
- let quote = 0
- endif
- return [processed, lines, quote]
-endfunction
-
-
-function! s:process_tag_list(line, lists)
-
- function! s:add_checkbox(line, rx_list)
- let st_tag = '<li>'
- let chk = matchlist(a:line, a:rx_list)
- if !empty(chk) && len(chk[1]) > 0
- let completion = index(vimwiki#vars#get_syntaxlocal('listsyms_list'), chk[1])
- let n = len(vimwiki#vars#get_syntaxlocal('listsyms_list'))
- if completion == 0
- let st_tag = '<li class="done0">'
- elseif completion == -1 && chk[1] == vimwiki#vars#get_global('listsym_rejected')
- let st_tag = '<li class="rejected">'
- elseif completion > 0 && completion < n
- let completion = float2nr(round(completion / (n-1.0) * 3.0 + 0.5 ))
- let st_tag = '<li class="done'.completion.'">'
- endif
- endif
- return [st_tag, '']
- endfunction
-
-
- let in_list = (len(a:lists) > 0)
-
- " If it is not list yet then do not process line that starts from *bold*
- " text.
- " XXX necessary? in *bold* text, no space must follow the first *
- if !in_list
- let pos = match(a:line, '^\s*'.vimwiki#vars#get_syntaxlocal('rxBold'))
- if pos != -1
- return [0, []]
- endif
- endif
-
- let lines = []
- let processed = 0
-
- if a:line =~# '^\s*'.s:bullets.'\s'
- let lstSym = matchstr(a:line, s:bullets)
- let lstTagOpen = '<ul>'
- let lstTagClose = '</ul>'
- let lstRegExp = '^\s*'.s:bullets.'\s'
- elseif a:line =~# '^\s*'.s:numbers.'\s'
- let lstSym = matchstr(a:line, s:numbers)
- let lstTagOpen = '<ol>'
- let lstTagClose = '</ol>'
- let lstRegExp = '^\s*'.s:numbers.'\s'
- else
- let lstSym = ''
- let lstTagOpen = ''
- let lstTagClose = ''
- let lstRegExp = ''
- endif
-
- if lstSym != ''
- " To get proper indent level 'retab' the line -- change all tabs
- " to spaces*tabstop
- let line = substitute(a:line, '\t', repeat(' ', &tabstop), 'g')
- let indent = stridx(line, lstSym)
-
- let checkbox = '\s*\[\(.\)\]\s*'
- let [st_tag, en_tag] = s:add_checkbox(line, lstRegExp.checkbox)
-
- if !in_list
- call add(a:lists, [lstTagClose, indent])
- call add(lines, lstTagOpen)
- elseif (in_list && indent > a:lists[-1][1])
- let item = remove(a:lists, -1)
- call add(lines, item[0])
-
- call add(a:lists, [lstTagClose, indent])
- call add(lines, lstTagOpen)
- elseif (in_list && indent < a:lists[-1][1])
- while len(a:lists) && indent < a:lists[-1][1]
- let item = remove(a:lists, -1)
- call add(lines, item[0])
- endwhile
- elseif in_list
- let item = remove(a:lists, -1)
- call add(lines, item[0])
- endif
-
- call add(a:lists, [en_tag, indent])
- call add(lines, st_tag)
- call add(lines, substitute(a:line, lstRegExp.'\%('.checkbox.'\)\?', '', ''))
- let processed = 1
- elseif in_list && a:line =~# '^\s\+\S\+'
- if vimwiki#vars#get_global('list_ignore_newline')
- call add(lines, a:line)
- else
- call add(lines, '<br />'.a:line)
- endif
- let processed = 1
- else
- call s:close_tag_list(a:lists, lines)
- endif
- return [processed, lines]
-endfunction
-
-
-function! s:process_tag_def_list(line, deflist)
- let lines = []
- let deflist = a:deflist
- let processed = 0
- let matches = matchlist(a:line, '\(^.*\)::\%(\s\|$\)\(.*\)')
- if !deflist && len(matches) > 0
- call add(lines, "<dl>")
- let deflist = 1
- endif
- if deflist && len(matches) > 0
- if matches[1] != ''
- call add(lines, "<dt>".matches[1]."</dt>")
- endif
- if matches[2] != ''
- call add(lines, "<dd>".matches[2]."</dd>")
- endif
- let processed = 1
- elseif deflist
- let deflist = 0
- call add(lines, "</dl>")
- endif
- return [processed, lines, deflist]
-endfunction
-
-
-function! s:process_tag_para(line, para)
- let lines = []
- let para = a:para
- let processed = 0
- if a:line =~# '^\s\{,3}\S'
- if !para
- call add(lines, "<p>")
- let para = 1
- endif
- let processed = 1
- if vimwiki#vars#get_global('text_ignore_newline')
- call add(lines, a:line)
- else
- call add(lines, a:line."<br />")
- endif
- elseif para && a:line =~# '^\s*$'
- call add(lines, "</p>")
- let para = 0
- endif
- return [processed, lines, para]
-endfunction
-
-
-function! s:process_tag_h(line, id)
- let line = a:line
- let processed = 0
- let h_level = 0
- let h_text = ''
- let h_id = ''
-
- if a:line =~# vimwiki#vars#get_syntaxlocal('rxHeader')
- let h_level = vimwiki#u#count_first_sym(a:line)
- endif
- if h_level > 0
-
- let h_text = vimwiki#u#trim(matchstr(line, vimwiki#vars#get_syntaxlocal('rxHeader')))
- let h_number = ''
- let h_complete_id = ''
- let h_id = s:escape_html_attribute(h_text)
- let centered = (a:line =~# '^\s')
-
- if h_text !=# vimwiki#vars#get_global('toc_header')
-
- let a:id[h_level-1] = [h_text, a:id[h_level-1][1]+1]
-
- " reset higher level ids
- for level in range(h_level, 5)
- let a:id[level] = ['', 0]
- endfor
-
- for l in range(h_level-1)
- let h_number .= a:id[l][1].'.'
- if a:id[l][0] != ''
- let h_complete_id .= a:id[l][0].'-'
- endif
- endfor
- let h_number .= a:id[h_level-1][1]
- let h_complete_id .= a:id[h_level-1][0]
-
- if vimwiki#vars#get_global('html_header_numbering')
- let num = matchstr(h_number,
- \ '^\(\d.\)\{'.(vimwiki#vars#get_global('html_header_numbering')-1).'}\zs.*')
- if !empty(num)
- let num .= vimwiki#vars#get_global('html_header_numbering_sym')
- endif
- let h_text = num.' '.h_text
- endif
- let h_complete_id = s:escape_html_attribute(h_complete_id)
- let h_part = '<div id="'.h_complete_id.'">'
- let h_part .= '<h'.h_level.' id="'.h_id.'" class="header">'
- let h_part .= '<a href="#'.h_complete_id.'"'
-
- else
-
- let h_part = '<div id="'.h_id.'" class="toc"><h1 id="'.h_id.'"'
-
- endif
-
- if centered
- let h_part .= ' class="justcenter">'
- else
- let h_part .= '>'
- endif
-
- let h_text = s:process_inline_tags(h_text, a:id)
-
- let line = h_part.h_text.'</a></h'.h_level.'></div>'
-
- let processed = 1
- endif
- return [processed, line]
-endfunction
-
-
-function! s:process_tag_hr(line)
- let line = a:line
- let processed = 0
- if a:line =~# '^-----*$'
- let line = '<hr />'
- let processed = 1
- endif
- return [processed, line]
-endfunction
-
-
-function! s:process_tag_table(line, table, header_ids)
- function! s:table_empty_cell(value)
- let cell = {}
-
- if a:value =~# '^\s*\\/\s*$'
- let cell.body = ''
- let cell.rowspan = 0
- let cell.colspan = 1
- elseif a:value =~# '^\s*>\s*$'
- let cell.body = ''
- let cell.rowspan = 1
- let cell.colspan = 0
- elseif a:value =~# '^\s*$'
- let cell.body = ' '
- let cell.rowspan = 1
- let cell.colspan = 1
- else
- let cell.body = a:value
- let cell.rowspan = 1
- let cell.colspan = 1
- endif
-
- return cell
- endfunction
-
- function! s:table_add_row(table, line)
- if empty(a:table)
- if a:line =~# '^\s\+'
- let row = ['center', []]
- else
- let row = ['normal', []]
- endif
- else
- let row = [[]]
- endif
- return row
- endfunction
-
- let table = a:table
- let lines = []
- let processed = 0
-
- if vimwiki#tbl#is_separator(a:line)
- call extend(table, s:table_add_row(a:table, a:line))
- let processed = 1
- elseif vimwiki#tbl#is_table(a:line)
- call extend(table, s:table_add_row(a:table, a:line))
-
- let processed = 1
- " let cells = split(a:line, vimwiki#tbl#cell_splitter(), 1)[1: -2]
- let cells = vimwiki#tbl#get_cells(a:line)
- call map(cells, 's:table_empty_cell(v:val)')
- call extend(table[-1], cells)
- else
- let table = s:close_tag_table(table, lines, a:header_ids)
- endif
- return [processed, lines, table]
-endfunction
-
-
-function! s:parse_line(line, state)
- let state = {}
- let state.para = a:state.para
- let state.quote = a:state.quote
- let state.pre = a:state.pre[:]
- let state.math = a:state.math[:]
- let state.table = a:state.table[:]
- let state.lists = a:state.lists[:]
- let state.deflist = a:state.deflist
- let state.placeholder = a:state.placeholder
- let state.header_ids = a:state.header_ids
-
- let res_lines = []
-
- let line = s:safe_html_line(a:line)
-
- let processed = 0
-
- " pres
- if !processed
- let [processed, lines, state.pre] = s:process_tag_pre(line, state.pre)
- " pre is just fine to be in the list -- do not close list item here.
- " if processed && len(state.lists)
- " call s:close_tag_list(state.lists, lines)
- " endif
- if !processed
- let [processed, lines, state.math] = s:process_tag_math(line, state.math)
- endif
- if processed && len(state.table)
- let state.table = s:close_tag_table(state.table, lines, state.header_ids)
- endif
- if processed && state.deflist
- let state.deflist = s:close_tag_def_list(state.deflist, lines)
- endif
- if processed && state.quote
- let state.quote = s:close_tag_quote(state.quote, lines)
- endif
- if processed && state.para
- let state.para = s:close_tag_para(state.para, lines)
- endif
- call extend(res_lines, lines)
- endif
-
-
- if !processed
- if line =~# vimwiki#vars#get_syntaxlocal('rxComment')
- let processed = 1
- endif
- endif
-
- " nohtml -- placeholder
- if !processed
- if line =~# '\m^\s*%nohtml\s*$'
- let processed = 1
- let state.placeholder = ['nohtml']
- endif
- endif
-
- " title -- placeholder
- if !processed
- if line =~# '\m^\s*%title\%(\s.*\)\?$'
- let processed = 1
- let param = matchstr(line, '\m^\s*%title\s\+\zs.*')
- let state.placeholder = ['title', param]
- endif
- endif
-
- " date -- placeholder
- if !processed
- if line =~# '\m^\s*%date\%(\s.*\)\?$'
- let processed = 1
- let param = matchstr(line, '\m^\s*%date\s\+\zs.*')
- let state.placeholder = ['date', param]
- endif
- endif
-
- " html template -- placeholder
- if !processed
- if line =~# '\m^\s*%template\%(\s.*\)\?$'
- let processed = 1
- let param = matchstr(line, '\m^\s*%template\s\+\zs.*')
- let state.placeholder = ['template', param]
- endif
- endif
-
-
- " tables
- if !processed
- let [processed, lines, state.table] = s:process_tag_table(line, state.table, state.header_ids)
- call extend(res_lines, lines)
- endif
-
-
- " lists
- if !processed
- let [processed, lines] = s:process_tag_list(line, state.lists)
- if processed && state.quote
- let state.quote = s:close_tag_quote(state.quote, lines)
- endif
- if processed && state.pre[0]
- let state.pre = s:close_tag_pre(state.pre, lines)
- endif
- if processed && state.math[0]
- let state.math = s:close_tag_math(state.math, lines)
- endif
- if processed && len(state.table)
- let state.table = s:close_tag_table(state.table, lines, state.header_ids)
- endif
- if processed && state.deflist
- let state.deflist = s:close_tag_def_list(state.deflist, lines)
- endif
- if processed && state.para
- let state.para = s:close_tag_para(state.para, lines)
- endif
-
- call map(lines, 's:process_inline_tags(v:val, state.header_ids)')
-
- call extend(res_lines, lines)
- endif
-
-
- " headers
- if !processed
- let [processed, line] = s:process_tag_h(line, state.header_ids)
- if processed
- call s:close_tag_list(state.lists, res_lines)
- let state.table = s:close_tag_table(state.table, res_lines, state.header_ids)
- let state.pre = s:close_tag_pre(state.pre, res_lines)
- let state.math = s:close_tag_math(state.math, res_lines)
- let state.quote = s:close_tag_quote(state.quote, res_lines)
- let state.para = s:close_tag_para(state.para, res_lines)
-
- call add(res_lines, line)
- endif
- endif
-
-
- " quotes
- if !processed
- let [processed, lines, state.quote] = s:process_tag_quote(line, state.quote)
- if processed && len(state.lists)
- call s:close_tag_list(state.lists, lines)
- endif
- if processed && state.deflist
- let state.deflist = s:close_tag_def_list(state.deflist, lines)
- endif
- if processed && len(state.table)
- let state.table = s:close_tag_table(state.table, lines, state.header_ids)
- endif
- if processed && state.pre[0]
- let state.pre = s:close_tag_pre(state.pre, lines)
- endif
- if processed && state.math[0]
- let state.math = s:close_tag_math(state.math, lines)
- endif
- if processed && state.para
- let state.para = s:close_tag_para(state.para, lines)
- endif
-
- call map(lines, 's:process_inline_tags(v:val, state.header_ids)')
-
- call extend(res_lines, lines)
- endif
-
-
- " horizontal rules
- if !processed
- let [processed, line] = s:process_tag_hr(line)
- if processed
- call s:close_tag_list(state.lists, res_lines)
- let state.table = s:close_tag_table(state.table, res_lines, state.header_ids)
- let state.pre = s:close_tag_pre(state.pre, res_lines)
- let state.math = s:close_tag_math(state.math, res_lines)
- call add(res_lines, line)
- endif
- endif
-
-
- " definition lists
- if !processed
- let [processed, lines, state.deflist] = s:process_tag_def_list(line, state.deflist)
-
- call map(lines, 's:process_inline_tags(v:val, state.header_ids)')
-
- call extend(res_lines, lines)
- endif
-
-
- "" P
- if !processed
- let [processed, lines, state.para] = s:process_tag_para(line, state.para)
- if processed && len(state.lists)
- call s:close_tag_list(state.lists, lines)
- endif
- if processed && state.quote
- let state.quote = s:close_tag_quote(state.quote, res_lines)
- endif
- if processed && state.pre[0]
- let state.pre = s:close_tag_pre(state.pre, res_lines)
- endif
- if processed && state.math[0]
- let state.math = s:close_tag_math(state.math, res_lines)
- endif
- if processed && len(state.table)
- let state.table = s:close_tag_table(state.table, res_lines, state.header_ids)
- endif
-
- call map(lines, 's:process_inline_tags(v:val, state.header_ids)')
-
- call extend(res_lines, lines)
- endif
-
-
- "" add the rest
- if !processed
- call add(res_lines, line)
- endif
-
- return [res_lines, state]
-
-endfunction
-
-
-function! s:use_custom_wiki2html()
- let custom_wiki2html = vimwiki#vars#get_wikilocal('custom_wiki2html')
- return !empty(custom_wiki2html) &&
- \ (s:file_exists(custom_wiki2html) || s:binary_exists(custom_wiki2html))
-endfunction
-
-
-function! vimwiki#html#CustomWiki2HTML(path, wikifile, force)
- call vimwiki#path#mkdir(a:path)
- echomsg system(vimwiki#vars#get_wikilocal('custom_wiki2html'). ' '.
- \ a:force. ' '.
- \ vimwiki#vars#get_wikilocal('syntax'). ' '.
- \ strpart(vimwiki#vars#get_wikilocal('ext'), 1). ' '.
- \ shellescape(a:path). ' '.
- \ shellescape(a:wikifile). ' '.
- \ shellescape(s:default_CSS_full_name(a:path)). ' '.
- \ (len(vimwiki#vars#get_wikilocal('template_path')) > 1 ?
- \ shellescape(expand(vimwiki#vars#get_wikilocal('template_path'))) : '-'). ' '.
- \ (len(vimwiki#vars#get_wikilocal('template_default')) > 0 ?
- \ vimwiki#vars#get_wikilocal('template_default') : '-'). ' '.
- \ (len(vimwiki#vars#get_wikilocal('template_ext')) > 0 ?
- \ vimwiki#vars#get_wikilocal('template_ext') : '-'). ' '.
- \ (len(vimwiki#vars#get_bufferlocal('subdir')) > 0 ?
- \ shellescape(s:root_path(vimwiki#vars#get_bufferlocal('subdir'))) : '-'). ' '.
- \ (len(vimwiki#vars#get_wikilocal('custom_wiki2html_args')) > 0 ?
- \ vimwiki#vars#get_wikilocal('custom_wiki2html_args') : '-'))
-endfunction
-
-
-function! s:convert_file(path_html, wikifile)
- let done = 0
-
- let wikifile = fnamemodify(a:wikifile, ":p")
-
- let path_html = expand(a:path_html).vimwiki#vars#get_bufferlocal('subdir')
- let htmlfile = fnamemodify(wikifile, ":t:r").'.html'
-
- " the currently processed file name is needed when processing links
- " yeah yeah, shame on me for using (quasi-) global variables
- let s:current_wiki_file = wikifile
- let s:current_html_file = path_html . htmlfile
-
- if s:use_custom_wiki2html()
- let force = 1
- call vimwiki#html#CustomWiki2HTML(path_html, wikifile, force)
- let done = 1
- endif
-
- if s:syntax_supported() && done == 0
- let lsource = readfile(wikifile)
- let ldest = []
-
- call vimwiki#path#mkdir(path_html)
-
- " nohtml placeholder -- to skip html generation.
- let nohtml = 0
-
- " template placeholder
- let template_name = ''
-
- " for table of contents placeholders.
- let placeholders = []
-
- " current state of converter
- let state = {}
- let state.para = 0
- let state.quote = 0
- let state.pre = [0, 0] " [in_pre, indent_pre]
- let state.math = [0, 0] " [in_math, indent_math]
- let state.table = []
- let state.deflist = 0
- let state.lists = []
- let state.placeholder = []
- let state.header_ids = [['', 0], ['', 0], ['', 0], ['', 0], ['', 0], ['', 0]]
- " [last seen header text in this level, number]
-
- " prepare constants for s:safe_html_line()
- let s:lt_pattern = '<'
- let s:gt_pattern = '>'
- if vimwiki#vars#get_global('valid_html_tags') != ''
- let tags = join(split(vimwiki#vars#get_global('valid_html_tags'), '\s*,\s*'), '\|')
- let s:lt_pattern = '\c<\%(/\?\%('.tags.'\)\%(\s\{-1}\S\{-}\)\{-}/\?>\)\@!'
- let s:gt_pattern = '\c\%(</\?\%('.tags.'\)\%(\s\{-1}\S\{-}\)\{-}/\?\)\@<!>'
- endif
-
- " prepare regexps for lists
- let s:bullets = '[*-]'
- let s:numbers = '\C\%(#\|\d\+)\|\d\+\.\|[ivxlcdm]\+)\|[IVXLCDM]\+)\|\l\{1,2})\|\u\{1,2})\)'
-
- for line in lsource
- let oldquote = state.quote
- let [lines, state] = s:parse_line(line, state)
-
- " Hack: There could be a lot of empty strings before s:process_tag_quote
- " find out `quote` is over. So we should delete them all. Think of the way
- " to refactor it out.
- if oldquote != state.quote
- call s:remove_blank_lines(ldest)
- endif
-
- if !empty(state.placeholder)
- if state.placeholder[0] ==# 'nohtml'
- let nohtml = 1
- break
- elseif state.placeholder[0] ==# 'template'
- let template_name = state.placeholder[1]
- else
- call add(placeholders, [state.placeholder, len(ldest), len(placeholders)])
- endif
- let state.placeholder = []
- endif
-
- call extend(ldest, lines)
- endfor
-
-
- if nohtml
- echon "\r"."%nohtml placeholder found"
- return ''
- endif
-
- call s:remove_blank_lines(ldest)
-
- " process end of file
- " close opened tags if any
- let lines = []
- call s:close_tag_quote(state.quote, lines)
- call s:close_tag_para(state.para, lines)
- call s:close_tag_pre(state.pre, lines)
- call s:close_tag_math(state.math, lines)
- call s:close_tag_list(state.lists, lines)
- call s:close_tag_def_list(state.deflist, lines)
- call s:close_tag_table(state.table, lines, state.header_ids)
- call extend(ldest, lines)
-
- let title = s:process_title(placeholders, fnamemodify(a:wikifile, ":t:r"))
- let date = s:process_date(placeholders, strftime('%Y-%m-%d'))
-
- let html_lines = s:get_html_template(template_name)
-
- " processing template variables (refactor to a function)
- call map(html_lines, 'substitute(v:val, "%title%", "'. title .'", "g")')
- call map(html_lines, 'substitute(v:val, "%date%", "'. date .'", "g")')
- call map(html_lines, 'substitute(v:val, "%root_path%", "'.
- \ s:root_path(vimwiki#vars#get_bufferlocal('subdir')) .'", "g")')
-
- let css_name = expand(vimwiki#vars#get_wikilocal('css_name'))
- let css_name = substitute(css_name, '\', '/', 'g')
- call map(html_lines, 'substitute(v:val, "%css%", "'. css_name .'", "g")')
-
- let enc = &fileencoding
- if enc == ''
- let enc = &encoding
- endif
- call map(html_lines, 'substitute(v:val, "%encoding%", "'. enc .'", "g")')
-
- let html_lines = s:html_insert_contents(html_lines, ldest) " %contents%
-
- call writefile(html_lines, path_html.htmlfile)
- let done = 1
-
- endif
-
- if done == 0
- echomsg 'Vimwiki Error: Conversion to HTML is not supported for this syntax'
- return ''
- endif
-
- return path_html.htmlfile
-endfunction
-
-
-function! vimwiki#html#Wiki2HTML(path_html, wikifile)
- let result = s:convert_file(a:path_html, a:wikifile)
- if result != ''
- call s:create_default_CSS(a:path_html)
- endif
- return result
-endfunction
-
-
-function! vimwiki#html#WikiAll2HTML(path_html)
- if !s:syntax_supported() && !s:use_custom_wiki2html()
- echomsg 'Vimwiki Error: Conversion to HTML is not supported for this syntax'
- return
- endif
-
- echomsg 'Vimwiki: Saving Vimwiki files ...'
- let save_eventignore = &eventignore
- let &eventignore = "all"
- try
- wall
- catch
- " just ignore errors
- endtry
- let &eventignore = save_eventignore
-
- let path_html = expand(a:path_html)
- call vimwiki#path#mkdir(path_html)
-
- echomsg 'Vimwiki: Deleting non-wiki html files ...'
- call s:delete_html_files(path_html)
-
- echomsg 'Vimwiki: Converting wiki to html files ...'
- let setting_more = &more
- setlocal nomore
-
- " temporarily adjust current_subdir global state variable
- let current_subdir = vimwiki#vars#get_bufferlocal('subdir')
- let current_invsubdir = vimwiki#vars#get_bufferlocal('invsubdir')
-
- let wikifiles = split(glob(vimwiki#vars#get_wikilocal('path').'**/*'.
- \ vimwiki#vars#get_wikilocal('ext')), '\n')
- for wikifile in wikifiles
- let wikifile = fnamemodify(wikifile, ":p")
-
- " temporarily adjust 'subdir' and 'invsubdir' state variables
- let subdir = vimwiki#base#subdir(vimwiki#vars#get_wikilocal('path'), wikifile)
- call vimwiki#vars#set_bufferlocal('subdir', subdir)
- call vimwiki#vars#set_bufferlocal('invsubdir', vimwiki#base#invsubdir(subdir))
-
- if !s:is_html_uptodate(wikifile)
- echomsg 'Vimwiki: Processing '.wikifile
-
- call s:convert_file(path_html, wikifile)
- else
- echomsg 'Vimwiki: Skipping '.wikifile
- endif
- endfor
- " reset 'subdir' state variable
- call vimwiki#vars#set_bufferlocal('subdir', current_subdir)
- call vimwiki#vars#set_bufferlocal('invsubdir', current_invsubdir)
-
- let created = s:create_default_CSS(path_html)
- if created
- echomsg 'Vimwiki: Default style.css has been created'
- endif
- echomsg 'Vimwiki: HTML exported to '.path_html
- echomsg 'Vimwiki: Done!'
-
- let &more = setting_more
-endfunction
-
-
-function! s:file_exists(fname)
- return !empty(getftype(expand(a:fname)))
-endfunction
-
-
-function! s:binary_exists(fname)
- return executable(expand(a:fname))
-endfunction
-
-
-function! s:get_wikifile_url(wikifile)
- return vimwiki#vars#get_wikilocal('path_html') .
- \ vimwiki#base#subdir(vimwiki#vars#get_wikilocal('path'), a:wikifile).
- \ fnamemodify(a:wikifile, ":t:r").'.html'
-endfunction
-
-
-function! vimwiki#html#PasteUrl(wikifile)
- execute 'r !echo file://'.s:get_wikifile_url(a:wikifile)
-endfunction
-
-
-function! vimwiki#html#CatUrl(wikifile)
- execute '!echo file://'.s:get_wikifile_url(a:wikifile)
-endfunction
-
diff --git a/.config/nvim/autoload/vimwiki/lst.vim b/.config/nvim/autoload/vimwiki/lst.vim
@@ -1,1697 +0,0 @@
-" vim:tabstop=2:shiftwidth=2:expandtab:textwidth=99
-" Vimwiki autoload plugin file
-" Description: Everything concerning lists and checkboxes
-" Home: https://github.com/vimwiki/vimwiki/
-
-
-if exists("g:loaded_vimwiki_list_auto") || &cp
- finish
-endif
-let g:loaded_vimwiki_list_auto = 1
-
-
-" ---------------------------------------------------------
-" incrementation functions for the various kinds of numbers
-" ---------------------------------------------------------
-
-function! s:increment_1(value)
- return eval(a:value) + 1
-endfunction
-
-
-function! s:increment_A(value)
- let list_of_chars = split(a:value, '.\zs')
- let done = 0
- for idx in reverse(range(len(list_of_chars)))
- let cur_num = char2nr(list_of_chars[idx])
- if cur_num < 90
- let list_of_chars[idx] = nr2char(cur_num + 1)
- let done = 1
- break
- else
- let list_of_chars[idx] = 'A'
- endif
- endfor
- if !done
- call insert(list_of_chars, 'A')
- endif
- return join(list_of_chars, '')
-endfunction
-
-
-function! s:increment_a(value)
- let list_of_chars = split(a:value, '.\zs')
- let done = 0
- for idx in reverse(range(len(list_of_chars)))
- let cur_num = char2nr(list_of_chars[idx])
- if cur_num < 122
- let list_of_chars[idx] = nr2char(cur_num + 1)
- let done = 1
- break
- else
- let list_of_chars[idx] = 'a'
- endif
- endfor
- if !done
- call insert(list_of_chars, 'a')
- endif
- return join(list_of_chars, '')
-endfunction
-
-
-function! s:increment_I(value)
- let subst_list = [ ['XLVIII$', 'IL'], ['VIII$', 'IX'], ['III$', 'IV'],
- \ ['DCCCXCIX$', 'CM'], ['CCCXCIX$', 'CD'], ['LXXXIX$', 'XC'],
- \ ['XXXIX$', 'XL'], ['\(I\{1,2\}\)$', '\1I'], ['CDXCIX$', 'D'],
- \ ['CMXCIX$', 'M'], ['XCIX$', 'C'], ['I\([VXLCDM]\)$', '\1'],
- \ ['\([VXLCDM]\)$', '\1I'] ]
- for [regex, subst] in subst_list
- if a:value =~# regex
- return substitute(a:value, regex, subst, '')
- endif
- endfor
- return ''
-endfunction
-
-
-function! s:increment_i(value)
- let subst_list = [ ['xlviii$', 'il'], ['viii$', 'ix'], ['iii$', 'iv'],
- \ ['dcccxcix$', 'cm'], ['cccxcix$', 'cd'], ['lxxxix$', 'xc'],
- \ ['xxxix$', 'xl'], ['\(i\{1,2\}\)$', '\1i'], ['cdxcix$', 'd'],
- \ ['cmxcix$', 'm'], ['xcix$', 'c'], ['i\([vxlcdm]\)$', '\1'],
- \ ['\([vxlcdm]\)$', '\1i'] ]
- for [regex, subst] in subst_list
- if a:value =~# regex
- return substitute(a:value, regex, subst, '')
- endif
- endfor
- return ''
-endfunction
-
-
-" ---------------------------------------------------------
-" utility functions
-" ---------------------------------------------------------
-
-function! s:substitute_rx_in_line(lnum, pattern, new_string)
- call setline(a:lnum, substitute(getline(a:lnum), a:pattern, a:new_string, ''))
-endfunction
-
-
-function! s:substitute_string_in_line(lnum, old_string, new_string)
- call s:substitute_rx_in_line(a:lnum, vimwiki#u#escape(a:old_string), a:new_string)
-endfunction
-
-
-function! s:first_char(string)
- return matchstr(a:string, '^.')
-endfunction
-
-
-if exists("*strdisplaywidth")
- function! s:string_length(str)
- return strdisplaywidth(a:str)
- endfunction
-else
- function! s:string_length(str)
- return strlen(substitute(a:str, '.', 'x', 'g'))
- endfunction
-endif
-
-
-function! vimwiki#lst#default_symbol()
- return vimwiki#vars#get_syntaxlocal('list_markers')[0]
-endfunction
-
-
-function! vimwiki#lst#get_list_margin()
- let list_margin = vimwiki#vars#get_wikilocal('list_margin')
- if list_margin < 0
- return &sw
- else
- return list_margin
- endif
-endfunction
-
-
-"Returns: the column where the text of a line starts (possible list item
-"markers and checkboxes are skipped)
-function! s:text_begin(lnum)
- return s:string_length(matchstr(getline(a:lnum), vimwiki#vars#get_syntaxlocal('rxListItem')))
-endfunction
-
-
-"Returns: 2 if there is a marker and text
-" 1 for a marker and no text
-" 0 for no marker at all (empty line or only text)
-function! s:line_has_marker(lnum)
- if getline(a:lnum) =~# vimwiki#vars#get_syntaxlocal('rxListItem').'\s*$'
- return 1
- elseif getline(a:lnum) =~# vimwiki#vars#get_syntaxlocal('rxListItem').'\s*\S'
- return 2
- else
- return 0
- endif
-endfunction
-
-
-" ---------------------------------------------------------
-" get properties of a list item
-" ---------------------------------------------------------
-
-"Returns: the mainly used data structure in this file
-"An item represents a single list item and is a dictionary with the keys
-"lnum - the line number of the list item
-"type - 1 for bulleted item, 2 for numbered item, 0 for a regular line
-"mrkr - the concrete marker, e.g. '**' or 'b)'
-"cb - the char in the checkbox or '' if there is no checkbox
-function! s:get_item(lnum)
- let item = {'lnum': a:lnum}
- if a:lnum == 0 || a:lnum > line('$')
- let item.type = 0
- return item
- endif
-
- let matches = matchlist(getline(a:lnum), vimwiki#vars#get_syntaxlocal('rxListItem'))
- if matches == [] ||
- \ (matches[1] == '' && matches[2] == '') ||
- \ (matches[1] != '' && matches[2] != '')
- let item.type = 0
- return item
- endif
-
- let item.cb = matches[3]
-
- if matches[1] != ''
- let item.type = 1
- let item.mrkr = matches[1]
- else
- let item.type = 2
- let item.mrkr = matches[2]
- endif
-
- return item
-endfunction
-
-
-function! s:empty_item()
- return {'type': 0}
-endfunction
-
-
-"Returns: level of the line
-"0 is the 'highest' level
-function! s:get_level(lnum)
- if getline(a:lnum) =~# '^\s*$'
- return 0
- endif
- if !vimwiki#vars#get_syntaxlocal('recurring_bullets')
- let level = indent(a:lnum)
- else
- let level = s:string_length(matchstr(getline(a:lnum),
- \ vimwiki#vars#get_syntaxlocal(rx_bullet_chars)))-1
- if level < 0
- let level = (indent(a:lnum) == 0) ? 0 : 9999
- endif
- endif
- return level
-endfunction
-
-
-"Returns: 1, a, i, A, I or ''
-"If in doubt if alphanumeric character or romanian
-"numeral, peek in the previous line
-function! s:guess_kind_of_numbered_item(item)
- if a:item.type != 2 | return '' | endif
- let number_chars = a:item.mrkr[:-2]
- let divisor = a:item.mrkr[-1:]
-
- let number_kinds = vimwiki#vars#get_syntaxlocal('number_kinds')
-
- if number_chars =~# '\d\+'
- return '1'
- endif
- if number_chars =~# '\l\+'
- if number_chars !~# '^[ivxlcdm]\+' || index(number_kinds, 'i') == -1
- return 'a'
- else
-
- let item_above = s:get_prev_list_item(a:item, 0)
- if item_above.type != 0
- if index(number_kinds, 'a') == -1 ||
- \ (item_above.mrkr[-1:] !=# divisor && number_chars =~# 'i\+') ||
- \ s:increment_i(item_above.mrkr[:-2]) ==# number_chars
- return 'i'
- else
- return 'a'
- endif
- else
- if number_chars =~# 'i\+' || index(number_kinds, 'a') == -1
- return 'i'
- else
- return 'a'
- endif
- endif
-
- endif
- endif
- if number_chars =~# '\u\+'
- if number_chars !~# '^[IVXLCDM]\+' || index(number_kinds, 'I') == -1
- return 'A'
- else
-
- let item_above = s:get_prev_list_item(a:item, 0)
- if item_above.type != 0
- if index(number_kinds, 'A') == -1 ||
- \ (item_above.mrkr[-1:] !=# divisor && number_chars =~# 'I\+') ||
- \ s:increment_I(item_above.mrkr[:-2]) ==# number_chars
- return 'I'
- else
- return 'A'
- endif
- else
- if number_chars =~# 'I\+' || index(number_kinds, 'A') == -1
- return 'I'
- else
- return 'A'
- endif
- endif
-
- endif
- endif
-endfunction
-
-
-function! s:regexp_of_marker(item)
- if a:item.type == 1
- return vimwiki#u#escape(a:item.mrkr)
- elseif a:item.type == 2
- let number_divisors = vimwiki#vars#get_syntaxlocal('number_divisors')
- for ki in ['d', 'u', 'l']
- let match = matchstr(a:item.mrkr, '\'.ki.'\+['.number_divisors.']')
- if match != ''
- return '\'.ki.'\+'.vimwiki#u#escape(match[-1:])
- endif
- endfor
- else
- return ''
- endif
-endfunction
-
-
-" Returns: Whether or not the checkbox of a list item is [X] or [-]
-function! s:is_closed(item)
- let state = a:item.cb
- return state ==# vimwiki#vars#get_syntaxlocal('listsyms_list')[-1]
- \ || state ==# vimwiki#vars#get_global('listsym_rejected')
-endfunction
-
-" ---------------------------------------------------------
-" functions for navigating between items
-" ---------------------------------------------------------
-
-"Returns: the list item after a:item or an empty item
-"If a:ignore_kind is 1, the markers can differ
-function! s:get_next_list_item(item, ignore_kind)
- let org_lvl = s:get_level(a:item.lnum)
- if !a:ignore_kind
- let org_regex = s:regexp_of_marker(a:item)
- endif
-
- let cur_ln = s:get_next_line(a:item.lnum)
- while cur_ln <= line('$')
- let cur_lvl = s:get_level(cur_ln)
- if cur_lvl <= org_lvl
- if a:ignore_kind
- return s:get_any_item_of_level(cur_ln, cur_lvl, org_lvl)
- else
- return s:get_item_of_level(cur_ln, cur_lvl, org_lvl, org_regex)
- endif
- endif
- let cur_ln = s:get_next_line(cur_ln)
- endwhile
- return s:empty_item()
-endfunction
-
-
-"Returns: the list item before a:item or an empty item
-"If a:ignore_kind is 1, the markers can differ
-function! s:get_prev_list_item(item, ignore_kind)
- let org_lvl = s:get_level(a:item.lnum)
- if !a:ignore_kind
- let org_regex = s:regexp_of_marker(a:item)
- endif
-
- let cur_ln = s:get_prev_line(a:item.lnum)
- while cur_ln >= 1
- let cur_lvl = s:get_level(cur_ln)
- if cur_lvl <= org_lvl
- if a:ignore_kind
- return s:get_any_item_of_level(cur_ln, cur_lvl, org_lvl)
- else
- return s:get_item_of_level(cur_ln, cur_lvl, org_lvl, org_regex)
- endif
- endif
- let cur_ln = s:get_prev_line(cur_ln)
- endwhile
- return s:empty_item()
-endfunction
-
-
-function! s:get_item_of_level(cur_ln, cur_lvl, org_lvl, org_regex)
- let cur_linecontent = getline(a:cur_ln)
- if a:cur_lvl == a:org_lvl
- if cur_linecontent =~# '^\s*'.a:org_regex.'\s'
- return s:get_item(a:cur_ln)
- else
- return s:empty_item()
- endif
- elseif a:cur_lvl < a:org_lvl
- return s:empty_item()
- endif
-endfunction
-
-
-function! s:get_any_item_of_level(cur_ln, cur_lvl, org_lvl)
- if a:cur_lvl == a:org_lvl
- return s:get_item(a:cur_ln)
- elseif a:cur_lvl < a:org_lvl
- return s:empty_item()
- endif
-endfunction
-
-
-function! s:get_first_item_in_list(item, ignore_kind)
- let cur_item = a:item
- while 1
- let prev_item = s:get_prev_list_item(cur_item, a:ignore_kind)
- if prev_item.type == 0
- break
- else
- let cur_item = prev_item
- endif
- endwhile
- return cur_item
-endfunction
-
-
-function! s:get_last_item_in_list(item, ignore_kind)
- let cur_item = a:item
- while 1
- let next_item = s:get_next_list_item(cur_item, a:ignore_kind)
- if next_item.type == 0
- break
- else
- let cur_item = next_item
- endif
- endwhile
- return cur_item
-endfunction
-
-
-"Returns: lnum+1 in most cases, but skips blank lines and preformatted text,
-"0 in case of nonvalid line.
-"If there is no second argument, 0 is returned at a header, otherwise the
-"header is skipped
-function! s:get_next_line(lnum, ...)
- if getline(a:lnum) =~# vimwiki#vars#get_syntaxlocal('rxPreStart')
- let cur_ln = a:lnum + 1
- while cur_ln <= line('$') && getline(cur_ln) !~# vimwiki#vars#get_syntaxlocal('rxPreEnd')
- let cur_ln += 1
- endwhile
- let next_line = cur_ln
- else
- let next_line = nextnonblank(a:lnum+1)
- endif
-
- if a:0 > 0 && getline(next_line) =~# vimwiki#vars#get_syntaxlocal('rxHeader')
- let next_line = s:get_next_line(next_line, 1)
- endif
-
- if next_line < 0 || next_line > line('$') ||
- \ (getline(next_line) =~# vimwiki#vars#get_syntaxlocal('rxHeader') && a:0 == 0)
- return 0
- endif
-
- return next_line
-endfunction
-
-
-"Returns: lnum-1 in most cases, but skips blank lines and preformatted text
-"0 in case of nonvalid line and a header, because a header ends every list
-function! s:get_prev_line(lnum)
- let prev_line = prevnonblank(a:lnum-1)
-
- if getline(prev_line) =~# vimwiki#vars#get_syntaxlocal('rxPreEnd')
- let cur_ln = a:lnum - 1
- while 1
- if cur_ln == 0 || getline(cur_ln) =~# vimwiki#vars#get_syntaxlocal('rxPreStart')
- break
- endif
- let cur_ln -= 1
- endwhile
- let prev_line = cur_ln
- endif
-
- if prev_line < 0 || prev_line > line('$') ||
- \ getline(prev_line) =~# vimwiki#vars#get_syntaxlocal('rxHeader')
- return 0
- endif
-
- return prev_line
-endfunction
-
-
-function! s:get_first_child(item)
- if a:item.lnum >= line('$')
- return s:empty_item()
- endif
- let org_lvl = s:get_level(a:item.lnum)
- let cur_item = s:get_item(s:get_next_line(a:item.lnum))
- while 1
- if cur_item.type != 0 && s:get_level(cur_item.lnum) > org_lvl
- return cur_item
- endif
- if cur_item.lnum > line('$') || cur_item.lnum <= 0 || s:get_level(cur_item.lnum) <= org_lvl
- return s:empty_item()
- endif
- let cur_item = s:get_item(s:get_next_line(cur_item.lnum))
- endwhile
-endfunction
-
-
-"Returns: the next sibling of a:child, given the parent item
-"Used for iterating over children
-"Note: child items do not necessarily have the same indent, i.e. level
-function! s:get_next_child_item(parent, child)
- if a:parent.type == 0 | return s:empty_item() | endif
- let parent_lvl = s:get_level(a:parent.lnum)
- let cur_ln = s:get_last_line_of_item_incl_children(a:child)
- while 1
- let next_line = s:get_next_line(cur_ln)
- if next_line == 0 || s:get_level(next_line) <= parent_lvl
- break
- endif
- let cur_ln = next_line
- let cur_item = s:get_item(cur_ln)
- if cur_item.type > 0
- return cur_item
- endif
- endwhile
- return s:empty_item()
-endfunction
-
-
-function! s:get_parent(item)
- let parent_line = 0
-
- let cur_ln = prevnonblank(a:item.lnum)
- let child_lvl = s:get_level(cur_ln)
- if child_lvl == 0
- return s:empty_item()
- endif
-
- while 1
- let cur_ln = s:get_prev_line(cur_ln)
- if cur_ln == 0 | break | endif
- let cur_lvl = s:get_level(cur_ln)
- if cur_lvl < child_lvl
- let cur_item = s:get_item(cur_ln)
- if cur_item.type == 0
- let child_lvl = cur_lvl
- continue
- endif
- let parent_line = cur_ln
- break
- endif
- endwhile
- return s:get_item(parent_line)
-endfunction
-
-
-"Returns: the item above or the item below or an empty item
-function! s:get_a_neighbor_item(item)
- let prev_item = s:get_prev_list_item(a:item, 1)
- if prev_item.type != 0
- return prev_item
- else
- let next_item = s:get_next_list_item(a:item, 1)
- if next_item.type != 0
- return next_item
- endif
- endif
- return s:empty_item()
-endfunction
-
-
-function! s:get_a_neighbor_item_in_column(lnum, column)
- let cur_ln = s:get_prev_line(a:lnum)
- while cur_ln >= 1
- if s:get_level(cur_ln) <= a:column
- return s:get_corresponding_item(cur_ln)
- endif
- let cur_ln = s:get_prev_line(cur_ln)
- endwhile
- return s:empty_item()
-endfunction
-
-
-"Returns: the item if there is one in a:lnum
-"else the multiline item a:lnum belongs to
-function! s:get_corresponding_item(lnum)
- let item = s:get_item(a:lnum)
- if item.type != 0
- return item
- endif
- let org_lvl = s:get_level(a:lnum)
- let cur_ln = a:lnum
- while cur_ln > 0
- let cur_lvl = s:get_level(cur_ln)
- let cur_item = s:get_item(cur_ln)
- if cur_lvl < org_lvl && cur_item.type != 0
- return cur_item
- endif
- if cur_lvl < org_lvl
- let org_lvl = cur_lvl
- endif
- let cur_ln = s:get_prev_line(cur_ln)
- endwhile
- return s:empty_item()
-endfunction
-
-
-"Returns: the last line of a (possibly multiline) item, including all children
-function! s:get_last_line_of_item_incl_children(item)
- let cur_ln = a:item.lnum
- let org_lvl = s:get_level(a:item.lnum)
- while 1
- let next_line = s:get_next_line(cur_ln)
- if next_line == 0 || s:get_level(next_line) <= org_lvl
- return cur_ln
- endif
- let cur_ln = next_line
- endwhile
-endfunction
-
-
-"Returns: the last line of a (possibly multiline) item
-"Note: there can be other list items between the first and last line
-function! s:get_last_line_of_item(item)
- if a:item.type == 0 | return 0 | endif
- let org_lvl = s:get_level(a:item.lnum)
- let last_corresponding_line = a:item.lnum
-
- let cur_ln = s:get_next_line(a:item.lnum)
- while 1
- if cur_ln == 0 || s:get_level(cur_ln) <= org_lvl
- break
- endif
- let cur_item = s:get_item(cur_ln)
- if cur_item.type == 0
- let last_corresponding_line = cur_ln
- let cur_ln = s:get_next_line(cur_ln)
- else
- let cur_ln = s:get_next_line(s:get_last_line_of_item_incl_children(cur_item))
- endif
- endwhile
-
- return last_corresponding_line
-endfunction
-
-
-" ---------------------------------------------------------
-" renumber list items
-" ---------------------------------------------------------
-
-"Renumbers the current list from a:item on downwards
-"Returns: the last item that was adjusted
-function! s:adjust_numbered_list_below(item, recursive)
- if !(a:item.type == 2 || (a:item.type == 1 && a:recursive))
- return a:item
- endif
-
- let kind = s:guess_kind_of_numbered_item(a:item)
-
- let cur_item = a:item
- while 1
- if a:recursive
- call s:adjust_items_recursively(cur_item)
- endif
-
- let next_item = s:get_next_list_item(cur_item, 0)
- if next_item.type == 0
- break
- endif
-
- if cur_item.type == 2
- let new_val = s:increment_{kind}(cur_item.mrkr[:-2]) . cur_item.mrkr[-1:]
- call s:substitute_string_in_line(next_item.lnum, next_item.mrkr, new_val)
- let next_item.mrkr = new_val
- endif
-
- let cur_item = next_item
- endwhile
- return cur_item
-endfunction
-
-
-function! s:adjust_items_recursively(parent)
- if a:parent.type == 0
- return s:empty_item()
- end
-
- let child_item = s:get_first_child(a:parent)
- if child_item.type == 0
- return child_item
- endif
- while 1
- let last_item = s:adjust_numbered_list(child_item, 1, 1)
-
- let child_item = s:get_next_child_item(a:parent, last_item)
- if child_item.type == 0
- return last_item
- endif
- endwhile
-endfunction
-
-
-"Renumbers the list a:item is in.
-"If a:ignore_kind == 0, only the items which have the same kind of marker as
-"a:item are considered, otherwise all items.
-"Returns: the last item that was adjusted
-function! s:adjust_numbered_list(item, ignore_kind, recursive)
- if !(a:item.type == 2 || (a:item.type == 1 && (a:ignore_kind || a:recursive)))
- return s:empty_item()
- end
-
- let first_item = s:get_first_item_in_list(a:item, a:ignore_kind)
-
- while 1
- if first_item.type == 2
- let new_mrkr = s:guess_kind_of_numbered_item(first_item) . first_item.mrkr[-1:]
- call s:substitute_string_in_line(first_item.lnum, first_item.mrkr, new_mrkr)
- let first_item.mrkr = new_mrkr
- endif
-
- let last_item = s:adjust_numbered_list_below(first_item, a:recursive)
-
- let next_first_item = s:get_next_list_item(last_item, 1)
- if a:ignore_kind == 0 || next_first_item.type == 0
- return last_item
- endif
- let first_item = next_first_item
- endwhile
-endfunction
-
-
-"Renumbers the list the cursor is in
-"also update its parents checkbox state
-function! vimwiki#lst#adjust_numbered_list()
- let cur_item = s:get_corresponding_item(line('.'))
- if cur_item.type == 0 | return | endif
- call s:adjust_numbered_list(cur_item, 1, 0)
- call s:update_state(s:get_parent(cur_item))
-endfunction
-
-
-"Renumbers all lists of the buffer
-"of course, this might take some seconds
-function! vimwiki#lst#adjust_whole_buffer()
- let cur_ln = 1
- while 1
- let cur_item = s:get_item(cur_ln)
- if cur_item.type != 0
- let cur_item = s:adjust_numbered_list(cur_item, 0, 1)
- endif
- let cur_ln = s:get_next_line(cur_item.lnum, 1)
- if cur_ln <= 0 || cur_ln > line('$')
- return
- endif
- endwhile
-endfunction
-
-
-" ---------------------------------------------------------
-" checkbox stuff
-" ---------------------------------------------------------
-
-"Returns: the rate of checkboxed list item in percent
-function! s:get_rate(item)
- if a:item.type == 0 || a:item.cb == ''
- return -1
- endif
- let state = a:item.cb
- if state == vimwiki#vars#get_global('listsym_rejected')
- return -1
- endif
- let n = len(vimwiki#vars#get_syntaxlocal('listsyms_list'))
- return index(vimwiki#vars#get_syntaxlocal('listsyms_list'), state) * 100/(n-1)
-endfunction
-
-
-"Set state of the list item to [ ] or [o] or whatever
-"Returns: 1 if the state changed, 0 otherwise
-function! s:set_state(item, new_rate)
- let new_state = s:rate_to_state(a:new_rate)
- let old_state = s:rate_to_state(s:get_rate(a:item))
- if new_state !=# old_state
- call s:substitute_rx_in_line(a:item.lnum, '\[.]', '['.new_state.']')
- return 1
- else
- return 0
- endif
-endfunction
-
-
-" Sets the state of the list item to [ ] or [o] or whatever. Updates the states of its child items.
-" If the new state should be [X] or [-], the state of the current list item is changed to this
-" state, but if a child item already has [X] or [-] it is left alone.
-function! s:set_state_plus_children(item, new_rate, ...)
- let retain_state_if_closed = a:0 > 0 && a:1 > 0
-
- if !(retain_state_if_closed && (a:new_rate == 100 || a:new_rate == -1) && s:is_closed(a:item))
- call s:set_state(a:item, a:new_rate)
- endif
-
- let all_children_are_done = 1
- let all_children_are_rejected = 1
-
- let child_item = s:get_first_child(a:item)
- while 1
- if child_item.type == 0
- break
- endif
- if child_item.cb != vimwiki#vars#get_global('listsym_rejected')
- let all_children_are_rejected = 0
- endif
- if child_item.cb != vimwiki#vars#get_syntaxlocal('listsyms_list')[-1]
- let all_children_are_done = 0
- endif
- if !all_children_are_done && !all_children_are_rejected
- break
- endif
- let child_item = s:get_next_child_item(a:item, child_item)
- endwhile
-
- if (a:new_rate == 100 && all_children_are_done) ||
- \ (a:new_rate == -1) && all_children_are_rejected
- return
- endif
-
- if (a:new_rate == -1 && all_children_are_done) ||
- \ (a:new_rate == 100 && all_children_are_rejected)
- let retain_closed_children = 0
- else
- let retain_closed_children = 1
- endif
-
- let child_item = s:get_first_child(a:item)
- while 1
- if child_item.type == 0
- break
- endif
- if child_item.cb != ''
- call s:set_state_plus_children(child_item, a:new_rate, retain_closed_children)
- endif
- let child_item = s:get_next_child_item(a:item, child_item)
- endwhile
-endfunction
-
-
-"Returns: the appropriate symbol for a given percent rate
-function! s:rate_to_state(rate)
- let listsyms_list = vimwiki#vars#get_syntaxlocal('listsyms_list')
- let state = ''
- let n = len(listsyms_list)
- if a:rate == 100
- let state = listsyms_list[n-1]
- elseif a:rate == 0
- let state = listsyms_list[0]
- elseif a:rate == -1
- let state = vimwiki#vars#get_global('listsym_rejected')
- else
- let index = float2nr(ceil(a:rate/100.0*(n-2)))
- let state = listsyms_list[index]
- endif
- return state
-endfunction
-
-
-"updates the symbol of a checkboxed item according to the symbols of its
-"children
-function! s:update_state(item)
- if a:item.type == 0 || a:item.cb == ''
- return
- endif
-
- let sum_children_rate = 0
- let count_children_with_cb = 0
- let count_rejected_children = 0
-
- let child_item = s:get_first_child(a:item)
-
- while 1
- if child_item.type == 0
- break
- endif
- if child_item.cb != ''
- let rate = s:get_rate(child_item)
- if rate == -1
- " for calculating the parent rate, a [-] item counts as much as a [X] item ...
- let rate = 100
- " ... with the exception that a parent with *only* [-] items will be [-] too
- let count_rejected_children += 1
- endif
- let count_children_with_cb += 1
- let sum_children_rate += rate
- endif
- let child_item = s:get_next_child_item(a:item, child_item)
- endwhile
-
- if count_children_with_cb > 0
- if count_rejected_children == count_children_with_cb
- let new_rate = -1
- else
- let new_rate = sum_children_rate / count_children_with_cb
- endif
- call s:set_state_recursively(a:item, new_rate)
- else
- let rate = s:get_rate(a:item)
- if rate > 0 && rate < 100
- call s:set_state_recursively(a:item, 0)
- endif
- endif
-endfunction
-
-
-function! s:set_state_recursively(item, new_rate)
- let state_changed = s:set_state(a:item, a:new_rate)
- if state_changed
- call s:update_state(s:get_parent(a:item))
- endif
-endfunction
-
-
-"Creates checkbox in a list item.
-"Returns: 1 if successful
-function! s:create_cb(item, start_rate)
- if a:item.type == 0 || a:item.cb != ''
- return 0
- endif
-
- let new_item = a:item
- let new_item.cb = s:rate_to_state(a:start_rate)
- call s:substitute_rx_in_line(new_item.lnum,
- \ vimwiki#u#escape(new_item.mrkr) . '\zs\ze', ' [' . new_item.cb . ']')
-
- call s:update_state(new_item)
- return 1
-endfunction
-
-
-function! s:remove_cb(item)
- let item = a:item
- if item.type != 0 && item.cb != ''
- let item.cb = ''
- call s:substitute_rx_in_line(item.lnum, '\s\+\[.\]', '')
- endif
- return item
-endfunction
-
-
-" Change state of the checkboxes in the lines of the given range
-function! s:change_cb(from_line, to_line, new_rate)
- let from_item = s:get_corresponding_item(a:from_line)
- if from_item.type == 0
- return
- endif
-
- let parent_items_of_lines = []
-
- for cur_ln in range(from_item.lnum, a:to_line)
- let cur_item = s:get_item(cur_ln)
- if cur_item.type != 0 && cur_item.cb != ''
- call s:set_state_plus_children(cur_item, a:new_rate)
- let cur_parent_item = s:get_parent(cur_item)
- if index(parent_items_of_lines, cur_parent_item) == -1
- call insert(parent_items_of_lines, cur_parent_item)
- endif
- endif
- endfor
-
- for parent_item in parent_items_of_lines
- call s:update_state(parent_item)
- endfor
-
-endfunction
-
-
-" Toggles checkbox between two states in the lines of the given range, creates checkboxes (with
-" a:start_rate as state) if there aren't any.
-function! s:toggle_create_cb(from_line, to_line, state1, state2, start_rate)
- let from_item = s:get_corresponding_item(a:from_line)
- if from_item.type == 0
- return
- endif
-
- if from_item.cb == ''
-
- "if from_line has no CB, make a CB in every selected line
- let parent_items_of_lines = []
- for cur_ln in range(from_item.lnum, a:to_line)
- let cur_item = s:get_item(cur_ln)
- let success = s:create_cb(cur_item, a:start_rate)
-
- if success
- let cur_parent_item = s:get_parent(cur_item)
- if index(parent_items_of_lines, cur_parent_item) == -1
- call insert(parent_items_of_lines, cur_parent_item)
- endif
- endif
- endfor
-
- for parent_item in parent_items_of_lines
- call s:update_state(parent_item)
- endfor
-
- else
-
- "if from_line has CB, toggle it and set all siblings to the same new state
- let rate_first_line = s:get_rate(from_item)
- let new_rate = rate_first_line == a:state1 ? a:state2 : a:state1
-
- call s:change_cb(a:from_line, a:to_line, new_rate)
-
- endif
-
-endfunction
-
-
-"Decrement checkbox between [ ] and [X]
-"in the lines of the given range
-function! vimwiki#lst#decrement_cb(from_line, to_line)
- let from_item = s:get_corresponding_item(a:from_line)
- if from_item.type == 0
- return
- endif
-
- "if from_line has CB, decrement it and set all siblings to the same new state
- let rate_first_line = s:get_rate(from_item)
- let n = len(vimwiki#vars#get_syntaxlocal('listsyms_list'))
- let new_rate = max([rate_first_line - 100/(n-1)-1, 0])
-
- call s:change_cb(a:from_line, a:to_line, new_rate)
-
-endfunction
-
-
-"Increment checkbox between [ ] and [X]
-"in the lines of the given range
-function! vimwiki#lst#increment_cb(from_line, to_line)
- let from_item = s:get_corresponding_item(a:from_line)
- if from_item.type == 0
- return
- endif
-
- "if from_line has CB, increment it and set all siblings to the same new state
- let rate_first_line = s:get_rate(from_item)
- let n = len(vimwiki#vars#get_syntaxlocal('listsyms_list'))
- let new_rate = min([rate_first_line + 100/(n-1)+1, 100])
-
- call s:change_cb(a:from_line, a:to_line, new_rate)
-
-endfunction
-
-
-"Toggles checkbox between [ ] and [X] or creates one
-"in the lines of the given range
-function! vimwiki#lst#toggle_cb(from_line, to_line)
- return s:toggle_create_cb(a:from_line, a:to_line, 100, 0, 0)
-endfunction
-
-
-"Toggles checkbox between [ ] and [-] or creates one
-"in the lines of the given range
-function! vimwiki#lst#toggle_rejected_cb(from_line, to_line)
- return s:toggle_create_cb(a:from_line, a:to_line, -1, 0, -1)
-endfunction
-
-
-function! vimwiki#lst#remove_cb(first_line, last_line)
- let first_item = s:get_corresponding_item(a:first_line)
- let last_item = s:get_corresponding_item(a:last_line)
-
- if first_item.type == 0 || last_item.type == 0
- return
- endif
-
- let parent_items_of_lines = []
- let cur_ln = first_item.lnum
- while 1
- if cur_ln <= 0 || cur_ln > last_item.lnum | break | endif
- let cur_item = s:get_item(cur_ln)
- if cur_item.type != 0
- let cur_item = s:remove_cb(cur_item)
- let cur_parent_item = s:get_parent(cur_item)
- if index(parent_items_of_lines, cur_parent_item) == -1
- call insert(parent_items_of_lines, cur_parent_item)
- endif
- endif
- let cur_ln = s:get_next_line(cur_ln)
- endwhile
- for parent_item in parent_items_of_lines
- call s:update_state(parent_item)
- endfor
-endfunction
-
-
-function! vimwiki#lst#remove_cb_in_list()
- let first_item = s:get_first_item_in_list(s:get_corresponding_item(line('.')), 0)
-
- let cur_item = first_item
- while 1
- let next_item = s:get_next_list_item(cur_item, 0)
- let cur_item = s:remove_cb(cur_item)
- if next_item.type == 0
- break
- else
- let cur_item = next_item
- endif
- endwhile
-
- call s:update_state(s:get_parent(first_item))
-endfunction
-
-
-
-" ---------------------------------------------------------
-" change the level of list items
-" ---------------------------------------------------------
-
-function! s:set_indent(lnum, new_indent)
- if &expandtab
- let indentstring = repeat(' ', a:new_indent)
- else
- let indentstring = repeat('\t', a:new_indent / &tabstop) . repeat(' ', a:new_indent % &tabstop)
- endif
- call s:substitute_rx_in_line(a:lnum, '^\s*', indentstring)
-endfunction
-
-
-function! s:decrease_level(item)
- let removed_indent = 0
- if vimwiki#vars#get_syntaxlocal('recurring_bullets') && a:item.type == 1 &&
- \ index(vimwiki#vars#get_syntaxlocal('multiple_bullet_chars'),
- \ s:first_char(a:item.mrkr)) > -1
- if s:string_length(a:item.mrkr) >= 2
- call s:substitute_string_in_line(a:item.lnum, s:first_char(a:item.mrkr), '')
- let removed_indent = -1
- endif
- else
- let old_indent = indent(a:item.lnum)
- if &shiftround
- let new_indent = (old_indent - 1) / vimwiki#u#sw() * vimwiki#u#sw()
- else
- let new_indent = old_indent - vimwiki#u#sw()
- endif
- call s:set_indent(a:item.lnum, new_indent)
- let removed_indent = new_indent - old_indent
- endif
- return removed_indent
-endfunction
-
-
-function! s:increase_level(item)
- let additional_indent = 0
- if vimwiki#vars#get_syntaxlocal('recurring_bullets') && a:item.type == 1 &&
- \ index(vimwiki#vars#get_syntaxlocal('multiple_bullet_chars'),
- \ s:first_char(a:item.mrkr)) > -1
- call s:substitute_string_in_line(a:item.lnum, a:item.mrkr, a:item.mrkr .
- \ s:first_char(a:item.mrkr))
- let additional_indent = 1
- else
- let old_indent = indent(a:item.lnum)
- if &shiftround
- let new_indent = (old_indent / vimwiki#u#sw() + 1) * vimwiki#u#sw()
- else
- let new_indent = old_indent + vimwiki#u#sw()
- endif
- call s:set_indent(a:item.lnum, new_indent)
- let additional_indent = new_indent - old_indent
- endif
- return additional_indent
-endfunction
-
-
-"adds a:indent_by to the current indent
-"a:indent_by can be negative
-function! s:indent_line_by(lnum, indent_by)
- let item = s:get_item(a:lnum)
- if vimwiki#vars#get_syntaxlocal('recurring_bullets') && item.type == 1 &&
- \ index(vimwiki#vars#get_syntaxlocal('multiple_bullet_chars'),
- \ s:first_char(item.mrkr)) > -1
- if a:indent_by > 0
- call s:substitute_string_in_line(a:lnum, item.mrkr, item.mrkr . s:first_char(item.mrkr))
- elseif a:indent_by < 0
- call s:substitute_string_in_line(a:lnum, s:first_char(item.mrkr), '')
- endif
- else
- call s:set_indent(a:lnum, indent(a:lnum) + a:indent_by)
- endif
-endfunction
-
-
-"changes lvl of lines in selection
-function! s:change_level(from_line, to_line, direction, plus_children)
- let from_item = s:get_corresponding_item(a:from_line)
- if from_item.type == 0
- if a:direction ==# 'increase' && a:from_line == a:to_line && empty(getline(a:from_line))
- "that's because :> doesn't work on an empty line
- normal! gi
- else
- execute a:from_line.','.a:to_line.(a:direction ==# 'increase' ? '>' : '<')
- endif
- return
- endif
-
- if a:direction ==# 'decrease' && s:get_level(from_item.lnum) == 0
- return
- endif
-
- if a:from_line == a:to_line
- if a:plus_children
- let to_line = s:get_last_line_of_item_incl_children(from_item)
- else
- let to_line = s:get_last_line_of_item(from_item)
- endif
- else
- let to_item = s:get_corresponding_item(a:to_line)
- if to_item.type == 0
- let to_line = a:to_line
- else
- if a:plus_children
- let to_line = s:get_last_line_of_item_incl_children(to_item)
- else
- let to_line = s:get_last_line_of_item(to_item)
- endif
- endif
- endif
-
- if to_line == 0
- return
- endif
-
- let to_be_adjusted = s:get_a_neighbor_item(from_item)
- let old_parent = s:get_parent(from_item)
- let first_line_level = s:get_level(from_item.lnum)
- let more_than_one_level_concerned = 0
-
- let first_line_indented_by = (a:direction ==# 'increase') ?
- \ s:increase_level(from_item) : s:decrease_level(from_item)
-
- let cur_ln = s:get_next_line(from_item.lnum)
- while cur_ln > 0 && cur_ln <= to_line
- if !more_than_one_level_concerned &&
- \ s:get_level(cur_ln) != first_line_level &&
- \ s:get_item(cur_ln).type != 0
- let more_than_one_level_concerned = 1
- endif
- call s:indent_line_by(cur_ln, first_line_indented_by)
- let cur_ln = s:get_next_line(cur_ln, 1)
- endwhile
-
- if a:from_line == a:to_line
- call s:adjust_mrkr(from_item)
- endif
- call s:update_state(old_parent)
- let from_item = s:get_item(from_item.lnum)
- if from_item.cb != ''
- call s:update_state(from_item)
- call s:update_state(s:get_parent(from_item))
- endif
-
- if more_than_one_level_concerned
- call vimwiki#lst#adjust_whole_buffer()
- else
- call s:adjust_numbered_list(from_item, 0, 0)
- call s:adjust_numbered_list(to_be_adjusted, 0, 0)
- endif
-endfunction
-
-
-function! vimwiki#lst#change_level(from_line, to_line, direction, plus_children)
- let cur_col = col('$') - col('.')
- call s:change_level(a:from_line, a:to_line, a:direction, a:plus_children)
- call cursor('.', col('$') - cur_col)
-endfunction
-
-
-"indent line a:lnum to be the continuation of a:prev_item
-function! s:indent_multiline(prev_item, lnum)
- if a:prev_item.type != 0
- call s:set_indent(a:lnum, s:text_begin(a:prev_item.lnum))
- endif
-endfunction
-
-
-" ---------------------------------------------------------
-" change markers of list items
-" ---------------------------------------------------------
-
-"Returns: the position of a marker in g:vimwiki_list_markers
-function! s:get_idx_list_markers(item)
- if a:item.type == 1
- let m = s:first_char(a:item.mrkr)
- else
- let m = s:guess_kind_of_numbered_item(a:item) . a:item.mrkr[-1:]
- endif
- return index(vimwiki#vars#get_syntaxlocal('list_markers'), m)
-endfunction
-
-
-"changes the marker of the given item to the next in g:vimwiki_list_markers
-function! s:get_next_mrkr(item)
- let markers = vimwiki#vars#get_syntaxlocal('list_markers')
- if a:item.type == 0
- let new_mrkr = markers[0]
- else
- let idx = s:get_idx_list_markers(a:item)
- let new_mrkr = markers[(idx+1) % len(markers)]
- endif
- return new_mrkr
-endfunction
-
-
-"changes the marker of the given item to the previous in g:vimwiki_list_markers
-function! s:get_prev_mrkr(item)
- let markers = vimwiki#vars#get_syntaxlocal('list_markers')
- if a:item.type == 0
- return markers[-1]
- endif
- let idx = s:get_idx_list_markers(a:item)
- if idx == -1
- return markers[-1]
- else
- return markers[(idx - 1 + len(markers)) % len(markers)]
- endif
-endfunction
-
-
-function! s:set_new_mrkr(item, new_mrkr)
- if a:item.type == 0
- call s:substitute_rx_in_line(a:item.lnum, '^\s*\zs\ze', a:new_mrkr.' ')
- if indent(a:item.lnum) == 0 && !vimwiki#vars#get_syntaxlocal('recurring_bullets')
- call s:set_indent(a:item.lnum, vimwiki#lst#get_list_margin())
- endif
- else
- call s:substitute_string_in_line(a:item.lnum, a:item.mrkr, a:new_mrkr)
- endif
-endfunction
-
-
-function! vimwiki#lst#change_marker(from_line, to_line, new_mrkr, mode)
- let cur_col_from_eol = col("$") - (a:mode ==# "i" ? col("'^") : col('.'))
- let new_mrkr = a:new_mrkr
- let cur_ln = a:from_line
- while 1
- let cur_item = s:get_item(cur_ln)
-
- if new_mrkr ==# "next"
- let new_mrkr = s:get_next_mrkr(cur_item)
- elseif new_mrkr ==# "prev"
- let new_mrkr = s:get_prev_mrkr(cur_item)
- endif
-
- "handle markers like ***
- if index(vimwiki#vars#get_syntaxlocal('multiple_bullet_chars'), s:first_char(new_mrkr)) > -1
- "use *** if the item above has *** too
- let item_above = s:get_prev_list_item(cur_item, 1)
- if item_above.type == 1 && s:first_char(item_above.mrkr) ==# s:first_char(new_mrkr)
- let new_mrkr = item_above.mrkr
- else
- "use *** if the item below has *** too
- let item_below = s:get_next_list_item(cur_item, 1)
- if item_below.type == 1 && s:first_char(item_below.mrkr) ==# s:first_char(new_mrkr)
- let new_mrkr = item_below.mrkr
- else
- "if the old is ### and the new is * use ***
- if cur_item.type == 1 &&
- \ index(vimwiki#vars#get_syntaxlocal('multiple_bullet_chars'),
- \ s:first_char(cur_item.mrkr))>-1
- let new_mrkr = repeat(new_mrkr, s:string_length(cur_item.mrkr))
- else
- "use *** if the parent item has **
- let parent_item = s:get_parent(cur_item)
- if parent_item.type == 1 && s:first_char(parent_item.mrkr) ==# s:first_char(new_mrkr)
- let new_mrkr = repeat(s:first_char(parent_item.mrkr),
- \ s:string_length(parent_item.mrkr)+1)
- endif
- endif
- endif
- endif
-
- endif
-
- call s:set_new_mrkr(cur_item, new_mrkr)
- call s:adjust_numbered_list(s:get_item(cur_ln), 1, 0)
-
- if cur_ln >= a:to_line | break | endif
- let cur_ln = s:get_next_line(cur_ln, 1)
- endwhile
-
- call cursor('.', col('$') - cur_col_from_eol)
-endfunction
-
-
-function! vimwiki#lst#change_marker_in_list(new_mrkr)
- let cur_item = s:get_corresponding_item(line('.'))
- let first_item = s:get_first_item_in_list(cur_item, 0)
- let last_item = s:get_last_item_in_list(cur_item, 0)
- if first_item.type == 0 || last_item.type == 0 | return | endif
- let first_item_line = first_item.lnum
-
- let cur_item = first_item
- while cur_item.type != 0 && cur_item.lnum <= last_item.lnum
- call s:set_new_mrkr(cur_item, a:new_mrkr)
- let cur_item = s:get_next_list_item(cur_item, 1)
- endwhile
-
- call s:adjust_numbered_list(s:get_item(first_item_line), 0, 0)
-endfunction
-
-
-"sets kind of the item depending on neighbor items and the parent item
-function! s:adjust_mrkr(item)
- if a:item.type == 0 || vimwiki#vars#get_syntaxlocal('recurring_bullets')
- return
- endif
-
- let new_mrkr = a:item.mrkr
- let neighbor_item = s:get_a_neighbor_item(a:item)
- if neighbor_item.type != 0
- let new_mrkr = neighbor_item.mrkr
- endif
-
- "if possible, set e.g. *** if parent has ** as marker
- if neighbor_item.type == 0 && a:item.type == 1 &&
- \ index(vimwiki#vars#get_syntaxlocal('multiple_bullet_chars'),
- \ s:first_char(a:item.mrkr)) > -1
- let parent_item = s:get_parent(a:item)
- if parent_item.type == 1 && s:first_char(parent_item.mrkr) ==# s:first_char(a:item.mrkr)
- let new_mrkr = repeat(s:first_char(parent_item.mrkr), s:string_length(parent_item.mrkr)+1)
- endif
- endif
-
- call s:substitute_string_in_line(a:item.lnum, a:item.mrkr, new_mrkr)
- call s:adjust_numbered_list(a:item, 0, 1)
-endfunction
-
-
-function! s:clone_marker_from_to(from, to)
- let item_from = s:get_item(a:from)
- if item_from.type == 0 | return | endif
- let new_mrkr = item_from.mrkr . ' '
- call s:substitute_rx_in_line(a:to, '^\s*', new_mrkr)
- let new_indent = ( vimwiki#vars#get_syntaxlocal('recurring_bullets') ? 0 : indent(a:from) )
- call s:set_indent(a:to, new_indent)
- if item_from.cb != ''
- call s:create_cb(s:get_item(a:to), 0)
- call s:update_state(s:get_parent(s:get_item(a:to)))
- endif
- if item_from.type == 2
- let adjust_from = ( a:from < a:to ? a:from : a:to )
- call s:adjust_numbered_list_below(s:get_item(adjust_from), 0)
- endif
-endfunction
-
-
-function! s:remove_mrkr(item)
- let item = a:item
- if item.cb != ''
- let item = s:remove_cb(item)
- let parent_item = s:get_parent(item)
- else
- let parent_item = s:empty_item()
- endif
- call s:substitute_rx_in_line(item.lnum, vimwiki#u#escape(item.mrkr).'\s*', '')
- call remove(item, 'mrkr')
- call remove(item, 'cb')
- let item.type = 0
- call s:update_state(parent_item)
- return item
-endfunction
-
-
-function! s:create_marker(lnum)
- let new_sibling = s:get_corresponding_item(a:lnum)
- if new_sibling.type == 0
- let new_sibling = s:get_a_neighbor_item_in_column(a:lnum, virtcol('.'))
- endif
- if new_sibling.type != 0
- call s:clone_marker_from_to(new_sibling.lnum, a:lnum)
- else
- let cur_item = s:get_item(a:lnum)
- call s:set_new_mrkr(cur_item, vimwiki#vars#get_syntaxlocal('list_markers')[0])
- call s:adjust_numbered_list(cur_item, 0, 0)
- endif
-endfunction
-
-
-" ---------------------------------------------------------
-" handle keys
-" ---------------------------------------------------------
-
-function! vimwiki#lst#kbd_o()
- let fold_end = foldclosedend('.')
- let lnum = (fold_end == -1) ? line('.') : fold_end
- let cur_item = s:get_item(lnum)
- "inserting and deleting the x is necessary
- "because otherwise the indent is lost
- normal! ox
- if cur_item.lnum < s:get_last_line_of_item(cur_item)
- call s:indent_multiline(cur_item, cur_item.lnum+1)
- else
- call s:clone_marker_from_to(cur_item.lnum, cur_item.lnum+1)
- endif
- startinsert!
-endfunction
-
-
-function! vimwiki#lst#kbd_O()
- normal! Ox
- let cur_ln = line('.')
- if getline(cur_ln+1) !~# '^\s*$'
- call s:clone_marker_from_to(cur_ln+1, cur_ln)
- else
- call s:clone_marker_from_to(cur_ln-1, cur_ln)
- endif
- startinsert!
-endfunction
-
-
-function! s:cr_on_empty_list_item(lnum, behavior)
- if a:behavior == 1
- "just make a new list item
- normal! gi
- call s:clone_marker_from_to(a:lnum, a:lnum+1)
- startinsert!
- return
- elseif a:behavior == 2
- "insert new marker but remove marker in old line
- call append(a:lnum-1, '')
- startinsert!
- return
- elseif a:behavior == 3
- "list is finished, but cursor stays in current line
- let item = s:get_item(a:lnum)
- let neighbor_item = s:get_a_neighbor_item(item)
- let child_item = s:get_first_child(item)
- let parent_item = (item.cb != '') ? s:get_parent(item) : s:empty_item()
- normal! "_cc
- call s:adjust_numbered_list(neighbor_item, 0, 0)
- call s:adjust_numbered_list(child_item, 0, 0)
- call s:update_state(parent_item)
- startinsert
- return
- elseif a:behavior == 4
- "list is finished, but cursor goes to next line
- let item = s:get_item(a:lnum)
- let neighbor_item = s:get_a_neighbor_item(item)
- let child_item = s:get_first_child(item)
- let parent_item = (item.cb != '') ? s:get_parent(item) : s:empty_item()
- normal! "_cc
- call s:adjust_numbered_list(neighbor_item, 0, 0)
- call s:adjust_numbered_list(child_item, 0, 0)
- call s:update_state(parent_item)
- startinsert
- return
- elseif a:behavior == 5
- "successively decrease level
- if s:get_level(a:lnum) > 0
- call s:change_level(a:lnum, a:lnum, 'decrease', 0)
- startinsert!
- else
- let item = s:get_item(a:lnum)
- let neighbor_item = s:get_a_neighbor_item(item)
- let child_item = s:get_first_child(item)
- let parent_item = (item.cb != '') ? s:get_parent(item) : s:empty_item()
- normal! "_cc
- call s:adjust_numbered_list(neighbor_item, 0, 0)
- call s:adjust_numbered_list(child_item, 0, 0)
- call s:update_state(parent_item)
- startinsert
- endif
- return
- endif
-endfunction
-
-
-function! s:cr_on_empty_line(lnum, behavior)
- "inserting and deleting the x is necessary
- "because otherwise the indent is lost
- normal! gix
- if a:behavior == 2 || a:behavior == 3
- call s:create_marker(a:lnum+1)
- endif
-endfunction
-
-
-function! s:cr_on_list_item(lnum, insert_new_marker, not_at_eol)
- if a:insert_new_marker
- "the ultimate feature of this script: make new marker on <CR>
- normal! gi
- call s:clone_marker_from_to(a:lnum, a:lnum+1)
- "tiny sweet extra feature: indent next line if current line ends with :
- if !a:not_at_eol && getline(a:lnum) =~# ':$'
- call s:change_level(a:lnum+1, a:lnum+1, 'increase', 0)
- endif
- else
- " || (cur_item.lnum < s:get_last_line_of_item(cur_item))
- "indent this line so that it becomes the continuation of the line above
- normal! gi
- let prev_line = s:get_corresponding_item(s:get_prev_line(a:lnum+1))
- call s:indent_multiline(prev_line, a:lnum+1)
- endif
-endfunction
-
-
-function! vimwiki#lst#kbd_cr(normal, just_mrkr)
- let lnum = line('.')
- let has_bp = s:line_has_marker(lnum)
-
- if has_bp != 0 && virtcol('.') < s:text_begin(lnum)
- call append(lnum-1, '')
- startinsert!
- return
- endif
-
- if has_bp == 1
- call s:cr_on_empty_list_item(lnum, a:just_mrkr)
- return
- endif
-
- let insert_new_marker = (a:normal == 1 || a:normal == 3)
- if getline('.')[col("'^")-1:] =~# '^\s\+$'
- let cur_col = 0
- else
- let cur_col = col("$") - col("'^")
- if getline('.')[col("'^")-1] =~# '\s' && exists("*strdisplaywidth")
- let ws_behind_cursor =
- \ strdisplaywidth(matchstr(getline('.')[col("'^")-1:], '\s\+'),
- \ virtcol("'^")-1)
- let cur_col -= ws_behind_cursor
- endif
- if insert_new_marker && cur_col == 0 && getline(lnum) =~# '\s$'
- let insert_new_marker = 0
- endif
- endif
-
- if has_bp == 0
- call s:cr_on_empty_line(lnum, a:normal)
- endif
-
- if has_bp == 2
- call s:cr_on_list_item(lnum, insert_new_marker, cur_col)
- endif
-
- call cursor(lnum+1, col("$") - cur_col)
- if cur_col == 0
- startinsert!
- else
- startinsert
- endif
-
-endfunction
-
-
-"creates a list item in the current line or removes it
-function! vimwiki#lst#toggle_list_item()
- let cur_col_from_eol = col("$") - col("'^")
- let cur_item = s:get_item(line('.'))
-
- if cur_item.type == 0
- call s:create_marker(cur_item.lnum)
- else
- let prev_item = s:get_prev_list_item(cur_item, 1)
- if prev_item.type == 0
- let prev_item = s:get_corresponding_item(s:get_prev_line(cur_item.lnum))
- endif
- let cur_item = s:remove_mrkr(cur_item)
- let adjust_prev_item = (prev_item.type == 2 &&
- \ s:get_level(cur_item.lnum) <= s:get_level(prev_item.lnum)) ? 1 : 0
- call s:indent_multiline(prev_item, cur_item.lnum)
- if adjust_prev_item
- call s:adjust_numbered_list_below(prev_item, 0)
- endif
- endif
-
- "set cursor position s.t. it's on the same char as before
- let new_cur_col = col("$") - cur_col_from_eol
- call cursor(cur_item.lnum, new_cur_col >= 1 ? new_cur_col : 1)
-
- if cur_col_from_eol == 0 || getline(cur_item.lnum) =~# '^\s*$'
- startinsert!
- else
- startinsert
- endif
-endfunction
-
-
-" ---------------------------------------------------------
-" misc stuff
-" ---------------------------------------------------------
-
-function! vimwiki#lst#TO_list_item(inner, visual)
- let lnum = prevnonblank('.')
- let item = s:get_corresponding_item(lnum)
- if item.type == 0
- return
- endif
- let from_line = item.lnum
- if a:inner
- let to_line = s:get_last_line_of_item(item)
- else
- let to_line = s:get_last_line_of_item_incl_children(item)
- endif
- normal! V
- call cursor(to_line, 0)
- normal! o
- call cursor(from_line, 0)
-endfunction
-
-
-function! vimwiki#lst#fold_level(lnum)
- let cur_item = s:get_item(a:lnum)
- if cur_item.type != 0
- let parent_item = s:get_parent(cur_item)
- let child_item = s:get_first_child(cur_item)
- let next_item = s:get_next_child_item(parent_item, cur_item)
- if child_item.type != 0
- return 'a1'
- elseif next_item.type == 0
- return 's1'
- endif
- endif
- return '='
-endfunction
-
diff --git a/.config/nvim/autoload/vimwiki/markdown_base.vim b/.config/nvim/autoload/vimwiki/markdown_base.vim
@@ -1,150 +0,0 @@
-" vim:tabstop=2:shiftwidth=2:expandtab:textwidth=99
-" Vimwiki autoload plugin file
-" Description: Link functions for markdown syntax
-" Home: https://github.com/vimwiki/vimwiki/
-
-
-function! s:safesubstitute(text, search, replace, mode)
- " Substitute regexp but do not interpret replace
- let escaped = escape(a:replace, '\&')
- return substitute(a:text, a:search, escaped, a:mode)
-endfunction
-
-
-function! vimwiki#markdown_base#scan_reflinks()
- let mkd_refs = {}
- " construct list of references using vimgrep
- try
- " Why noautocmd? Because https://github.com/vimwiki/vimwiki/issues/121
- noautocmd execute 'vimgrep #'.vimwiki#vars#get_syntaxlocal('rxMkdRef').'#j %'
- catch /^Vim\%((\a\+)\)\=:E480/ " No Match
- "Ignore it, and move on to the next file
- endtry
-
- for d in getqflist()
- let matchline = join(getline(d.lnum, min([d.lnum+1, line('$')])), ' ')
- let descr = matchstr(matchline, vimwiki#vars#get_syntaxlocal('rxMkdRefMatchDescr'))
- let url = matchstr(matchline, vimwiki#vars#get_syntaxlocal('rxMkdRefMatchUrl'))
- if descr != '' && url != ''
- let mkd_refs[descr] = url
- endif
- endfor
- call vimwiki#vars#set_bufferlocal('markdown_refs', mkd_refs)
- return mkd_refs
-endfunction
-
-
-" try markdown reference links
-function! vimwiki#markdown_base#open_reflink(link)
- " echom "vimwiki#markdown_base#open_reflink"
- let link = a:link
- let mkd_refs = vimwiki#vars#get_bufferlocal('markdown_refs')
- if has_key(mkd_refs, link)
- let url = mkd_refs[link]
- call vimwiki#base#system_open_link(url)
- return 1
- else
- return 0
- endif
-endfunction
-
-
-function! s:normalize_link_syntax_n()
- let lnum = line('.')
-
- " try WikiIncl
- let lnk = vimwiki#base#matchstr_at_cursor(vimwiki#vars#get_global('rxWikiIncl'))
- if !empty(lnk)
- " NO-OP !!
- return
- endif
-
- " try WikiLink0: replace with WikiLink1
- let lnk = vimwiki#base#matchstr_at_cursor(vimwiki#vars#get_syntaxlocal('rxWikiLink0'))
- if !empty(lnk)
- let sub = vimwiki#base#normalize_link_helper(lnk,
- \ vimwiki#vars#get_syntaxlocal('rxWikiLinkMatchUrl'),
- \ vimwiki#vars#get_syntaxlocal('rxWikiLinkMatchDescr'),
- \ vimwiki#vars#get_syntaxlocal('WikiLink1Template2'))
- call vimwiki#base#replacestr_at_cursor(vimwiki#vars#get_syntaxlocal('rxWikiLink0'), sub)
- return
- endif
-
- " try WikiLink1: replace with WikiLink0
- let lnk = vimwiki#base#matchstr_at_cursor(vimwiki#vars#get_syntaxlocal('rxWikiLink1'))
- if !empty(lnk)
- let sub = vimwiki#base#normalize_link_helper(lnk,
- \ vimwiki#vars#get_syntaxlocal('rxWikiLinkMatchUrl'),
- \ vimwiki#vars#get_syntaxlocal('rxWikiLinkMatchDescr'),
- \ vimwiki#vars#get_global('WikiLinkTemplate2'))
- call vimwiki#base#replacestr_at_cursor(vimwiki#vars#get_syntaxlocal('rxWikiLink1'), sub)
- return
- endif
-
- " try Weblink
- let lnk = vimwiki#base#matchstr_at_cursor(vimwiki#vars#get_syntaxlocal('rxWeblink'))
- if !empty(lnk)
- let sub = vimwiki#base#normalize_link_helper(lnk,
- \ vimwiki#vars#get_syntaxlocal('rxWeblinkMatchUrl'),
- \ vimwiki#vars#get_syntaxlocal('rxWeblinkMatchDescr'),
- \ vimwiki#vars#get_syntaxlocal('Weblink1Template'))
- call vimwiki#base#replacestr_at_cursor(vimwiki#vars#get_syntaxlocal('rxWeblink'), sub)
- return
- endif
-
- " try Word (any characters except separators)
- " rxWord is less permissive than rxWikiLinkUrl which is used in
- " normalize_link_syntax_v
- let lnk = vimwiki#base#matchstr_at_cursor(vimwiki#vars#get_global('rxWord'))
- if !empty(lnk)
- let sub = vimwiki#base#normalize_link_helper(lnk,
- \ vimwiki#vars#get_global('rxWord'), '',
- \ vimwiki#vars#get_syntaxlocal('Weblink1Template'))
- call vimwiki#base#replacestr_at_cursor('\V'.lnk, sub)
- return
- endif
-
-endfunction
-
-
-function! s:normalize_link_syntax_v()
- let lnum = line('.')
- let sel_save = &selection
- let &selection = "old"
- let rv = @"
- let rt = getregtype('"')
- let done = 0
-
- try
- norm! gvy
- let visual_selection = @"
- let link = s:safesubstitute(vimwiki#vars#get_syntaxlocal('Weblink1Template'),
- \ '__LinkUrl__', visual_selection, '')
- let link = s:safesubstitute(link, '__LinkDescription__', visual_selection, '')
-
- call setreg('"', substitute(link, '\n', '', ''), visualmode())
-
- " paste result
- norm! `>""pgvd
-
- finally
- call setreg('"', rv, rt)
- let &selection = sel_save
- endtry
-
-endfunction
-
-
-function! vimwiki#markdown_base#normalize_link(is_visual_mode)
- if 0
- " Syntax-specific links
- else
- if !a:is_visual_mode
- call s:normalize_link_syntax_n()
- elseif line("'<") == line("'>")
- " action undefined for multi-line visual mode selections
- call s:normalize_link_syntax_v()
- endif
- endif
-endfunction
-
diff --git a/.config/nvim/autoload/vimwiki/path.vim b/.config/nvim/autoload/vimwiki/path.vim
@@ -1,183 +0,0 @@
-" vim:tabstop=2:shiftwidth=2:expandtab:textwidth=99
-" Vimwiki autoload plugin file
-" Description: Path manipulation functions
-" Home: https://github.com/vimwiki/vimwiki/
-
-
-function! vimwiki#path#chomp_slash(str)
- return substitute(a:str, '[/\\]\+$', '', '')
-endfunction
-
-
-" Define path-compare function, either case-sensitive or not, depending on OS.
-if vimwiki#u#is_windows()
- function! vimwiki#path#is_equal(p1, p2)
- return a:p1 ==? a:p2
- endfunction
-else
- function! vimwiki#path#is_equal(p1, p2)
- return a:p1 ==# a:p2
- endfunction
-endif
-
-
-" collapse sections like /a/b/../c to /a/c
-function! vimwiki#path#normalize(path)
- let path = a:path
- while 1
- let result = substitute(path, '/[^/]\+/\.\.', '', '')
- if result ==# path
- break
- endif
- let path = result
- endwhile
- return result
-endfunction
-
-
-function! vimwiki#path#path_norm(path)
- " /-slashes
- if a:path !~# '^scp:'
- let path = substitute(a:path, '\', '/', 'g')
- " treat multiple consecutive slashes as one path separator
- let path = substitute(path, '/\+', '/', 'g')
- " ensure that we are not fooled by a symbolic link
- return resolve(path)
- else
- return a:path
- endif
-endfunction
-
-
-function! vimwiki#path#is_link_to_dir(link)
- " Check if link is to a directory.
- " It should be ended with \ or /.
- return a:link =~# '\m[/\\]$'
-endfunction
-
-
-function! vimwiki#path#abs_path_of_link(link)
- return vimwiki#path#normalize(expand("%:p:h").'/'.a:link)
-endfunction
-
-
-" return longest common path prefix of 2 given paths.
-" '~/home/usrname/wiki', '~/home/usrname/wiki/shmiki' => '~/home/usrname/wiki'
-function! vimwiki#path#path_common_pfx(path1, path2)
- let p1 = split(a:path1, '[/\\]', 1)
- let p2 = split(a:path2, '[/\\]', 1)
-
- let idx = 0
- let minlen = min([len(p1), len(p2)])
- while (idx < minlen) && vimwiki#path#is_equal(p1[idx], p2[idx])
- let idx = idx + 1
- endwhile
- if idx == 0
- return ''
- else
- return join(p1[: idx-1], '/')
- endif
-endfunction
-
-
-function! vimwiki#path#wikify_path(path)
- let result = resolve(fnamemodify(a:path, ':p'))
- if vimwiki#u#is_windows()
- let result = substitute(result, '\\', '/', 'g')
- endif
- let result = vimwiki#path#chomp_slash(result)
- return result
-endfunction
-
-
-function! vimwiki#path#current_wiki_file()
- return vimwiki#path#wikify_path(expand('%:p'))
-endfunction
-
-
-" Returns: the relative path from a:dir to a:file
-function! vimwiki#path#relpath(dir, file)
- let result = []
- let dir = split(a:dir, '/')
- let file = split(a:file, '/')
- while (len(dir) > 0 && len(file) > 0) && vimwiki#path#is_equal(dir[0], file[0])
- call remove(dir, 0)
- call remove(file, 0)
- endwhile
- if empty(dir) && empty(file)
- return './'
- endif
- for segment in dir
- let result += ['..']
- endfor
- for segment in file
- let result += [segment]
- endfor
- let result_path = join(result, '/')
- if a:file =~ '\m/$'
- let result_path .= '/'
- endif
- return result_path
-endfunction
-
-
-" If the optional argument provided and nonzero,
-" it will ask before creating a directory
-" Returns: 1 iff directory exists or successfully created
-function! vimwiki#path#mkdir(path, ...)
- let path = expand(a:path)
-
- if path =~# '^scp:'
- " we can not do much, so let's pretend everything is ok
- return 1
- endif
-
- if isdirectory(path)
- return 1
- else
- if !exists("*mkdir")
- return 0
- endif
-
- let path = vimwiki#path#chomp_slash(path)
- if vimwiki#u#is_windows() && !empty(vimwiki#vars#get_global('w32_dir_enc'))
- let path = iconv(path, &enc, vimwiki#vars#get_global('w32_dir_enc'))
- endif
-
- if a:0 && a:1 && input("Vimwiki: Make new directory: ".path."\n [y]es/[N]o? ") !~? '^y'
- return 0
- endif
-
- call mkdir(path, "p")
- return 1
- endif
-endfunction
-
-
-function! vimwiki#path#is_absolute(path)
- if vimwiki#u#is_windows()
- return a:path =~? '\m^\a:'
- else
- return a:path =~# '\m^/\|\~/'
- endif
-endfunction
-
-
-" Combine a directory and a file into one path, doesn't generate duplicate
-" path separator in case the directory is also having an ending / or \. This
-" is because on windows ~\vimwiki//.tags is invalid but ~\vimwiki/.tags is a
-" valid path.
-if vimwiki#u#is_windows()
- function! vimwiki#path#join_path(directory, file)
- let directory = vimwiki#path#chomp_slash(a:directory)
- let file = substitute(a:file, '\m^[\\/]\+', '', '')
- return directory . '/' . file
- endfunction
-else
- function! vimwiki#path#join_path(directory, file)
- let directory = substitute(a:directory, '\m/\+$', '', '')
- let file = substitute(a:file, '\m^/\+', '', '')
- return directory . '/' . file
- endfunction
-endif
-
diff --git a/.config/nvim/autoload/vimwiki/style.css b/.config/nvim/autoload/vimwiki/style.css
@@ -1,83 +0,0 @@
-body {font-family: Tahoma, Geneva, sans-serif; margin: 1em 2em 1em 2em; font-size: 100%; line-height: 130%;}
-h1, h2, h3, h4, h5, h6 {font-family: Trebuchet MS, Helvetica, sans-serif; font-weight: bold; line-height:100%; margin-top: 1.5em; margin-bottom: 0.5em;}
-h1 {font-size: 2.6em; color: #000000;}
-h2 {font-size: 2.2em; color: #404040;}
-h3 {font-size: 1.8em; color: #707070;}
-h4 {font-size: 1.4em; color: #909090;}
-h5 {font-size: 1.3em; color: #989898;}
-h6 {font-size: 1.2em; color: #9c9c9c;}
-p, pre, blockquote, table, ul, ol, dl {margin-top: 1em; margin-bottom: 1em;}
-ul ul, ul ol, ol ol, ol ul {margin-top: 0.5em; margin-bottom: 0.5em;}
-li {margin: 0.3em auto;}
-ul {margin-left: 2em; padding-left: 0.5em;}
-dt {font-weight: bold;}
-img {border: none;}
-pre {border-left: 1px solid #ccc; margin-left: 2em; padding-left: 0.5em;}
-blockquote {padding: 0.4em; background-color: #f6f5eb;}
-th, td {border: 1px solid #ccc; padding: 0.3em;}
-th {background-color: #f0f0f0;}
-hr {border: none; border-top: 1px solid #ccc; width: 100%;}
-del {text-decoration: line-through; color: #777777;}
-.toc li {list-style-type: none;}
-.todo {font-weight: bold; background-color: #f0ece8; color: #a03020;}
-.justleft {text-align: left;}
-.justright {text-align: right;}
-.justcenter {text-align: center;}
-.center {margin-left: auto; margin-right: auto;}
-.tag {background-color: #eeeeee; font-family: monospace; padding: 2px;}
-.header a {text-decoration: none; color: inherit;}
-
-/* classes for items of todo lists */
-.rejected {
- /* list-style: none; */
- background-image: url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAA8AAAAPCAMAAAAMCGV4AAAACXBIWXMAAADFAAAAxQEdzbqoAAAAB3RJTUUH4QgEFhAtuWgv9wAAAPZQTFRFmpqam5iYnJaWnJeXnpSUn5OTopCQpoqKpouLp4iIqIiIrYCAt3V1vW1tv2xsmZmZmpeXnpKS/x4e/x8f/yAg/yIi/yQk/yUl/yYm/ygo/ykp/yws/zAw/zIy/zMz/zQ0/zU1/zY2/zw8/0BA/0ZG/0pK/1FR/1JS/1NT/1RU/1VV/1ZW/1dX/1pa/15e/19f/2Zm/2lp/21t/25u/3R0/3p6/4CA/4GB/4SE/4iI/46O/4+P/52d/6am/6ur/66u/7Oz/7S0/7e3/87O/9fX/9zc/93d/+Dg/+vr/+3t/+/v//Dw//Ly//X1//f3//n5//z8////gzaKowAAAA90Uk5T/Pz8/Pz8/Pz8/Pz8/f39ppQKWQAAAAFiS0dEEnu8bAAAAACuSURBVAhbPY9ZF4FQFEZPSKbIMmWep4gMGTKLkIv6/3/GPbfF97b3w17rA0kQOPgvAeHW6uJ6+5h7HqLdwowgOzejXRXBdx6UdSru216xuOMBHHNU0clTzeSUA6EhF8V8kqroluMiU6HKcuf4phGPr1o2q9kYZWwNq1qfRRmTaXpqsyjj17KkWCxKBUBgXWueHIyiAIg18gsse4KHkLF5IKIY10WQgv7fOy4ST34BRiopZ8WLNrgAAAAASUVORK5CYII=);
- background-repeat: no-repeat;
- background-position: 0 .2em;
- padding-left: 1.5em;
-}
-.done0 {
- /* list-style: none; */
- background-image: url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAA8AAAAPCAYAAAA71pVKAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAAAxQAAAMUBHc26qAAAABl0RVh0U29mdHdhcmUAd3d3Lmlua3NjYXBlLm9yZ5vuPBoAAAA7SURBVCiR7dMxEgAgCANBI3yVRzF5KxNbW6wsuH7LQ2YKQK1mkswBVERYF5Os3UV3gwd/jF2SkXy66gAZkxS6BniubAAAAABJRU5ErkJggg==);
- background-repeat: no-repeat;
- background-position: 0 .2em;
- padding-left: 1.5em;
-}
-.done1 {
- background-image: url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAA8AAAAPCAYAAAA71pVKAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAAAxQAAAMUBHc26qAAAABl0RVh0U29mdHdhcmUAd3d3Lmlua3NjYXBlLm9yZ5vuPBoAAABtSURBVCiR1ZO7DYAwDER9BDmTeZQMFXmUbGYpOjrEryA0wOvO8itOslFrJYAug5BMM4BeSkmjsrv3aVTa8p48Xw1JSkSsWVUFwD05IqS1tmYzk5zzae9jnVVVzGyXb8sALjse+euRkEzu/uirFomVIdDGOLjuAAAAAElFTkSuQmCC);
- background-repeat: no-repeat;
- background-position: 0 .15em;
- padding-left: 1.5em;
-}
-.done2 {
- background-image: url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAA8AAAAPCAYAAAA71pVKAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAAAxQAAAMUBHc26qAAAABl0RVh0U29mdHdhcmUAd3d3Lmlua3NjYXBlLm9yZ5vuPBoAAAB1SURBVCiRzdO5DcAgDAVQGxjAYgTvxlDIu1FTIRYAp8qlFISkSH7l5kk+ZIwxKiI2mIyqWoeILYRgZ7GINDOLjnmF3VqklKCUMgTee2DmM661Qs55iI3Zm/1u5h9sm4ig9z4ERHTFzLyd4G4+nFlVrYg8+qoF/c0kdpeMsmcAAAAASUVORK5CYII=);
- background-repeat: no-repeat;
- background-position: 0 .15em;
- padding-left: 1.5em;
-}
-.done3 {
- background-image: url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAA8AAAAPCAYAAAA71pVKAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAAAxQAAAMUBHc26qAAAABl0RVh0U29mdHdhcmUAd3d3Lmlua3NjYXBlLm9yZ5vuPBoAAABoSURBVCiR7dOxDcAgDATA/0DtUdiKoZC3YhLkHjkVKF3idJHiztKfvrHZWnOSE8Fx95RJzlprimJVnXktvXeY2S0SEZRSAAAbmxnGGKH2I5T+8VfxPhIReQSuuY3XyYWa3T2p6quvOgGrvSFGlewuUAAAAABJRU5ErkJggg==);
- background-repeat: no-repeat;
- background-position: 0 .15em;
- padding-left: 1.5em;
-}
-.done4 {
- background-image: url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABIAAAAQCAYAAAAbBi9cAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAAAzgAAAM4BlP6ToAAAABl0RVh0U29mdHdhcmUAd3d3Lmlua3NjYXBlLm9yZ5vuPBoAAAIISURBVDiNnZQ9SFtRFMd/773kpTaGJoQk1im4VDpWQcTNODhkFBcVTCNCF0NWyeDiIIiCm82QoIMIUkHUxcFBg1SEQoZszSat6cdTn1qNue92CMbEr9Sey+XC/Z/zu+f8h6ukUil3sVg0+M+4cFxk42/jH2wAqqqKSCSiPQdwcHHAnDHH9s/tN1h8V28ETdP+eU8fT9Nt62ancYdIPvJNtsu87bmjrJlrTDVM4RROJs1JrHPrD4Bar7A6cpc54iKOaTdJXCUI2UMVrQZ0Js7YPN18ECKkYNQcJe/OE/4dZsw7VqNXQMvHy3QZXQypQ6ycrtwDjf8aJ+PNEDSCzLpn7+m2pD8ZKHlKarYhy6XjEoCYGcN95qansQeA3fNdki+SaJZGTMQIOoL3W/Z89rxv+tokubNajlvk/vm+LFpF2XnUKZHI0I+QrI7Dw0OZTqdzUkpsM7mZTyfy5OPGyw1tK7AFSvmB/Ks8w8YwbUYbe6/3QEKv0vugfxWPnMLJun+d/kI/WLdizpNjMbAIKrhMF4OuwadBALqqs+RfInwUvuNi+fBd+wjogfogAFVRmffO02q01mZZ0HHdgXIzdz0QQLPezIQygX6llxNKKgOFARYCC49CqhoHIUTlss/Vx2phlYwjw8j1CAlfAiwQiJpiy7o1VHnsG5FISkoJu7Q/2YmmaV+i0ei7v38L2CBguSi5AAAAAElFTkSuQmCC);
- background-repeat: no-repeat;
- background-position: 0 .15em;
- padding-left: 1.5em;
-}
-
-code {
- font-family: Monaco,"Courier New","DejaVu Sans Mono","Bitstream Vera Sans Mono",monospace;
- -webkit-border-radius: 1px;
- -moz-border-radius: 1px;
- border-radius: 1px;
- -moz-background-clip: padding;
- -webkit-background-clip: padding-box;
- background-clip: padding-box;
- padding: 0px 3px;
- display: inline-block;
- color: #52595d;
- border: 1px solid #ccc;
- background-color: #f9f9f9;
-}
diff --git a/.config/nvim/autoload/vimwiki/tags.vim b/.config/nvim/autoload/vimwiki/tags.vim
@@ -1,342 +0,0 @@
-" vim:tabstop=2:shiftwidth=2:expandtab:textwidth=99
-" Vimwiki autoload plugin file
-
-
-let s:TAGS_METADATA_FILE_NAME = '.tags'
-
-
-
-" Tags metadata in-memory format:
-" metadata := { 'pagename': [entries, ...] }
-" entry := { 'tagname':..., 'lineno':..., 'link':... }
-
-" Tags metadata in-file format:
-"
-" Is based on CTags format (see |tags-file-format|).
-"
-" {tagaddress} is set to lineno. We'll let vim search by exact line number; we
-" can afford that, we assume metadata file is always updated before use.
-"
-" Pagename and link are not saved in standard ctags fields, so we'll add
-" an optional field, "vimwiki:". In this field, we encode tab-separated values
-" of missing parameters -- "pagename" and "link".
-
-
-
-" Update tags metadata.
-" a:full_rebuild == 1: re-scan entire wiki
-" a:full_rebuild == 0: only re-scan current page
-" a:all_files == '': only if the file is newer than .tags
-function! vimwiki#tags#update_tags(full_rebuild, all_files)
- let all_files = a:all_files != ''
- if !a:full_rebuild
- " Updating for one page (current)
- let page_name = vimwiki#vars#get_bufferlocal('subdir') . expand('%:t:r')
- " Collect tags in current file
- let tags = s:scan_tags(getline(1, '$'), page_name)
- " Load metadata file
- let metadata = s:load_tags_metadata()
- " Drop old tags
- let metadata = s:remove_page_from_tags(metadata, page_name)
- " Merge in the new ones
- let metadata = s:merge_tags(metadata, page_name, tags)
- " Save
- call s:write_tags_metadata(metadata)
- else " full rebuild
- let files = vimwiki#base#find_files(vimwiki#vars#get_bufferlocal('wiki_nr'), 0)
- let wiki_base_dir = vimwiki#vars#get_wikilocal('path')
- let tags_file_last_modification = getftime(vimwiki#tags#metadata_file_path())
- let metadata = s:load_tags_metadata()
- for file in files
- if all_files || getftime(file) >= tags_file_last_modification
- let subdir = vimwiki#base#subdir(wiki_base_dir, file)
- let page_name = subdir . fnamemodify(file, ':t:r')
- let tags = s:scan_tags(readfile(file), page_name)
- let metadata = s:remove_page_from_tags(metadata, page_name)
- let metadata = s:merge_tags(metadata, page_name, tags)
- endif
- endfor
- call s:write_tags_metadata(metadata)
- endif
-endfunction
-
-
-" Scans the list of text lines (argument) and produces tags metadata as a list of tag entries.
-function! s:scan_tags(lines, page_name)
-
- let entries = []
-
- " Code wireframe to scan for headers -- borrowed from
- " vimwiki#base#get_anchors(), with minor modifications.
-
- let rxheader = vimwiki#vars#get_syntaxlocal('header_search')
- let rxtag = vimwiki#vars#get_syntaxlocal('tag_search')
-
- let anchor_level = ['', '', '', '', '', '', '']
- let current_complete_anchor = ''
-
- let PROXIMITY_LINES_NR = 2
- let header_line_nr = - (2 * PROXIMITY_LINES_NR)
-
- for line_nr in range(1, len(a:lines))
- let line = a:lines[line_nr - 1]
-
- " process headers
- let h_match = matchlist(line, rxheader)
- if !empty(h_match) " got a header
- let header_line_nr = line_nr
- let header = vimwiki#u#trim(h_match[2])
- let level = len(h_match[1])
- let anchor_level[level-1] = header
- for l in range(level, 6)
- let anchor_level[l] = ''
- endfor
- if level == 1
- let current_complete_anchor = header
- else
- let current_complete_anchor = ''
- for l in range(level-1)
- if anchor_level[l] != ''
- let current_complete_anchor .= anchor_level[l].'#'
- endif
- endfor
- let current_complete_anchor .= header
- endif
- continue " tags are not allowed in headers
- endif
-
- " TODO ignore verbatim blocks
-
- " Scan line for tags. There can be many of them.
- let str = line
- while 1
- let tag_group = matchstr(str, rxtag)
- if tag_group == ''
- break
- endif
- let tagend = matchend(str, rxtag)
- let str = str[(tagend):]
- for tag in split(tag_group, ':')
- " Create metadata entry
- let entry = {}
- let entry.tagname = tag
- let entry.lineno = line_nr
- if line_nr <= PROXIMITY_LINES_NR && header_line_nr < 0
- " Tag appeared at the top of the file
- let entry.link = a:page_name
- elseif line_nr <= (header_line_nr + PROXIMITY_LINES_NR)
- " Tag appeared right below a header
- let entry.link = a:page_name . '#' . current_complete_anchor
- else
- " Tag stands on its own
- let entry.link = a:page_name . '#' . tag
- endif
- call add(entries, entry)
- endfor
- endwhile
-
- endfor " loop over lines
- return entries
-endfunction
-
-
-" Returns tags metadata file path
-function! vimwiki#tags#metadata_file_path() abort
- return fnamemodify(vimwiki#path#join_path(vimwiki#vars#get_wikilocal('path'),
- \ s:TAGS_METADATA_FILE_NAME), ':p')
-endfunction
-
-
-" Loads tags metadata from file, returns a dictionary
-function! s:load_tags_metadata() abort
- let metadata_path = vimwiki#tags#metadata_file_path()
- if !filereadable(metadata_path)
- return {}
- endif
- let metadata = {}
- for line in readfile(metadata_path)
- if line =~ '^!_TAG_FILE_'
- continue
- endif
- let parts = matchlist(line, '^\(.\{-}\);"\(.*\)$')
- if parts[0] == '' || parts[1] == '' || parts[2] == ''
- throw 'VimwikiTags1: Metadata file corrupted'
- endif
- let std_fields = split(parts[1], '\t')
- if len(std_fields) != 3
- throw 'VimwikiTags2: Metadata file corrupted'
- endif
- let vw_part = parts[2]
- if vw_part[0] != "\t"
- throw 'VimwikiTags3: Metadata file corrupted'
- endif
- let vw_fields = split(vw_part[1:], "\t")
- if len(vw_fields) != 1 || vw_fields[0] !~ '^vimwiki:'
- throw 'VimwikiTags4: Metadata file corrupted'
- endif
- let vw_data = substitute(vw_fields[0], '^vimwiki:', '', '')
- let vw_data = substitute(vw_data, '\\n', "\n", 'g')
- let vw_data = substitute(vw_data, '\\r', "\r", 'g')
- let vw_data = substitute(vw_data, '\\t', "\t", 'g')
- let vw_data = substitute(vw_data, '\\\\', "\\", 'g')
- let vw_fields = split(vw_data, "\t")
- if len(vw_fields) != 2
- throw 'VimwikiTags5: Metadata file corrupted'
- endif
- let pagename = vw_fields[0]
- let entry = {}
- let entry.tagname = std_fields[0]
- let entry.lineno = std_fields[2]
- let entry.link = vw_fields[1]
- if has_key(metadata, pagename)
- call add(metadata[pagename], entry)
- else
- let metadata[pagename] = [entry]
- endif
- endfor
- return metadata
-endfunction
-
-
-" Removes all entries for given page from metadata in-place. Returns updated
-" metadata (just in case).
-function! s:remove_page_from_tags(metadata, page_name)
- if has_key(a:metadata, a:page_name)
- call remove(a:metadata, a:page_name)
- return a:metadata
- else
- return a:metadata
- endif
-endfunction
-
-
-" Merges metadata of one file into a:metadata
-function! s:merge_tags(metadata, pagename, file_metadata)
- let metadata = a:metadata
- let metadata[a:pagename] = a:file_metadata
- return metadata
-endfunction
-
-
-" Compares two actual lines from tags file. Return value is in strcmp style.
-" See help on sort() -- that's what this function is going to be used for.
-" See also s:write_tags_metadata below -- that's where we compose these tags
-" file lines.
-"
-" This function is needed for tags sorting, since plain sort() compares line
-" numbers as strings, not integers, and so, for example, tag at line 14
-" preceeds the same tag on the same page at line 9. (Because string "14" is
-" alphabetically 'less than' string "9".)
-function! s:tags_entry_cmp(i1, i2)
- let items = []
- for orig_item in [a:i1, a:i2]
- let fields = split(orig_item, "\t")
- let item = {}
- let item.text = fields[0]."\t".fields[1]
- let item.lineno = 0 + matchstr(fields[2], '\m\d\+')
- call add(items, item)
- endfor
- if items[0].text ># items[1].text
- return 1
- elseif items[0].text <# items[1].text
- return -1
- elseif items[0].lineno > items[1].lineno
- return 1
- elseif items[0].lineno < items[1].lineno
- return -1
- else
- return 0
- endif
-endfunction
-
-
-" Saves metadata object into a file. Throws exceptions in case of problems.
-function! s:write_tags_metadata(metadata)
- let metadata_path = vimwiki#tags#metadata_file_path()
- let tags = []
- for pagename in keys(a:metadata)
- for entry in a:metadata[pagename]
- let entry_data = pagename . "\t" . entry.link
- let entry_data = substitute(entry_data, "\\", '\\\\', 'g')
- let entry_data = substitute(entry_data, "\t", '\\t', 'g')
- let entry_data = substitute(entry_data, "\r", '\\r', 'g')
- let entry_data = substitute(entry_data, "\n", '\\n', 'g')
- call add(tags,
- \ entry.tagname . "\t"
- \ . pagename . vimwiki#vars#get_wikilocal('ext') . "\t"
- \ . entry.lineno
- \ . ';"'
- \ . "\t" . "vimwiki:" . entry_data
- \)
- endfor
- endfor
- call sort(tags, "s:tags_entry_cmp")
- call insert(tags, "!_TAG_FILE_SORTED\t1\t")
- call writefile(tags, metadata_path)
-endfunction
-
-
-" Returns list of unique tags found in the .tags file
-function! vimwiki#tags#get_tags()
- let metadata = s:load_tags_metadata()
- let tags = {}
- for entries in values(metadata)
- for entry in entries
- let tags[entry.tagname] = 1
- endfor
- endfor
- return keys(tags)
-endfunction
-
-
-" Similar to vimwiki#base#generate_links. In the current buffer, appends
-" tags and references to all their instances. If no arguments (tags) are
-" specified, outputs all tags.
-function! vimwiki#tags#generate_tags(...) abort
- let need_all_tags = (a:0 == 0)
- let specific_tags = a:000
-
- let metadata = s:load_tags_metadata()
-
- " make a dictionary { tag_name: [tag_links, ...] }
- let tags_entries = {}
- for entries in values(metadata)
- for entry in entries
- if has_key(tags_entries, entry.tagname)
- call add(tags_entries[entry.tagname], entry.link)
- else
- let tags_entries[entry.tagname] = [entry.link]
- endif
- endfor
- endfor
-
- let lines = []
- let bullet = repeat(' ', vimwiki#lst#get_list_margin()).vimwiki#lst#default_symbol().' '
- for tagname in sort(keys(tags_entries))
- if need_all_tags || index(specific_tags, tagname) != -1
- call extend(lines, [
- \ '',
- \ substitute(vimwiki#vars#get_syntaxlocal('rxH2_Template'), '__Header__', tagname, ''),
- \ '' ])
- for taglink in sort(tags_entries[tagname])
- call add(lines, bullet . substitute(vimwiki#vars#get_global('WikiLinkTemplate1'),
- \ '__LinkUrl__', taglink, ''))
- endfor
- endif
- endfor
-
- let links_rx = '\m\%(^\s*$\)\|\%('.vimwiki#vars#get_syntaxlocal('rxH2').'\)\|\%(^\s*'
- \ .vimwiki#u#escape(vimwiki#lst#default_symbol()).' '
- \ .vimwiki#vars#get_syntaxlocal('rxWikiLink').'$\)'
-
- call vimwiki#base#update_listing_in_buffer(lines, 'Generated Tags', links_rx, line('$')+1, 1)
-endfunction
-
-
-function! vimwiki#tags#complete_tags(ArgLead, CmdLine, CursorPos) abort
- " We can safely ignore args if we use -custom=complete option, Vim engine
- " will do the job of filtering.
- let taglist = vimwiki#tags#get_tags()
- return join(taglist, "\n")
-endfunction
-
diff --git a/.config/nvim/autoload/vimwiki/tbl.vim b/.config/nvim/autoload/vimwiki/tbl.vim
@@ -1,703 +0,0 @@
-" vim:tabstop=2:shiftwidth=2:expandtab:textwidth=99
-" Vimwiki autoload plugin file
-" Description: Tables
-" | Easily | manageable | text | tables | ! |
-" |--------|------------|-------|--------|---------|
-" | Have | fun! | Drink | tea | Period. |
-"
-" Home: https://github.com/vimwiki/vimwiki/
-
-
-
-if exists("g:loaded_vimwiki_tbl_auto") || &cp
- finish
-endif
-let g:loaded_vimwiki_tbl_auto = 1
-
-
-let s:textwidth = &tw
-
-
-function! s:rxSep()
- return vimwiki#vars#get_syntaxlocal('rxTableSep')
-endfunction
-
-
-function! s:wide_len(str)
- " vim73 has new function that gives correct string width.
- if exists("*strdisplaywidth")
- return strdisplaywidth(a:str)
- endif
-
- " get str display width in vim ver < 7.2
- if !vimwiki#vars#get_global('CJK_length')
- let ret = strlen(substitute(a:str, '.', 'x', 'g'))
- else
- let savemodified = &modified
- let save_cursor = getpos('.')
- exe "norm! o\<esc>"
- call setline(line("."), a:str)
- let ret = virtcol("$") - 1
- d
- call setpos('.', save_cursor)
- let &modified = savemodified
- endif
- return ret
-endfunction
-
-
-function! s:cell_splitter()
- return '\s*'.s:rxSep().'\s*'
-endfunction
-
-
-function! s:sep_splitter()
- return '-'.s:rxSep().'-'
-endfunction
-
-
-function! s:is_table(line)
- return s:is_separator(a:line) ||
- \ (a:line !~# s:rxSep().s:rxSep() && a:line =~# '^\s*'.s:rxSep().'.\+'.s:rxSep().'\s*$')
-endfunction
-
-
-function! s:is_separator(line)
- return a:line =~# '^\s*'.s:rxSep().'\(--\+'.s:rxSep().'\)\+\s*$'
-endfunction
-
-
-function! s:is_separator_tail(line)
- return a:line =~# '^\{-1}\%(\s*\|-*\)\%('.s:rxSep().'-\+\)\+'.s:rxSep().'\s*$'
-endfunction
-
-
-function! s:is_last_column(lnum, cnum)
- let line = strpart(getline(a:lnum), a:cnum - 1)
- return line =~# s:rxSep().'\s*$' && line !~# s:rxSep().'.*'.s:rxSep().'\s*$'
-endfunction
-
-
-function! s:is_first_column(lnum, cnum)
- let line = strpart(getline(a:lnum), 0, a:cnum - 1)
- return line =~# '^\s*$' ||
- \ (line =~# '^\s*'.s:rxSep() && line !~# '^\s*'.s:rxSep().'.*'.s:rxSep())
-endfunction
-
-
-function! s:count_separators_up(lnum)
- let lnum = a:lnum - 1
- while lnum > 1
- if !s:is_separator(getline(lnum))
- break
- endif
- let lnum -= 1
- endwhile
-
- return (a:lnum-lnum)
-endfunction
-
-
-function! s:count_separators_down(lnum)
- let lnum = a:lnum + 1
- while lnum < line('$')
- if !s:is_separator(getline(lnum))
- break
- endif
- let lnum += 1
- endwhile
-
- return (lnum-a:lnum)
-endfunction
-
-
-function! s:create_empty_row(cols)
- let row = s:rxSep()
- let cell = " ".s:rxSep()
-
- for c in range(a:cols)
- let row .= cell
- endfor
-
- return row
-endfunction
-
-
-function! s:create_row_sep(cols)
- let row = s:rxSep()
- let cell = "---".s:rxSep()
-
- for c in range(a:cols)
- let row .= cell
- endfor
-
- return row
-endfunction
-
-
-function! vimwiki#tbl#get_cells(line)
- let result = []
- let cell = ''
- let quote = ''
- let state = 'NONE'
-
- " 'Simple' FSM
- for idx in range(strlen(a:line))
- " The only way I know Vim can do Unicode...
- let ch = a:line[idx]
- if state ==# 'NONE'
- if ch == '|'
- let state = 'CELL'
- endif
- elseif state ==# 'CELL'
- if ch == '[' || ch == '{'
- let state = 'BEFORE_QUOTE_START'
- let quote = ch
- elseif ch == '|'
- call add(result, vimwiki#u#trim(cell))
- let cell = ""
- else
- let cell .= ch
- endif
- elseif state ==# 'BEFORE_QUOTE_START'
- if ch == '[' || ch == '{'
- let state = 'QUOTE'
- let quote .= ch
- else
- let state = 'CELL'
- let cell .= quote.ch
- let quote = ''
- endif
- elseif state ==# 'QUOTE'
- if ch == ']' || ch == '}'
- let state = 'BEFORE_QUOTE_END'
- endif
- let quote .= ch
- elseif state ==# 'BEFORE_QUOTE_END'
- if ch == ']' || ch == '}'
- let state = 'CELL'
- endif
- let cell .= quote.ch
- let quote = ''
- endif
- endfor
-
- if cell.quote != ''
- call add(result, vimwiki#u#trim(cell.quote, '|'))
- endif
- return result
-endfunction
-
-
-function! s:col_count(lnum)
- return len(vimwiki#tbl#get_cells(getline(a:lnum)))
-endfunction
-
-
-function! s:get_indent(lnum)
- if !s:is_table(getline(a:lnum))
- return
- endif
-
- let indent = 0
-
- let lnum = a:lnum - 1
- while lnum > 1
- let line = getline(lnum)
- if !s:is_table(line)
- let indent = indent(lnum+1)
- break
- endif
- let lnum -= 1
- endwhile
-
- return indent
-endfunction
-
-
-function! s:get_rows(lnum)
- if !s:is_table(getline(a:lnum))
- return
- endif
-
- let upper_rows = []
- let lower_rows = []
-
- let lnum = a:lnum - 1
- while lnum >= 1
- let line = getline(lnum)
- if s:is_table(line)
- call add(upper_rows, [lnum, line])
- else
- break
- endif
- let lnum -= 1
- endwhile
- call reverse(upper_rows)
-
- let lnum = a:lnum
- while lnum <= line('$')
- let line = getline(lnum)
- if s:is_table(line)
- call add(lower_rows, [lnum, line])
- else
- break
- endif
- let lnum += 1
- endwhile
-
- return upper_rows + lower_rows
-endfunction
-
-
-function! s:get_cell_max_lens(lnum, ...)
- let max_lens = {}
- for [lnum, row] in s:get_rows(a:lnum)
- if s:is_separator(row)
- continue
- endif
- let cells = a:0 > 1 ? a:1[lnum - a:2] : vimwiki#tbl#get_cells(row)
- for idx in range(len(cells))
- let value = cells[idx]
- if has_key(max_lens, idx)
- let max_lens[idx] = max([s:wide_len(value), max_lens[idx]])
- else
- let max_lens[idx] = s:wide_len(value)
- endif
- endfor
- endfor
- return max_lens
-endfunction
-
-
-function! s:get_aligned_rows(lnum, col1, col2)
- let rows = s:get_rows(a:lnum)
- let startlnum = rows[0][0]
- let cells = []
- for [lnum, row] in rows
- call add(cells, vimwiki#tbl#get_cells(row))
- endfor
- let max_lens = s:get_cell_max_lens(a:lnum, cells, startlnum)
- let result = []
- for [lnum, row] in rows
- if s:is_separator(row)
- let new_row = s:fmt_sep(max_lens, a:col1, a:col2)
- else
- let new_row = s:fmt_row(cells[lnum - startlnum], max_lens, a:col1, a:col2)
- endif
- call add(result, [lnum, new_row])
- endfor
- return result
-endfunction
-
-
-" Number of the current column. Starts from 0.
-function! s:cur_column()
- let line = getline('.')
- if !s:is_table(line)
- return -1
- endif
- " TODO: do we need conditional: if s:is_separator(line)
-
- let curs_pos = col('.')
- let mpos = match(line, s:rxSep(), 0)
- let col = -1
- while mpos < curs_pos && mpos != -1
- let mpos = match(line, s:rxSep(), mpos+1)
- if mpos != -1
- let col += 1
- endif
- endwhile
- return col
-endfunction
-
-
-function! s:fmt_cell(cell, max_len)
- let cell = ' '.a:cell.' '
-
- let diff = a:max_len - s:wide_len(a:cell)
- if diff == 0 && empty(a:cell)
- let diff = 1
- endif
-
- let cell .= repeat(' ', diff)
- return cell
-endfunction
-
-
-function! s:fmt_row(cells, max_lens, col1, col2)
- let new_line = s:rxSep()
- for idx in range(len(a:cells))
- if idx == a:col1
- let idx = a:col2
- elseif idx == a:col2
- let idx = a:col1
- endif
- let value = a:cells[idx]
- let new_line .= s:fmt_cell(value, a:max_lens[idx]).s:rxSep()
- endfor
-
- let idx = len(a:cells)
- while idx < len(a:max_lens)
- let new_line .= s:fmt_cell('', a:max_lens[idx]).s:rxSep()
- let idx += 1
- endwhile
- return new_line
-endfunction
-
-
-function! s:fmt_cell_sep(max_len)
- if a:max_len == 0
- return repeat('-', 3)
- else
- return repeat('-', a:max_len+2)
- endif
-endfunction
-
-
-function! s:fmt_sep(max_lens, col1, col2)
- let new_line = s:rxSep()
- for idx in range(len(a:max_lens))
- if idx == a:col1
- let idx = a:col2
- elseif idx == a:col2
- let idx = a:col1
- endif
- let new_line .= s:fmt_cell_sep(a:max_lens[idx]).s:rxSep()
- endfor
- return new_line
-endfunction
-
-
-function! s:kbd_create_new_row(cols, goto_first)
- let cmd = "\<ESC>o".s:create_empty_row(a:cols)
- let cmd .= "\<ESC>:call vimwiki#tbl#format(line('.'))\<CR>"
- let cmd .= "\<ESC>0"
- if a:goto_first
- let cmd .= ":call search('\\(".s:rxSep()."\\)\\zs', 'c', line('.'))\<CR>"
- else
- let cmd .= (col('.')-1)."l"
- let cmd .= ":call search('\\(".s:rxSep()."\\)\\zs', 'bc', line('.'))\<CR>"
- endif
- let cmd .= "a"
-
- return cmd
-endfunction
-
-
-function! s:kbd_goto_next_row()
- let cmd = "\<ESC>j"
- let cmd .= ":call search('.\\(".s:rxSep()."\\)', 'c', line('.'))\<CR>"
- let cmd .= ":call search('\\(".s:rxSep()."\\)\\zs', 'bc', line('.'))\<CR>"
- let cmd .= "a"
- return cmd
-endfunction
-
-
-function! s:kbd_goto_prev_row()
- let cmd = "\<ESC>k"
- let cmd .= ":call search('.\\(".s:rxSep()."\\)', 'c', line('.'))\<CR>"
- let cmd .= ":call search('\\(".s:rxSep()."\\)\\zs', 'bc', line('.'))\<CR>"
- let cmd .= "a"
- return cmd
-endfunction
-
-
-" Used in s:kbd_goto_next_col
-function! vimwiki#tbl#goto_next_col()
- let curcol = virtcol('.')
- let lnum = line('.')
- let newcol = s:get_indent(lnum)
- let max_lens = s:get_cell_max_lens(lnum)
- for cell_len in values(max_lens)
- if newcol >= curcol-1
- break
- endif
- let newcol += cell_len + 3 " +3 == 2 spaces + 1 separator |<space>...<space>
- endfor
- let newcol += 2 " +2 == 1 separator + 1 space |<space
- call vimwiki#u#cursor(lnum, newcol)
-endfunction
-
-
-function! s:kbd_goto_next_col(jumpdown)
- let cmd = "\<ESC>"
- if a:jumpdown
- let seps = s:count_separators_down(line('.'))
- let cmd .= seps."j0"
- endif
- let cmd .= ":call vimwiki#tbl#goto_next_col()\<CR>a"
- return cmd
-endfunction
-
-
-" Used in s:kbd_goto_prev_col
-function! vimwiki#tbl#goto_prev_col()
- let curcol = virtcol('.')
- let lnum = line('.')
- let newcol = s:get_indent(lnum)
- let max_lens = s:get_cell_max_lens(lnum)
- let prev_cell_len = 0
- for cell_len in values(max_lens)
- let delta = cell_len + 3 " +3 == 2 spaces + 1 separator |<space>...<space>
- if newcol + delta > curcol-1
- let newcol -= (prev_cell_len + 3) " +3 == 2 spaces + 1 separator |<space>...<space>
- break
- elseif newcol + delta == curcol-1
- break
- endif
- let prev_cell_len = cell_len
- let newcol += delta
- endfor
- let newcol += 2 " +2 == 1 separator + 1 space |<space
- call vimwiki#u#cursor(lnum, newcol)
-endfunction
-
-
-function! s:kbd_goto_prev_col(jumpup)
- let cmd = "\<ESC>"
- if a:jumpup
- let seps = s:count_separators_up(line('.'))
- let cmd .= seps."k"
- let cmd .= "$"
- endif
- let cmd .= ":call vimwiki#tbl#goto_prev_col()\<CR>a"
- " let cmd .= ":call search('\\(".s:rxSep()."\\)\\zs', 'b', line('.'))\<CR>"
- " let cmd .= "a"
- "echomsg "DEBUG kbd_goto_prev_col> ".cmd
- return cmd
-endfunction
-
-
-function! vimwiki#tbl#kbd_cr()
- let lnum = line('.')
- if !s:is_table(getline(lnum))
- return ""
- endif
-
- if s:is_separator(getline(lnum+1)) || !s:is_table(getline(lnum+1))
- let cols = len(vimwiki#tbl#get_cells(getline(lnum)))
- return s:kbd_create_new_row(cols, 0)
- else
- return s:kbd_goto_next_row()
- endif
-endfunction
-
-
-function! vimwiki#tbl#kbd_tab()
- let lnum = line('.')
- if !s:is_table(getline(lnum))
- return "\<Tab>"
- endif
-
- let last = s:is_last_column(lnum, col('.'))
- let is_sep = s:is_separator_tail(getline(lnum))
- "echomsg "DEBUG kbd_tab> last=".last.", is_sep=".is_sep
- if (is_sep || last) && !s:is_table(getline(lnum+1))
- let cols = len(vimwiki#tbl#get_cells(getline(lnum)))
- return s:kbd_create_new_row(cols, 1)
- endif
- return s:kbd_goto_next_col(is_sep || last)
-endfunction
-
-
-function! vimwiki#tbl#kbd_shift_tab()
- let lnum = line('.')
- if !s:is_table(getline(lnum))
- return "\<S-Tab>"
- endif
-
- let first = s:is_first_column(lnum, col('.'))
- let is_sep = s:is_separator_tail(getline(lnum))
- "echomsg "DEBUG kbd_tab> ".first
- if (is_sep || first) && !s:is_table(getline(lnum-1))
- return ""
- endif
- return s:kbd_goto_prev_col(is_sep || first)
-endfunction
-
-
-function! vimwiki#tbl#format(lnum, ...)
- if !(&filetype ==? 'vimwiki')
- return
- endif
- let line = getline(a:lnum)
- if !s:is_table(line)
- return
- endif
-
- if a:0 == 2
- let col1 = a:1
- let col2 = a:2
- else
- let col1 = 0
- let col2 = 0
- endif
-
- let indent = s:get_indent(a:lnum)
- if &expandtab
- let indentstring = repeat(' ', indent)
- else
- let indentstring = repeat(' ', indent / &tabstop) . repeat(' ', indent % &tabstop)
- endif
-
- for [lnum, row] in s:get_aligned_rows(a:lnum, col1, col2)
- let row = indentstring.row
- call setline(lnum, row)
- endfor
-
- let &tw = s:textwidth
-endfunction
-
-
-function! vimwiki#tbl#create(...)
- if a:0 > 1
- let cols = a:1
- let rows = a:2
- elseif a:0 == 1
- let cols = a:1
- let rows = 2
- elseif a:0 == 0
- let cols = 5
- let rows = 2
- endif
-
- if cols < 1
- let cols = 5
- endif
-
- if rows < 1
- let rows = 2
- endif
-
- let lines = []
- let row = s:create_empty_row(cols)
-
- call add(lines, row)
- if rows > 1
- call add(lines, s:create_row_sep(cols))
- endif
-
- for r in range(rows - 1)
- call add(lines, row)
- endfor
-
- call append(line('.'), lines)
-endfunction
-
-
-function! vimwiki#tbl#align_or_cmd(cmd)
- if s:is_table(getline('.'))
- call vimwiki#tbl#format(line('.'))
- else
- exe 'normal! '.a:cmd
- endif
-endfunction
-
-
-function! vimwiki#tbl#reset_tw(lnum)
- if !(&filetype ==? 'vimwiki')
- return
- endif
- let line = getline(a:lnum)
- if !s:is_table(line)
- return
- endif
-
- let s:textwidth = &tw
- let &tw = 0
-endfunction
-
-
-" TODO: move_column_left and move_column_right are good candidates to be refactored.
-function! vimwiki#tbl#move_column_left()
-
- "echomsg "DEBUG move_column_left: "
-
- let line = getline('.')
-
- if !s:is_table(line)
- return
- endif
-
- let cur_col = s:cur_column()
- if cur_col == -1
- return
- endif
-
- if cur_col > 0
- call vimwiki#tbl#format(line('.'), cur_col-1, cur_col)
- call cursor(line('.'), 1)
-
- let sep = '\('.s:rxSep().'\).\zs'
- let mpos = -1
- let col = -1
- while col < cur_col-1
- let mpos = match(line, sep, mpos+1)
- if mpos != -1
- let col += 1
- else
- break
- endif
- endwhile
-
- endif
-endfunction
-
-
-function! vimwiki#tbl#move_column_right()
-
- let line = getline('.')
-
- if !s:is_table(line)
- return
- endif
-
- let cur_col = s:cur_column()
- if cur_col == -1
- return
- endif
-
- if cur_col < s:col_count(line('.'))-1
- call vimwiki#tbl#format(line('.'), cur_col, cur_col+1)
- call cursor(line('.'), 1)
-
- let sep = '\('.s:rxSep().'\).\zs'
- let mpos = -1
- let col = -1
- while col < cur_col+1
- let mpos = match(line, sep, mpos+1)
- if mpos != -1
- let col += 1
- else
- break
- endif
- endwhile
- endif
-endfunction
-
-
-function! vimwiki#tbl#get_rows(lnum)
- return s:get_rows(a:lnum)
-endfunction
-
-
-function! vimwiki#tbl#is_table(line)
- return s:is_table(a:line)
-endfunction
-
-
-function! vimwiki#tbl#is_separator(line)
- return s:is_separator(a:line)
-endfunction
-
-
-function! vimwiki#tbl#cell_splitter()
- return s:cell_splitter()
-endfunction
-
-
-function! vimwiki#tbl#sep_splitter()
- return s:sep_splitter()
-endfunction
-
diff --git a/.config/nvim/autoload/vimwiki/u.vim b/.config/nvim/autoload/vimwiki/u.vim
@@ -1,72 +0,0 @@
-" vim:tabstop=2:shiftwidth=2:expandtab:textwidth=99
-" Vimwiki autoload plugin file
-" Description: Utility functions
-" Home: https://github.com/vimwiki/vimwiki/
-
-function! vimwiki#u#trim(string, ...)
- let chars = ''
- if a:0 > 0
- let chars = a:1
- endif
- let res = substitute(a:string, '^[[:space:]'.chars.']\+', '', '')
- let res = substitute(res, '[[:space:]'.chars.']\+$', '', '')
- return res
-endfunction
-
-
-" Builtin cursor doesn't work right with unicode characters.
-function! vimwiki#u#cursor(lnum, cnum)
- exe a:lnum
- exe 'normal! 0'.a:cnum.'|'
-endfunction
-
-
-function! vimwiki#u#is_windows()
- return has("win32") || has("win64") || has("win95") || has("win16")
-endfunction
-
-
-function! vimwiki#u#is_macos()
- if has("mac") || has("macunix") || has("gui_mac")
- return 1
- endif
- " that still doesn't mean we are not on Mac OS
- let os = substitute(system('uname'), '\n', '', '')
- return os == 'Darwin' || os == 'Mac'
-endfunction
-
-
-function! vimwiki#u#count_first_sym(line)
- let first_sym = matchstr(a:line, '\S')
- return len(matchstr(a:line, first_sym.'\+'))
-endfunction
-
-
-function! vimwiki#u#escape(string)
- return escape(a:string, '~.*[]\^$')
-endfunction
-
-
-" Load concrete Wiki syntax: sets regexes and templates for headers and links
-function vimwiki#u#reload_regexes()
- execute 'runtime! syntax/vimwiki_'.vimwiki#vars#get_wikilocal('syntax').'.vim'
-endfunction
-
-
-" Load syntax-specific functionality
-function vimwiki#u#reload_regexes_custom()
- execute 'runtime! syntax/vimwiki_'.vimwiki#vars#get_wikilocal('syntax').'_custom.vim'
-endfunction
-
-
-" Backward compatible version of the built-in function shiftwidth()
-if exists('*shiftwidth')
- func vimwiki#u#sw()
- return shiftwidth()
- endfunc
-else
- func vimwiki#u#sw()
- return &sw
- endfunc
-endif
-
diff --git a/.config/nvim/autoload/vimwiki/vars.vim b/.config/nvim/autoload/vimwiki/vars.vim
@@ -1,850 +0,0 @@
-" vim:tabstop=2:shiftwidth=2:expandtab:textwidth=99
-" Vimwiki autoload plugin file
-" Home: https://github.com/vimwiki/vimwiki/
-
-
-
-" ------------------------------------------------------------------------------------------------
-" This file provides functions to manage the various state variables which are needed during a
-" Vimwiki session.
-" They consist of:
-"
-" - global variables. These are stored in the dict g:vimwiki_global_vars. They consist mainly of
-" global user variables and syntax stuff which is the same for every syntax.
-"
-" - wiki-local variables. They are stored in g:vimwiki_wikilocal_vars which is a list of
-" dictionaries, one dict for every registered wiki. The last dictionary contains default values
-" (used for temporary wikis).
-"
-" - syntax variables. Stored in the dict g:vimwiki_syntax_variables which holds all the regexes and
-" other stuff which is needed for highlighting.
-"
-" - buffer-local variables. They are stored as buffer variables directly (b:foo)
-
-" As a developer, you should, if possible, only use the get_ and set_ functions for these types of
-" variables, not the underlying dicts!
-" ------------------------------------------------------------------------------------------------
-
-
-function! s:populate_global_variables()
-
- let g:vimwiki_global_vars = {}
-
- call s:read_global_settings_from_user()
- call s:normalize_global_settings()
-
- " non-configurable global variables:
-
- " Scheme regexes must be defined even if syntax file is not loaded yet cause users should be
- " able to <leader>w<leader>w without opening any vimwiki file first
- let g:vimwiki_global_vars.schemes = join(['wiki\d\+', 'diary', 'local'], '\|')
- let g:vimwiki_global_vars.web_schemes1 = join(['http', 'https', 'file', 'ftp', 'gopher',
- \ 'telnet', 'nntp', 'ldap', 'rsync', 'imap', 'pop', 'irc', 'ircs', 'cvs', 'svn', 'svn+ssh',
- \ 'git', 'ssh', 'fish', 'sftp'], '\|')
- let web_schemes2 =
- \ join(['mailto', 'news', 'xmpp', 'sip', 'sips', 'doi', 'urn', 'tel', 'data'], '\|')
-
- let g:vimwiki_global_vars.rxSchemes = '\%('.
- \ g:vimwiki_global_vars.schemes . '\|'.
- \ g:vimwiki_global_vars.web_schemes1 . '\|'.
- \ web_schemes2 .
- \ '\)'
-
- " match URL for common protocols; see http://en.wikipedia.org/wiki/URI_scheme
- " http://tools.ietf.org/html/rfc3986
- let rxWebProtocols =
- \ '\%('.
- \ '\%('.
- \ '\%('.g:vimwiki_global_vars.web_schemes1 . '\):'.
- \ '\%(//\)'.
- \ '\)'.
- \ '\|'.
- \ '\%('.web_schemes2.'\):'.
- \ '\)'
-
- let g:vimwiki_global_vars.rxWeblinkUrl = rxWebProtocols . '\S\{-1,}'. '\%(([^ \t()]*)\)\='
-
- let wikilink_prefix = '[['
- let wikilink_suffix = ']]'
- let wikilink_separator = '|'
- let g:vimwiki_global_vars.rx_wikilink_prefix = vimwiki#u#escape(wikilink_prefix)
- let g:vimwiki_global_vars.rx_wikilink_suffix = vimwiki#u#escape(wikilink_suffix)
- let g:vimwiki_global_vars.rx_wikilink_separator = vimwiki#u#escape(wikilink_separator)
-
- " templates for the creation of wiki links
- " [[URL]]
- let g:vimwiki_global_vars.WikiLinkTemplate1 = wikilink_prefix . '__LinkUrl__'. wikilink_suffix
- " [[URL|DESCRIPTION]]
- let g:vimwiki_global_vars.WikiLinkTemplate2 = wikilink_prefix . '__LinkUrl__'. wikilink_separator
- \ . '__LinkDescription__' . wikilink_suffix
-
- let valid_chars = '[^\\\]]'
- let g:vimwiki_global_vars.rxWikiLinkUrl = valid_chars.'\{-}'
- let g:vimwiki_global_vars.rxWikiLinkDescr = valid_chars.'\{-}'
-
- " this regexp defines what can form a link when the user presses <CR> in the
- " buffer (and not on a link) to create a link
- " basically, it's Ascii alphanumeric characters plus #|./@-_~ plus all
- " non-Ascii characters, except that . is not accepted as the last character
- let g:vimwiki_global_vars.rxWord = '[^[:blank:]!"$%&''()*+,:;<=>?\[\]\\^`{}]*[^[:blank:]!"$%&''()*+.,:;<=>?\[\]\\^`{}]'
-
- let g:vimwiki_global_vars.rx_wikilink_prefix1 = g:vimwiki_global_vars.rx_wikilink_prefix .
- \ g:vimwiki_global_vars.rxWikiLinkUrl . g:vimwiki_global_vars.rx_wikilink_separator
- let g:vimwiki_global_vars.rx_wikilink_suffix1 = g:vimwiki_global_vars.rx_wikilink_suffix
-
- let g:vimwiki_global_vars.rxWikiInclPrefix = '{{'
- let g:vimwiki_global_vars.rxWikiInclSuffix = '}}'
- let g:vimwiki_global_vars.rxWikiInclSeparator = '|'
- " '{{__LinkUrl__}}'
- let g:vimwiki_global_vars.WikiInclTemplate1 = g:vimwiki_global_vars.rxWikiInclPrefix
- \ .'__LinkUrl__'. g:vimwiki_global_vars.rxWikiInclSuffix
- " '{{__LinkUrl____LinkDescription__}}'
- let g:vimwiki_global_vars.WikiInclTemplate2 = g:vimwiki_global_vars.rxWikiInclPrefix
- \ . '__LinkUrl__' . g:vimwiki_global_vars.rxWikiInclSeparator . '__LinkDescription__'
- \ . g:vimwiki_global_vars.rxWikiInclSuffix
-
- let valid_chars = '[^\\\}]'
- let g:vimwiki_global_vars.rxWikiInclUrl = valid_chars.'\{-}'
- let g:vimwiki_global_vars.rxWikiInclArg = valid_chars.'\{-}'
- let g:vimwiki_global_vars.rxWikiInclArgs = '\%('. g:vimwiki_global_vars.rxWikiInclSeparator.
- \ g:vimwiki_global_vars.rxWikiInclArg. '\)'.'\{-}'
-
- " *. {{URL}[{...}]} - i.e. {{URL}}, {{URL|ARG1}}, {{URL|ARG1|ARG2}}, etc.
- " *a) match {{URL}[{...}]}
- let g:vimwiki_global_vars.rxWikiIncl = g:vimwiki_global_vars.rxWikiInclPrefix.
- \ g:vimwiki_global_vars.rxWikiInclUrl.
- \ g:vimwiki_global_vars.rxWikiInclArgs. g:vimwiki_global_vars.rxWikiInclSuffix
- " *b) match URL within {{URL}[{...}]}
- let g:vimwiki_global_vars.rxWikiInclMatchUrl = g:vimwiki_global_vars.rxWikiInclPrefix.
- \ '\zs'. g:vimwiki_global_vars.rxWikiInclUrl . '\ze'.
- \ g:vimwiki_global_vars.rxWikiInclArgs . g:vimwiki_global_vars.rxWikiInclSuffix
-
- let g:vimwiki_global_vars.rxWikiInclPrefix1 = g:vimwiki_global_vars.rxWikiInclPrefix.
- \ g:vimwiki_global_vars.rxWikiInclUrl . g:vimwiki_global_vars.rxWikiInclSeparator
- let g:vimwiki_global_vars.rxWikiInclSuffix1 = g:vimwiki_global_vars.rxWikiInclArgs.
- \ g:vimwiki_global_vars.rxWikiInclSuffix
-
- let g:vimwiki_global_vars.rxTodo = '\C\<\%(TODO\|DONE\|STARTED\|FIXME\|FIXED\|XXX\)\>'
-
- " default colors when headers of different levels are highlighted differently
- " not making it yet another option; needed by ColorScheme autocommand
- let g:vimwiki_global_vars.hcolor_guifg_light = ['#aa5858', '#507030', '#1030a0', '#103040'
- \ , '#505050', '#636363']
- let g:vimwiki_global_vars.hcolor_ctermfg_light = ['DarkRed', 'DarkGreen', 'DarkBlue', 'Black'
- \ , 'Black', 'Black']
- let g:vimwiki_global_vars.hcolor_guifg_dark = ['#e08090', '#80e090', '#6090e0', '#c0c0f0'
- \ , '#e0e0f0', '#f0f0f0']
- let g:vimwiki_global_vars.hcolor_ctermfg_dark = ['Red', 'Green', 'Blue', 'White', 'White'
- \ , 'White']
-endfunction
-
-
-function! s:read_global_settings_from_user()
- let global_settings = {
- \ 'CJK_length': {'type': type(0), 'default': 0, 'min': 0, 'max': 1},
- \ 'auto_chdir': {'type': type(0), 'default': 0, 'min': 0, 'max': 1},
- \ 'autowriteall': {'type': type(0), 'default': 1, 'min': 0, 'max': 1},
- \ 'conceallevel': {'type': type(0), 'default': 2, 'min': 0, 'max': 3},
- \ 'diary_months': {'type': type({}), 'default':
- \ {
- \ 1: 'January', 2: 'February', 3: 'March',
- \ 4: 'April', 5: 'May', 6: 'June',
- \ 7: 'July', 8: 'August', 9: 'September',
- \ 10: 'October', 11: 'November', 12: 'December'
- \ }},
- \ 'dir_link': {'type': type(''), 'default': ''},
- \ 'ext2syntax': {'type': type({}), 'default': {}},
- \ 'folding': {'type': type(''), 'default': '', 'possible_values': ['', 'expr', 'syntax',
- \ 'list', 'custom', ':quick', 'expr:quick', 'syntax:quick', 'list:quick',
- \ 'custom:quick']},
- \ 'global_ext': {'type': type(0), 'default': 1, 'min': 0, 'max': 1},
- \ 'hl_cb_checked': {'type': type(0), 'default': 0, 'min': 0, 'max': 2},
- \ 'hl_headers': {'type': type(0), 'default': 0, 'min': 0, 'max': 1},
- \ 'html_header_numbering': {'type': type(0), 'default': 0, 'min': 0, 'max': 6},
- \ 'html_header_numbering_sym': {'type': type(''), 'default': ''},
- \ 'list_ignore_newline': {'type': type(0), 'default': 1, 'min': 0, 'max': 1},
- \ 'text_ignore_newline': {'type': type(0), 'default': 1, 'min': 0, 'max': 1},
- \ 'listsyms': {'type': type(''), 'default': ' .oOX', 'min_length': 2},
- \ 'listsym_rejected': {'type': type(''), 'default': '-', 'length': 1},
- \ 'map_prefix': {'type': type(''), 'default': '<Leader>w'},
- \ 'menu': {'type': type(''), 'default': 'Vimwiki'},
- \ 'table_auto_fmt': {'type': type(0), 'default': 1, 'min': 0, 'max': 1},
- \ 'table_mappings': {'type': type(0), 'default': 1, 'min': 0, 'max': 1},
- \ 'toc_header': {'type': type(''), 'default': 'Contents', 'min_length': 1},
- \ 'url_maxsave': {'type': type(0), 'default': 15, 'min': 0},
- \ 'use_calendar': {'type': type(0), 'default': 1, 'min': 0, 'max': 1},
- \ 'use_mouse': {'type': type(0), 'default': 0, 'min': 0, 'max': 1},
- \ 'user_htmls': {'type': type(''), 'default': ''},
- \ 'valid_html_tags': {'type': type(''), 'default':
- \ 'b,i,s,u,sub,sup,kbd,br,hr,div,center,strong,em'},
- \ 'w32_dir_enc': {'type': type(''), 'default': ''},
- \ }
-
- " copy the user's settings from variables of the form g:vimwiki_<option> into the dict
- " g:vimwiki_global_vars (or set a default value)
- for key in keys(global_settings)
- if exists('g:vimwiki_'.key)
- let users_value = g:vimwiki_{key}
- let value_infos = global_settings[key]
-
- call s:check_users_value(key, users_value, value_infos, 1)
-
- let g:vimwiki_global_vars[key] = users_value
- else
- let g:vimwiki_global_vars[key] = global_settings[key].default
- endif
- endfor
-
- " validate some settings individually
-
- let key = 'diary_months'
- let users_value = g:vimwiki_global_vars[key]
- for month in range(1, 12)
- if !has_key(users_value, month) || type(users_value[month]) != type('') ||
- \ empty(users_value[month])
- echom printf('Vimwiki Error: The provided value ''%s'' of the option ''g:vimwiki_%s'' is'
- \ . ' invalid. See '':h g:vimwiki_%s''.', string(users_value), key, key)
- break
- endif
- endfor
-
- let key = 'ext2syntax'
- let users_value = g:vimwiki_global_vars[key]
- for ext in keys(users_value)
- if empty(ext) || index(['markdown', 'media', 'mediawiki', 'default'], users_value[ext]) == -1
- echom printf('Vimwiki Error: The provided value ''%s'' of the option ''g:vimwiki_%s'' is'
- \ . ' invalid. See '':h g:vimwiki_%s''.', string(users_value), key, key)
- break
- endif
- endfor
-
-endfunction
-
-
-function! s:normalize_global_settings()
- let keys = keys(g:vimwiki_global_vars.ext2syntax)
- for ext in keys
- " ensure the file extensions in ext2syntax start with a dot
- if ext[0] != '.'
- let new_ext = '.' . ext
- let g:vimwiki_global_vars.ext2syntax[new_ext] = g:vimwiki_global_vars.ext2syntax[ext]
- call remove(g:vimwiki_global_vars.ext2syntax, ext)
- endif
- " for convenience, we also allow the term 'mediawiki'
- if g:vimwiki_global_vars.ext2syntax[ext] ==# 'mediawiki'
- let g:vimwiki_global_vars.ext2syntax[ext] = 'media'
- endif
- endfor
-endfunction
-
-
-function! s:populate_wikilocal_options()
- let default_values = {
- \ 'auto_diary_index': {'type': type(0), 'default': 0, 'min': 0, 'max': 1},
- \ 'auto_export': {'type': type(0), 'default': 0, 'min': 0, 'max': 1},
- \ 'auto_tags': {'type': type(0), 'default': 0, 'min': 0, 'max': 1},
- \ 'auto_toc': {'type': type(0), 'default': 0, 'min': 0, 'max': 1},
- \ 'automatic_nested_syntaxes': {'type': type(0), 'default': 1, 'min': 0, 'max': 1},
- \ 'css_name': {'type': type(''), 'default': 'style.css', 'min_length': 1},
- \ 'custom_wiki2html': {'type': type(''), 'default': ''},
- \ 'custom_wiki2html_args': {'type': type(''), 'default': ''},
- \ 'diary_header': {'type': type(''), 'default': 'Diary', 'min_length': 1},
- \ 'diary_index': {'type': type(''), 'default': 'diary', 'min_length': 1},
- \ 'diary_rel_path': {'type': type(''), 'default': 'diary/', 'min_length': 1},
- \ 'diary_sort': {'type': type(''), 'default': 'desc', 'possible_values': ['asc', 'desc']},
- \ 'ext': {'type': type(''), 'default': '.wiki', 'min_length': 1},
- \ 'index': {'type': type(''), 'default': 'index', 'min_length': 1},
- \ 'list_margin': {'type': type(0), 'default': -1, 'min': -1},
- \ 'maxhi': {'type': type(0), 'default': 0, 'min': 0, 'max': 1},
- \ 'nested_syntaxes': {'type': type({}), 'default': {}},
- \ 'path': {'type': type(''), 'default': $HOME . '/vimwiki/', 'min_length': 1},
- \ 'path_html': {'type': type(''), 'default': ''},
- \ 'syntax': {'type': type(''), 'default': 'default',
- \ 'possible_values': ['default', 'markdown', 'media', 'mediawiki']},
- \ 'template_default': {'type': type(''), 'default': 'default', 'min_length': 1},
- \ 'template_ext': {'type': type(''), 'default': '.tpl'},
- \ 'template_path': {'type': type(''), 'default': $HOME . '/vimwiki/templates/'},
- \ }
-
- let g:vimwiki_wikilocal_vars = []
-
- let default_wiki_settings = {}
- for key in keys(default_values)
- if exists('g:vimwiki_'.key)
- call s:check_users_value(key, g:vimwiki_{key}, default_values[key], 1)
- let default_wiki_settings[key] = g:vimwiki_{key}
- else
- let default_wiki_settings[key] = default_values[key].default
- endif
- endfor
-
- " set the wiki-local variables according to g:vimwiki_list (or the default settings)
- if exists('g:vimwiki_list')
- for users_wiki_settings in g:vimwiki_list
- let new_wiki_settings = {}
- for key in keys(default_values)
- if has_key(users_wiki_settings, key)
- call s:check_users_value(key, users_wiki_settings[key], default_values[key], 0)
- let new_wiki_settings[key] = users_wiki_settings[key]
- else
- let new_wiki_settings[key] = default_wiki_settings[key]
- endif
- endfor
-
- let new_wiki_settings.is_temporary_wiki = 0
-
- call add(g:vimwiki_wikilocal_vars, new_wiki_settings)
- endfor
- else
- " if the user hasn't registered any wiki, we register one wiki using the default values
- let new_wiki_settings = deepcopy(default_wiki_settings)
- let new_wiki_settings.is_temporary_wiki = 0
- call add(g:vimwiki_wikilocal_vars, new_wiki_settings)
- endif
-
- " default values for temporary wikis
- let temporary_wiki_settings = deepcopy(default_wiki_settings)
- let temporary_wiki_settings.is_temporary_wiki = 1
- call add(g:vimwiki_wikilocal_vars, temporary_wiki_settings)
-
- " check some values individually
- let key = 'nested_syntaxes'
- for wiki_settings in g:vimwiki_wikilocal_vars
- let users_value = wiki_settings[key]
- for keyword in keys(users_value)
- if type(keyword) != type('') || empty(keyword) || type(users_value[keyword]) != type('') ||
- \ empty(users_value[keyword])
- echom printf('Vimwiki Error: The provided value ''%s'' of the option ''g:vimwiki_%s'' is'
- \ . ' invalid. See '':h g:vimwiki_%s''.', string(users_value), key, key)
- break
- endif
- endfor
- endfor
-
- call s:normalize_wikilocal_settings()
-endfunction
-
-
-function! s:check_users_value(key, users_value, value_infos, comes_from_global_variable)
- let type_code_to_name = {
- \ type(0): 'number',
- \ type(''): 'string',
- \ type([]): 'list',
- \ type({}): 'dictionary'}
-
- let setting_origin = a:comes_from_global_variable ?
- \ printf('''g:vimwiki_%s''', a:key) :
- \ printf('''%s'' in g:vimwiki_list', a:key)
-
- if has_key(a:value_infos, 'type') && type(a:users_value) != a:value_infos.type
- echom printf('Vimwiki Error: The provided value of the option %s is a %s, ' .
- \ 'but expected is a %s. See '':h g:vimwiki_%s''.', setting_origin,
- \ type_code_to_name[type(a:users_value)], type_code_to_name[a:value_infos.type], a:key)
- endif
-
- if a:value_infos.type == type(0) && has_key(a:value_infos, 'min') &&
- \ a:users_value < a:value_infos.min
- echom printf('Vimwiki Error: The provided value ''%i'' of the option %s is'
- \ . ' too small. The minimum value is %i. See '':h g:vimwiki_%s''.', a:users_value,
- \ setting_origin, a:value_infos.min, a:key)
- endif
-
- if a:value_infos.type == type(0) && has_key(a:value_infos, 'max') &&
- \ a:users_value > a:value_infos.max
- echom printf('Vimwiki Error: The provided value ''%i'' of the option %s is'
- \ . ' too large. The maximum value is %i. See '':h g:vimwiki_%s''.', a:users_value,
- \ setting_origin, a:value_infos.max, a:key)
- endif
-
- if has_key(a:value_infos, 'possible_values') &&
- \ index(a:value_infos.possible_values, a:users_value) == -1
- echom printf('Vimwiki Error: The provided value ''%s'' of the option %s is'
- \ . ' invalid. Allowed values are %s. See ''g:vimwiki_%s''.', a:users_value,
- \ setting_origin, string(a:value_infos.possible_values), a:key)
- endif
-
- if a:value_infos.type == type('') && has_key(a:value_infos, 'length') &&
- \ strwidth(a:users_value) != a:value_infos.length
- echom printf('Vimwiki Error: The provided value ''%s'' of the option %s must'
- \ . ' contain exactly %i character(s) but has %i. See '':h g:vimwiki_%s''.',
- \ a:users_value, setting_origin, a:value_infos.length, strwidth(a:users_value), a:key)
- endif
-
- if a:value_infos.type == type('') && has_key(a:value_infos, 'min_length') &&
- \ strwidth(a:users_value) < a:value_infos.min_length
- echom printf('Vimwiki Error: The provided value ''%s'' of the option %s must'
- \ . ' have at least %d character(s) but has %d. See '':h g:vimwiki_%s''.', a:users_value,
- \ setting_origin, a:value_infos.min_length, strwidth(a:users_value), a:key)
- endif
-endfunction
-
-
-function! s:normalize_wikilocal_settings()
- for wiki_settings in g:vimwiki_wikilocal_vars
- let wiki_settings['path'] = s:normalize_path(wiki_settings['path'])
-
- let path_html = wiki_settings['path_html']
- if !empty(path_html)
- let wiki_settings['path_html'] = s:normalize_path(path_html)
- else
- let wiki_settings['path_html'] = s:normalize_path(
- \ substitute(wiki_settings['path'], '[/\\]\+$', '', '').'_html/')
- endif
-
- let wiki_settings['template_path'] = s:normalize_path(wiki_settings['template_path'])
- let wiki_settings['diary_rel_path'] = s:normalize_path(wiki_settings['diary_rel_path'])
-
- let ext = wiki_settings['ext']
- if !empty(ext) && ext[0] != '.'
- let wiki_settings['ext'] = '.' . ext
- endif
-
- " for convenience, we also allow the term 'mediawiki'
- if wiki_settings.syntax ==# 'mediawiki'
- let wiki_settings.syntax = 'media'
- endif
- endfor
-endfunction
-
-
-function! s:normalize_path(path)
- " trim trailing / and \ because otherwise resolve() doesn't work quite right
- let path = substitute(a:path, '[/\\]\+$', '', '')
- if path !~# '^scp:'
- return resolve(expand(path)).'/'
- else
- return path.'/'
- endif
-endfunction
-
-
-function! vimwiki#vars#populate_syntax_vars(syntax)
- if !exists('g:vimwiki_syntax_variables')
- let g:vimwiki_syntax_variables = {}
- endif
-
- if has_key(g:vimwiki_syntax_variables, a:syntax)
- return
- endif
-
- let g:vimwiki_syntax_variables[a:syntax] = {}
-
- execute 'runtime! syntax/vimwiki_'.a:syntax.'.vim'
-
- " generic stuff
- let header_symbol = g:vimwiki_syntax_variables[a:syntax].rxH
- if g:vimwiki_syntax_variables[a:syntax].symH
- " symmetric headers
- for i in range(1,6)
- let g:vimwiki_syntax_variables[a:syntax]['rxH'.i.'_Template'] =
- \ repeat(header_symbol, i).' __Header__ '.repeat(header_symbol, i)
- let g:vimwiki_syntax_variables[a:syntax]['rxH'.i] =
- \ '^\s*'.header_symbol.'\{'.i.'}[^'.header_symbol.'].*[^'.header_symbol.']'
- \ .header_symbol.'\{'.i.'}\s*$'
- let g:vimwiki_syntax_variables[a:syntax]['rxH'.i.'_Start'] =
- \ '^\s*'.header_symbol.'\{'.i.'}[^'.header_symbol.'].*[^'.header_symbol.']'
- \ .header_symbol.'\{'.i.'}\s*$'
- let g:vimwiki_syntax_variables[a:syntax]['rxH'.i.'_End'] =
- \ '^\s*'.header_symbol.'\{1,'.i.'}[^'.header_symbol.'].*[^'.header_symbol.']'
- \ .header_symbol.'\{1,'.i.'}\s*$'
- endfor
- let g:vimwiki_syntax_variables[a:syntax].rxHeader =
- \ '^\s*\('.header_symbol.'\{1,6}\)\zs[^'.header_symbol.'].*[^'.header_symbol.']\ze\1\s*$'
- else
- " asymmetric
- for i in range(1,6)
- let g:vimwiki_syntax_variables[a:syntax]['rxH'.i.'_Template'] =
- \ repeat(header_symbol, i).' __Header__'
- let g:vimwiki_syntax_variables[a:syntax]['rxH'.i] =
- \ '^\s*'.header_symbol.'\{'.i.'}[^'.header_symbol.'].*$'
- let g:vimwiki_syntax_variables[a:syntax]['rxH'.i.'_Start'] =
- \ '^\s*'.header_symbol.'\{'.i.'}[^'.header_symbol.'].*$'
- let g:vimwiki_syntax_variables[a:syntax]['rxH'.i.'_End'] =
- \ '^\s*'.header_symbol.'\{1,'.i.'}[^'.header_symbol.'].*$'
- endfor
- let g:vimwiki_syntax_variables[a:syntax].rxHeader =
- \ '^\s*\('.header_symbol.'\{1,6}\)\zs[^'.header_symbol.'].*\ze$'
- endif
-
- let g:vimwiki_syntax_variables[a:syntax].rxPreStart =
- \ '^\s*'.g:vimwiki_syntax_variables[a:syntax].rxPreStart
- let g:vimwiki_syntax_variables[a:syntax].rxPreEnd =
- \ '^\s*'.g:vimwiki_syntax_variables[a:syntax].rxPreEnd.'\s*$'
-
- let g:vimwiki_syntax_variables[a:syntax].rxMathStart =
- \ '^\s*'.g:vimwiki_syntax_variables[a:syntax].rxMathStart
- let g:vimwiki_syntax_variables[a:syntax].rxMathEnd =
- \ '^\s*'.g:vimwiki_syntax_variables[a:syntax].rxMathEnd.'\s*$'
-
- " list stuff
- let g:vimwiki_syntax_variables[a:syntax].rx_bullet_chars =
- \ '['.join(g:vimwiki_syntax_variables[a:syntax].bullet_types, '').']\+'
-
- let g:vimwiki_syntax_variables[a:syntax].multiple_bullet_chars =
- \ g:vimwiki_syntax_variables[a:syntax].recurring_bullets
- \ ? g:vimwiki_syntax_variables[a:syntax].bullet_types : []
-
- let g:vimwiki_syntax_variables[a:syntax].number_kinds = []
- let g:vimwiki_syntax_variables[a:syntax].number_divisors = ''
- for i in g:vimwiki_syntax_variables[a:syntax].number_types
- call add(g:vimwiki_syntax_variables[a:syntax].number_kinds, i[0])
- let g:vimwiki_syntax_variables[a:syntax].number_divisors .= vimwiki#u#escape(i[1])
- endfor
-
- let char_to_rx = {'1': '\d\+', 'i': '[ivxlcdm]\+', 'I': '[IVXLCDM]\+',
- \ 'a': '\l\{1,2}', 'A': '\u\{1,2}'}
-
- "create regexp for bulleted list items
- if !empty(g:vimwiki_syntax_variables[a:syntax].bullet_types)
- let g:vimwiki_syntax_variables[a:syntax].rxListBullet =
- \ join( map(copy(g:vimwiki_syntax_variables[a:syntax].bullet_types),
- \'vimwiki#u#escape(v:val).'
- \ .'repeat("\\+", g:vimwiki_syntax_variables[a:syntax].recurring_bullets)'
- \ ) , '\|')
- else
- "regex that matches nothing
- let g:vimwiki_syntax_variables[a:syntax].rxListBullet = '$^'
- endif
-
- "create regex for numbered list items
- if !empty(g:vimwiki_syntax_variables[a:syntax].number_types)
- let g:vimwiki_syntax_variables[a:syntax].rxListNumber = '\C\%('
- for type in g:vimwiki_syntax_variables[a:syntax].number_types[:-2]
- let g:vimwiki_syntax_variables[a:syntax].rxListNumber .= char_to_rx[type[0]] .
- \ vimwiki#u#escape(type[1]) . '\|'
- endfor
- let g:vimwiki_syntax_variables[a:syntax].rxListNumber .=
- \ char_to_rx[g:vimwiki_syntax_variables[a:syntax].number_types[-1][0]].
- \ vimwiki#u#escape(g:vimwiki_syntax_variables[a:syntax].number_types[-1][1]) . '\)'
- else
- "regex that matches nothing
- let g:vimwiki_syntax_variables[a:syntax].rxListNumber = '$^'
- endif
-
- "the user can set the listsyms as string, but vimwiki needs a list
- let g:vimwiki_syntax_variables[a:syntax].listsyms_list =
- \ split(vimwiki#vars#get_global('listsyms'), '\zs')
- if match(vimwiki#vars#get_global('listsyms'), vimwiki#vars#get_global('listsym_rejected')) != -1
- echomsg 'Vimwiki Warning: the value of g:vimwiki_listsym_rejected ('''
- \ . vimwiki#vars#get_global('listsym_rejected')
- \ . ''') must not be a part of g:vimwiki_listsyms (''' .
- \ . vimwiki#vars#get_global('listsyms') . ''')'
- endif
- let g:vimwiki_syntax_variables[a:syntax].rxListItemWithoutCB =
- \ '^\s*\%(\('.g:vimwiki_syntax_variables[a:syntax].rxListBullet.'\)\|\('
- \ .g:vimwiki_syntax_variables[a:syntax].rxListNumber.'\)\)\s'
- let g:vimwiki_syntax_variables[a:syntax].rxListItem =
- \ g:vimwiki_syntax_variables[a:syntax].rxListItemWithoutCB
- \ . '\+\%(\[\(['.vimwiki#vars#get_global('listsyms')
- \ . vimwiki#vars#get_global('listsym_rejected').']\)\]\s\)\?'
- if g:vimwiki_syntax_variables[a:syntax].recurring_bullets
- let g:vimwiki_syntax_variables[a:syntax].rxListItemAndChildren =
- \ '^\('.g:vimwiki_syntax_variables[a:syntax].rxListBullet.'\)\s\+\[['
- \ . g:vimwiki_syntax_variables[a:syntax].listsyms_list[-1]
- \ . vimwiki#vars#get_global('listsym_rejected') . ']\]\s.*\%(\n\%(\1\%('
- \ .g:vimwiki_syntax_variables[a:syntax].rxListBullet.'\).*\|^$\|\s.*\)\)*'
- else
- let g:vimwiki_syntax_variables[a:syntax].rxListItemAndChildren =
- \ '^\(\s*\)\%('.g:vimwiki_syntax_variables[a:syntax].rxListBullet.'\|'
- \ . g:vimwiki_syntax_variables[a:syntax].rxListNumber.'\)\s\+\[['
- \ . g:vimwiki_syntax_variables[a:syntax].listsyms_list[-1]
- \ . vimwiki#vars#get_global('listsym_rejected') . ']\]\s.*\%(\n\%(\1\s.*\|^$\)\)*'
- endif
-
- " 0. URL : free-standing links: keep URL UR(L) strip trailing punct: URL; URL) UR(L))
- " let g:vimwiki_rxWeblink = '[\["(|]\@<!'. g:vimwiki_rxWeblinkUrl .
- " \ '\%([),:;.!?]\=\%([ \t]\|$\)\)\@='
- let g:vimwiki_syntax_variables[a:syntax].rxWeblink =
- \ '\<'. g:vimwiki_global_vars.rxWeblinkUrl . '\S*'
- " 0a) match URL within URL
- let g:vimwiki_syntax_variables[a:syntax].rxWeblinkMatchUrl =
- \ g:vimwiki_syntax_variables[a:syntax].rxWeblink
- " 0b) match DESCRIPTION within URL
- let g:vimwiki_syntax_variables[a:syntax].rxWeblinkMatchDescr = ''
-
- " template for matching all wiki links with a given target file
- let g:vimwiki_syntax_variables[a:syntax].WikiLinkMatchUrlTemplate =
- \ g:vimwiki_global_vars.rx_wikilink_prefix .
- \ '\zs__LinkUrl__\ze\%(#.*\)\?' .
- \ g:vimwiki_global_vars.rx_wikilink_suffix .
- \ '\|' .
- \ g:vimwiki_global_vars.rx_wikilink_prefix .
- \ '\zs__LinkUrl__\ze\%(#.*\)\?' .
- \ g:vimwiki_global_vars.rx_wikilink_separator .
- \ '.*' .
- \ g:vimwiki_global_vars.rx_wikilink_suffix
-
- " a) match [[URL|DESCRIPTION]]
- let g:vimwiki_syntax_variables[a:syntax].rxWikiLink = g:vimwiki_global_vars.rx_wikilink_prefix.
- \ g:vimwiki_global_vars.rxWikiLinkUrl.'\%('.g:vimwiki_global_vars.rx_wikilink_separator.
- \ g:vimwiki_global_vars.rxWikiLinkDescr.'\)\?'.g:vimwiki_global_vars.rx_wikilink_suffix
- let g:vimwiki_syntax_variables[a:syntax].rxAnyLink =
- \ g:vimwiki_syntax_variables[a:syntax].rxWikiLink.'\|'.
- \ g:vimwiki_global_vars.rxWikiIncl.'\|'.g:vimwiki_syntax_variables[a:syntax].rxWeblink
- " b) match URL within [[URL|DESCRIPTION]]
- let g:vimwiki_syntax_variables[a:syntax].rxWikiLinkMatchUrl =
- \ g:vimwiki_global_vars.rx_wikilink_prefix . '\zs'. g:vimwiki_global_vars.rxWikiLinkUrl
- \ .'\ze\%('. g:vimwiki_global_vars.rx_wikilink_separator
- \ . g:vimwiki_global_vars.rxWikiLinkDescr.'\)\?'.g:vimwiki_global_vars.rx_wikilink_suffix
- " c) match DESCRIPTION within [[URL|DESCRIPTION]]
- let g:vimwiki_syntax_variables[a:syntax].rxWikiLinkMatchDescr =
- \ g:vimwiki_global_vars.rx_wikilink_prefix . g:vimwiki_global_vars.rxWikiLinkUrl
- \ . g:vimwiki_global_vars.rx_wikilink_separator.'\%(\zs'
- \ . g:vimwiki_global_vars.rxWikiLinkDescr. '\ze\)\?'
- \ . g:vimwiki_global_vars.rx_wikilink_suffix
-
- if a:syntax ==# 'markdown'
- call s:populate_extra_markdown_vars()
- endif
-endfunction
-
-
-function! s:populate_extra_markdown_vars()
- let mkd_syntax = g:vimwiki_syntax_variables['markdown']
-
- " 0a) match [[URL|DESCRIPTION]]
- let mkd_syntax.rxWikiLink0 = mkd_syntax.rxWikiLink
- " 0b) match URL within [[URL|DESCRIPTION]]
- let mkd_syntax.rxWikiLink0MatchUrl = mkd_syntax.rxWikiLinkMatchUrl
- " 0c) match DESCRIPTION within [[URL|DESCRIPTION]]
- let mkd_syntax.rxWikiLink0MatchDescr = mkd_syntax.rxWikiLinkMatchDescr
-
- let wikilink_md_prefix = '['
- let wikilink_md_suffix = ']'
- let wikilink_md_separator = ']['
- let rx_wikilink_md_separator = vimwiki#u#escape(wikilink_md_separator)
- let mkd_syntax.rx_wikilink_md_prefix = vimwiki#u#escape(wikilink_md_prefix)
- let mkd_syntax.rx_wikilink_md_suffix = vimwiki#u#escape(wikilink_md_suffix)
-
- " [URL][]
- let mkd_syntax.WikiLink1Template1 = wikilink_md_prefix . '__LinkUrl__'.
- \ wikilink_md_separator. wikilink_md_suffix
- " [DESCRIPTION][URL]
- let mkd_syntax.WikiLink1Template2 = wikilink_md_prefix. '__LinkDescription__'.
- \ wikilink_md_separator. '__LinkUrl__'. wikilink_md_suffix
- let mkd_syntax.WikiLinkMatchUrlTemplate .=
- \ '\|' .
- \ mkd_syntax.rx_wikilink_md_prefix .
- \ '.*' .
- \ rx_wikilink_md_separator .
- \ '\zs__LinkUrl__\ze\%(#.*\)\?' .
- \ mkd_syntax.rx_wikilink_md_suffix .
- \ '\|' .
- \ mkd_syntax.rx_wikilink_md_prefix .
- \ '\zs__LinkUrl__\ze\%(#.*\)\?' .
- \ rx_wikilink_md_separator .
- \ mkd_syntax.rx_wikilink_md_suffix
-
- let valid_chars = '[^\\\[\]]'
- let mkd_syntax.rxWikiLink1Url = valid_chars.'\{-}'
- let mkd_syntax.rxWikiLink1Descr = valid_chars.'\{-}'
- let mkd_syntax.rxWikiLink1InvalidPrefix = '[\]\[]\@<!'
- let mkd_syntax.rxWikiLink1InvalidSuffix = '[\]\[]\@!'
- let mkd_syntax.rx_wikilink_md_prefix = mkd_syntax.rxWikiLink1InvalidPrefix.
- \ mkd_syntax.rx_wikilink_md_prefix
- let mkd_syntax.rx_wikilink_md_suffix = mkd_syntax.rx_wikilink_md_suffix.
- \ mkd_syntax.rxWikiLink1InvalidSuffix
-
- " 1. match [URL][], [DESCRIPTION][URL]
- let mkd_syntax.rxWikiLink1 = mkd_syntax.rx_wikilink_md_prefix.
- \ mkd_syntax.rxWikiLink1Url. rx_wikilink_md_separator.
- \ mkd_syntax.rx_wikilink_md_suffix.
- \ '\|'. mkd_syntax.rx_wikilink_md_prefix.
- \ mkd_syntax.rxWikiLink1Descr . rx_wikilink_md_separator.
- \ mkd_syntax.rxWikiLink1Url . mkd_syntax.rx_wikilink_md_suffix
- " 2. match URL within [URL][], [DESCRIPTION][URL]
- let mkd_syntax.rxWikiLink1MatchUrl = mkd_syntax.rx_wikilink_md_prefix.
- \ '\zs'. mkd_syntax.rxWikiLink1Url. '\ze'. rx_wikilink_md_separator.
- \ mkd_syntax.rx_wikilink_md_suffix.
- \ '\|'. mkd_syntax.rx_wikilink_md_prefix.
- \ mkd_syntax.rxWikiLink1Descr. rx_wikilink_md_separator.
- \ '\zs'. mkd_syntax.rxWikiLink1Url. '\ze'. mkd_syntax.rx_wikilink_md_suffix
- " 3. match DESCRIPTION within [DESCRIPTION][URL]
- let mkd_syntax.rxWikiLink1MatchDescr = mkd_syntax.rx_wikilink_md_prefix.
- \ '\zs'. mkd_syntax.rxWikiLink1Descr.'\ze'. rx_wikilink_md_separator.
- \ mkd_syntax.rxWikiLink1Url . mkd_syntax.rx_wikilink_md_suffix
-
- let mkd_syntax.rxWikiLink1Prefix1 = mkd_syntax.rx_wikilink_md_prefix
- let mkd_syntax.rxWikiLink1Suffix1 = rx_wikilink_md_separator.
- \ mkd_syntax.rxWikiLink1Url . mkd_syntax.rx_wikilink_md_suffix
-
- " 1. match ANY wikilink
- let mkd_syntax.rxWikiLink = mkd_syntax.rxWikiLink0 . '\|' . mkd_syntax.rxWikiLink1
- " 2. match URL within ANY wikilink
- let mkd_syntax.rxWikiLinkMatchUrl = mkd_syntax.rxWikiLink0MatchUrl . '\|' .
- \ mkd_syntax.rxWikiLink1MatchUrl
- " 3. match DESCRIPTION within ANY wikilink
- let mkd_syntax.rxWikiLinkMatchDescr = mkd_syntax.rxWikiLink0MatchDescr . '\|' .
- \ mkd_syntax.rxWikiLink1MatchDescr
-
- " 0. URL : free-standing links: keep URL UR(L) strip trailing punct: URL; URL) UR(L))
- let mkd_syntax.rxWeblink0 = mkd_syntax.rxWeblink
- " 0a) match URL within URL
- let mkd_syntax.rxWeblinkMatchUrl0 = mkd_syntax.rxWeblinkMatchUrl
- " 0b) match DESCRIPTION within URL
- let mkd_syntax.rxWeblinkMatchDescr0 = mkd_syntax.rxWeblinkMatchDescr
-
- let mkd_syntax.rxWeblink1Prefix = '['
- let mkd_syntax.rxWeblink1Suffix = ')'
- let mkd_syntax.rxWeblink1Separator = ']('
- " [DESCRIPTION](URL)
- let mkd_syntax.Weblink1Template = mkd_syntax.rxWeblink1Prefix . '__LinkDescription__'.
- \ mkd_syntax.rxWeblink1Separator. '__LinkUrl__'.
- \ mkd_syntax.rxWeblink1Suffix
-
- let valid_chars = '[^\\]'
-
- let mkd_syntax.rxWeblink1Prefix = vimwiki#u#escape(mkd_syntax.rxWeblink1Prefix)
- let mkd_syntax.rxWeblink1Suffix = vimwiki#u#escape(mkd_syntax.rxWeblink1Suffix)
- let mkd_syntax.rxWeblink1Separator = vimwiki#u#escape(mkd_syntax.rxWeblink1Separator)
- let mkd_syntax.rxWeblink1Url = valid_chars.'\{-}'
- let mkd_syntax.rxWeblink1Descr = valid_chars.'\{-}'
-
- " 1. [DESCRIPTION](URL)
- " 1a) match [DESCRIPTION](URL)
- let mkd_syntax.rxWeblink1 = mkd_syntax.rxWeblink1Prefix.
- \ mkd_syntax.rxWeblink1Url . mkd_syntax.rxWeblink1Separator.
- \ mkd_syntax.rxWeblink1Descr . mkd_syntax.rxWeblink1Suffix
- " 1b) match URL within [DESCRIPTION](URL)
- let mkd_syntax.rxWeblink1MatchUrl = mkd_syntax.rxWeblink1Prefix.
- \ mkd_syntax.rxWeblink1Descr. mkd_syntax.rxWeblink1Separator.
- \ '\zs' . mkd_syntax.rxWeblink1Url . '\ze' . mkd_syntax.rxWeblink1Suffix
- " 1c) match DESCRIPTION within [DESCRIPTION](URL)
- let mkd_syntax.rxWeblink1MatchDescr = mkd_syntax.rxWeblink1Prefix.
- \ '\zs'.mkd_syntax.rxWeblink1Descr.'\ze'. mkd_syntax.rxWeblink1Separator.
- \ mkd_syntax.rxWeblink1Url. mkd_syntax.rxWeblink1Suffix
-
- " TODO: image links too !!
- let mkd_syntax.rxWeblink1Prefix1 = mkd_syntax.rxWeblink1Prefix
- let mkd_syntax.rxWeblink1Suffix1 = mkd_syntax.rxWeblink1Separator.
- \ mkd_syntax.rxWeblink1Url . mkd_syntax.rxWeblink1Suffix
-
- " *a) match ANY weblink
- let mkd_syntax.rxWeblink = ''.
- \ mkd_syntax.rxWeblink1.'\|'.
- \ mkd_syntax.rxWeblink0
- " *b) match URL within ANY weblink
- let mkd_syntax.rxWeblinkMatchUrl = ''.
- \ mkd_syntax.rxWeblink1MatchUrl.'\|'.
- \ mkd_syntax.rxWeblinkMatchUrl0
- " *c) match DESCRIPTION within ANY weblink
- let mkd_syntax.rxWeblinkMatchDescr = ''.
- \ mkd_syntax.rxWeblink1MatchDescr.'\|'.
- \ mkd_syntax.rxWeblinkMatchDescr0
-
- let mkd_syntax.rxAnyLink = mkd_syntax.rxWikiLink.'\|'.
- \ g:vimwiki_global_vars.rxWikiIncl.'\|'.mkd_syntax.rxWeblink
-
- let mkd_syntax.rxMkdRef = '\['.g:vimwiki_global_vars.rxWikiLinkDescr.']:\%(\s\+\|\n\)'.
- \ mkd_syntax.rxWeblink0
- let mkd_syntax.rxMkdRefMatchDescr =
- \ '\[\zs'.g:vimwiki_global_vars.rxWikiLinkDescr.'\ze]:\%(\s\+\|\n\)'. mkd_syntax.rxWeblink0
- let mkd_syntax.rxMkdRefMatchUrl =
- \ '\['.g:vimwiki_global_vars.rxWikiLinkDescr.']:\%(\s\+\|\n\)\zs'.
- \ mkd_syntax.rxWeblink0.'\ze'
-endfunction
-
-
-function! vimwiki#vars#init()
- call s:populate_global_variables()
- call s:populate_wikilocal_options()
-endfunction
-
-
-function! vimwiki#vars#get_syntaxlocal(key, ...)
- if a:0
- let syntax = a:1
- else
- let syntax = vimwiki#vars#get_wikilocal('syntax')
- endif
- if !exists('g:vimwiki_syntax_variables') || !has_key(g:vimwiki_syntax_variables, syntax)
- call vimwiki#vars#populate_syntax_vars(syntax)
- endif
-
- return g:vimwiki_syntax_variables[syntax][a:key]
-endfunction
-
-
-" Get a variable for the buffer we are currently in or for the given buffer (number or name).
-" Populate the variable, if it doesn't exist.
-function! vimwiki#vars#get_bufferlocal(key, ...)
- let buffer = a:0 ? a:1 : '%'
-
- let value = getbufvar(buffer, 'vimwiki_'.a:key, '/\/\')
- if type(value) != 1 || value !=# '/\/\'
- return value
- elseif a:key ==# 'wiki_nr'
- call setbufvar(buffer, 'vimwiki_wiki_nr', vimwiki#base#find_wiki(expand('%:p')))
- elseif a:key ==# 'subdir'
- call setbufvar(buffer, 'vimwiki_subdir', vimwiki#base#current_subdir())
- elseif a:key ==# 'invsubdir'
- let subdir = vimwiki#vars#get_bufferlocal('subdir')
- call setbufvar(buffer, 'vimwiki_invsubdir', vimwiki#base#invsubdir(subdir))
- elseif a:key ==# 'existing_wikifiles'
- call setbufvar(buffer, 'vimwiki_existing_wikifiles',
- \ vimwiki#base#get_wikilinks(vimwiki#vars#get_bufferlocal('wiki_nr'), 1))
- elseif a:key ==# 'existing_wikidirs'
- call setbufvar(buffer, 'vimwiki_existing_wikidirs',
- \ vimwiki#base#get_wiki_directories(vimwiki#vars#get_bufferlocal('wiki_nr')))
- elseif a:key ==# 'prev_link'
- call setbufvar(buffer, 'vimwiki_prev_link', [])
- elseif a:key ==# 'markdown_refs'
- call setbufvar(buffer, 'vimwiki_markdown_refs', vimwiki#markdown_base#scan_reflinks())
- else
- echoerr 'Vimwiki Error: unknown buffer variable ' . string(a:key)
- endif
-
- return getbufvar(buffer, 'vimwiki_'.a:key)
-endfunction
-
-
-function! vimwiki#vars#set_bufferlocal(key, value, ...)
- let buffer = a:0 ? a:1 : '%'
- call setbufvar(buffer, 'vimwiki_' . a:key, a:value)
-endfunction
-
-
-function! vimwiki#vars#get_global(key)
- return g:vimwiki_global_vars[a:key]
-endfunction
-
-
-" the second argument can be a wiki number. When absent, the wiki of the currently active buffer is
-" used
-function! vimwiki#vars#get_wikilocal(key, ...)
- if a:0
- return g:vimwiki_wikilocal_vars[a:1][a:key]
- else
- return g:vimwiki_wikilocal_vars[vimwiki#vars#get_bufferlocal('wiki_nr')][a:key]
- endif
-endfunction
-
-
-function! vimwiki#vars#get_wikilocal_default(key)
- return g:vimwiki_wikilocal_vars[-1][a:key]
-endfunction
-
-
-function! vimwiki#vars#set_wikilocal(key, value, wiki_nr)
- if a:wiki_nr == len(g:vimwiki_wikilocal_vars) - 1
- call insert(g:vimwiki_wikilocal_vars, {}, -1)
- endif
- let g:vimwiki_wikilocal_vars[a:wiki_nr][a:key] = a:value
-endfunction
-
-
-function! vimwiki#vars#add_temporary_wiki(settings)
- let new_temp_wiki_settings = copy(g:vimwiki_wikilocal_vars[-1])
- for [key, value] in items(a:settings)
- let new_temp_wiki_settings[key] = value
- endfor
- call insert(g:vimwiki_wikilocal_vars, new_temp_wiki_settings, -1)
- call s:normalize_wikilocal_settings()
-endfunction
-
-
-" number of registered wikis + temporary
-function! vimwiki#vars#number_of_wikis()
- return len(g:vimwiki_wikilocal_vars) - 1
-endfunction
-
diff --git a/.config/nvim/init.vim b/.config/nvim/init.vim
@@ -202,7 +202,6 @@ source ~/.config/nvim/modules/splits.vim
source ~/.config/nvim/modules/netrw.vim
source ~/.config/nvim/modules/term.vim
source ~/.config/nvim/modules/tabs.vim
-source ~/.config/nvim/modules/wiki.vim
source ~/.config/nvim/modules/edit.vim
source ~/.config/nvim/modules/window.vim
source ~/.config/nvim/modules/message.vim
diff --git a/.config/nvim/modules/wiki.vim b/.config/nvim/modules/wiki.vim
@@ -1,12 +0,0 @@
-augroup wikimaps
- autocmd WinNew,WinEnter,BufNew,BufEnter *.wiki :call Wikimaps()
-augroup END
-
-let g:vimwiki_listsyms='-~=X'
-
-function! Wikimaps()
- nnoremap <buffer> <leader>Wt :VimwikiTable
- nnoremap <buffer> <leader>W2h :Vimwiki2HTML
- " To be continued
-endfunction
-
diff --git a/.config/nvim/plugin/vimwiki.vim b/.config/nvim/plugin/vimwiki.vim
@@ -1,398 +0,0 @@
-" vim:tabstop=2:shiftwidth=2:expandtab:textwidth=99
-" Vimwiki plugin file
-" Home: https://github.com/vimwiki/vimwiki/
-" GetLatestVimScripts: 2226 1 :AutoInstall: vimwiki
-
-
-if exists("g:loaded_vimwiki") || &cp
- finish
-endif
-let g:loaded_vimwiki = 1
-
-" Set to version number for release, otherwise -1 for dev-branch
-let s:plugin_vers = "2.4.1"
-
-" Get the directory the script is installed in
-let s:plugin_dir = expand('<sfile>:p:h:h')
-
-let s:old_cpo = &cpo
-set cpo&vim
-
-
-if exists('g:vimwiki_autowriteall')
- let s:vimwiki_autowriteall_saved = g:vimwiki_autowriteall
-else
- let s:vimwiki_autowriteall_saved = 1
-endif
-
-
-" this is called when the cursor leaves the buffer
-function! s:setup_buffer_leave()
- " don't do anything if it's not managed by Vimwiki (that is, when it's not in
- " a registered wiki and not a temporary wiki)
- if vimwiki#vars#get_bufferlocal('wiki_nr') == -1
- return
- endif
-
- let &autowriteall = s:vimwiki_autowriteall_saved
-
- if !empty(vimwiki#vars#get_global('menu'))
- exe 'nmenu disable '.vimwiki#vars#get_global('menu').'.Table'
- endif
-endfunction
-
-
-" create a new temporary wiki for the current buffer
-function! s:create_temporary_wiki()
- let path = expand('%:p:h')
- let ext = '.'.expand('%:e')
-
- let syntax_mapping = vimwiki#vars#get_global('ext2syntax')
- if has_key(syntax_mapping, ext)
- let syntax = syntax_mapping[ext]
- else
- let syntax = vimwiki#vars#get_wikilocal_default('syntax')
- endif
-
- let new_temp_wiki_settings = {'path': path,
- \ 'ext': ext,
- \ 'syntax': syntax,
- \ }
-
- call vimwiki#vars#add_temporary_wiki(new_temp_wiki_settings)
-
- " Update the wiki number of the current buffer, because it may have changed when adding this
- " temporary wiki.
- call vimwiki#vars#set_bufferlocal('wiki_nr', vimwiki#base#find_wiki(expand('%:p')))
-endfunction
-
-
-" This function is called when Vim opens a new buffer with a known wiki
-" extension. Both when the buffer has never been opened in this session and
-" when it has.
-function! s:setup_new_wiki_buffer()
- let wiki_nr = vimwiki#vars#get_bufferlocal('wiki_nr')
- if wiki_nr == -1 " it's not in a known wiki directory
- if vimwiki#vars#get_global('global_ext')
- call s:create_temporary_wiki()
- else
- " the user does not want a temporary wiki, so do nothing
- return
- endif
- endif
-
- if vimwiki#vars#get_wikilocal('maxhi')
- call vimwiki#vars#set_bufferlocal('existing_wikifiles', vimwiki#base#get_wikilinks(wiki_nr, 1))
- call vimwiki#vars#set_bufferlocal('existing_wikidirs',
- \ vimwiki#base#get_wiki_directories(wiki_nr))
- endif
-
- " this makes that ftplugin/vimwiki.vim and afterwards syntax/vimwiki.vim are
- " sourced
- setfiletype vimwiki
-
-endfunction
-
-
-" this is called when the cursor enters the buffer
-function! s:setup_buffer_enter()
- " don't do anything if it's not managed by Vimwiki (that is, when it's not in
- " a registered wiki and not a temporary wiki)
- if vimwiki#vars#get_bufferlocal('wiki_nr') == -1
- return
- endif
-
- if &filetype != 'vimwiki'
- setfiletype vimwiki
- endif
-
- call s:set_global_options()
-
- call s:set_windowlocal_options()
-endfunction
-
-
-function! s:setup_cleared_syntax()
- " highlight groups that get cleared
- " on colorscheme change because they are not linked to Vim-predefined groups
- hi def VimwikiBold term=bold cterm=bold gui=bold
- hi def VimwikiItalic term=italic cterm=italic gui=italic
- hi def VimwikiBoldItalic term=bold cterm=bold gui=bold,italic
- hi def VimwikiUnderline gui=underline
- if vimwiki#vars#get_global('hl_headers') == 1
- for i in range(1,6)
- execute 'hi def VimwikiHeader'.i.' guibg=bg guifg='
- \ . vimwiki#vars#get_global('hcolor_guifg_'.&bg)[i-1]
- \ .' gui=bold ctermfg='.vimwiki#vars#get_global('hcolor_ctermfg_'.&bg)[i-1]
- \ .' term=bold cterm=bold'
- endfor
- endif
-endfunction
-
-
-function! s:vimwiki_get_known_extensions()
- " Getting all extensions that different wikis could have
- let extensions = {}
- for idx in range(vimwiki#vars#number_of_wikis())
- let ext = vimwiki#vars#get_wikilocal('ext', idx)
- let extensions[ext] = 1
- endfor
- " append extensions from g:vimwiki_ext2syntax
- for ext in keys(vimwiki#vars#get_global('ext2syntax'))
- let extensions[ext] = 1
- endfor
- return keys(extensions)
-endfunction
-
-
-" Set settings which are global for Vim, but should only be executed for
-" Vimwiki buffers. So they must be set when the cursor enters a Vimwiki buffer
-" and reset when the cursor leaves the buffer.
-function! s:set_global_options()
- let s:vimwiki_autowriteall_saved = &autowriteall
- let &autowriteall = vimwiki#vars#get_global('autowriteall')
-
- if !empty(vimwiki#vars#get_global('menu'))
- exe 'nmenu enable '.vimwiki#vars#get_global('menu').'.Table'
- endif
-endfunction
-
-
-" Set settings which are local to a window. In a new tab they would be reset to
-" Vim defaults. So we enforce our settings here when the cursor enters a
-" Vimwiki buffer.
-function! s:set_windowlocal_options()
- if !&diff " if Vim is currently in diff mode, don't interfere with its folding
- let foldmethod = vimwiki#vars#get_global('folding')
- if foldmethod =~? '^expr.*'
- setlocal foldmethod=expr
- setlocal foldexpr=VimwikiFoldLevel(v:lnum)
- setlocal foldtext=VimwikiFoldText()
- elseif foldmethod =~? '^list.*' || foldmethod =~? '^lists.*'
- setlocal foldmethod=expr
- setlocal foldexpr=VimwikiFoldListLevel(v:lnum)
- setlocal foldtext=VimwikiFoldText()
- elseif foldmethod =~? '^syntax.*'
- setlocal foldmethod=syntax
- setlocal foldtext=VimwikiFoldText()
- elseif foldmethod =~? '^custom.*'
- " do nothing
- else
- setlocal foldmethod=manual
- normal! zE
- endif
- endif
-
- if vimwiki#vars#get_global('conceallevel') && exists("+conceallevel")
- let &conceallevel = vimwiki#vars#get_global('conceallevel')
- endif
-
- if vimwiki#vars#get_global('auto_chdir')
- exe 'lcd' vimwiki#vars#get_wikilocal('path')
- endif
-endfunction
-
-
-function! s:get_version()
- if s:plugin_vers != -1
- echo "Stable version: " . string(s:plugin_vers)
- else
- let l:plugin_rev = system("git --git-dir " . s:plugin_dir . "/.git rev-parse --short HEAD")
- let l:plugin_branch = system("git --git-dir " . s:plugin_dir . "/.git rev-parse --abbrev-ref HEAD")
- let l:plugin_date = system("git --git-dir " . s:plugin_dir . "/.git show -s --format=%ci")
- if v:shell_error == 0
- echo "Branch: " . l:plugin_branch
- echo "Revision: " . l:plugin_rev
- echo "Date: " . l:plugin_date
- else
- echo "Unknown version"
- endif
- endif
-endfunction
-
-
-
-" Initialization of Vimwiki starts here. Make sure everything below does not
-" cause autoload/vimwiki/base.vim to be loaded
-
-call vimwiki#vars#init()
-
-
-" Define callback functions which the user can redefine
-if !exists("*VimwikiLinkHandler")
- function VimwikiLinkHandler(url)
- return 0
- endfunction
-endif
-
-if !exists("*VimwikiLinkConverter")
- function VimwikiLinkConverter(url, source, target)
- " Return the empty string when unable to process link
- return ''
- endfunction
-endif
-
-if !exists("*VimwikiWikiIncludeHandler")
- function! VimwikiWikiIncludeHandler(value)
- return ''
- endfunction
-endif
-
-
-
-" Define autocommands for all known wiki extensions
-
-let s:known_extensions = s:vimwiki_get_known_extensions()
-
-if index(s:known_extensions, '.wiki') > -1
- augroup filetypedetect
- " clear FlexWiki's stuff
- au! * *.wiki
- augroup end
-endif
-
-augroup vimwiki
- autocmd!
- autocmd ColorScheme * call s:setup_cleared_syntax()
- for s:ext in s:known_extensions
- exe 'autocmd BufNewFile,BufRead *'.s:ext.' call s:setup_new_wiki_buffer()'
- exe 'autocmd BufEnter *'.s:ext.' call s:setup_buffer_enter()'
- exe 'autocmd BufLeave *'.s:ext.' call s:setup_buffer_leave()'
- " Format tables when exit from insert mode. Do not use textwidth to
- " autowrap tables.
- if vimwiki#vars#get_global('table_auto_fmt')
- exe 'autocmd InsertLeave *'.s:ext.' call vimwiki#tbl#format(line("."))'
- exe 'autocmd InsertEnter *'.s:ext.' call vimwiki#tbl#reset_tw(line("."))'
- endif
- if vimwiki#vars#get_global('folding') =~? ':quick$'
- " from http://vim.wikia.com/wiki/Keep_folds_closed_while_inserting_text
- " Don't screw up folds when inserting text that might affect them, until
- " leaving insert mode. Foldmethod is local to the window. Protect against
- " screwing up folding when switching between windows.
- exe 'autocmd InsertEnter *'.s:ext.' if !exists("w:last_fdm") | let w:last_fdm=&foldmethod'.
- \ ' | setlocal foldmethod=manual | endif'
- exe 'autocmd InsertLeave,WinLeave *'.s:ext.' if exists("w:last_fdm") |'.
- \ 'let &l:foldmethod=w:last_fdm | unlet w:last_fdm | endif'
- endif
- endfor
-augroup END
-
-
-
-command! VimwikiUISelect call vimwiki#base#ui_select()
-" why not using <count> instead of v:count1?
-" See https://github.com/vimwiki-backup/vimwiki/issues/324
-command! -count=1 VimwikiIndex
- \ call vimwiki#base#goto_index(v:count1)
-command! -count=1 VimwikiTabIndex
- \ call vimwiki#base#goto_index(v:count1, 1)
-
-command! -count=1 VimwikiDiaryIndex
- \ call vimwiki#diary#goto_diary_index(v:count1)
-command! -count=1 VimwikiMakeDiaryNote
- \ call vimwiki#diary#make_note(v:count)
-command! -count=1 VimwikiTabMakeDiaryNote
- \ call vimwiki#diary#make_note(v:count, 1)
-command! -count=1 VimwikiMakeYesterdayDiaryNote
- \ call vimwiki#diary#make_note(v:count, 0,
- \ vimwiki#diary#diary_date_link(localtime() - 60*60*24))
-command! -count=1 VimwikiMakeTomorrowDiaryNote
- \ call vimwiki#diary#make_note(v:count, 0,
- \ vimwiki#diary#diary_date_link(localtime() + 60*60*24))
-
-command! VimwikiDiaryGenerateLinks
- \ call vimwiki#diary#generate_diary_section()
-
-command! VimwikiShowVersion call s:get_version()
-
-
-
-let s:map_prefix = vimwiki#vars#get_global('map_prefix')
-
-if !hasmapto('<Plug>VimwikiIndex')
- exe 'nmap <silent><unique> '.s:map_prefix.'w <Plug>VimwikiIndex'
-endif
-nnoremap <unique><script> <Plug>VimwikiIndex :VimwikiIndex<CR>
-
-if !hasmapto('<Plug>VimwikiTabIndex')
- exe 'nmap <silent><unique> '.s:map_prefix.'t <Plug>VimwikiTabIndex'
-endif
-nnoremap <unique><script> <Plug>VimwikiTabIndex :VimwikiTabIndex<CR>
-
-if !hasmapto('<Plug>VimwikiUISelect')
- exe 'nmap <silent><unique> '.s:map_prefix.'s <Plug>VimwikiUISelect'
-endif
-nnoremap <unique><script> <Plug>VimwikiUISelect :VimwikiUISelect<CR>
-
-if !hasmapto('<Plug>VimwikiDiaryIndex')
- exe 'nmap <silent><unique> '.s:map_prefix.'i <Plug>VimwikiDiaryIndex'
-endif
-nnoremap <unique><script> <Plug>VimwikiDiaryIndex :VimwikiDiaryIndex<CR>
-
-if !hasmapto('<Plug>VimwikiDiaryGenerateLinks')
- exe 'nmap <silent><unique> '.s:map_prefix.'<Leader>i <Plug>VimwikiDiaryGenerateLinks'
-endif
-nnoremap <unique><script> <Plug>VimwikiDiaryGenerateLinks :VimwikiDiaryGenerateLinks<CR>
-
-if !hasmapto('<Plug>VimwikiMakeDiaryNote')
- exe 'nmap <silent><unique> '.s:map_prefix.'<Leader>w <Plug>VimwikiMakeDiaryNote'
-endif
-nnoremap <unique><script> <Plug>VimwikiMakeDiaryNote :VimwikiMakeDiaryNote<CR>
-
-if !hasmapto('<Plug>VimwikiTabMakeDiaryNote')
- exe 'nmap <silent><unique> '.s:map_prefix.'<Leader>t <Plug>VimwikiTabMakeDiaryNote'
-endif
-nnoremap <unique><script> <Plug>VimwikiTabMakeDiaryNote
- \ :VimwikiTabMakeDiaryNote<CR>
-
-if !hasmapto('<Plug>VimwikiMakeYesterdayDiaryNote')
- exe 'nmap <silent><unique> '.s:map_prefix.'<Leader>y <Plug>VimwikiMakeYesterdayDiaryNote'
-endif
-nnoremap <unique><script> <Plug>VimwikiMakeYesterdayDiaryNote
- \ :VimwikiMakeYesterdayDiaryNote<CR>
-
-if !hasmapto('<Plug>VimwikiMakeTomorrowDiaryNote')
- exe 'nmap <silent><unique> '.s:map_prefix.'<Leader>m <Plug>VimwikiMakeTomorrowDiaryNote'
-endif
-nnoremap <unique><script> <Plug>VimwikiMakeTomorrowDiaryNote
- \ :VimwikiMakeTomorrowDiaryNote<CR>
-
-
-
-
-function! s:build_menu(topmenu)
- for idx in range(vimwiki#vars#number_of_wikis())
- let norm_path = fnamemodify(vimwiki#vars#get_wikilocal('path', idx), ':h:t')
- let norm_path = escape(norm_path, '\ \.')
- execute 'menu '.a:topmenu.'.Open\ index.'.norm_path.
- \ ' :call vimwiki#base#goto_index('.(idx+1).')<CR>'
- execute 'menu '.a:topmenu.'.Open/Create\ diary\ note.'.norm_path.
- \ ' :call vimwiki#diary#make_note('.(idx+1).')<CR>'
- endfor
-endfunction
-
-function! s:build_table_menu(topmenu)
- exe 'menu '.a:topmenu.'.-Sep- :'
- exe 'menu '.a:topmenu.'.Table.Create\ (enter\ cols\ rows) :VimwikiTable '
- exe 'nmenu '.a:topmenu.'.Table.Format<tab>gqq gqq'
- exe 'nmenu '.a:topmenu.'.Table.Move\ column\ left<tab><A-Left> :VimwikiTableMoveColumnLeft<CR>'
- exe 'nmenu '.a:topmenu.
- \ '.Table.Move\ column\ right<tab><A-Right> :VimwikiTableMoveColumnRight<CR>'
- exe 'nmenu disable '.a:topmenu.'.Table'
-endfunction
-
-
-if !empty(vimwiki#vars#get_global('menu'))
- call s:build_menu(vimwiki#vars#get_global('menu'))
- call s:build_table_menu(vimwiki#vars#get_global('menu'))
-endif
-
-
-" Hook for calendar.vim
-if vimwiki#vars#get_global('use_calendar')
- let g:calendar_action = 'vimwiki#diary#calendar_action'
- let g:calendar_sign = 'vimwiki#diary#calendar_sign'
-endif
-
-
-let &cpo = s:old_cpo
diff --git a/.config/sxhkd/sxhkdrc b/.config/sxhkd/sxhkdrc
@@ -1,5 +1,5 @@
-super + {shift, ctrl, alt} + v
- dinput "Are you sure?" "{sudo zzz, sudo halt, sudo reboot}"
+super + {shift, ctrl, alt, shift + ctrl, shift + alt} + v
+ dinput "Are you sure?" "{sudo zzz, sudo halt, sudo reboot, sudo ZZZ, pkill dwm}"
super + Return
st
@@ -17,7 +17,7 @@ super + ctrl + b
queuevid
super + c
- st -e slock_mod /tmp/mpv-socket /tmp/mpv-socket2
+ st -e slock_mod /tmp/mpv-socket /tmp/mpv-socket2 /tmp/mpv-socket3
super + d
dmenu_run
@@ -52,6 +52,12 @@ super + alt + w
super + shift + w
colour-wall
+super + ctrl + t
+ chradio
+
+super + akt + t
+ hmpv quit /tmp/mpv-socket3
+
super + ctrl + y
dmpv general/videos/ /tmp/mpv-socket2 /tmp/mpv-socket --fs fuzz
diff --git a/.config/zsh/alias.zsh b/.config/zsh/alias.zsh
@@ -54,10 +54,11 @@ alias irc-us.oscss.eu=" ssh -p 222 hayden@140.82.11.69"
alias freebsd.oscss=" ssh -p 22122 hayden@freebsd.oscss.eu"
alias sdf=" ssh haydenh@tty.sdf.org"
alias localserve=" ssh void@192.168.1.20"
+alias sfeed_curses=" sfeed_update $XDG_CONFIG_HOME/sfeed/config && SFEED_PLUMBER=urlhand2 \sfeed_curses $XDG_CACHE_HOME/sfeed/*"
alias irc=" ssh -p 15551 hayden@77.68.91.186"
alias vps2=" ssh -p 15552 hayden@vps2.haydenvh.com"
alias dd=" echo PLEASE TRIPLE CHECK, THEN RUN ddd"
-alias ddd=" dd"
+alias ddd=" \dd"
alias diff=" colordiff"
alias ~d=" cd ~/general/downloads; ls"
alias ~do=" cd ~/general/documents; ls"
diff --git a/.scripts/bin/dmenu/chradio b/.scripts/bin/dmenu/chradio
@@ -0,0 +1,6 @@
+#!/bin/sh
+
+station=$(echo "http://relay4.slayradio.org:8000/
+http://bitreich.org:3232/live" | dmenu -i -p "Station? ")
+
+mpv --input-ipc-server=/tmp/mpv-socket3 $station
diff --git a/.scripts/bin/dmenu/chrtmp b/.scripts/bin/dmenu/chrtmp
@@ -0,0 +1,5 @@
+#!/bin/sh
+
+station=$(echo "rtmp://flatearth.nop.ninja/live/saturday-night" | dmenu -i -p "Stream? ")
+
+mpv --input-ipc-server=/tmp/mpv-socket3 $station
diff --git a/.scripts/bin/genman/hvol b/.scripts/bin/genman/hvol
@@ -1,12 +1,4 @@
-#!/bin/bash
-if [ "$1" = "toggle" ]
-then
- amixer set Master $1
- volume=$(amixer sget Master | awk '/Mono/ {print $6}' | sed 's/\[//g' | sed 's/\]//g')
- volume=$(echo $volume | sed -ne 's/.*/Volume set to &/p')
-else
- amixer set Master $1
- volume=$(amixer sget Master | awk '/Mono/ {print $4}' | sed 's/\[//g' | sed 's/\]//g')
-fi
+#!/bin/sh
+amixer set Master $1
$HOME/.scripts/dwmblocks/vol > /tmp/blocks/vol
diff --git a/.scripts/bin/genman/slock_mod b/.scripts/bin/genman/slock_mod
@@ -1,6 +1,7 @@
#!/bin/bash
socket1="$1"
socket2="$2"
+socket3="$3"
echo "dmpv/rmpv: $(hmpv state $socket1)" > ~/.cache/socket
echo "dmpvurl: $(hmpv state $socket2)" >> ~/.cache/socket
@@ -8,17 +9,13 @@ echo "dmpvurl: $(hmpv state $socket2)" >> ~/.cache/socket
hmpv pause $socket1
sleep 0.2
hmpv pause $socket2
- sleep 0.2
- hmpv pause $socket2
- sleep 0.2
- hmpv pause $socket2
+ hvol toggle
) &
-bat=$(head -n 1 < $HOME/.cache/blocks/bat | perl -pe 's/\^.*?\^//g;s/^\[B //g;s/\]$//g;s/$/ /g;s/ /% /g' | head -n 1)
-weather=$(head -n 1 < $HOME/.cache/blocks/weather | perl -pe 's/\^.*?\^//g;s/^\[//g;s/\]$//g' | head -n 1)
-slock -m "$(echo -e "Locked at $(date) | $USER@$hostname\nBatteries (time of screen-locking) | $bat\nWeather | $weather" | tr -s ' ')"
+slock -m "$(echo "Locked at $(date) | $USER@$hostname" | tr -s ' ')"
state=$(cat ~/.cache/socket | awk '/:/')
state1=$(echo "$state" | head -n -1 | awk '{print $2}')
state2=$(echo "$state" | tail +2 | awk '{print $2}')
[ "$state1" = "playing" ] && hmpv unpause $socket1
[ "$state2" = "playing" ] && hmpv unpause $socket2
+hvol toggle
diff --git a/.scripts/bin/misc/filesed b/.scripts/bin/misc/filesed
@@ -0,0 +1,11 @@
+#!/bin/sh
+
+[ -z $1 ] && echo "usage: <sed exp> <file> ..."
+
+sedexp="$1"
+shift
+
+for file in $@
+do
+ mv "$file" "$(echo "$file" | sed "$sedexp")"
+done
diff --git a/.scripts/bin/misc/mpvms b/.scripts/bin/misc/mpvms
@@ -0,0 +1,8 @@
+#!/bin/sh
+
+[ "$1" = "video" ] && {
+ shift
+ mpv --input-ipc-server=/tmp/mpv-socket2 $@
+} || {
+ mpv --input-ipc-server=/tmp/mpv-socket --no-video $@
+}
diff --git a/.scripts/bin/misc/number b/.scripts/bin/misc/number
@@ -0,0 +1,5 @@
+#!/bin/sh
+
+[ -z $1 ] && echo "usage: number <number> <file>" && exit
+
+mv "$2" "$1.-.$2"
diff --git a/.scripts/bin/misc/remind b/.scripts/bin/misc/remind
@@ -12,21 +12,39 @@ usage(){
echo "usage: remind $(tput bold)ARGS$(tput sgr0)
ARGS:
- -a DATE::STRING - add STRING as reminder for DATE (follows \`date +%d%%%m%%%y\` format)
- -n - print number of reminders for today
- -e - print reminders for today
- -r - clear today's reminders
- -d DATE - get reminders for DATE (follows \`date +%d%%%m%%%y\` format)"
+$(echo " -a DATE||STRING - add STRING as reminder for DATE (follows \`date +%d/%m/%y\` format)
+ -a DATE|TIME|STRING - add STRING as a reminder for DATE (\`date +%d/%m/%y|%H:%M\` format), will create a popup using ${EDITOR:-st} (requires \`at\`, and it's respective daemon running)
+ -n - print number of reminders for today
+ -e - print reminders for today
+ -r - clear today's reminders
+ -d DATE - get reminders for DATE (follows \`date +%d/%m/%y\` format)" | column -t -s "$(printf "\t")")"
exit 1
}
add(){
- fdate=$(echo "$1" | grep -o '.*::' | sed 's/::$//g')
- string=$(echo "$1" | grep -o '::.*' | sed 's/^:://g')
+ echo "$1" | grep '^[0-9/%]*|[0-9:]*|' > /dev/null && {
+ pdate=${1%%|*} && fdate=$(echo "$pdate" | tr '/' '%')
+ ftime=${1#*|} && ftime=${ftime%%|*}
+ string=${1#*|*|}
- mkdir $cache/remind/$fdate -p
- num=$(ls $cache/remind/$fdate | wc -l)
- echo "$string" >> $cache/remind/$fdate/$num && echo 'reminder set' || echo 'failed to set reminder'
+ mkdir $cache/remind/$fdate -p
+ num=$(ls $cache/remind/$fdate | wc -l)
+ echo "$string" >> $cache/remind/$fdate/$num || {
+ echo 'failed to set reminder (writing to file failed)'
+ exit 1
+ }
+ echo "${EDITOR:-st} -e sh -c 'cat \"$cache/remind/$fdate/$num\" /dev/stdin'" | at "$ftime $(echo "$pdate" | tr '/' '.')" && echo "reminder set" || {
+ echo 'failed to set reminder (`at` failed)'
+ exit 1
+ }
+ } || {
+ fdate=${1%%||*}
+ string=${1#*||}
+
+ mkdir $cache/remind/$fdate -p
+ num=$(ls $cache/remind/$fdate | wc -l)
+ echo "$string" >> $cache/remind/$fdate/$num && echo 'reminder set' || echo 'failed to set reminder'
+ }
}
num(){
diff --git a/.scripts/bin/misc/urlhand b/.scripts/bin/misc/urlhand
@@ -4,7 +4,8 @@ link=$(grep -Eo '[A-Za-z][A-Za-z]*://\S*' < /dev/stdin 2>/dev/null | awk '{print
IFS=$'\n'
-hand=$(printf "mpv
+hand=$(printf "mpvms video
+mpvms
popupmpv
youtube-dl --add-metadata -ic
youtube-dl --add-metadata -xic
diff --git a/.scripts/bin/misc/urlhand2 b/.scripts/bin/misc/urlhand2
@@ -0,0 +1,19 @@
+#!/bin/bash
+
+hand=$(printf "mpvms video
+mpvms
+popupmpv
+youtube-dl --add-metadata -ic
+youtube-dl --add-metadata -xic
+vimb --no-maximize
+toxclip
+netimg
+netvid
+popupcurl
+popupcgo" | dmenu -i -p "Select a handler:")
+
+pkill mpvlisten
+hmpv pause /tmp/mpv-socket
+hmpv pause /tmp/mpv-socket2
+sh -c "$hand $1"
+mpvlisten /tmp/mpv-socket2 /tmp/mpv-socket &
diff --git a/.scripts/dwmblocks/news b/.scripts/dwmblocks/news
@@ -1,15 +0,0 @@
-#!/bin/bash
-#
-# dwmblocks/news
-# Created by Hayden Hamilton
-#
-# haydenvh.com
-# Copyright (c) 2019 Hayden Hamilton.
-
-newsboat -x reload 2>/dev/null && {
- rss=$(newsboat -x print-unread | sed 's/ unread articles//g')
- rssbnb=$(srssbnbc -n)
- echo "[NWS $(($rss + $rssbnb))]"
- echo
- echo \#498364
-}
diff --git a/.scripts/dwmblocks/rem b/.scripts/dwmblocks/rem
@@ -1,6 +1,6 @@
#!/bin/sh
rem=$(remind -n)
-[ "$rem" = "0" ] && exit 1
+[ "$rem" = "0" ] && rm /tmp/blocks/rem /tmp/dwmblocks/rem && exit 1
echo "[Reminders: ^c#892b2b^$rem!!]"
echo
echo \#000000
diff --git a/.scripts/dwmblocks/vol b/.scripts/dwmblocks/vol
@@ -1,4 +1,4 @@
-#!/bin/bash
+#!/bin/sh
#
# dwmblocks/vol
# Created by Hayden Hamilton
@@ -6,9 +6,9 @@
# haydenvh.com
# Copyright (c) 2019 Hayden Hamilton.
-toggled=$(amixer sget Master | awk '/Mono/ {print $6}' | sed 's/\[//g' | sed 's/\]//g')
-volume=$(amixer sget Master | awk '/Mono/ {print $4}' | sed 's/\[//g' | sed 's/\]//g')
-output=$(echo $(echo ${volume}|tr "\n" " ")$(echo ${toggled}|tr "\n" " "|sed 's/ //g'))
+toggled=$(amixer sget Master | awk '/Mono/ {print $6}' | tr -d '[]')
+volume=$(amixer sget Master | awk '/Mono/ {print $4}' | tr -d '[]')
+output=$(echo $(echo ${volume}|tr "\n" " ")$(echo ${toggled} | tr "\n" " " | sed 's/ //g'))
echo "[VOL $output]"
echo
echo \#218888