o
    Zh                     @   s   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	 ddl
mZmZ dedeeef fdd	Zdedefd
dZdefddZdefddZdd ZdS )zQ
Utilities for getting information about IPython and the system it's running in.
    N)Path)release)_sysinfoencodingpkg_pathreturnc                 C   sR   t jrdt jfS tjddtjtj| d}| \}}|r'd| 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)r   procZrepo_commit_ r   L/var/www/html/lang_env/lib/python3.10/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_versionZsys_executablesys_platformplatformos_nameZdefault_encoding)r   dictr   versionsys
executabler   osnamer   ZDEFAULT_ENCODING)r   srcZhshr   r   r   pkg_infoF   s   r&   c                  C   s   t td j} tt| S )zBReturn useful information about IPython and the system, as a dict.z..)r   __file__resolveparentr&   str)pathr   r   r   get_sys_infoa   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_infof   s   r/   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)r3   r   r   r   num_cpus{   s   r7   )__doc__r#   r   r-   r!   r   pathlibr   ZIPython.corer   ZIPython.utilsr   r   r*   tupler   r   r&   r,   r/   r7   r   r   r   r   <module>   s   &