diff options
Diffstat (limited to '')
| -rw-r--r-- | README.md | 10 | ||||
| -rw-r--r-- | autoload/vim_ai.vim | 41 | ||||
| -rw-r--r-- | autoload/vim_ai_config.vim | 3 | ||||
| -rw-r--r-- | doc/vim-ai.txt | 3 |
4 files changed, 46 insertions, 11 deletions
@@ -186,6 +186,8 @@ Below are listed all available configuration options, along with their default v ```vim " :AI " - options: openai config (see https://platform.openai.com/docs/api-reference/completions) +" - options.request_timout: request timeout in seconds +" - options.selection_boundary: seleciton prompt wrapper (eliminates empty responses, see #20) " - engine: complete | chat - see how to configure chat engine in the section below let g:vim_ai_complete = { \ "engine": "complete", @@ -194,11 +196,14 @@ let g:vim_ai_complete = { \ "max_tokens": 1000, \ "temperature": 0.1, \ "request_timeout": 20, +\ "selection_boundary": "#####", \ }, \} " :AIEdit " - options: openai config (see https://platform.openai.com/docs/api-reference/completions) +" - options.request_timout: request timeout in seconds +" - options.selection_boundary: seleciton prompt wrapper " - engine: complete | chat - see how to configure chat engine in the section below let g:vim_ai_edit = { \ "engine": "complete", @@ -207,6 +212,7 @@ let g:vim_ai_edit = { \ "max_tokens": 1000, \ "temperature": 0.1, \ "request_timeout": 20, +\ "selection_boundary": "#####", \ }, \} @@ -221,6 +227,8 @@ END " :AIChat " - options: openai config (see https://platform.openai.com/docs/api-reference/chat) " - options.initial_prompt: prompt prepended to every chat request +" - options.request_timout: request timeout in seconds +" - options.selection_boundary: seleciton prompt wrapper " - ui.populate_options: put [chat-options] to the chat header " - ui.open_chat_command: customize how to open chat window " - ui.scratch_buffer_keep_open: re-use scratch buffer within the vim session @@ -230,6 +238,7 @@ let g:vim_ai_chat = { \ "max_tokens": 1000, \ "temperature": 1, \ "request_timeout": 20, +\ "selection_boundary": "", \ "initial_prompt": s:initial_chat_prompt, \ }, \ "ui": { @@ -271,6 +280,7 @@ let chat_engine_config = { \ "max_tokens": 1000, \ "temperature": 0.1, \ "request_timeout": 20, +\ "selection_boundary": "", \ "initial_prompt": initial_prompt, \ }, \} diff --git a/autoload/vim_ai.vim b/autoload/vim_ai.vim index d1c27a9..69a0f95 100644 --- a/autoload/vim_ai.vim +++ b/autoload/vim_ai.vim @@ -44,25 +44,42 @@ function! vim_ai#MakeScratchWindow() endif endfunction -function! s:MakePrompt(is_selection, lines, instruction) +function! s:MakeSelectionPrompt(is_selection, lines, instruction, options) + let l:selection = "" + if a:instruction == "" + let l:selection = a:lines + elseif a:is_selection + let l:boundary = a: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 + else + let l:selection = a:lines + endif + endif + return l:selection +endfunction + +function! s:MakePrompt(is_selection, lines, instruction, options) 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 = a:is_selection || l:instruction == "" ? l:lines : "" + let l:selection = s:MakeSelectionPrompt(a:is_selection, l:lines, l:instruction, a:options) 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'] + 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) + let l:prompt = s:MakePrompt(a:is_selection, l:lines, l:instruction, l:options) let s:last_command = "complete" let s:last_instruction = l:instruction let s:last_is_selection = a:is_selection - let l:engine = g:vim_ai_complete['engine'] - let l:options = g:vim_ai_complete['options'] let l:cursor_on_empty_line = trim(join(l:lines, "\n")) == "" set paste if l:cursor_on_empty_line @@ -76,15 +93,16 @@ function! vim_ai#AIRun(is_selection, ...) range endfunction function! vim_ai#AIEditRun(is_selection, ...) range + let l:engine = g:vim_ai_edit['engine'] + let l:options = g:vim_ai_edit['options'] + let l:instruction = a:0 ? a:1 : "" - let l:prompt = s:MakePrompt(a:is_selection, getline(a:firstline, a:lastline), l:instruction) + let l:prompt = s:MakePrompt(a:is_selection, getline(a:firstline, a:lastline), l:instruction, l:options) let s:last_command = "edit" let s:last_instruction = l:instruction let s:last_is_selection = a:is_selection - let l:engine = g:vim_ai_edit['engine'] - let l:options = g:vim_ai_edit['options'] set paste execute "normal! " . a:firstline . "GV" . a:lastline . "Gc" execute "py3file " . s:complete_py @@ -92,6 +110,9 @@ function! vim_ai#AIEditRun(is_selection, ...) range endfunction function! vim_ai#AIChatRun(is_selection, ...) range + let l:options = g:vim_ai_chat['options'] + let l:ui = g:vim_ai_chat['ui'] + let l:instruction = "" let l:lines = getline(a:firstline, a:lastline) set paste @@ -101,7 +122,7 @@ 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) + let l:prompt = s:MakePrompt(a:is_selection, l:lines, l:instruction, l:options) endif execute "normal! Gi" . l:prompt endif @@ -110,8 +131,6 @@ function! vim_ai#AIChatRun(is_selection, ...) range let s:last_instruction = l:instruction let s:last_is_selection = a:is_selection - let l:options = g:vim_ai_chat['options'] - let l:ui = g:vim_ai_chat['ui'] execute "py3file " . s:chat_py set nopaste endfunction diff --git a/autoload/vim_ai_config.vim b/autoload/vim_ai_config.vim index 92d791a..409070b 100644 --- a/autoload/vim_ai_config.vim +++ b/autoload/vim_ai_config.vim @@ -5,6 +5,7 @@ let g:vim_ai_complete_default = { \ "max_tokens": 1000, \ "temperature": 0.1, \ "request_timeout": 20, +\ "selection_boundary": "#####", \ }, \} let g:vim_ai_edit_default = { @@ -14,6 +15,7 @@ let g:vim_ai_edit_default = { \ "max_tokens": 1000, \ "temperature": 0.1, \ "request_timeout": 20, +\ "selection_boundary": "#####", \ }, \} @@ -29,6 +31,7 @@ let g:vim_ai_chat_default = { \ "max_tokens": 1000, \ "temperature": 1, \ "request_timeout": 20, +\ "selection_boundary": "", \ "initial_prompt": s:initial_chat_prompt, \ }, \ "ui": { diff --git a/doc/vim-ai.txt b/doc/vim-ai.txt index 37d7add..5cc0718 100644 --- a/doc/vim-ai.txt +++ b/doc/vim-ai.txt @@ -28,6 +28,7 @@ Options: > \ "max_tokens": 1000, \ "temperature": 0.1, \ "request_timeout": 20, + \ "selection_boundary": "#####", \ }, \} @@ -48,6 +49,7 @@ Options: > \ "max_tokens": 1000, \ "temperature": 0.1, \ "request_timeout": 20, + \ "selection_boundary": "#####", \ }, \} @@ -75,6 +77,7 @@ Options: > \ "max_tokens": 1000, \ "temperature": 1, \ "request_timeout": 20, + \ "selection_boundary": "#####", \ "initial_prompt": s:initial_chat_prompt, \ }, \ "ui": { |