
    f<!                         d Z ddlZddl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ZdZ G d de      Zd Zy)ztsys.excepthook for IPython itself, leaves a detailed report on disk.

Authors:

* Fernando Perez
* Brian E. Granger
    N)pformat)Path)ultratb)author_email)sys_info)input)__version__)Optionala  Oops, {app_name} crashed. We do our best to make it stable, but...

A crash report was automatically generated with the following information:
  - A verbatim copy of the crash traceback.
  - A copy of your input history during this session.
  - Data on your current {app_name} configuration.

It was left in the file named:
	'{crash_report_fname}'
If you can email this file to the developers, the information in it will help
them in understanding and correcting the problem.

You can mail it to: {contact_name} at {contact_email}
with the subject '{app_name} Crash Report'.

If you want to do it now, the following command will work (under Unix):
mail -s '{app_name} Crash Report' {contact_email} < {crash_report_fname}

In your email, please also include information about:
- The operating system under which the crash happened: Linux, macOS, Windows,
  other, and which exact version (for example: Ubuntu 16.04.3, macOS 10.13.2,
  Windows 10 Pro), and whether it is 32-bit or 64-bit;
- How {app_name} was installed: using pip or conda, from GitHub, as part of
  a Docker container, or other, providing more detail if possible;
- How to reproduce the crash: what exact sequence of instructions can one
  input to get the same crash? Ideally, find a minimal yet complete sequence
  of instructions that yields the crash.

To ensure accurate tracking of this issue, please file a report about it at:
{bug_tracker}
a  
If you suspect this is an IPython {version} bug, please report it at:
    https://github.com/ipython/ipython/issues
or send an email to the mailing list at {email}

You can print a more detailed traceback right now with "%tb", or use "%debug"
to interactively debug it.

Extra-detailed tracebacks for bug-reporting purposes can be enabled via:
    {config}Application.verbose_crash=True
c                   ^    e Zd ZdZeZdZ	 	 	 	 	 ddee   dee   dee   de	de	f
d	Z
d
 Zd Zy)CrashHandlerzCustomizable crash handlers for IPython applications.

    Instances of this class provide a :meth:`__call__` method which can be
    used as a ``sys.excepthook``.  The :meth:`__call__` signature is::

        def __call__(self, etype, evalue, etb)
    zO

***************************************************************************

Ncontact_namecontact_emailbug_trackershow_crash_tracebackcall_pdbc                     d|j                   z  | _        || _        || _        || _        t        |j                   |||| j                        | _        y)a  Create a new crash handler

        Parameters
        ----------
        app : Application
            A running :class:`Application` instance, which will be queried at
            crash time for internal information.
        contact_name : str
            A string with the name of the person to contact.
        contact_email : str
            A string with the email address of the contact.
        bug_tracker : str
            A string with the URL for your project's bug tracker.
        show_crash_traceback : bool
            If false, don't print the crash traceback on stderr, only generate
            the on-disk report
        call_pdb
            Whether to call pdb on crash

        Attributes
        ----------
        These instances contain some non-argument attributes which allow for
        further customization of the crash handler's behavior. Please see the
        source for further details.

        zCrash_report_%s.txt)app_namer   r   r   crash_report_fnameN)namer   appr   r   dictinfo)selfr   r   r   r   r   r   s          T/var/www/cvtools/html/venv/lib/python3.12/site-packages/IPython/core/crashhandler.py__init__zCrashHandler.__init__c   sQ    F #8#(("B $8!CHH#/$1"-)-)@)@	B	    c                    t         j                  t         _        d}	 | j                  j                  }|t        j                  |      st        j                         }|| j                  z  }|| _        || j                  d<   t        j                  |d| j                        }| j                  r ||||       y|j                  |||d      }| j                  rt        |t         j                          	 t#        |d	d
      }	|	5  t        dt         j                          t         | j$                  j&                  di | j                  t         j                          |	j)                  | j+                  |             ddd       t-        d       y#  t        j                         }Y ~xY w#  t        dt         j                          Y yxY w# 1 sw Y   SxY w)z<Handle an exception, call for compatible with sys.excepthookNoColorNr      )color_schemelong_headerr      )contextfilewzutf-8)encodingz&Could not create crash report on disk.zH
**********************************************************************
z.Hit <Enter> to quit (your terminal may close): )sys__excepthook__
excepthookr   ipython_dirr   cwdis_dirr   r   r   	VerboseTBr   textr   printstderropenmessage_templateformatwritemake_reportr   )
r   etypeevalueetbr    rptdirreport_name	TBhandler	tracebackreports
             r   __call__zCrashHandler.__call__   s    ++ !	 XX))F >V!4XXZFt666 #.*5		&'%%%]]
	
 ==eF3'!uVCCI $$)#**-	+sW=F
  	6"4.$''..;;#**M LL)))45	6 	>?O	 XXZF4	:L	6 	6s$   F 9F4 	A;GF14GGc                 >   | j                   }dg}|j                  } |t                      	 t        | j                  j
                        } ||        |d| j                  z          |d        ||        ||dz   |z          dj                  |      S #  Y #xY w)z*Return a string containing a crash report.zi***************************************************************************

IPython post-mortem report

zApplication name: %s

z'Current user configuration structure:

zCrash traceback:

 )section_sepappendr   r   r   configr   join)r   r>   sec_sepr?   rpt_addrE   s         r   r7   zCrashHandler.make_report   s     ""@A--
	TXX__-FG.>??@FO 	..:;wwv		s   AB B)NNNTF)__name__
__module____qualname____doc___default_message_templater4   rC   r
   strboolr   r@   r7   r(   r   r   r   r   W   s{     1&K
 '+'+%)%),B sm,B  }	,B
 c],B #,B ,B^6@pr   r   c                     t        j                  | ||       ddlm} |j	                         rd}nd}t        t        j                  t        |t              t        j                         y)zAa light excepthook, adding a small message to the usual tracebackr   )InteractiveShellz%config zc.)emailrE   versionr$   N)r>   print_exceptionIPython.core.interactiveshellrQ   initializedr1   _lite_message_templater5   r   rS   r)   r2   )r8   r9   tbrQ   rE   s        r   crash_handler_literY      sT    eVR0>##% 	
 
'
'l6SZ
'
[beblblmr   )rL   r)   r>   pprintr   pathlibr   IPython.corer   IPython.core.releaser   IPython.utils.sysinfor   IPython.utils.py3compatr   r	   rS   typingr
   rM   rW   objectr   rY   r(   r   r   <module>rb      sP   (       - * ) 7  B
 F6 FRnr   