mirror of
https://github.com/BerriAI/litellm.git
synced 2025-04-26 11:14:04 +00:00
Merge pull request #9261 from briandevvn/fix_ollama_pt
Fix "system" role has become unacceptable in ollama
This commit is contained in:
commit
59fd58643b
2 changed files with 36 additions and 0 deletions
|
@ -219,6 +219,31 @@ def ollama_pt(
|
|||
if user_content_str:
|
||||
prompt += f"### User:\n{user_content_str}\n\n"
|
||||
|
||||
system_content_str = ""
|
||||
## MERGE CONSECUTIVE SYSTEM CONTENT ##
|
||||
while (
|
||||
msg_i < len(messages) and messages[msg_i]["role"] == "system"
|
||||
):
|
||||
msg_content = messages[msg_i].get("content")
|
||||
if msg_content:
|
||||
if isinstance(msg_content, list):
|
||||
for m in msg_content:
|
||||
if m.get("type", "") == "image_url":
|
||||
if isinstance(m["image_url"], str):
|
||||
images.append(m["image_url"])
|
||||
elif isinstance(m["image_url"], dict):
|
||||
images.append(m["image_url"]["url"])
|
||||
elif m.get("type", "") == "text":
|
||||
system_content_str += m["text"]
|
||||
else:
|
||||
# Tool message content will always be a string
|
||||
system_content_str += msg_content
|
||||
|
||||
msg_i += 1
|
||||
|
||||
if system_content_str:
|
||||
prompt += f"### System:\n{system_content_str}\n\n"
|
||||
|
||||
assistant_content_str = ""
|
||||
## MERGE CONSECUTIVE ASSISTANT CONTENT ##
|
||||
while msg_i < len(messages) and messages[msg_i]["role"] == "assistant":
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue