3
(h@                 @   s   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mZmZ G dd deZG d	d
 d
eeZG dd deZG dd deeZdS )    )unicode_literals)ImproperlyConfigured)models)Http404)ugettext)ContextMixinTemplateResponseMixinViewc                   s^   e Zd ZdZdZdZdZdZdZdZ	dZ
dddZdd	 Zd
d Zdd Z fddZ  ZS )SingleObjectMixinzT
    Provides the ability to retrieve a single object for further manipulation.
    NslugpkFc             C   s   |dkr| j  }| jj| j}| jj| j}|dk	r@|j|d}|dk	rn|dksV| jrn| j }|jf ||i}|dkr|dkrtd| j	j
 y|j }W n2 |jjk
r   ttdd|jjji Y nX |S )z
        Returns the object the view is displaying.

        By default this requires `self.queryset` and a `pk` or `slug` argument
        in the URLconf, but subclasses can override this to return any object.
        N)r   zIGeneric detail view %s must be called with either an object pk or a slug.z,No %(verbose_name)s found matching the queryverbose_name)get_querysetkwargsgetpk_url_kwargslug_url_kwargfilterquery_pk_and_slugget_slug_fieldAttributeError	__class____name__modelZDoesNotExistr   __metar   )selfquerysetr   r   
slug_fieldobj r    ?/tmp/pip-install-q3hcpn_q/Django/django/views/generic/detail.py
get_object   s$    	zSingleObjectMixin.get_objectc             C   s:   | j dkr0| jr| jjj S tdd| jji | j j S )z
        Return the `QuerySet` that will be used to look up the object.

        Note that this method is called by the default implementation of
        `get_object` and may not be called if `get_object` is overridden.
        Nzj%(cls)s is missing a QuerySet. Define %(cls)s.model, %(cls)s.queryset, or override %(cls)s.get_queryset().cls)r   r   Z_default_managerallr   r   r   )r   r    r    r!   r   ;   s    
zSingleObjectMixin.get_querysetc             C   s   | j S )zM
        Get the name of a slug field to be used to look up by slug.
        )r   )r   r    r    r!   r   O   s    z SingleObjectMixin.get_slug_fieldc             C   s(   | j r| j S t|tjr |jjS dS dS )z5
        Get the name to use for the object.
        N)context_object_name
isinstancer   Modelr   
model_name)r   r   r    r    r!   get_context_object_nameU   s
    z)SingleObjectMixin.get_context_object_namec                sJ   i }| j r.| j |d< | j| j }|r.| j ||< |j| tt| jf |S )zA
        Insert the single object into the context dict.
        object)r*   r)   updatesuperr
   get_context_data)r   r   contextr%   )r   r    r!   r-   `   s    


z"SingleObjectMixin.get_context_data)N)r   
__module____qualname____doc__r   r   r   r%   r   r   r   r"   r   r   r)   r-   __classcell__r    r    )r   r!   r
   
   s   
%r
   c               @   s   e Zd ZdZdd ZdS )BaseDetailViewz4
    A base view for displaying a single object
    c             O   s"   | j  | _| j| jd}| j|S )N)r*   )r"   r*   r-   Zrender_to_response)r   requestargsr   r.   r    r    r!   r   r   s    
zBaseDetailView.getN)r   r/   r0   r1   r   r    r    r    r!   r3   n   s   r3   c                   s$   e Zd ZdZdZ fddZ  ZS )!SingleObjectTemplateResponseMixinNZ_detailc                s   yt t| j }W n tk
r   g }| jrR| jrRt| j| jd}|rR|jd| t| jt	j
r| jj}|jd|j|j| jf  nDt| dr| jdk	rt| jt	j
r|jd| jjj| jjj| jf  |s΂ Y nX |S )a  
        Return a list of template names to be used for the request. May not be
        called if render_to_response is overridden. Returns the following list:

        * the value of ``template_name`` on the view (if provided)
        * the contents of the ``template_name_field`` field on the
          object instance that the view is operating upon (if available)
        * ``<app_label>/<model_name><template_name_suffix>.html``
        Nr   z%s/%s%s.htmlr   )r,   r6   get_template_namesr   r*   template_name_fieldgetattrinsertr&   r   r'   r   appendZ	app_labelr(   template_name_suffixhasattrr   
issubclass)r   namesnameZobject_meta)r   r    r!   r7   |   s,    
"z4SingleObjectTemplateResponseMixin.get_template_names)r   r/   r0   r8   r<   r7   r2   r    r    )r   r!   r6   x   s   r6   c               @   s   e Zd ZdZdS )
DetailViewz
    Render a "detail" view of an object.

    By default this is a model instance looked up from `self.queryset`, but the
    view will support display of *any* object by overriding `self.get_object()`.
    N)r   r/   r0   r1   r    r    r    r!   rA      s   rA   N)
__future__r   Zdjango.core.exceptionsr   Z	django.dbr   Zdjango.httpr   Zdjango.utils.translationr   r   Zdjango.views.generic.baser   r   r	   r
   r3   r6   rA   r    r    r    r!   <module>   s   d
5