a Ra@sddlZddlZddlmZddlmZddlmZddlm Z ej drZddlm Z ne d d d Z Gd d d e ZeeedddZd gZdS)N) ConfigParser)Path)Optional)PlatformDirsABCZlinux)getuidreturncCs tddS)Nzshould only be used on Linux) RuntimeErrorr r N/opt/alt/python39/lib/python3.9/site-packages/pip/_vendor/platformdirs/unix.pyr src@seZdZdZeedddZeedddZeeddd Zeedd d Z eedd d Z eedddZ eedddZ eedddZ eedddZeedddZeedddZeedddZeedddZdS) UnixaD On Unix/Linux, we follow the `XDG Basedir Spec `_. 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 `, `version `, `multipath `, `opinion `. rcCs,tjdd}|s"tjd}||S)z :return: data directory tied to the user, e.g. ``~/.local/share/$appname/$version`` or ``$XDG_DATA_HOME/$appname/$version`` Z XDG_DATA_HOMEz~/.local/shareosenvirongetstrippath expanduser_append_app_name_and_versionselfrr r r user_data_dirs zUnix.user_data_dircCs.tjdd}|s$dtjd}||S)aY :return: data directories shared by users (if `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)rrrrpathsep_with_multi_pathrr r r site_data_dir(szUnix.site_data_dir)rr cs<|tj}js|dd}fdd|D}tj|S)Nrrcsg|]}tj|qSr )rrrr).0prr r 9z)Unix._with_multi_path..)splitrr multipathjoin)rr path_listr rr r5s   zUnix._with_multi_pathcCs,tjdd}|s"tjd}||S)z :return: config directory tied to the user, e.g. ``~/.config/$appname/$version`` or ``$XDG_CONFIG_HOME/$appname/$version`` ZXDG_CONFIG_HOMErz ~/.configrrr r r user_config_dir<s zUnix.user_config_dircCs$tjdd}|sd}||S)a/ :return: config directories shared by users (if `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)rrrrrrr r r site_config_dirGszUnix.site_config_dircCs,tjdd}|s"tjd}||S)z :return: cache directory tied to the user, e.g. ``~/.cache/$appname/$version`` or ``~/$XDG_CACHE_HOME/$appname/$version`` ZXDG_CACHE_HOMErz~/.cacherrr r r user_cache_dirTs zUnix.user_cache_dircCs,tjdd}|s"tjd}||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/staterrr r r 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$rr r r user_log_dirjszUnix.user_log_dircCs6td}|dur2tjdd}|s2tjd}|S)zU :return: documents directory tied to the user, e.g. ``~/Documents`` ZXDG_DOCUMENTS_DIRNrz ~/Documents)_get_user_dirs_folderrrrrrr)rZ documents_dirr r r user_documents_dirts  zUnix.user_documents_dircCs,tjdd}|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/)rrrrrrrr r r user_runtime_dirs zUnix.user_runtime_dircCs ||jS)zd:return: data path shared by users. Only return first item, even if ``multipath`` is set to ``True``) _first_item_as_path_if_multipathrrr r r site_data_pathszUnix.site_data_pathcCs ||jS)zj:return: config path shared by the users. Only return first item, even if ``multipath`` is set to ``True``)r/r'rr r r site_config_pathszUnix.site_config_path) directoryr cCs|jr|tjd}t|S)Nr)r#r"rrr)rr2r r r r/sz%Unix._first_item_as_path_if_multipathN)__name__ __module__ __qualname____doc__propertystrrrrr&r'r(r)r+r-r.rr0r1r/r r r r r s2          r )keyr cCstjtjd}tj|rt}t|$}|d| Wdn1sV0Y||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] Ntop"z$HOME~) rrr$r r&existsropenZ read_stringreadrreplacer)r9Zuser_dirs_config_pathparserstreamrr r r r,s  2 r,)rsysZ configparserrpathlibrtypingrZapirplatform startswithrintr r8r,__all__r r r r s