mirror of
				https://github.com/kovidgoyal/calibre.git
				synced 2025-10-25 15:52:25 -04:00 
			
		
		
		
	DRYer
This commit is contained in:
		
							parent
							
								
									817f936a56
								
							
						
					
					
						commit
						3b036b4853
					
				| @ -127,13 +127,13 @@ def as_chat_responses(d: dict[str, Any], model: Model) -> Iterator[ChatResponse] | |||||||
|             type=ChatMessageType.assistant, reasoning=reasoning, content=content, has_metadata=has_metadata, model=model.id, plugin_name=OllamaAI.name) |             type=ChatMessageType.assistant, reasoning=reasoning, content=content, has_metadata=has_metadata, model=model.id, plugin_name=OllamaAI.name) | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| def read_streaming_response(rq: Request, provider_name: str = 'AI provider') -> Iterator[dict[str, Any]]: | def read_streaming_response(rq: Request) -> Iterator[dict[str, Any]]: | ||||||
|     with opener().open(rq) as response: |     with opener().open(rq) as response: | ||||||
|         if response.status != http.HTTPStatus.OK: |         if response.status != http.HTTPStatus.OK: | ||||||
|             details = '' |             details = '' | ||||||
|             with suppress(Exception): |             with suppress(Exception): | ||||||
|                 details = response.read().decode('utf-8', 'replace') |                 details = response.read().decode('utf-8', 'replace') | ||||||
|             raise Exception(f'Reading from {provider_name} failed with HTTP response status: {response.status} and body: {details}') |             raise Exception(f'Reading from {OllamaAI.name} failed with HTTP response status: {response.status} and body: {details}') | ||||||
|         for raw_line in response: |         for raw_line in response: | ||||||
|             yield json.loads(raw_line) |             yield json.loads(raw_line) | ||||||
| 
 | 
 | ||||||
| @ -150,7 +150,7 @@ def text_chat_implementation(messages: Iterable[ChatMessage], use_model: str = ' | |||||||
|         'messages': [for_assistant(m) for m in messages], |         'messages': [for_assistant(m) for m in messages], | ||||||
|     } |     } | ||||||
|     rq = chat_request(data, model) |     rq = chat_request(data, model) | ||||||
|     for datum in read_streaming_response(rq, OllamaAI.name): |     for datum in read_streaming_response(rq): | ||||||
|         for res in as_chat_responses(datum, model): |         for res in as_chat_responses(datum, model): | ||||||
|             yield res |             yield res | ||||||
|             if res.exception: |             if res.exception: | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user