diff options
| author | Martin Bielik <mx.bielik@gmail.com> | 2023-03-22 22:14:25 +0100 |
|---|---|---|
| committer | Martin Bielik <mx.bielik@gmail.com> | 2023-03-22 22:14:25 +0100 |
| commit | 08036fb76c437b705d916708d903c7c6c2eef0ba (patch) | |
| tree | f8d1c4f3f652c13c265d2f75e104f3b3907c4551 /py | |
| parent | 9b707d99b106c6535e476f00095053b470428bcc (diff) | |
| download | vim-ai-08036fb76c437b705d916708d903c7c6c2eef0ba.tar.gz | |
completion configuration
Diffstat (limited to 'py')
| -rw-r--r-- | py/chat.py | 15 | ||||
| -rw-r--r-- | py/complete.py | 11 | ||||
| -rw-r--r-- | py/utils.py | 9 |
3 files changed, 15 insertions, 20 deletions
@@ -4,11 +4,11 @@ import openai plugin_root = vim.eval("s:plugin_root") vim.command(f"py3file {plugin_root}/py/utils.py") -openai.api_key = load_api_key() - -options = vim.eval("options") +options = make_options() file_content = vim.eval('trim(join(getline(1, "$"), "\n"))') +openai.api_key = load_api_key() + lines = file_content.splitlines() messages = [] @@ -38,14 +38,7 @@ try: print('Answering...') vim.command("redraw") - response = openai.ChatCompletion.create( - messages=messages, - stream=True, - model=options['model'], - max_tokens=int(options['max_tokens']), - temperature=float(options['temperature']), - request_timeout=float(options['request_timeout']), - ) + response = openai.ChatCompletion.create(messages=messages, stream=True, **options) generating_text = False for resp in response: diff --git a/py/complete.py b/py/complete.py index f469592..f82707a 100644 --- a/py/complete.py +++ b/py/complete.py @@ -5,7 +5,7 @@ plugin_root = vim.eval("s:plugin_root") vim.command(f"py3file {plugin_root}/py/utils.py") prompt = vim.eval("prompt") -options = vim.eval("options") +options = make_options() openai.api_key = load_api_key() @@ -15,14 +15,7 @@ try: print('Completing...') vim.command("redraw") - response = openai.Completion.create( - stream=True, - prompt=prompt, - model=options['model'], - max_tokens=int(options['max_tokens']), - temperature=float(options['temperature']), - request_timeout=float(options['request_timeout']), - ) + response = openai.Completion.create(stream=True, prompt=prompt, **options) generating_text = False for resp in response: diff --git a/py/utils.py b/py/utils.py index c9e88f2..8366eec 100644 --- a/py/utils.py +++ b/py/utils.py @@ -10,3 +10,12 @@ def load_api_key(): except Exception: pass return api_key.strip() + +def make_options(): + options_default = vim.eval("options_default") + options_user = vim.eval("options") + options = {**options_default, **options_user} + options['request_timeout'] = float(options['request_timeout']) + options['temperature'] = float(options['temperature']) + options['max_tokens'] = int(options['max_tokens']) + return options |