summaryrefslogtreecommitdiff
path: root/py/chat.py
diff options
context:
space:
mode:
authorMartin Bielik <mx.bielik@gmail.com>2023-03-14 19:10:09 +0100
committerMartin Bielik <mx.bielik@gmail.com>2023-03-14 19:10:09 +0100
commit641ac91387da52197d31a0e6bc5a06e28281f0e1 (patch)
treef75cf68bb73eb26898f272b5550ea4a1774ced9d /py/chat.py
parent9545d08a879380d47901a7398c0c3aa6972933bf (diff)
downloadvim-ai-641ac91387da52197d31a0e6bc5a06e28281f0e1.tar.gz
ctrl c to cancel completion
Diffstat (limited to 'py/chat.py')
-rw-r--r--py/chat.py43
1 files changed, 24 insertions, 19 deletions
diff --git a/py/chat.py b/py/chat.py
index 066227b..551bfb8 100644
--- a/py/chat.py
+++ b/py/chat.py
@@ -29,24 +29,29 @@ if not messages:
file_content = ">>> user\n\n" + file_content
messages.append({"role": "user", "content": file_content })
-if messages[-1]["content"].strip():
-
- vim.command("normal! Go\n<<< assistant\n\n")
- vim.command("redraw")
-
- response = openai.ChatCompletion.create(
- model="gpt-3.5-turbo",
- messages=messages,
- stream=True,
- )
-
- generating_text = False
- for resp in response:
- text = resp['choices'][0]['delta'].get('content', '')
- if not text.strip() and not generating_text:
- continue # trim newlines from the beginning
- vim.command("normal! a" + text)
+try:
+ if messages[-1]["content"].strip():
+ vim.command("normal! Go\n<<< assistant\n\n")
vim.command("redraw")
- vim.command("normal! a\n\n>>> user\n\n")
- vim.command("redraw")
+ print('Answering...')
+ vim.command("redraw")
+
+ response = openai.ChatCompletion.create(
+ model="gpt-3.5-turbo",
+ messages=messages,
+ stream=True,
+ )
+
+ generating_text = False
+ for resp in response:
+ text = resp['choices'][0]['delta'].get('content', '')
+ if not text.strip() and not generating_text:
+ continue # trim newlines from the beginning
+ vim.command("normal! a" + text)
+ vim.command("redraw")
+
+ vim.command("normal! a\n\n>>> user\n\n")
+ vim.command("redraw")
+except KeyboardInterrupt:
+ vim.command("normal! a Ctrl-C...")