
                             d dl mZ d dlmZ d dlmZ d dlmZ d dlmZ d dl	m
Z
 d dlmZ d dlmZ d d	lmZ d d
lmZ  G d de
      Z	 ddZ	 ddZy)    )
xform_name)OperationModel)get_service_module_name)document_model_driven_method)document_custom_method)BaseDocumenter)%document_model_driven_resource_method)get_resource_ignore_params)get_resource_public_actions)add_resource_type_overviewc                       e Zd Zd Zy)ActionDocumenterc           	         | j                   j                  }i }|D ]  }|||j                  <    t        | j                  j
                        }t        |      | j                  d<   t        |ddd       t        |      D ]  }|j                  |      }|dv r| j                   j                  rlt        ||| j                  | j                  j                  j                  j                  j                  | j                   j                  | j                          ||v rZt#        || j                  | j                  j                  j                  j                  j                  ||   | j                          t%        ||||           y )	NactionsActionszActions call operations on resources.  They may automatically handle the passing in of arguments set from identifiers and some attributes.actions_intro)sectionresource_typedescription
intro_link)loadreload)r   action_nameresource_nameevent_emitter
load_modelservice_model)r   r   r   action_modelr   )_resource_modelr   namer   	_resource	__class__sorted
member_mapr   add_new_sectionr   document_load_reload_action_resource_namemetaclientevents_service_modeldocument_actionr   )selfr   modeled_actions_listmodeled_actionsmodeled_actionresource_actionsr   action_sections           $lib/third_party/boto3/docs/action.pydocument_actionsz!ActionDocumenter.document_actions   sd   #33;;2N3AON//0 36NN$$&%+,<%=	""#8 '	( ""23K$44[AN00T5I5I5N5N+* +"&"5"5"&.."5"5"<"<"A"A"H"H#3388"&"5"5 /*"&"5"5"&.."5"5"<"<"A"A"H"H!0!="&"5"5 '"K1A+1NP) 4    N)__name__
__module____qualname__r4    r5   r3   r   r      s    &Pr5   r   c                    |j                  |j                  j                        }t        |j                  j                        }d}|j
                  rt        |j
                  j                        }t        |      }	|j                  |k(  r|}	|d|	d|j                  }
t        | |j                  |||j                  |
|||	       y)a  Documents a resource action

    :param section: The section to write to

    :param resource_name: The name of the resource

    :param event_emitter: The event emitter to use to emit events

    :param action_model: The model of the action

    :param service_model: The model of the service

    :param include_signature: Whether or not to include the signature.
        It is useful for generating docstrings.
    responsez = .)	r   method_nameoperation_modelr   method_descriptionexample_prefixexclude_inputresource_action_modelinclude_signatureN)r>   request	operationr
   paramsresourcer   typeservice_namer    r	   documentation)r   r   r   r   r   rC   r>   ignore_paramsexample_return_valueexample_resource_namer@   s              r3   r,   r,   D   s    " $33&&(O.|/C/C/J/JKM%),*?*?*D*DE&}5!!]2 -3\5F5FHN)\%6%6'#*88%#*+	r5   c           	          dt        |      dt        |j                  j                        d|d}t        |      }|j                  |k(  r|}|d|}	t        | |t        i |      |||	|       y)a  Documents the resource load action

    :param section: The section to write to

    :param action_name: The name of the loading action should be load or reload

    :param resource_name: The name of the resource

    :param event_emitter: The event emitter to use to emit events

    :param load_model: The model of the load action

    :param service_model: The model of the service

    :param include_signature: Whether or not to include the signature.
        It is useful for generating docstrings.
    zCalls  :py:meth:`z.Client.z"` to update the attributes of the ze resource. Note that the load and reload methods are the same method and can be used interchangeably.r<   )r   r=   r>   r   r?   r@   rC   N)r   r   rD   rE   rI   r   r   )
r   r   r   r   r   r   rC   r   rM   r@   s
             r3   r&   r&   m   s{    0 $M2z))334	  '}5!!]2 - 5{CN [&r=9#&%+r5   N)T)botocorer   botocore.modelr   botocore.utilsr   botocore.docs.methodr   r   boto3.docs.baser   boto3.docs.methodr	   boto3.docs.utilsr
   r   r   r   r,   r&   r9   r5   r3   <module>rV      sI      ) 2 = 7 * C 7 8 7'P~ 'PV 6:&V 37'r5   