diff options
| author | Martin Bielik <mx.bielik@gmail.com> | 2024-01-25 23:18:15 +0100 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2024-01-25 23:18:15 +0100 |
| commit | 819c1bb3c79080128a076aff03b16cfc1f4548c7 (patch) | |
| tree | 457b7c81b511b42ece0704e03b673702a6786d0e /py/utils.py | |
| parent | 4692eec84b5aa9d95256bef515bd1d17471e5570 (diff) | |
| parent | 9e6f8e8d037a477c55939ece36ab7b000f876e85 (diff) | |
| download | vim-ai-819c1bb3c79080128a076aff03b16cfc1f4548c7.tar.gz | |
Merge pull request #74 from jkoelker/include
feat(chat): add `include` role to include files
Diffstat (limited to 'py/utils.py')
| -rw-r--r-- | py/utils.py | 36 |
1 files changed, 36 insertions, 0 deletions
diff --git a/py/utils.py b/py/utils.py index d04b18d..a5c489f 100644 --- a/py/utils.py +++ b/py/utils.py @@ -1,5 +1,6 @@ import vim import datetime +import glob import sys import os import json @@ -103,6 +104,7 @@ def render_text_chunks(chunks, is_selection): if not full_text.strip(): print_info_message('Empty response received. Tip: You can try modifying the prompt and retry.') + def parse_chat_messages(chat_content): lines = chat_content.splitlines() messages = [] @@ -113,6 +115,9 @@ def parse_chat_messages(chat_content): if line.startswith(">>> user"): messages.append({"role": "user", "content": ""}) continue + if line.startswith(">>> include"): + messages.append({"role": "include", "content": ""}) + continue if line.startswith("<<< assistant"): messages.append({"role": "assistant", "content": ""}) continue @@ -124,6 +129,37 @@ def parse_chat_messages(chat_content): # strip newlines from the content as it causes empty responses message["content"] = message["content"].strip() + if message["role"] == "include": + message["role"] = "user" + paths = message["content"].split("\n") + message["content"] = "" + + pwd = vim.eval("getcwd()") + for i in range(len(paths)): + path = os.path.expanduser(paths[i]) + if not os.path.isabs(path): + path = os.path.join(pwd, path) + + paths[i] = path + + if '**' in path: + paths[i] = None + paths.extend(glob.glob(path, recursive=True)) + + for path in paths: + if path is None: + continue + + if os.path.isdir(path): + continue + + try: + with open(path, "r") as file: + message["content"] += f"\n\n==> {path} <==\n" + file.read() + except UnicodeDecodeError: + message["content"] += "\n\n" + f"==> {path} <==" + message["content"] += "\n" + "Binary file, cannot display" + return messages def parse_chat_header_options(): |