Current File : //lib/python3.9/site-packages/pip/_vendor/platformdirs/__pycache__/unix.cpython-39.pyc
a

[��f��@s�ddlZddlZddlmZddlmZddlmZddlm	Z	ej
�d�rZddlmZne
d	�d
d�ZGdd
�d
e	�Zeeed�dd�Zd
gZdS)�N)�ConfigParser)�Path)�Optional�)�PlatformDirsABCZlinux)�getuid��returncCstd��dS)Nzshould only be used on Linux)�RuntimeError�rr�A/usr/lib/python3.9/site-packages/pip/_vendor/platformdirs/unix.pyr
src@s�eZdZdZeed�dd��Zeed�dd��Zeed�dd	�Zeed�d
d��Z	eed�dd
��Z
eed�dd��Zeed�dd��Zeed�dd��Z
eed�dd��Zeed�dd��Zeed�dd��Zeed�dd��Zeed�dd�ZdS) �UnixaD
    On Unix/Linux, we follow the
    `XDG Basedir Spec <https://specifications.freedesktop.org/basedir-spec/basedir-spec-latest.html>`_. The spec allows
    overriding directories with environment variables. The examples show are the default values, alongside the name of
    the environment variable that overrides them. Makes use of the
    `appname <platformdirs.api.PlatformDirsABC.appname>`,
    `version <platformdirs.api.PlatformDirsABC.version>`,
    `multipath <platformdirs.api.PlatformDirsABC.multipath>`,
    `opinion <platformdirs.api.PlatformDirsABC.opinion>`.
    rcCs,tj�dd�}|��s"tj�d�}|�|�S)z�
        :return: data directory tied to the user, e.g. ``~/.local/share/$appname/$version`` or
         ``$XDG_DATA_HOME/$appname/$version``
        Z
XDG_DATA_HOME�z~/.local/share��os�environ�get�strip�path�
expanduser�_append_app_name_and_version��selfrrrr�
user_data_dirszUnix.user_data_dircCs.tj�dd�}|��s$dtj�d�}|�|�S)aY
        :return: data directories shared by users (if `multipath <platformdirs.api.PlatformDirsABC.multipath>` is
         enabled and ``XDG_DATA_DIR`` is set and a multi path the response is also a multi path separated by the OS
         path separator), e.g. ``/usr/local/share/$appname/$version`` or ``/usr/share/$appname/$version``
        Z
XDG_DATA_DIRSrz/usr/local/sharez
/usr/share)rrrr�pathsep�_with_multi_pathrrrr�
site_data_dir(szUnix.site_data_dir)rr	cs<|�tj�}�js|dd�}�fdd�|D�}tj�|�S)Nrrcsg|]}��tj�|���qSr)rrrr)�.0�p�rrr�
<listcomp>9�z)Unix._with_multi_path.<locals>.<listcomp>)�splitrr�	multipath�join)rr�	path_listrrrr5s
zUnix._with_multi_pathcCs,tj�dd�}|��s"tj�d�}|�|�S)z�
        :return: config directory tied to the user, e.g. ``~/.config/$appname/$version`` or
         ``$XDG_CONFIG_HOME/$appname/$version``
        ZXDG_CONFIG_HOMErz	~/.configrrrrr�user_config_dir<szUnix.user_config_dircCs$tj�dd�}|��sd}|�|�S)a/
        :return: config directories shared by users (if `multipath <platformdirs.api.PlatformDirsABC.multipath>`
         is enabled and ``XDG_DATA_DIR`` is set and a multi path the response is also a multi path separated by the OS
         path separator), e.g. ``/etc/xdg/$appname/$version``
        ZXDG_CONFIG_DIRSrz/etc/xdg)rrrrrrrrr�site_config_dirGszUnix.site_config_dircCs,tj�dd�}|��s"tj�d�}|�|�S)z�
        :return: cache directory tied to the user, e.g. ``~/.cache/$appname/$version`` or
         ``~/$XDG_CACHE_HOME/$appname/$version``
        ZXDG_CACHE_HOMErz~/.cacherrrrr�user_cache_dirTszUnix.user_cache_dircCs,tj�dd�}|��s"tj�d�}|�|�S)z�
        :return: state directory tied to the user, e.g. ``~/.local/state/$appname/$version`` or
         ``$XDG_STATE_HOME/$appname/$version``
        ZXDG_STATE_HOMErz~/.local/staterrrrr�user_state_dir_szUnix.user_state_dircCs|j}|jrtj�|d�}|S)zx
        :return: log directory tied to the user, same as `user_data_dir` if not opinionated else ``log`` in it
        �log)r(Zopinionrrr$rrrr�user_log_dirjszUnix.user_log_dircCs6td�}|dur2tj�dd���}|s2tj�d�}|S)zU
        :return: documents directory tied to the user, e.g. ``~/Documents``
        ZXDG_DOCUMENTS_DIRNrz~/Documents)�_get_user_dirs_folderrrrrrr)rZ
documents_dirrrr�user_documents_dirtszUnix.user_documents_dircCs,tj�dd�}|��s"dt���}|�|�S)z�
        :return: runtime directory tied to the user, e.g. ``/run/user/$(id -u)/$appname/$version`` or
         ``$XDG_RUNTIME_DIR/$appname/$version``
        ZXDG_RUNTIME_DIRrz
/run/user/)rrrrrrrrrr�user_runtime_dir�szUnix.user_runtime_dircCs|�|j�S)zd:return: data path shared by users. Only return first item, even if ``multipath`` is set to ``True``)� _first_item_as_path_if_multipathrrrrr�site_data_path�szUnix.site_data_pathcCs|�|j�S)zj:return: config path shared by the users. Only return first item, even if ``multipath`` is set to ``True``)r/r'rrrr�site_config_path�szUnix.site_config_path)�	directoryr	cCs|jr|�tj�d}t|�S)Nr)r#r"rrr)rr2rrrr/�sz%Unix._first_item_as_path_if_multipathN)�__name__�
__module__�__qualname__�__doc__�property�strrrrr&r'r(r)r+r-r.rr0r1r/rrrrr
s2



	
r
)�keyr	cCs�tj�t�jd�}tj�|�r�t�}t|��$}|�d|�	����Wd�n1sV0Y||dvrpdS|d|�
d�}|�dtj�d��}|SdS)zjReturn directory from user-dirs.dirs config file. See https://freedesktop.org/wiki/Software/xdg-user-dirs/zuser-dirs.dirsz[top]
N�top�"z$HOME�~)
rrr$r
r&�existsr�openZread_string�readr�replacer)r9Zuser_dirs_config_path�parser�streamrrrrr,�s
2r,)r�sysZconfigparserr�pathlibr�typingrZapir�platform�
startswithr�intr
r8r,�__all__rrrr�<module>s
�