summaryrefslogtreecommitdiff
path: root/uvim/runtime/autoload/vimcomplete.vim
diff options
context:
space:
mode:
authorMehmet Samet Duman <yongdohyun@projecttick.org>2026-04-03 22:21:25 +0300
committerMehmet Samet Duman <yongdohyun@projecttick.org>2026-04-04 00:23:03 +0300
commit2eae5db069dc171f74cd863487655f6a88e5384d (patch)
tree2d9d05e09978a2a44acbfbb8d651f240df3ca052 /uvim/runtime/autoload/vimcomplete.vim
parent473d922faed49241a5d29d9e37dc4819cd512006 (diff)
downloadProject-Tick-2eae5db069dc171f74cd863487655f6a88e5384d.tar.gz
Project-Tick-2eae5db069dc171f74cd863487655f6a88e5384d.zip
NOISSUE rebrand vim to MNV's not Vim
Signed-off-by: Mehmet Samet Duman <yongdohyun@projecttick.org>
Diffstat (limited to 'uvim/runtime/autoload/vimcomplete.vim')
-rw-r--r--uvim/runtime/autoload/vimcomplete.vim96
1 files changed, 0 insertions, 96 deletions
diff --git a/uvim/runtime/autoload/vimcomplete.vim b/uvim/runtime/autoload/vimcomplete.vim
deleted file mode 100644
index d95c8b1caa..0000000000
--- a/uvim/runtime/autoload/vimcomplete.vim
+++ /dev/null
@@ -1,96 +0,0 @@
-vim9script
-
-# Vim completion script
-# Language: Vim script
-# Maintainer: Maxim Kim <habamax@gmail.com>
-# Last Change: 2025-10-15
-#
-# Usage:
-# setlocal omnifunc=vimcomplete#Complete
-#
-# Simple complete function for Vim script
-
-var trigger: string = ""
-var prefix: string = ""
-
-
-def GetTrigger(line: string): list<any>
- var result = ""
- var result_len = 0
-
- if line =~ '->\k*$'
- result = 'function'
- elseif line =~ '\v%(^|\s+)\&\k*$'
- result = 'option'
- elseif line =~ '\vse%[t]\s+(\k+\s+)*no\k*$'
- result = 'nooption'
- result_len = -2
- elseif line =~ '[\[(]\s*$'
- result = 'expression'
- elseif line =~ '[lvgsb]:\k*$'
- result = 'var'
- result_len = 2
- elseif line !~ '^\s*$'
- result = getcompletiontype(line) ?? 'cmdline'
- endif
- return [result, result_len]
-enddef
-
-export def Complete(findstart: number, base: string): any
- if findstart > 0
- prefix = ""
- var line = getline('.')->strpart(0, col('.') - 1)
- var keyword = line->matchstr('\k\+$')
- var stx = synstack(line('.'), col('.') - 1)->map('synIDattr(v:val, "name")')->join()
- if stx =~? 'Comment' || (stx =~ 'String' && stx !~ 'vimStringInterpolationExpr')
- return -2
- endif
- var trigger_len: number = 0
- [trigger, trigger_len] = GetTrigger(line)
- if keyword->empty() && trigger->empty()
- return -2
- endif
- prefix = line
- return line->len() - keyword->len() - trigger_len
- endif
-
- var items = []
- if trigger == 'function'
- items = getcompletion(base, 'function')
- ->mapnew((_, v) => ({word: v, kind: 'v', menu: 'Function', dup: 0}))
- elseif trigger == 'option'
- items = getcompletion(base, 'option')
- ->mapnew((_, v) => ({word: v, kind: 'v', menu: 'Option', dup: 0}))
- elseif trigger == 'nooption'
- items = getcompletion(base[2 : ], 'option')
- ->mapnew((_, v) => ({word: v, kind: 'v', menu: 'Option', dup: 0}))
- elseif trigger == 'var'
- items = getcompletion(base, 'var')
- ->mapnew((_, v) => ({word: v, kind: 'v', menu: 'Variable', dup: 0}))
- elseif trigger == 'expression'
- items = getcompletion(base, 'expression')
- ->mapnew((_, v) => ({word: v, kind: 'v', menu: 'Expression', dup: 0}))
- elseif trigger == 'command'
- var commands = getcompletion(base, 'command')
- ->mapnew((_, v) => ({word: v, kind: 'v', menu: 'Command', dup: 0}))
- var functions = getcompletion(base, 'function')
- ->mapnew((_, v) => ({word: v, kind: 'v', menu: 'Function', dup: 0}))
- items = commands + functions
- else
- try
- # :! and :term completion is very slow on Windows and WSL, disable it there.
- if !((has("win32") || has("win32unix") || exists("$WSLENV")) && getcompletiontype(prefix) == 'shellcmd')
- items = getcompletion(prefix, 'cmdline')
- ->mapnew((_, v) => ({word: v->matchstr('\k\+'), kind: 'v', dup: 0}))
- endif
- catch /E220/
- endtry
-
- if empty(items) && !empty(base)
- items = getcompletion(base, 'expression')
- ->mapnew((_, v) => ({word: v, kind: 'v', menu: 'Expression', dup: 0}))
- endif
- endif
-
- return items->empty() ? v:none : items
-enddef