o
    Ďi                     @   sX   d dl mZ d dlmZ edg dZG dd deZdd Zdd	 ZG d
d dZdS )    )
namedtuple)import_moduleServiceContext)service_nameservice_modelservice_waiter_modelresource_json_definitionsc                   @   s   e Zd ZdZdS )r   a   Provides important service-wide, read-only information about a service

    :type service_name: str
    :param service_name: The name of the service

    :type service_model: :py:class:`botocore.model.ServiceModel`
    :param service_model: The model of the service.

    :type service_waiter_model: :py:class:`botocore.waiter.WaiterModel` or
        a waiter model-like object such as
        :py:class:`boto3.utils.LazyLoadedWaiterModel`
    :param service_waiter_model: The waiter model of the service.

    :type resource_json_definitions: dict
    :param resource_json_definitions: The loaded json models of all resource
        shapes for a service. It is equivalient of loading a
        ``resource-1.json`` and retrieving the value at the key "resources".
    N)__name__
__module____qualname____doc__ r   r   G/home/jeff/fluffinator/venv/lib/python3.10/site-packages/boto3/utils.pyr      s    c                    s   | fdd}|S )Nc                     s6     dd\}}t|}|  t||di | S )N.   r   )rsplitr   updategetattr)kwargsmodulefunction_name	full_nameparent_kwargsr   r   _handler5   s   
zlazy_call.<locals>._handlerr   )r   r   r   r   r   r   	lazy_call2   s   r   c                 C   s$   || v rt d| d|| |< d S )NzCannot inject class attribute "z*", attribute already exists in class dict.)RuntimeError)class_attributesnamevaluer   r   r   inject_attribute>   s
   
r    c                   @   s    e Zd ZdZdd Zdd ZdS )LazyLoadedWaiterModelat  A lazily loaded waiter model

    This does not load the service waiter model until an attempt is made
    to retrieve the waiter model for a specific waiter. This is helpful
    in docstring generation where we do not need to actually need to grab
    the waiter-2.json until it is accessed through a ``get_waiter`` call
    when the docstring is generated/accessed.
    c                 C   s   || _ || _|| _d S N)_session_service_name_api_version)self
bc_sessionr   api_versionr   r   r   __init__R   s   
zLazyLoadedWaiterModel.__init__c                 C   s   | j | j| j|S r"   )r#   get_waiter_modelr$   r%   
get_waiter)r&   waiter_namer   r   r   r+   W   s
   z LazyLoadedWaiterModel.get_waiterN)r	   r
   r   r   r)   r+   r   r   r   r   r!   H   s    	r!   N)	collectionsr   	importlibr   _ServiceContextr   r   r    r!   r   r   r   r   <module>   s   
