ރUddlmZddlZddlZddlZddlZddlmZddlm Z m Z ddl m Z m Z ddlmZddlmZmZmZejeZeejZeed dZd ed <d"dZd#dZd#dZd#dZ gdZ!ej"de!#d d$d%dZ$d#dZ%d#d Z&d#d!Z'dS)&) annotationsN)Callable)InvalidSchemeCombinationUserInstallationInvalid) SCHEME_KEYSScheme)running_under_virtualenv) change_rootget_major_minor_versionis_osx_frameworkget_preferred_schemezCallable[[str], str] | None_PREFERRED_SCHEME_APIreturnboolcNdtvot o tS)aCheck for Apple's ``osx_framework_library`` scheme. Python distributed by Apple's Command Line Tools has this special scheme that's used when: * This is a framework build. * We are installing into the system prefix. This does not account for ``pip install --prefix`` (also means we're not installing to the system prefix), which should use ``posix_prefix``, but logic here means ``_infer_prefix()`` outputs ``osx_framework_library``. But since ``prefix`` is not available for ``sysconfig.get_default_scheme()``, which is the stdlib replacement for ``_infer_prefix()``, presumably Apple wouldn't be able to magically switch between ``osx_framework_library`` and ``posix_prefix``. ``_infer_prefix()`` returning ``osx_framework_library`` means its behavior is consistent whether we use the stdlib implementation or our own, and we deal with this special case in ``get_scheme()`` instead. osx_framework_library)_AVAILABLE_SCHEMESr r /builddir/build/BUILD/imunify360-venv-2.6.2/opt/imunify360/venv/lib/python3.11/site-packages/pip/_internal/locations/_sysconfig.py _should_use_osx_framework_prefixr!s1( #55 (** *    rstrcltrtdStrdStjjdt j}|t vr|Stjjt vrtjjSt jd}|t vr|St jt vr t jSdS)a!Try to find a prefix scheme for the current platform. This tries: * A special ``osx_framework_library`` for Python distributed by Apple's Command Line Tools, when not running in a virtual environment. * Implementation + OS, used by PyPy on Windows (``pypy_nt``). * Implementation without OS, used by PyPy on POSIX (``pypy``). * OS + "prefix", used by CPython on POSIX (``posix_prefix``). * Just the OS name, used by CPython on Windows (``nt``). If none of the above works, fall back to ``posix_prefix``. prefixr__prefix posix_prefix)rrsysimplementationnameosr)implementation_suffixedsuffixeds r _infer_prefixr%;s/$X...'))'&&!$!3!8DD27DD"444&& "444!&&'"""H%%% w$$$w >rctrtdStrtsd}ntjd}|t vr|Sdt vrt dS)z3Try to find a user scheme for the current platform.userosx_framework_user_user posix_user)rr r r"r!rrr$s r _infer_userr,Zsy-$V,,,%":"<"<%'g$$$%%%---%''' -$V,,,'   H%%% zget_scheme..s111Q111rci|]}|Srr)r>r?rs rr@zget_scheme..s3331Q333r)schemevarsr7r3pythonincludesiteUNKNOWNplatlibpurelibscriptsdata)rHrIheadersrJrKr)rr1r,r% _HOME_KEYS sysconfig get_pathsr getrrr r"pathjoinrrr getattr)r8r'r.r:r;r scheme_name variablespathsr3 python_xyrBconverted_keyskeys ` ` r get_schemerZs * ==&x<<< ==&x<<< !mm &!mm #oo k-DDD$  1111j111  3333 333   { C C CE !!  5==SZ88DD==44D846688 7<<iKKi  i i  U9-y99i 6] F  J JC"-dGFC4H4H"I"IN3  )).)) MrctjdddkrtjdddkrdStjdS)Ndarwinz/System/Library/z/usr/local/binrJ)rplatformrrNrOrrrget_bin_prefixr`sG |BQB8## 3B3;M(M(M    ++rc4tjdS)NrIrNrOrrr get_purelibrc    ++rc4tjdS)NrHrbrrr get_platlibrfrdr)rr)rr)FNNFN)r8rr'rr.r9r:r9r;rrr9rr)( __future__rloggingr"rrNtypingrpip._internal.exceptionsrrpip._internal.models.schemerrpip._internal.utils.virtualenvr r3r r r getLogger__name__loggersetget_scheme_namesrrSr__annotations__rr%r,r1rMget_config_varappendrZr`rcrfrrrrus""""""" VVVVVVVV;;;;;;;;CCCCCCHHHHHHHHHH  8 $ $S3355665     9J''3j!!!  KKKKK\,,,,,,,,,,,,,,r