File: //lib/python3/dist-packages/requests_toolbelt/downloadutils/__pycache__/tee.cpython-310.pyc
o
�ˀX
� @ sN d Z ddlZdZg d�Zdd� Zedfdd�Zedfd d
�Zedfdd�ZdS )
zTee function implementations.� Ni )�tee�tee_to_file�tee_to_bytearrayc c s* � | j j||d�D ] }||� |V q d S )N)�amt�decode_content)�raw�stream)�response�callback� chunksizer �chunk� r
�E/usr/lib/python3/dist-packages/requests_toolbelt/downloadutils/tee.py�_tee s �
��r c C s4 dt |dd�v st|tj�std��t| |j||�S )a" Stream the response both to the generator and a file.
This will stream the response body while writing the bytes to
``fileobject``.
Example usage:
.. code-block:: python
resp = requests.get(url, stream=True)
with open('save_file', 'wb') as save_file:
for chunk in tee(resp, save_file):
# do stuff with chunk
.. code-block:: python
import io
resp = requests.get(url, stream=True)
fileobject = io.BytesIO()
for chunk in tee(resp, fileobject):
# do stuff with chunk
:param response: Response from requests.
:type response: requests.Response
:param fileobject: Writable file-like object.
:type fileobject: file, io.BytesIO
:param int chunksize: (optional), Size of chunk to attempt to stream.
:param bool decode_content: (optional), If True, this will decode the
compressed content of the response.
:raises: TypeError if the fileobject wasn't opened with the right mode
or isn't a BytesIO object.
�b�mode� z�tee() will write bytes directly to this fileobject, it must be opened with the "b" flag if it is a file or inherit from io.BytesIO.)�getattr�
isinstance�io�BytesIO� TypeErrorr �write)r �
fileobjectr r r
r
r r s
(
�r c c sL � t |d��}t| |||�D ]}|V qW d � dS 1 sw Y dS )a� Stream the response both to the generator and a file.
This will open a file named ``filename`` and stream the response body
while writing the bytes to the opened file object.
Example usage:
.. code-block:: python
resp = requests.get(url, stream=True)
for chunk in tee_to_file(resp, 'save_file'):
# do stuff with chunk
:param response: Response from requests.
:type response: requests.Response
:param str filename: Name of file in which we write the response content.
:param int chunksize: (optional), Size of chunk to attempt to stream.
:param bool decode_content: (optional), If True, this will decode the
compressed content of the response.
�wbN)�openr )r �filenamer r �fdr r
r
r r A s ��"�r c C s"