llmir 0.0.10__tar.gz → 0.0.12__tar.gz
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- {llmir-0.0.10 → llmir-0.0.12}/PKG-INFO +1 -1
- {llmir-0.0.10 → llmir-0.0.12}/llmir/adapter/openai.py +39 -16
- {llmir-0.0.10 → llmir-0.0.12}/llmir.egg-info/PKG-INFO +1 -1
- {llmir-0.0.10 → llmir-0.0.12}/pyproject.toml +1 -1
- {llmir-0.0.10 → llmir-0.0.12}/README.md +0 -0
- {llmir-0.0.10 → llmir-0.0.12}/llmir/__init__.py +0 -0
- {llmir-0.0.10 → llmir-0.0.12}/llmir/adapter/__init__.py +0 -0
- {llmir-0.0.10 → llmir-0.0.12}/llmir/chunks.py +0 -0
- {llmir-0.0.10 → llmir-0.0.12}/llmir/messages.py +0 -0
- {llmir-0.0.10 → llmir-0.0.12}/llmir/py.typed +0 -0
- {llmir-0.0.10 → llmir-0.0.12}/llmir/rich_repr.py +0 -0
- {llmir-0.0.10 → llmir-0.0.12}/llmir/roles.py +0 -0
- {llmir-0.0.10 → llmir-0.0.12}/llmir/tools.py +0 -0
- {llmir-0.0.10 → llmir-0.0.12}/llmir.egg-info/SOURCES.txt +0 -0
- {llmir-0.0.10 → llmir-0.0.12}/llmir.egg-info/dependency_links.txt +0 -0
- {llmir-0.0.10 → llmir-0.0.12}/llmir.egg-info/requires.txt +0 -0
- {llmir-0.0.10 → llmir-0.0.12}/llmir.egg-info/top_level.txt +0 -0
- {llmir-0.0.10 → llmir-0.0.12}/setup.cfg +0 -0
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
from typing import TypedDict, Literal, Required
|
|
2
2
|
|
|
3
|
-
from ..messages import AIMessages, AIMessageToolResponse
|
|
3
|
+
from ..messages import AIMessages, AIMessageToolResponse, AIRoles
|
|
4
4
|
from ..chunks import AIChunkText, AIChunkImageURL, AIChunkFile, AIChunkToolCall
|
|
5
5
|
import base64
|
|
6
6
|
import json
|
|
@@ -33,7 +33,7 @@ OpenAIContents = OpenAIText | OpenAIImageURL
|
|
|
33
33
|
|
|
34
34
|
|
|
35
35
|
class OpenAIMessage(TypedDict, total=False):
|
|
36
|
-
role: Required[
|
|
36
|
+
role: Required[Literal["system", "user", "assistant"]]
|
|
37
37
|
content: list[OpenAIContents]
|
|
38
38
|
tool_calls: list[OpenAIToolCall]
|
|
39
39
|
|
|
@@ -81,21 +81,44 @@ def to_openai(messages: list[AIMessages]) -> list[OpenAIMessages]:
|
|
|
81
81
|
)
|
|
82
82
|
)
|
|
83
83
|
else:
|
|
84
|
-
|
|
85
|
-
|
|
84
|
+
|
|
85
|
+
assert(role != "tool")
|
|
86
|
+
content_chunks: list[AIChunkText | AIChunkFile | AIChunkImageURL] = []
|
|
87
|
+
tool_call_chunks: list[AIChunkToolCall] = []
|
|
88
|
+
|
|
89
|
+
media_chunks: list[AIChunkFile | AIChunkImageURL] = []
|
|
90
|
+
|
|
91
|
+
for chunk in message.chunks:
|
|
92
|
+
|
|
93
|
+
if isinstance(chunk, AIChunkToolCall):
|
|
94
|
+
tool_call_chunks.append(chunk)
|
|
95
|
+
|
|
96
|
+
elif role != AIRoles.USER and not isinstance(chunk, AIChunkText):
|
|
97
|
+
media_chunks.append(chunk)
|
|
98
|
+
|
|
99
|
+
else:
|
|
100
|
+
content_chunks.append(chunk)
|
|
101
|
+
|
|
102
|
+
|
|
103
|
+
if content_chunks or tool_call_chunks:
|
|
104
|
+
formatted = OpenAIMessage(
|
|
105
|
+
role=role
|
|
106
|
+
)
|
|
107
|
+
if content_chunks:
|
|
108
|
+
formatted["content"] = [content_chunk_to_openai(c) for c in content_chunks]
|
|
109
|
+
if tool_call_chunks:
|
|
110
|
+
formatted["tool_calls"] = [tool_call_chunk_to_openai(c) for c in tool_call_chunks]
|
|
111
|
+
|
|
112
|
+
result.append(formatted)
|
|
113
|
+
|
|
114
|
+
if media_chunks:
|
|
115
|
+
result.append(OpenAIMessage(
|
|
116
|
+
role="user", # Hacky too, but what else to circumvent API limitations in a broadly compatible way?
|
|
117
|
+
content=[
|
|
118
|
+
content_chunk_to_openai(c) for c in media_chunks
|
|
119
|
+
]
|
|
120
|
+
)
|
|
86
121
|
)
|
|
87
|
-
content: list[OpenAIContents] = [
|
|
88
|
-
content_chunk_to_openai(chunk) for chunk in message.chunks if not isinstance(chunk, AIChunkToolCall)
|
|
89
|
-
]
|
|
90
|
-
tool_calls: list[OpenAIToolCall] = [
|
|
91
|
-
tool_call_chunk_to_openai(chunk) for chunk in message.chunks if isinstance(chunk, AIChunkToolCall)
|
|
92
|
-
]
|
|
93
|
-
if content:
|
|
94
|
-
formatted["content"] = content
|
|
95
|
-
if tool_calls:
|
|
96
|
-
formatted["tool_calls"] = tool_calls
|
|
97
|
-
|
|
98
|
-
result.append(formatted)
|
|
99
122
|
|
|
100
123
|
return result
|
|
101
124
|
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|