o
    Zh5#                     @  s   d Z ddlm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lmZ G dd	 d	eZedd
dddZedd
dddZedd
dddZedd
dddZedd
dddZedd
dddZd	gZdS )zAndroid.    )annotationsN)	lru_cache)TYPE_CHECKINGcast   )PlatformDirsABCc                   @  s   e Zd ZdZed%ddZed%ddZed%dd	Zed%d
dZed%ddZ	ed%ddZ
ed%ddZed%ddZed%ddZed%ddZed%ddZed%ddZed%ddZed%ddZed%d d!Zed%d"d#Zd$S )&Androida"  
    Follows the guidance `from here <https://android.stackexchange.com/a/216132>`_.

    Makes use of the `appname <platformdirs.api.PlatformDirsABC.appname>`, `version
    <platformdirs.api.PlatformDirsABC.version>`, `ensure_exists <platformdirs.api.PlatformDirsABC.ensure_exists>`.

    returnstrc                 C     |  tdt dS )zd:return: data directory tied to the user, e.g. ``/data/user/<userid>/<packagename>/files/<AppName>``r
   files_append_app_name_and_versionr   _android_folderself r   O/var/www/auris/lib/python3.10/site-packages/pip/_vendor/platformdirs/android.pyuser_data_dir      zAndroid.user_data_dirc                 C     | j S )z@:return: data directory shared by users, same as `user_data_dir`r   r   r   r   r   site_data_dir      zAndroid.site_data_dirc                 C  r   )z
        :return: config directory tied to the user, e.g.         ``/data/user/<userid>/<packagename>/shared_prefs/<AppName>``
        r
   Zshared_prefsr   r   r   r   r   user_config_dir!   s   zAndroid.user_config_dirc                 C  r   )zH:return: config directory shared by the users, same as `user_config_dir`)r   r   r   r   r   site_config_dir)   r   zAndroid.site_config_dirc                 C  r   )ze:return: cache directory tied to the user, e.g.,``/data/user/<userid>/<packagename>/cache/<AppName>``r
   cacher   r   r   r   r   user_cache_dir.   r   zAndroid.user_cache_dirc                 C  r   )zB:return: cache directory shared by users, same as `user_cache_dir`)r   r   r   r   r   site_cache_dir3   r   zAndroid.site_cache_dirc                 C  r   )zB:return: state directory tied to the user, same as `user_data_dir`r   r   r   r   r   user_state_dir8   r   zAndroid.user_state_dirc                 C     | j }| jrtj|d}|S )z
        :return: log directory tied to the user, same as `user_cache_dir` if not opinionated else ``log`` in it,
          e.g. ``/data/user/<userid>/<packagename>/cache/<AppName>/log``
        logr   opinionospathjoinr   r%   r   r   r   user_log_dir=      zAndroid.user_log_dirc                 C     t  S )zT:return: documents directory tied to the user e.g. ``/storage/emulated/0/Documents``)_android_documents_folderr   r   r   r   user_documents_dirH   r   zAndroid.user_documents_dirc                 C  r*   )zT:return: downloads directory tied to the user e.g. ``/storage/emulated/0/Downloads``)_android_downloads_folderr   r   r   r   user_downloads_dirM   r   zAndroid.user_downloads_dirc                 C  r*   )zR:return: pictures directory tied to the user e.g. ``/storage/emulated/0/Pictures``)_android_pictures_folderr   r   r   r   user_pictures_dirR   r   zAndroid.user_pictures_dirc                 C  r*   )zS:return: videos directory tied to the user e.g. ``/storage/emulated/0/DCIM/Camera``)_android_videos_folderr   r   r   r   user_videos_dirW   r   zAndroid.user_videos_dirc                 C  r*   )zL:return: music directory tied to the user e.g. ``/storage/emulated/0/Music``)_android_music_folderr   r   r   r   user_music_dir\   r   zAndroid.user_music_dirc                 C  s   dS )zP:return: desktop directory tied to the user e.g. ``/storage/emulated/0/Desktop``z/storage/emulated/0/Desktopr   r   r   r   r   user_desktop_dira   s   zAndroid.user_desktop_dirc                 C  r    )z
        :return: runtime directory tied to the user, same as `user_cache_dir` if not opinionated else ``tmp`` in it,
          e.g. ``/data/user/<userid>/<packagename>/cache/<AppName>/tmp``
        tmpr"   r'   r   r   r   user_runtime_dirf   r)   zAndroid.user_runtime_dirc                 C  r   )zF:return: runtime directory shared by users, same as `user_runtime_dir`)r7   r   r   r   r   site_runtime_dirq   r   zAndroid.site_runtime_dirNr	   r
   )__name__
__module____qualname____doc__propertyr   r   r   r   r   r   r   r(   r,   r.   r0   r2   r4   r5   r7   r8   r   r   r   r   r      sD    

r   )maxsizer	   
str | Nonec                  C  s  d} t s'zddlm} td| }|   } W n ty&   d} Y nw | du rKzddl	m
} |d}|   } W n tyJ   d} Y nw | du rjtd}tjD ]}||rg|dd }  nqWd} | du rtd}tjD ]}||r|dd }  | S qvd} | S )	zE:return: base folder for the Android OS or None if it cannot be foundNr   )	mActivityandroid.content.Context	autoclassz /data/(data|user/\d+)/(.+)/filesz/filesz7/mnt/expand/[a-fA-F0-9-]{36}/(data|user/\d+)/(.+)/files)r   ZandroidrA   r   ZgetApplicationContextZgetFilesDirZgetParentFilegetAbsolutePath	ExceptionjniusrD   recompilesysr%   matchsplit)resultrA   contextrD   patternr%   r   r   r   r   w   sF   





r   r
   c                  C  L   zddl m}  | d}| d}||j }W |S  ty%   d}Y |S w )z,:return: documents folder for the Android OSr   rC   rB   android.os.Environmentz/storage/emulated/0/Documents)rG   rD   getExternalFilesDirZDIRECTORY_DOCUMENTSrE   rF   )rD   rN   environmentdocuments_dirr   r   r   r+         r+   c                  C  rP   )z,:return: downloads folder for the Android OSr   rC   rB   rQ   z/storage/emulated/0/Downloads)rG   rD   rR   ZDIRECTORY_DOWNLOADSrE   rF   )rD   rN   rS   Zdownloads_dirr   r   r   r-      rU   r-   c                  C  rP   )z+:return: pictures folder for the Android OSr   rC   rB   rQ   z/storage/emulated/0/Pictures)rG   rD   rR   ZDIRECTORY_PICTURESrE   rF   )rD   rN   rS   Zpictures_dirr   r   r   r/      rU   r/   c                  C  rP   )z):return: videos folder for the Android OSr   rC   rB   rQ   z/storage/emulated/0/DCIM/Camera)rG   rD   rR   ZDIRECTORY_DCIMrE   rF   )rD   rN   rS   Z
videos_dirr   r   r   r1      rU   r1   c                  C  rP   )z(:return: music folder for the Android OSr   rC   rB   rQ   z/storage/emulated/0/Music)rG   rD   rR   ZDIRECTORY_MUSICrE   rF   )rD   rN   rS   Z	music_dirr   r   r   r3      rU   r3   )r	   r@   r9   )r=   
__future__r   r$   rH   rJ   	functoolsr   typingr   r   apir   r   r   r+   r-   r/   r1   r3   __all__r   r   r   r   <module>   s.    i/