a
    lc                     @   st   d Z ddlZddlZddlZddlZddlZddlmZ ddlm	Z	m
Z
 dd Zdd Zd	d
 Zdd Zdd ZdS )zQ
Utilities for getting information about IPython and the system it's running in.
    N)release)_sysinfoencodingc                 C   sR   t jrdt jfS tjddtjtj| d}| \}}|rNd| dfS dS )a"  Get short form of commit hash given directory `pkg_path`

    We get the commit hash from (in order of preference):

    * IPython.utils._sysinfo.commit
    * git output, if we are in a git repository

    If these fail, we return a not-found placeholder tuple

    Parameters
    ----------
    pkg_path : str
        directory containing package
        only used for getting commit from active repo

    Returns
    -------
    hash_from : str
        Where we got the hash from - description
    hash_str : str
        short form of hash
    Zinstallationzgit rev-parse --short HEAD )stdoutstderrcwd
repositoryascii)z(none found)z<not found>)	r   commit
subprocessPopensplitPIPEcommunicatestripdecode)pkg_pathprocZrepo_commit_ r   Q/var/www/html/django/DPS/env/lib/python3.9/site-packages/IPython/utils/sysinfo.pypkg_commit_hash   s    
r   c                 C   s8   t | \}}ttj| ||tjtjtjt tjt	j
d
S )zReturn dict describing the context of this package

    Parameters
    ----------
    pkg_path : str
        path containing __init__.py for package

    Returns
    -------
    context : dict
        with named parameters of interest
    )
Zipython_versionZipython_pathZcommit_sourceZcommit_hashsys_versionsys_executablesys_platformplatformos_nameZdefault_encoding)r   dictr   versionsys
executabler   osnamer   DEFAULT_ENCODING)r   srcZhshr   r   r   pkg_infoD   s    r&   c               
   C   s,   t j} | | | | td}t|S )zBReturn useful information about IPython and the system, as a dict.z..)r"   pathrealpathdirnameabspathjoin__file__r&   )pr'   r   r   r   get_sys_info_   s    r.   c                   C   s   t t S )au  Return useful information about IPython and the system, as a string.

    Examples
    --------
    ::
    
        In [2]: print(sys_info())
        {'commit_hash': '144fdae',      # random
         'commit_source': 'repository',
         'ipython_path': '/home/fperez/usr/lib/python2.6/site-packages/IPython',
         'ipython_version': '0.11.dev',
         'os_name': 'posix',
         'platform': 'Linux-2.6.35-22-generic-i686-with-Ubuntu-10.10-maverick',
         'sys_executable': '/usr/bin/python',
         'sys_platform': 'linux2',
         'sys_version': '2.6.6 (r266:84292, Sep 15 2010, 15:52:39) \n[GCC 4.4.5]'}
    )pprintpformatr.   r   r   r   r   sys_infoe   s    r1   c                  C   s$   ddl } | jdtdd t p"dS )a  DEPRECATED

    Return the effective number of CPUs in the system as an integer.

    This cross-platform function makes an attempt at finding the total number of
    available CPUs in the system, as returned by various underlying system and
    python calls.

    If it can't find a sensible answer, it returns 1 (though an error *may* make
    it return a large positive number that's actually incorrect).
    r   NzG`num_cpus` is deprecated since IPython 8.0. Use `os.cpu_count` instead.   )
stacklevel   )warningswarnDeprecationWarningr"   	cpu_count)r5   r   r   r   num_cpusz   s    r9   )__doc__r"   r   r/   r    r   IPython.corer   IPython.utilsr   r   r   r&   r.   r1   r9   r   r   r   r   <module>   s   &