diff options
| author | Martin Bielik <mx.bielik@gmail.com> | 2023-04-22 15:09:19 +0200 |
|---|---|---|
| committer | Martin Bielik <mx.bielik@gmail.com> | 2023-04-22 15:09:19 +0200 |
| commit | ad45ecff60461377788220da3b6f0ca8006f24cb (patch) | |
| tree | 7065468248af9ca8581fa6c0332763833ead88af /autoload | |
| parent | 26d55d99768b0eafdd379a00f0eeb5b7bf7e2dab (diff) | |
| download | vim-ai-ad45ecff60461377788220da3b6f0ca8006f24cb.tar.gz | |
pass config as a parameter
Diffstat (limited to 'autoload')
| -rw-r--r-- | autoload/vim_ai.vim | 43 | ||||
| -rw-r--r-- | autoload/vim_ai_config.vim | 6 |
2 files changed, 25 insertions, 24 deletions
diff --git a/autoload/vim_ai.vim b/autoload/vim_ai.vim index a4eb453..b058b54 100644 --- a/autoload/vim_ai.vim +++ b/autoload/vim_ai.vim @@ -8,6 +8,7 @@ let s:chat_py = s:plugin_root . "/py/chat.py" let s:last_is_selection = 0 let s:last_instruction = "" let s:last_command = "" +let s:last_config = {} let s:scratch_buffer_name = ">>> AI chat" @@ -44,12 +45,12 @@ function! vim_ai#MakeScratchWindow() endif endfunction -function! s:MakeSelectionPrompt(is_selection, lines, instruction, options) +function! s:MakeSelectionPrompt(is_selection, lines, instruction, config) let l:selection = "" if a:instruction == "" let l:selection = a:lines elseif a:is_selection - let l:boundary = a:options['selection_boundary'] + let l:boundary = a:config['options']['selection_boundary'] if l:boundary != "" && match(a:lines, l:boundary) == -1 " NOTE: surround selection with boundary (e.g. #####) in order to eliminate empty responses let l:selection = l:boundary . "\n" . a:lines . "\n" . l:boundary @@ -60,23 +61,23 @@ function! s:MakeSelectionPrompt(is_selection, lines, instruction, options) return l:selection endfunction -function! s:MakePrompt(is_selection, lines, instruction, options) +function! s:MakePrompt(is_selection, lines, instruction, config) let l:lines = trim(join(a:lines, "\n")) let l:instruction = trim(a:instruction) let l:delimiter = l:instruction != "" && a:is_selection ? ":\n" : "" - let l:selection = s:MakeSelectionPrompt(a:is_selection, l:lines, l:instruction, a:options) + let l:selection = s:MakeSelectionPrompt(a:is_selection, l:lines, l:instruction, a:config) return join([l:instruction, l:delimiter, l:selection], "") endfunction -function! vim_ai#AIRun(is_selection, ...) range - let l:engine = g:vim_ai_complete['engine'] - let l:options = g:vim_ai_complete['options'] +function! vim_ai#AIRun(is_selection, config, ...) range + let l:config = vim_ai_config#ExtendDeep(g:vim_ai_complete, a:config) let l:instruction = a:0 ? a:1 : "" let l:lines = getline(a:firstline, a:lastline) - let l:prompt = s:MakePrompt(a:is_selection, l:lines, l:instruction, l:options) + let l:prompt = s:MakePrompt(a:is_selection, l:lines, l:instruction, l:config) let s:last_command = "complete" + let s:last_config = a:config let s:last_instruction = l:instruction let s:last_is_selection = a:is_selection @@ -92,14 +93,14 @@ function! vim_ai#AIRun(is_selection, ...) range set nopaste endfunction -function! vim_ai#AIEditRun(is_selection, ...) range - let l:engine = g:vim_ai_edit['engine'] - let l:options = g:vim_ai_edit['options'] +function! vim_ai#AIEditRun(is_selection, config, ...) range + let l:config = vim_ai_config#ExtendDeep(g:vim_ai_edit, a:config) let l:instruction = a:0 ? a:1 : "" - let l:prompt = s:MakePrompt(a:is_selection, getline(a:firstline, a:lastline), l:instruction, l:options) + let l:prompt = s:MakePrompt(a:is_selection, getline(a:firstline, a:lastline), l:instruction, l:config) let s:last_command = "edit" + let s:last_config = a:config let s:last_instruction = l:instruction let s:last_is_selection = a:is_selection @@ -109,9 +110,8 @@ function! vim_ai#AIEditRun(is_selection, ...) range set nopaste endfunction -function! vim_ai#AIChatRun(is_selection, ...) range - let l:options = g:vim_ai_chat['options'] - let l:ui = g:vim_ai_chat['ui'] +function! vim_ai#AIChatRun(is_selection, config, ...) range + let l:config = vim_ai_config#ExtendDeep(g:vim_ai_chat, a:config) let l:instruction = "" let l:lines = getline(a:firstline, a:lastline) @@ -131,10 +131,11 @@ function! vim_ai#AIChatRun(is_selection, ...) range let l:prompt = "" if a:0 || a:is_selection let l:instruction = a:0 ? a:1 : "" - let l:prompt = s:MakePrompt(a:is_selection, l:lines, l:instruction, l:options) + let l:prompt = s:MakePrompt(a:is_selection, l:lines, l:instruction, l:config) endif let s:last_command = "chat" + let s:last_config = a:config let s:last_instruction = l:instruction let s:last_is_selection = a:is_selection @@ -146,20 +147,20 @@ function! vim_ai#AIRedoRun() execute "normal! u" if s:last_command == "complete" if s:last_is_selection - '<,'>call vim_ai#AIRun(s:last_is_selection, s:last_instruction) + '<,'>call vim_ai#AIRun(s:last_is_selection, s:last_config, s:last_instruction) else - call vim_ai#AIRun(s:last_is_selection, s:last_instruction) + call vim_ai#AIRun(s:last_is_selection, s:last_config, s:last_instruction) endif endif if s:last_command == "edit" if s:last_is_selection - '<,'>call vim_ai#AIEditRun(s:last_is_selection, s:last_instruction) + '<,'>call vim_ai#AIEditRun(s:last_is_selection, s:last_config, s:last_instruction) else - call vim_ai#AIEditRun(s:last_is_selection, s:last_instruction) + call vim_ai#AIEditRun(s:last_is_selection, s:last_config, s:last_instruction) endif endif if s:last_command == "chat" " chat does not need prompt, all information are in the buffer already - call vim_ai#AIChatRun(0) + call vim_ai#AIChatRun(0, s:last_config) endif endfunction diff --git a/autoload/vim_ai_config.vim b/autoload/vim_ai_config.vim index 409070b..3b182c0 100644 --- a/autoload/vim_ai_config.vim +++ b/autoload/vim_ai_config.vim @@ -50,11 +50,11 @@ if !exists("g:vim_ai_debug_log_file") let g:vim_ai_debug_log_file = "/tmp/vim_ai_debug.log" endif -function! s:ExtendDeep(defaults, override) abort +function! vim_ai_config#ExtendDeep(defaults, override) abort let l:result = a:defaults for [l:key, l:value] in items(a:override) if type(get(l:result, l:key)) is v:t_dict && type(l:value) is v:t_dict - call s:ExtendDeep(l:result[l:key], l:value) + call vim_ai_config#ExtendDeep(l:result[l:key], l:value) else let l:result[l:key] = l:value endif @@ -65,7 +65,7 @@ endfunction function! s:MakeConfig(config_name) abort let l:defaults = copy(g:[a:config_name . "_default"]) let l:override = exists("g:" . a:config_name) ? g:[a:config_name] : {} - let g:[a:config_name] = s:ExtendDeep(l:defaults, l:override) + let g:[a:config_name] = vim_ai_config#ExtendDeep(l:defaults, l:override) endfunction call s:MakeConfig("vim_ai_chat") |