cli-ih 0.6.3__py3-none-any.whl → 0.6.3.1__py3-none-any.whl

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (424) hide show
  1. cli_ih/asyncClient.py +13 -7
  2. cli_ih/client.py +13 -6
  3. {cli_ih-0.6.3.dist-info → cli_ih-0.6.3.1.dist-info}/METADATA +1 -1
  4. cli_ih-0.6.3.1.dist-info/RECORD +425 -0
  5. {cli_ih-0.6.3.dist-info → cli_ih-0.6.3.1.dist-info}/WHEEL +1 -1
  6. {cli_ih-0.6.3.dist-info → cli_ih-0.6.3.1.dist-info}/top_level.txt +1 -0
  7. venv/Lib/site-packages/__editable___cli_ih_0_6_3_1_finder.py +85 -0
  8. venv/Lib/site-packages/pip/__init__.py +13 -0
  9. venv/Lib/site-packages/pip/__main__.py +24 -0
  10. venv/Lib/site-packages/pip/__pip-runner__.py +50 -0
  11. venv/Lib/site-packages/pip/_internal/__init__.py +18 -0
  12. venv/Lib/site-packages/pip/_internal/build_env.py +349 -0
  13. venv/Lib/site-packages/pip/_internal/cache.py +291 -0
  14. venv/Lib/site-packages/pip/_internal/cli/__init__.py +3 -0
  15. venv/Lib/site-packages/pip/_internal/cli/autocompletion.py +184 -0
  16. venv/Lib/site-packages/pip/_internal/cli/base_command.py +244 -0
  17. venv/Lib/site-packages/pip/_internal/cli/cmdoptions.py +1138 -0
  18. venv/Lib/site-packages/pip/_internal/cli/command_context.py +28 -0
  19. venv/Lib/site-packages/pip/_internal/cli/index_command.py +175 -0
  20. venv/Lib/site-packages/pip/_internal/cli/main.py +80 -0
  21. venv/Lib/site-packages/pip/_internal/cli/main_parser.py +134 -0
  22. venv/Lib/site-packages/pip/_internal/cli/parser.py +298 -0
  23. venv/Lib/site-packages/pip/_internal/cli/progress_bars.py +151 -0
  24. venv/Lib/site-packages/pip/_internal/cli/req_command.py +351 -0
  25. venv/Lib/site-packages/pip/_internal/cli/spinners.py +235 -0
  26. venv/Lib/site-packages/pip/_internal/cli/status_codes.py +6 -0
  27. venv/Lib/site-packages/pip/_internal/commands/__init__.py +139 -0
  28. venv/Lib/site-packages/pip/_internal/commands/cache.py +231 -0
  29. venv/Lib/site-packages/pip/_internal/commands/check.py +66 -0
  30. venv/Lib/site-packages/pip/_internal/commands/completion.py +135 -0
  31. venv/Lib/site-packages/pip/_internal/commands/configuration.py +288 -0
  32. venv/Lib/site-packages/pip/_internal/commands/debug.py +203 -0
  33. venv/Lib/site-packages/pip/_internal/commands/download.py +145 -0
  34. venv/Lib/site-packages/pip/_internal/commands/freeze.py +107 -0
  35. venv/Lib/site-packages/pip/_internal/commands/hash.py +58 -0
  36. venv/Lib/site-packages/pip/_internal/commands/help.py +40 -0
  37. venv/Lib/site-packages/pip/_internal/commands/index.py +159 -0
  38. venv/Lib/site-packages/pip/_internal/commands/inspect.py +92 -0
  39. venv/Lib/site-packages/pip/_internal/commands/install.py +798 -0
  40. venv/Lib/site-packages/pip/_internal/commands/list.py +400 -0
  41. venv/Lib/site-packages/pip/_internal/commands/lock.py +170 -0
  42. venv/Lib/site-packages/pip/_internal/commands/search.py +178 -0
  43. venv/Lib/site-packages/pip/_internal/commands/show.py +231 -0
  44. venv/Lib/site-packages/pip/_internal/commands/uninstall.py +113 -0
  45. venv/Lib/site-packages/pip/_internal/commands/wheel.py +181 -0
  46. venv/Lib/site-packages/pip/_internal/configuration.py +397 -0
  47. venv/Lib/site-packages/pip/_internal/distributions/__init__.py +21 -0
  48. venv/Lib/site-packages/pip/_internal/distributions/base.py +55 -0
  49. venv/Lib/site-packages/pip/_internal/distributions/installed.py +33 -0
  50. venv/Lib/site-packages/pip/_internal/distributions/sdist.py +165 -0
  51. venv/Lib/site-packages/pip/_internal/distributions/wheel.py +44 -0
  52. venv/Lib/site-packages/pip/_internal/exceptions.py +881 -0
  53. venv/Lib/site-packages/pip/_internal/index/__init__.py +1 -0
  54. venv/Lib/site-packages/pip/_internal/index/collector.py +489 -0
  55. venv/Lib/site-packages/pip/_internal/index/package_finder.py +1059 -0
  56. venv/Lib/site-packages/pip/_internal/index/sources.py +287 -0
  57. venv/Lib/site-packages/pip/_internal/locations/__init__.py +441 -0
  58. venv/Lib/site-packages/pip/_internal/locations/_distutils.py +173 -0
  59. venv/Lib/site-packages/pip/_internal/locations/_sysconfig.py +215 -0
  60. venv/Lib/site-packages/pip/_internal/locations/base.py +82 -0
  61. venv/Lib/site-packages/pip/_internal/main.py +12 -0
  62. venv/Lib/site-packages/pip/_internal/metadata/__init__.py +164 -0
  63. venv/Lib/site-packages/pip/_internal/metadata/_json.py +87 -0
  64. venv/Lib/site-packages/pip/_internal/metadata/base.py +685 -0
  65. venv/Lib/site-packages/pip/_internal/metadata/importlib/__init__.py +6 -0
  66. venv/Lib/site-packages/pip/_internal/metadata/importlib/_compat.py +87 -0
  67. venv/Lib/site-packages/pip/_internal/metadata/importlib/_dists.py +223 -0
  68. venv/Lib/site-packages/pip/_internal/metadata/importlib/_envs.py +143 -0
  69. venv/Lib/site-packages/pip/_internal/metadata/pkg_resources.py +298 -0
  70. venv/Lib/site-packages/pip/_internal/models/__init__.py +1 -0
  71. venv/Lib/site-packages/pip/_internal/models/candidate.py +25 -0
  72. venv/Lib/site-packages/pip/_internal/models/direct_url.py +227 -0
  73. venv/Lib/site-packages/pip/_internal/models/format_control.py +78 -0
  74. venv/Lib/site-packages/pip/_internal/models/index.py +28 -0
  75. venv/Lib/site-packages/pip/_internal/models/installation_report.py +57 -0
  76. venv/Lib/site-packages/pip/_internal/models/link.py +613 -0
  77. venv/Lib/site-packages/pip/_internal/models/pylock.py +188 -0
  78. venv/Lib/site-packages/pip/_internal/models/scheme.py +25 -0
  79. venv/Lib/site-packages/pip/_internal/models/search_scope.py +126 -0
  80. venv/Lib/site-packages/pip/_internal/models/selection_prefs.py +53 -0
  81. venv/Lib/site-packages/pip/_internal/models/target_python.py +122 -0
  82. venv/Lib/site-packages/pip/_internal/models/wheel.py +141 -0
  83. venv/Lib/site-packages/pip/_internal/network/__init__.py +1 -0
  84. venv/Lib/site-packages/pip/_internal/network/auth.py +564 -0
  85. venv/Lib/site-packages/pip/_internal/network/cache.py +133 -0
  86. venv/Lib/site-packages/pip/_internal/network/download.py +342 -0
  87. venv/Lib/site-packages/pip/_internal/network/lazy_wheel.py +213 -0
  88. venv/Lib/site-packages/pip/_internal/network/session.py +528 -0
  89. venv/Lib/site-packages/pip/_internal/network/utils.py +98 -0
  90. venv/Lib/site-packages/pip/_internal/network/xmlrpc.py +61 -0
  91. venv/Lib/site-packages/pip/_internal/operations/__init__.py +0 -0
  92. venv/Lib/site-packages/pip/_internal/operations/build/__init__.py +0 -0
  93. venv/Lib/site-packages/pip/_internal/operations/build/build_tracker.py +140 -0
  94. venv/Lib/site-packages/pip/_internal/operations/build/metadata.py +38 -0
  95. venv/Lib/site-packages/pip/_internal/operations/build/metadata_editable.py +41 -0
  96. venv/Lib/site-packages/pip/_internal/operations/build/metadata_legacy.py +73 -0
  97. venv/Lib/site-packages/pip/_internal/operations/build/wheel.py +38 -0
  98. venv/Lib/site-packages/pip/_internal/operations/build/wheel_editable.py +47 -0
  99. venv/Lib/site-packages/pip/_internal/operations/build/wheel_legacy.py +119 -0
  100. venv/Lib/site-packages/pip/_internal/operations/check.py +175 -0
  101. venv/Lib/site-packages/pip/_internal/operations/freeze.py +259 -0
  102. venv/Lib/site-packages/pip/_internal/operations/install/__init__.py +1 -0
  103. venv/Lib/site-packages/pip/_internal/operations/install/editable_legacy.py +48 -0
  104. venv/Lib/site-packages/pip/_internal/operations/install/wheel.py +746 -0
  105. venv/Lib/site-packages/pip/_internal/operations/prepare.py +742 -0
  106. venv/Lib/site-packages/pip/_internal/pyproject.py +182 -0
  107. venv/Lib/site-packages/pip/_internal/req/__init__.py +105 -0
  108. venv/Lib/site-packages/pip/_internal/req/constructors.py +562 -0
  109. venv/Lib/site-packages/pip/_internal/req/req_dependency_group.py +75 -0
  110. venv/Lib/site-packages/pip/_internal/req/req_file.py +620 -0
  111. venv/Lib/site-packages/pip/_internal/req/req_install.py +937 -0
  112. venv/Lib/site-packages/pip/_internal/req/req_set.py +81 -0
  113. venv/Lib/site-packages/pip/_internal/req/req_uninstall.py +639 -0
  114. venv/Lib/site-packages/pip/_internal/resolution/__init__.py +0 -0
  115. venv/Lib/site-packages/pip/_internal/resolution/base.py +20 -0
  116. venv/Lib/site-packages/pip/_internal/resolution/legacy/__init__.py +0 -0
  117. venv/Lib/site-packages/pip/_internal/resolution/legacy/resolver.py +598 -0
  118. venv/Lib/site-packages/pip/_internal/resolution/resolvelib/__init__.py +0 -0
  119. venv/Lib/site-packages/pip/_internal/resolution/resolvelib/base.py +142 -0
  120. venv/Lib/site-packages/pip/_internal/resolution/resolvelib/candidates.py +582 -0
  121. venv/Lib/site-packages/pip/_internal/resolution/resolvelib/factory.py +814 -0
  122. venv/Lib/site-packages/pip/_internal/resolution/resolvelib/found_candidates.py +166 -0
  123. venv/Lib/site-packages/pip/_internal/resolution/resolvelib/provider.py +276 -0
  124. venv/Lib/site-packages/pip/_internal/resolution/resolvelib/reporter.py +85 -0
  125. venv/Lib/site-packages/pip/_internal/resolution/resolvelib/requirements.py +247 -0
  126. venv/Lib/site-packages/pip/_internal/resolution/resolvelib/resolver.py +336 -0
  127. venv/Lib/site-packages/pip/_internal/self_outdated_check.py +254 -0
  128. venv/Lib/site-packages/pip/_internal/utils/__init__.py +0 -0
  129. venv/Lib/site-packages/pip/_internal/utils/_jaraco_text.py +109 -0
  130. venv/Lib/site-packages/pip/_internal/utils/_log.py +38 -0
  131. venv/Lib/site-packages/pip/_internal/utils/appdirs.py +52 -0
  132. venv/Lib/site-packages/pip/_internal/utils/compat.py +85 -0
  133. venv/Lib/site-packages/pip/_internal/utils/compatibility_tags.py +201 -0
  134. venv/Lib/site-packages/pip/_internal/utils/datetime.py +10 -0
  135. venv/Lib/site-packages/pip/_internal/utils/deprecation.py +126 -0
  136. venv/Lib/site-packages/pip/_internal/utils/direct_url_helpers.py +87 -0
  137. venv/Lib/site-packages/pip/_internal/utils/egg_link.py +81 -0
  138. venv/Lib/site-packages/pip/_internal/utils/entrypoints.py +88 -0
  139. venv/Lib/site-packages/pip/_internal/utils/filesystem.py +152 -0
  140. venv/Lib/site-packages/pip/_internal/utils/filetypes.py +24 -0
  141. venv/Lib/site-packages/pip/_internal/utils/glibc.py +102 -0
  142. venv/Lib/site-packages/pip/_internal/utils/hashes.py +150 -0
  143. venv/Lib/site-packages/pip/_internal/utils/logging.py +364 -0
  144. venv/Lib/site-packages/pip/_internal/utils/misc.py +765 -0
  145. venv/Lib/site-packages/pip/_internal/utils/packaging.py +44 -0
  146. venv/Lib/site-packages/pip/_internal/utils/retry.py +45 -0
  147. venv/Lib/site-packages/pip/_internal/utils/setuptools_build.py +149 -0
  148. venv/Lib/site-packages/pip/_internal/utils/subprocess.py +248 -0
  149. venv/Lib/site-packages/pip/_internal/utils/temp_dir.py +294 -0
  150. venv/Lib/site-packages/pip/_internal/utils/unpacking.py +337 -0
  151. venv/Lib/site-packages/pip/_internal/utils/urls.py +55 -0
  152. venv/Lib/site-packages/pip/_internal/utils/virtualenv.py +105 -0
  153. venv/Lib/site-packages/pip/_internal/utils/wheel.py +132 -0
  154. venv/Lib/site-packages/pip/_internal/vcs/__init__.py +15 -0
  155. venv/Lib/site-packages/pip/_internal/vcs/bazaar.py +130 -0
  156. venv/Lib/site-packages/pip/_internal/vcs/git.py +571 -0
  157. venv/Lib/site-packages/pip/_internal/vcs/mercurial.py +186 -0
  158. venv/Lib/site-packages/pip/_internal/vcs/subversion.py +335 -0
  159. venv/Lib/site-packages/pip/_internal/vcs/versioncontrol.py +693 -0
  160. venv/Lib/site-packages/pip/_internal/wheel_builder.py +334 -0
  161. venv/Lib/site-packages/pip/_vendor/__init__.py +117 -0
  162. venv/Lib/site-packages/pip/_vendor/cachecontrol/__init__.py +29 -0
  163. venv/Lib/site-packages/pip/_vendor/cachecontrol/_cmd.py +70 -0
  164. venv/Lib/site-packages/pip/_vendor/cachecontrol/adapter.py +168 -0
  165. venv/Lib/site-packages/pip/_vendor/cachecontrol/cache.py +75 -0
  166. venv/Lib/site-packages/pip/_vendor/cachecontrol/caches/__init__.py +8 -0
  167. venv/Lib/site-packages/pip/_vendor/cachecontrol/caches/file_cache.py +145 -0
  168. venv/Lib/site-packages/pip/_vendor/cachecontrol/caches/redis_cache.py +48 -0
  169. venv/Lib/site-packages/pip/_vendor/cachecontrol/controller.py +511 -0
  170. venv/Lib/site-packages/pip/_vendor/cachecontrol/filewrapper.py +119 -0
  171. venv/Lib/site-packages/pip/_vendor/cachecontrol/heuristics.py +157 -0
  172. venv/Lib/site-packages/pip/_vendor/cachecontrol/py.typed +0 -0
  173. venv/Lib/site-packages/pip/_vendor/cachecontrol/serialize.py +146 -0
  174. venv/Lib/site-packages/pip/_vendor/cachecontrol/wrapper.py +43 -0
  175. venv/Lib/site-packages/pip/_vendor/certifi/__init__.py +4 -0
  176. venv/Lib/site-packages/pip/_vendor/certifi/__main__.py +12 -0
  177. venv/Lib/site-packages/pip/_vendor/certifi/core.py +83 -0
  178. venv/Lib/site-packages/pip/_vendor/certifi/py.typed +0 -0
  179. venv/Lib/site-packages/pip/_vendor/dependency_groups/__init__.py +13 -0
  180. venv/Lib/site-packages/pip/_vendor/dependency_groups/__main__.py +65 -0
  181. venv/Lib/site-packages/pip/_vendor/dependency_groups/_implementation.py +209 -0
  182. venv/Lib/site-packages/pip/_vendor/dependency_groups/_lint_dependency_groups.py +59 -0
  183. venv/Lib/site-packages/pip/_vendor/dependency_groups/_pip_wrapper.py +62 -0
  184. venv/Lib/site-packages/pip/_vendor/dependency_groups/_toml_compat.py +9 -0
  185. venv/Lib/site-packages/pip/_vendor/dependency_groups/py.typed +0 -0
  186. venv/Lib/site-packages/pip/_vendor/distlib/__init__.py +33 -0
  187. venv/Lib/site-packages/pip/_vendor/distlib/compat.py +1137 -0
  188. venv/Lib/site-packages/pip/_vendor/distlib/resources.py +358 -0
  189. venv/Lib/site-packages/pip/_vendor/distlib/scripts.py +447 -0
  190. venv/Lib/site-packages/pip/_vendor/distlib/util.py +1984 -0
  191. venv/Lib/site-packages/pip/_vendor/distro/__init__.py +54 -0
  192. venv/Lib/site-packages/pip/_vendor/distro/__main__.py +4 -0
  193. venv/Lib/site-packages/pip/_vendor/distro/distro.py +1403 -0
  194. venv/Lib/site-packages/pip/_vendor/distro/py.typed +0 -0
  195. venv/Lib/site-packages/pip/_vendor/idna/__init__.py +45 -0
  196. venv/Lib/site-packages/pip/_vendor/idna/codec.py +122 -0
  197. venv/Lib/site-packages/pip/_vendor/idna/compat.py +15 -0
  198. venv/Lib/site-packages/pip/_vendor/idna/core.py +437 -0
  199. venv/Lib/site-packages/pip/_vendor/idna/idnadata.py +4243 -0
  200. venv/Lib/site-packages/pip/_vendor/idna/intranges.py +57 -0
  201. venv/Lib/site-packages/pip/_vendor/idna/package_data.py +1 -0
  202. venv/Lib/site-packages/pip/_vendor/idna/py.typed +0 -0
  203. venv/Lib/site-packages/pip/_vendor/idna/uts46data.py +8681 -0
  204. venv/Lib/site-packages/pip/_vendor/msgpack/__init__.py +55 -0
  205. venv/Lib/site-packages/pip/_vendor/msgpack/exceptions.py +48 -0
  206. venv/Lib/site-packages/pip/_vendor/msgpack/ext.py +170 -0
  207. venv/Lib/site-packages/pip/_vendor/msgpack/fallback.py +929 -0
  208. venv/Lib/site-packages/pip/_vendor/packaging/__init__.py +15 -0
  209. venv/Lib/site-packages/pip/_vendor/packaging/_elffile.py +109 -0
  210. venv/Lib/site-packages/pip/_vendor/packaging/_manylinux.py +262 -0
  211. venv/Lib/site-packages/pip/_vendor/packaging/_musllinux.py +85 -0
  212. venv/Lib/site-packages/pip/_vendor/packaging/_parser.py +353 -0
  213. venv/Lib/site-packages/pip/_vendor/packaging/_structures.py +61 -0
  214. venv/Lib/site-packages/pip/_vendor/packaging/_tokenizer.py +195 -0
  215. venv/Lib/site-packages/pip/_vendor/packaging/licenses/__init__.py +145 -0
  216. venv/Lib/site-packages/pip/_vendor/packaging/licenses/_spdx.py +759 -0
  217. venv/Lib/site-packages/pip/_vendor/packaging/markers.py +362 -0
  218. venv/Lib/site-packages/pip/_vendor/packaging/metadata.py +862 -0
  219. venv/Lib/site-packages/pip/_vendor/packaging/py.typed +0 -0
  220. venv/Lib/site-packages/pip/_vendor/packaging/requirements.py +91 -0
  221. venv/Lib/site-packages/pip/_vendor/packaging/specifiers.py +1019 -0
  222. venv/Lib/site-packages/pip/_vendor/packaging/tags.py +656 -0
  223. venv/Lib/site-packages/pip/_vendor/packaging/utils.py +163 -0
  224. venv/Lib/site-packages/pip/_vendor/packaging/version.py +582 -0
  225. venv/Lib/site-packages/pip/_vendor/pkg_resources/__init__.py +3676 -0
  226. venv/Lib/site-packages/pip/_vendor/platformdirs/__init__.py +631 -0
  227. venv/Lib/site-packages/pip/_vendor/platformdirs/__main__.py +55 -0
  228. venv/Lib/site-packages/pip/_vendor/platformdirs/android.py +249 -0
  229. venv/Lib/site-packages/pip/_vendor/platformdirs/api.py +299 -0
  230. venv/Lib/site-packages/pip/_vendor/platformdirs/macos.py +144 -0
  231. venv/Lib/site-packages/pip/_vendor/platformdirs/py.typed +0 -0
  232. venv/Lib/site-packages/pip/_vendor/platformdirs/unix.py +272 -0
  233. venv/Lib/site-packages/pip/_vendor/platformdirs/version.py +21 -0
  234. venv/Lib/site-packages/pip/_vendor/platformdirs/windows.py +272 -0
  235. venv/Lib/site-packages/pip/_vendor/pygments/__init__.py +82 -0
  236. venv/Lib/site-packages/pip/_vendor/pygments/__main__.py +17 -0
  237. venv/Lib/site-packages/pip/_vendor/pygments/console.py +70 -0
  238. venv/Lib/site-packages/pip/_vendor/pygments/filter.py +70 -0
  239. venv/Lib/site-packages/pip/_vendor/pygments/filters/__init__.py +940 -0
  240. venv/Lib/site-packages/pip/_vendor/pygments/formatter.py +129 -0
  241. venv/Lib/site-packages/pip/_vendor/pygments/formatters/__init__.py +157 -0
  242. venv/Lib/site-packages/pip/_vendor/pygments/formatters/_mapping.py +23 -0
  243. venv/Lib/site-packages/pip/_vendor/pygments/lexer.py +963 -0
  244. venv/Lib/site-packages/pip/_vendor/pygments/lexers/__init__.py +362 -0
  245. venv/Lib/site-packages/pip/_vendor/pygments/lexers/_mapping.py +602 -0
  246. venv/Lib/site-packages/pip/_vendor/pygments/lexers/python.py +1201 -0
  247. venv/Lib/site-packages/pip/_vendor/pygments/modeline.py +43 -0
  248. venv/Lib/site-packages/pip/_vendor/pygments/plugin.py +72 -0
  249. venv/Lib/site-packages/pip/_vendor/pygments/regexopt.py +91 -0
  250. venv/Lib/site-packages/pip/_vendor/pygments/scanner.py +104 -0
  251. venv/Lib/site-packages/pip/_vendor/pygments/sphinxext.py +247 -0
  252. venv/Lib/site-packages/pip/_vendor/pygments/style.py +203 -0
  253. venv/Lib/site-packages/pip/_vendor/pygments/styles/__init__.py +61 -0
  254. venv/Lib/site-packages/pip/_vendor/pygments/styles/_mapping.py +54 -0
  255. venv/Lib/site-packages/pip/_vendor/pygments/token.py +214 -0
  256. venv/Lib/site-packages/pip/_vendor/pygments/unistring.py +153 -0
  257. venv/Lib/site-packages/pip/_vendor/pygments/util.py +324 -0
  258. venv/Lib/site-packages/pip/_vendor/pyproject_hooks/__init__.py +31 -0
  259. venv/Lib/site-packages/pip/_vendor/pyproject_hooks/_impl.py +410 -0
  260. venv/Lib/site-packages/pip/_vendor/pyproject_hooks/_in_process/__init__.py +21 -0
  261. venv/Lib/site-packages/pip/_vendor/pyproject_hooks/_in_process/_in_process.py +389 -0
  262. venv/Lib/site-packages/pip/_vendor/pyproject_hooks/py.typed +0 -0
  263. venv/Lib/site-packages/pip/_vendor/requests/__init__.py +179 -0
  264. venv/Lib/site-packages/pip/_vendor/requests/__version__.py +14 -0
  265. venv/Lib/site-packages/pip/_vendor/requests/_internal_utils.py +50 -0
  266. venv/Lib/site-packages/pip/_vendor/requests/adapters.py +719 -0
  267. venv/Lib/site-packages/pip/_vendor/requests/api.py +157 -0
  268. venv/Lib/site-packages/pip/_vendor/requests/auth.py +314 -0
  269. venv/Lib/site-packages/pip/_vendor/requests/certs.py +17 -0
  270. venv/Lib/site-packages/pip/_vendor/requests/compat.py +90 -0
  271. venv/Lib/site-packages/pip/_vendor/requests/cookies.py +561 -0
  272. venv/Lib/site-packages/pip/_vendor/requests/exceptions.py +151 -0
  273. venv/Lib/site-packages/pip/_vendor/requests/help.py +127 -0
  274. venv/Lib/site-packages/pip/_vendor/requests/hooks.py +33 -0
  275. venv/Lib/site-packages/pip/_vendor/requests/models.py +1039 -0
  276. venv/Lib/site-packages/pip/_vendor/requests/packages.py +25 -0
  277. venv/Lib/site-packages/pip/_vendor/requests/sessions.py +831 -0
  278. venv/Lib/site-packages/pip/_vendor/requests/status_codes.py +128 -0
  279. venv/Lib/site-packages/pip/_vendor/requests/structures.py +99 -0
  280. venv/Lib/site-packages/pip/_vendor/requests/utils.py +1086 -0
  281. venv/Lib/site-packages/pip/_vendor/resolvelib/__init__.py +27 -0
  282. venv/Lib/site-packages/pip/_vendor/resolvelib/providers.py +196 -0
  283. venv/Lib/site-packages/pip/_vendor/resolvelib/py.typed +0 -0
  284. venv/Lib/site-packages/pip/_vendor/resolvelib/reporters.py +55 -0
  285. venv/Lib/site-packages/pip/_vendor/resolvelib/resolvers/__init__.py +27 -0
  286. venv/Lib/site-packages/pip/_vendor/resolvelib/resolvers/abstract.py +47 -0
  287. venv/Lib/site-packages/pip/_vendor/resolvelib/resolvers/criterion.py +48 -0
  288. venv/Lib/site-packages/pip/_vendor/resolvelib/resolvers/exceptions.py +57 -0
  289. venv/Lib/site-packages/pip/_vendor/resolvelib/resolvers/resolution.py +622 -0
  290. venv/Lib/site-packages/pip/_vendor/resolvelib/structs.py +209 -0
  291. venv/Lib/site-packages/pip/_vendor/rich/__init__.py +177 -0
  292. venv/Lib/site-packages/pip/_vendor/rich/__main__.py +245 -0
  293. venv/Lib/site-packages/pip/_vendor/rich/_cell_widths.py +454 -0
  294. venv/Lib/site-packages/pip/_vendor/rich/_emoji_codes.py +3610 -0
  295. venv/Lib/site-packages/pip/_vendor/rich/_emoji_replace.py +32 -0
  296. venv/Lib/site-packages/pip/_vendor/rich/_export_format.py +76 -0
  297. venv/Lib/site-packages/pip/_vendor/rich/_extension.py +10 -0
  298. venv/Lib/site-packages/pip/_vendor/rich/_fileno.py +24 -0
  299. venv/Lib/site-packages/pip/_vendor/rich/_inspect.py +268 -0
  300. venv/Lib/site-packages/pip/_vendor/rich/_log_render.py +94 -0
  301. venv/Lib/site-packages/pip/_vendor/rich/_loop.py +43 -0
  302. venv/Lib/site-packages/pip/_vendor/rich/_null_file.py +69 -0
  303. venv/Lib/site-packages/pip/_vendor/rich/_palettes.py +309 -0
  304. venv/Lib/site-packages/pip/_vendor/rich/_pick.py +17 -0
  305. venv/Lib/site-packages/pip/_vendor/rich/_ratio.py +153 -0
  306. venv/Lib/site-packages/pip/_vendor/rich/_spinners.py +482 -0
  307. venv/Lib/site-packages/pip/_vendor/rich/_stack.py +16 -0
  308. venv/Lib/site-packages/pip/_vendor/rich/_timer.py +19 -0
  309. venv/Lib/site-packages/pip/_vendor/rich/_win32_console.py +661 -0
  310. venv/Lib/site-packages/pip/_vendor/rich/_windows.py +71 -0
  311. venv/Lib/site-packages/pip/_vendor/rich/_windows_renderer.py +56 -0
  312. venv/Lib/site-packages/pip/_vendor/rich/_wrap.py +93 -0
  313. venv/Lib/site-packages/pip/_vendor/rich/abc.py +33 -0
  314. venv/Lib/site-packages/pip/_vendor/rich/align.py +306 -0
  315. venv/Lib/site-packages/pip/_vendor/rich/ansi.py +241 -0
  316. venv/Lib/site-packages/pip/_vendor/rich/bar.py +93 -0
  317. venv/Lib/site-packages/pip/_vendor/rich/box.py +474 -0
  318. venv/Lib/site-packages/pip/_vendor/rich/cells.py +174 -0
  319. venv/Lib/site-packages/pip/_vendor/rich/color.py +621 -0
  320. venv/Lib/site-packages/pip/_vendor/rich/color_triplet.py +38 -0
  321. venv/Lib/site-packages/pip/_vendor/rich/columns.py +187 -0
  322. venv/Lib/site-packages/pip/_vendor/rich/console.py +2680 -0
  323. venv/Lib/site-packages/pip/_vendor/rich/constrain.py +37 -0
  324. venv/Lib/site-packages/pip/_vendor/rich/containers.py +167 -0
  325. venv/Lib/site-packages/pip/_vendor/rich/control.py +219 -0
  326. venv/Lib/site-packages/pip/_vendor/rich/default_styles.py +193 -0
  327. venv/Lib/site-packages/pip/_vendor/rich/diagnose.py +39 -0
  328. venv/Lib/site-packages/pip/_vendor/rich/emoji.py +91 -0
  329. venv/Lib/site-packages/pip/_vendor/rich/errors.py +34 -0
  330. venv/Lib/site-packages/pip/_vendor/rich/file_proxy.py +57 -0
  331. venv/Lib/site-packages/pip/_vendor/rich/filesize.py +88 -0
  332. venv/Lib/site-packages/pip/_vendor/rich/highlighter.py +232 -0
  333. venv/Lib/site-packages/pip/_vendor/rich/json.py +139 -0
  334. venv/Lib/site-packages/pip/_vendor/rich/jupyter.py +101 -0
  335. venv/Lib/site-packages/pip/_vendor/rich/layout.py +442 -0
  336. venv/Lib/site-packages/pip/_vendor/rich/live.py +400 -0
  337. venv/Lib/site-packages/pip/_vendor/rich/live_render.py +106 -0
  338. venv/Lib/site-packages/pip/_vendor/rich/logging.py +297 -0
  339. venv/Lib/site-packages/pip/_vendor/rich/markup.py +251 -0
  340. venv/Lib/site-packages/pip/_vendor/rich/measure.py +151 -0
  341. venv/Lib/site-packages/pip/_vendor/rich/padding.py +141 -0
  342. venv/Lib/site-packages/pip/_vendor/rich/pager.py +34 -0
  343. venv/Lib/site-packages/pip/_vendor/rich/palette.py +100 -0
  344. venv/Lib/site-packages/pip/_vendor/rich/panel.py +317 -0
  345. venv/Lib/site-packages/pip/_vendor/rich/pretty.py +1016 -0
  346. venv/Lib/site-packages/pip/_vendor/rich/progress.py +1715 -0
  347. venv/Lib/site-packages/pip/_vendor/rich/progress_bar.py +223 -0
  348. venv/Lib/site-packages/pip/_vendor/rich/prompt.py +400 -0
  349. venv/Lib/site-packages/pip/_vendor/rich/protocol.py +42 -0
  350. venv/Lib/site-packages/pip/_vendor/rich/py.typed +0 -0
  351. venv/Lib/site-packages/pip/_vendor/rich/region.py +10 -0
  352. venv/Lib/site-packages/pip/_vendor/rich/repr.py +149 -0
  353. venv/Lib/site-packages/pip/_vendor/rich/rule.py +130 -0
  354. venv/Lib/site-packages/pip/_vendor/rich/scope.py +86 -0
  355. venv/Lib/site-packages/pip/_vendor/rich/screen.py +54 -0
  356. venv/Lib/site-packages/pip/_vendor/rich/segment.py +752 -0
  357. venv/Lib/site-packages/pip/_vendor/rich/spinner.py +132 -0
  358. venv/Lib/site-packages/pip/_vendor/rich/status.py +131 -0
  359. venv/Lib/site-packages/pip/_vendor/rich/style.py +796 -0
  360. venv/Lib/site-packages/pip/_vendor/rich/styled.py +42 -0
  361. venv/Lib/site-packages/pip/_vendor/rich/syntax.py +985 -0
  362. venv/Lib/site-packages/pip/_vendor/rich/table.py +1006 -0
  363. venv/Lib/site-packages/pip/_vendor/rich/terminal_theme.py +153 -0
  364. venv/Lib/site-packages/pip/_vendor/rich/text.py +1361 -0
  365. venv/Lib/site-packages/pip/_vendor/rich/theme.py +115 -0
  366. venv/Lib/site-packages/pip/_vendor/rich/themes.py +5 -0
  367. venv/Lib/site-packages/pip/_vendor/rich/traceback.py +899 -0
  368. venv/Lib/site-packages/pip/_vendor/rich/tree.py +257 -0
  369. venv/Lib/site-packages/pip/_vendor/tomli/__init__.py +8 -0
  370. venv/Lib/site-packages/pip/_vendor/tomli/_parser.py +770 -0
  371. venv/Lib/site-packages/pip/_vendor/tomli/_re.py +112 -0
  372. venv/Lib/site-packages/pip/_vendor/tomli/_types.py +10 -0
  373. venv/Lib/site-packages/pip/_vendor/tomli/py.typed +1 -0
  374. venv/Lib/site-packages/pip/_vendor/tomli_w/__init__.py +4 -0
  375. venv/Lib/site-packages/pip/_vendor/tomli_w/_writer.py +229 -0
  376. venv/Lib/site-packages/pip/_vendor/tomli_w/py.typed +1 -0
  377. venv/Lib/site-packages/pip/_vendor/truststore/__init__.py +36 -0
  378. venv/Lib/site-packages/pip/_vendor/truststore/_api.py +333 -0
  379. venv/Lib/site-packages/pip/_vendor/truststore/_macos.py +571 -0
  380. venv/Lib/site-packages/pip/_vendor/truststore/_openssl.py +66 -0
  381. venv/Lib/site-packages/pip/_vendor/truststore/_ssl_constants.py +31 -0
  382. venv/Lib/site-packages/pip/_vendor/truststore/_windows.py +567 -0
  383. venv/Lib/site-packages/pip/_vendor/truststore/py.typed +0 -0
  384. venv/Lib/site-packages/pip/_vendor/urllib3/__init__.py +102 -0
  385. venv/Lib/site-packages/pip/_vendor/urllib3/_collections.py +355 -0
  386. venv/Lib/site-packages/pip/_vendor/urllib3/_version.py +2 -0
  387. venv/Lib/site-packages/pip/_vendor/urllib3/connection.py +572 -0
  388. venv/Lib/site-packages/pip/_vendor/urllib3/connectionpool.py +1140 -0
  389. venv/Lib/site-packages/pip/_vendor/urllib3/contrib/__init__.py +0 -0
  390. venv/Lib/site-packages/pip/_vendor/urllib3/contrib/_appengine_environ.py +36 -0
  391. venv/Lib/site-packages/pip/_vendor/urllib3/contrib/_securetransport/__init__.py +0 -0
  392. venv/Lib/site-packages/pip/_vendor/urllib3/contrib/_securetransport/bindings.py +519 -0
  393. venv/Lib/site-packages/pip/_vendor/urllib3/contrib/_securetransport/low_level.py +397 -0
  394. venv/Lib/site-packages/pip/_vendor/urllib3/contrib/appengine.py +314 -0
  395. venv/Lib/site-packages/pip/_vendor/urllib3/contrib/ntlmpool.py +130 -0
  396. venv/Lib/site-packages/pip/_vendor/urllib3/contrib/pyopenssl.py +518 -0
  397. venv/Lib/site-packages/pip/_vendor/urllib3/contrib/securetransport.py +920 -0
  398. venv/Lib/site-packages/pip/_vendor/urllib3/contrib/socks.py +216 -0
  399. venv/Lib/site-packages/pip/_vendor/urllib3/exceptions.py +323 -0
  400. venv/Lib/site-packages/pip/_vendor/urllib3/fields.py +274 -0
  401. venv/Lib/site-packages/pip/_vendor/urllib3/filepost.py +98 -0
  402. venv/Lib/site-packages/pip/_vendor/urllib3/packages/__init__.py +0 -0
  403. venv/Lib/site-packages/pip/_vendor/urllib3/packages/backports/__init__.py +0 -0
  404. venv/Lib/site-packages/pip/_vendor/urllib3/packages/backports/makefile.py +51 -0
  405. venv/Lib/site-packages/pip/_vendor/urllib3/packages/backports/weakref_finalize.py +155 -0
  406. venv/Lib/site-packages/pip/_vendor/urllib3/packages/six.py +1076 -0
  407. venv/Lib/site-packages/pip/_vendor/urllib3/poolmanager.py +540 -0
  408. venv/Lib/site-packages/pip/_vendor/urllib3/request.py +191 -0
  409. venv/Lib/site-packages/pip/_vendor/urllib3/response.py +879 -0
  410. venv/Lib/site-packages/pip/_vendor/urllib3/util/__init__.py +49 -0
  411. venv/Lib/site-packages/pip/_vendor/urllib3/util/connection.py +149 -0
  412. venv/Lib/site-packages/pip/_vendor/urllib3/util/proxy.py +57 -0
  413. venv/Lib/site-packages/pip/_vendor/urllib3/util/queue.py +22 -0
  414. venv/Lib/site-packages/pip/_vendor/urllib3/util/request.py +137 -0
  415. venv/Lib/site-packages/pip/_vendor/urllib3/util/response.py +107 -0
  416. venv/Lib/site-packages/pip/_vendor/urllib3/util/retry.py +622 -0
  417. venv/Lib/site-packages/pip/_vendor/urllib3/util/ssl_.py +504 -0
  418. venv/Lib/site-packages/pip/_vendor/urllib3/util/ssl_match_hostname.py +159 -0
  419. venv/Lib/site-packages/pip/_vendor/urllib3/util/ssltransport.py +221 -0
  420. venv/Lib/site-packages/pip/_vendor/urllib3/util/timeout.py +271 -0
  421. venv/Lib/site-packages/pip/_vendor/urllib3/util/url.py +435 -0
  422. venv/Lib/site-packages/pip/_vendor/urllib3/util/wait.py +152 -0
  423. venv/Lib/site-packages/pip/py.typed +4 -0
  424. cli_ih-0.6.3.dist-info/RECORD +0 -8
@@ -0,0 +1,598 @@
1
+ """Dependency Resolution
2
+
3
+ The dependency resolution in pip is performed as follows:
4
+
5
+ for top-level requirements:
6
+ a. only one spec allowed per project, regardless of conflicts or not.
7
+ otherwise a "double requirement" exception is raised
8
+ b. they override sub-dependency requirements.
9
+ for sub-dependencies
10
+ a. "first found, wins" (where the order is breadth first)
11
+ """
12
+
13
+ from __future__ import annotations
14
+
15
+ import logging
16
+ import sys
17
+ from collections import defaultdict
18
+ from collections.abc import Iterable
19
+ from itertools import chain
20
+ from typing import Optional
21
+
22
+ from pip._vendor.packaging import specifiers
23
+ from pip._vendor.packaging.requirements import Requirement
24
+
25
+ from pip._internal.cache import WheelCache
26
+ from pip._internal.exceptions import (
27
+ BestVersionAlreadyInstalled,
28
+ DistributionNotFound,
29
+ HashError,
30
+ HashErrors,
31
+ InstallationError,
32
+ NoneMetadataError,
33
+ UnsupportedPythonVersion,
34
+ )
35
+ from pip._internal.index.package_finder import PackageFinder
36
+ from pip._internal.metadata import BaseDistribution
37
+ from pip._internal.models.link import Link
38
+ from pip._internal.models.wheel import Wheel
39
+ from pip._internal.operations.prepare import RequirementPreparer
40
+ from pip._internal.req.req_install import (
41
+ InstallRequirement,
42
+ check_invalid_constraint_type,
43
+ )
44
+ from pip._internal.req.req_set import RequirementSet
45
+ from pip._internal.resolution.base import BaseResolver, InstallRequirementProvider
46
+ from pip._internal.utils import compatibility_tags
47
+ from pip._internal.utils.compatibility_tags import get_supported
48
+ from pip._internal.utils.direct_url_helpers import direct_url_from_link
49
+ from pip._internal.utils.logging import indent_log
50
+ from pip._internal.utils.misc import normalize_version_info
51
+ from pip._internal.utils.packaging import check_requires_python
52
+
53
+ logger = logging.getLogger(__name__)
54
+
55
+ DiscoveredDependencies = defaultdict[Optional[str], list[InstallRequirement]]
56
+
57
+
58
+ def _check_dist_requires_python(
59
+ dist: BaseDistribution,
60
+ version_info: tuple[int, int, int],
61
+ ignore_requires_python: bool = False,
62
+ ) -> None:
63
+ """
64
+ Check whether the given Python version is compatible with a distribution's
65
+ "Requires-Python" value.
66
+
67
+ :param version_info: A 3-tuple of ints representing the Python
68
+ major-minor-micro version to check.
69
+ :param ignore_requires_python: Whether to ignore the "Requires-Python"
70
+ value if the given Python version isn't compatible.
71
+
72
+ :raises UnsupportedPythonVersion: When the given Python version isn't
73
+ compatible.
74
+ """
75
+ # This idiosyncratically converts the SpecifierSet to str and let
76
+ # check_requires_python then parse it again into SpecifierSet. But this
77
+ # is the legacy resolver so I'm just not going to bother refactoring.
78
+ try:
79
+ requires_python = str(dist.requires_python)
80
+ except FileNotFoundError as e:
81
+ raise NoneMetadataError(dist, str(e))
82
+ try:
83
+ is_compatible = check_requires_python(
84
+ requires_python,
85
+ version_info=version_info,
86
+ )
87
+ except specifiers.InvalidSpecifier as exc:
88
+ logger.warning(
89
+ "Package %r has an invalid Requires-Python: %s", dist.raw_name, exc
90
+ )
91
+ return
92
+
93
+ if is_compatible:
94
+ return
95
+
96
+ version = ".".join(map(str, version_info))
97
+ if ignore_requires_python:
98
+ logger.debug(
99
+ "Ignoring failed Requires-Python check for package %r: %s not in %r",
100
+ dist.raw_name,
101
+ version,
102
+ requires_python,
103
+ )
104
+ return
105
+
106
+ raise UnsupportedPythonVersion(
107
+ f"Package {dist.raw_name!r} requires a different Python: "
108
+ f"{version} not in {requires_python!r}"
109
+ )
110
+
111
+
112
+ class Resolver(BaseResolver):
113
+ """Resolves which packages need to be installed/uninstalled to perform \
114
+ the requested operation without breaking the requirements of any package.
115
+ """
116
+
117
+ _allowed_strategies = {"eager", "only-if-needed", "to-satisfy-only"}
118
+
119
+ def __init__(
120
+ self,
121
+ preparer: RequirementPreparer,
122
+ finder: PackageFinder,
123
+ wheel_cache: WheelCache | None,
124
+ make_install_req: InstallRequirementProvider,
125
+ use_user_site: bool,
126
+ ignore_dependencies: bool,
127
+ ignore_installed: bool,
128
+ ignore_requires_python: bool,
129
+ force_reinstall: bool,
130
+ upgrade_strategy: str,
131
+ py_version_info: tuple[int, ...] | None = None,
132
+ ) -> None:
133
+ super().__init__()
134
+ assert upgrade_strategy in self._allowed_strategies
135
+
136
+ if py_version_info is None:
137
+ py_version_info = sys.version_info[:3]
138
+ else:
139
+ py_version_info = normalize_version_info(py_version_info)
140
+
141
+ self._py_version_info = py_version_info
142
+
143
+ self.preparer = preparer
144
+ self.finder = finder
145
+ self.wheel_cache = wheel_cache
146
+
147
+ self.upgrade_strategy = upgrade_strategy
148
+ self.force_reinstall = force_reinstall
149
+ self.ignore_dependencies = ignore_dependencies
150
+ self.ignore_installed = ignore_installed
151
+ self.ignore_requires_python = ignore_requires_python
152
+ self.use_user_site = use_user_site
153
+ self._make_install_req = make_install_req
154
+
155
+ self._discovered_dependencies: DiscoveredDependencies = defaultdict(list)
156
+
157
+ def resolve(
158
+ self, root_reqs: list[InstallRequirement], check_supported_wheels: bool
159
+ ) -> RequirementSet:
160
+ """Resolve what operations need to be done
161
+
162
+ As a side-effect of this method, the packages (and their dependencies)
163
+ are downloaded, unpacked and prepared for installation. This
164
+ preparation is done by ``pip.operations.prepare``.
165
+
166
+ Once PyPI has static dependency metadata available, it would be
167
+ possible to move the preparation to become a step separated from
168
+ dependency resolution.
169
+ """
170
+ requirement_set = RequirementSet(check_supported_wheels=check_supported_wheels)
171
+ for req in root_reqs:
172
+ if req.constraint:
173
+ check_invalid_constraint_type(req)
174
+ self._add_requirement_to_set(requirement_set, req)
175
+
176
+ # Actually prepare the files, and collect any exceptions. Most hash
177
+ # exceptions cannot be checked ahead of time, because
178
+ # _populate_link() needs to be called before we can make decisions
179
+ # based on link type.
180
+ discovered_reqs: list[InstallRequirement] = []
181
+ hash_errors = HashErrors()
182
+ for req in chain(requirement_set.all_requirements, discovered_reqs):
183
+ try:
184
+ discovered_reqs.extend(self._resolve_one(requirement_set, req))
185
+ except HashError as exc:
186
+ exc.req = req
187
+ hash_errors.append(exc)
188
+
189
+ if hash_errors:
190
+ raise hash_errors
191
+
192
+ return requirement_set
193
+
194
+ def _add_requirement_to_set(
195
+ self,
196
+ requirement_set: RequirementSet,
197
+ install_req: InstallRequirement,
198
+ parent_req_name: str | None = None,
199
+ extras_requested: Iterable[str] | None = None,
200
+ ) -> tuple[list[InstallRequirement], InstallRequirement | None]:
201
+ """Add install_req as a requirement to install.
202
+
203
+ :param parent_req_name: The name of the requirement that needed this
204
+ added. The name is used because when multiple unnamed requirements
205
+ resolve to the same name, we could otherwise end up with dependency
206
+ links that point outside the Requirements set. parent_req must
207
+ already be added. Note that None implies that this is a user
208
+ supplied requirement, vs an inferred one.
209
+ :param extras_requested: an iterable of extras used to evaluate the
210
+ environment markers.
211
+ :return: Additional requirements to scan. That is either [] if
212
+ the requirement is not applicable, or [install_req] if the
213
+ requirement is applicable and has just been added.
214
+ """
215
+ # If the markers do not match, ignore this requirement.
216
+ if not install_req.match_markers(extras_requested):
217
+ logger.info(
218
+ "Ignoring %s: markers '%s' don't match your environment",
219
+ install_req.name,
220
+ install_req.markers,
221
+ )
222
+ return [], None
223
+
224
+ # If the wheel is not supported, raise an error.
225
+ # Should check this after filtering out based on environment markers to
226
+ # allow specifying different wheels based on the environment/OS, in a
227
+ # single requirements file.
228
+ if install_req.link and install_req.link.is_wheel:
229
+ wheel = Wheel(install_req.link.filename)
230
+ tags = compatibility_tags.get_supported()
231
+ if requirement_set.check_supported_wheels and not wheel.supported(tags):
232
+ raise InstallationError(
233
+ f"{wheel.filename} is not a supported wheel on this platform."
234
+ )
235
+
236
+ # This next bit is really a sanity check.
237
+ assert (
238
+ not install_req.user_supplied or parent_req_name is None
239
+ ), "a user supplied req shouldn't have a parent"
240
+
241
+ # Unnamed requirements are scanned again and the requirement won't be
242
+ # added as a dependency until after scanning.
243
+ if not install_req.name:
244
+ requirement_set.add_unnamed_requirement(install_req)
245
+ return [install_req], None
246
+
247
+ try:
248
+ existing_req: InstallRequirement | None = requirement_set.get_requirement(
249
+ install_req.name
250
+ )
251
+ except KeyError:
252
+ existing_req = None
253
+
254
+ has_conflicting_requirement = (
255
+ parent_req_name is None
256
+ and existing_req
257
+ and not existing_req.constraint
258
+ and existing_req.extras == install_req.extras
259
+ and existing_req.req
260
+ and install_req.req
261
+ and existing_req.req.specifier != install_req.req.specifier
262
+ )
263
+ if has_conflicting_requirement:
264
+ raise InstallationError(
265
+ f"Double requirement given: {install_req} "
266
+ f"(already in {existing_req}, name={install_req.name!r})"
267
+ )
268
+
269
+ # When no existing requirement exists, add the requirement as a
270
+ # dependency and it will be scanned again after.
271
+ if not existing_req:
272
+ requirement_set.add_named_requirement(install_req)
273
+ # We'd want to rescan this requirement later
274
+ return [install_req], install_req
275
+
276
+ # Assume there's no need to scan, and that we've already
277
+ # encountered this for scanning.
278
+ if install_req.constraint or not existing_req.constraint:
279
+ return [], existing_req
280
+
281
+ does_not_satisfy_constraint = install_req.link and not (
282
+ existing_req.link and install_req.link.path == existing_req.link.path
283
+ )
284
+ if does_not_satisfy_constraint:
285
+ raise InstallationError(
286
+ f"Could not satisfy constraints for '{install_req.name}': "
287
+ "installation from path or url cannot be "
288
+ "constrained to a version"
289
+ )
290
+ # If we're now installing a constraint, mark the existing
291
+ # object for real installation.
292
+ existing_req.constraint = False
293
+ # If we're now installing a user supplied requirement,
294
+ # mark the existing object as such.
295
+ if install_req.user_supplied:
296
+ existing_req.user_supplied = True
297
+ existing_req.extras = tuple(
298
+ sorted(set(existing_req.extras) | set(install_req.extras))
299
+ )
300
+ logger.debug(
301
+ "Setting %s extras to: %s",
302
+ existing_req,
303
+ existing_req.extras,
304
+ )
305
+ # Return the existing requirement for addition to the parent and
306
+ # scanning again.
307
+ return [existing_req], existing_req
308
+
309
+ def _is_upgrade_allowed(self, req: InstallRequirement) -> bool:
310
+ if self.upgrade_strategy == "to-satisfy-only":
311
+ return False
312
+ elif self.upgrade_strategy == "eager":
313
+ return True
314
+ else:
315
+ assert self.upgrade_strategy == "only-if-needed"
316
+ return req.user_supplied or req.constraint
317
+
318
+ def _set_req_to_reinstall(self, req: InstallRequirement) -> None:
319
+ """
320
+ Set a requirement to be installed.
321
+ """
322
+ # Don't uninstall the conflict if doing a user install and the
323
+ # conflict is not a user install.
324
+ assert req.satisfied_by is not None
325
+ if not self.use_user_site or req.satisfied_by.in_usersite:
326
+ req.should_reinstall = True
327
+ req.satisfied_by = None
328
+
329
+ def _check_skip_installed(self, req_to_install: InstallRequirement) -> str | None:
330
+ """Check if req_to_install should be skipped.
331
+
332
+ This will check if the req is installed, and whether we should upgrade
333
+ or reinstall it, taking into account all the relevant user options.
334
+
335
+ After calling this req_to_install will only have satisfied_by set to
336
+ None if the req_to_install is to be upgraded/reinstalled etc. Any
337
+ other value will be a dist recording the current thing installed that
338
+ satisfies the requirement.
339
+
340
+ Note that for vcs urls and the like we can't assess skipping in this
341
+ routine - we simply identify that we need to pull the thing down,
342
+ then later on it is pulled down and introspected to assess upgrade/
343
+ reinstalls etc.
344
+
345
+ :return: A text reason for why it was skipped, or None.
346
+ """
347
+ if self.ignore_installed:
348
+ return None
349
+
350
+ req_to_install.check_if_exists(self.use_user_site)
351
+ if not req_to_install.satisfied_by:
352
+ return None
353
+
354
+ if self.force_reinstall:
355
+ self._set_req_to_reinstall(req_to_install)
356
+ return None
357
+
358
+ if not self._is_upgrade_allowed(req_to_install):
359
+ if self.upgrade_strategy == "only-if-needed":
360
+ return "already satisfied, skipping upgrade"
361
+ return "already satisfied"
362
+
363
+ # Check for the possibility of an upgrade. For link-based
364
+ # requirements we have to pull the tree down and inspect to assess
365
+ # the version #, so it's handled way down.
366
+ if not req_to_install.link:
367
+ try:
368
+ self.finder.find_requirement(req_to_install, upgrade=True)
369
+ except BestVersionAlreadyInstalled:
370
+ # Then the best version is installed.
371
+ return "already up-to-date"
372
+ except DistributionNotFound:
373
+ # No distribution found, so we squash the error. It will
374
+ # be raised later when we re-try later to do the install.
375
+ # Why don't we just raise here?
376
+ pass
377
+
378
+ self._set_req_to_reinstall(req_to_install)
379
+ return None
380
+
381
+ def _find_requirement_link(self, req: InstallRequirement) -> Link | None:
382
+ upgrade = self._is_upgrade_allowed(req)
383
+ best_candidate = self.finder.find_requirement(req, upgrade)
384
+ if not best_candidate:
385
+ return None
386
+
387
+ # Log a warning per PEP 592 if necessary before returning.
388
+ link = best_candidate.link
389
+ if link.is_yanked:
390
+ reason = link.yanked_reason or "<none given>"
391
+ msg = (
392
+ # Mark this as a unicode string to prevent
393
+ # "UnicodeEncodeError: 'ascii' codec can't encode character"
394
+ # in Python 2 when the reason contains non-ascii characters.
395
+ "The candidate selected for download or install is a "
396
+ f"yanked version: {best_candidate}\n"
397
+ f"Reason for being yanked: {reason}"
398
+ )
399
+ logger.warning(msg)
400
+
401
+ return link
402
+
403
+ def _populate_link(self, req: InstallRequirement) -> None:
404
+ """Ensure that if a link can be found for this, that it is found.
405
+
406
+ Note that req.link may still be None - if the requirement is already
407
+ installed and not needed to be upgraded based on the return value of
408
+ _is_upgrade_allowed().
409
+
410
+ If preparer.require_hashes is True, don't use the wheel cache, because
411
+ cached wheels, always built locally, have different hashes than the
412
+ files downloaded from the index server and thus throw false hash
413
+ mismatches. Furthermore, cached wheels at present have undeterministic
414
+ contents due to file modification times.
415
+ """
416
+ if req.link is None:
417
+ req.link = self._find_requirement_link(req)
418
+
419
+ if self.wheel_cache is None or self.preparer.require_hashes:
420
+ return
421
+
422
+ assert req.link is not None, "_find_requirement_link unexpectedly returned None"
423
+ cache_entry = self.wheel_cache.get_cache_entry(
424
+ link=req.link,
425
+ package_name=req.name,
426
+ supported_tags=get_supported(),
427
+ )
428
+ if cache_entry is not None:
429
+ logger.debug("Using cached wheel link: %s", cache_entry.link)
430
+ if req.link is req.original_link and cache_entry.persistent:
431
+ req.cached_wheel_source_link = req.link
432
+ if cache_entry.origin is not None:
433
+ req.download_info = cache_entry.origin
434
+ else:
435
+ # Legacy cache entry that does not have origin.json.
436
+ # download_info may miss the archive_info.hashes field.
437
+ req.download_info = direct_url_from_link(
438
+ req.link, link_is_in_wheel_cache=cache_entry.persistent
439
+ )
440
+ req.link = cache_entry.link
441
+
442
+ def _get_dist_for(self, req: InstallRequirement) -> BaseDistribution:
443
+ """Takes a InstallRequirement and returns a single AbstractDist \
444
+ representing a prepared variant of the same.
445
+ """
446
+ if req.editable:
447
+ return self.preparer.prepare_editable_requirement(req)
448
+
449
+ # satisfied_by is only evaluated by calling _check_skip_installed,
450
+ # so it must be None here.
451
+ assert req.satisfied_by is None
452
+ skip_reason = self._check_skip_installed(req)
453
+
454
+ if req.satisfied_by:
455
+ return self.preparer.prepare_installed_requirement(req, skip_reason)
456
+
457
+ # We eagerly populate the link, since that's our "legacy" behavior.
458
+ self._populate_link(req)
459
+ dist = self.preparer.prepare_linked_requirement(req)
460
+
461
+ # NOTE
462
+ # The following portion is for determining if a certain package is
463
+ # going to be re-installed/upgraded or not and reporting to the user.
464
+ # This should probably get cleaned up in a future refactor.
465
+
466
+ # req.req is only avail after unpack for URL
467
+ # pkgs repeat check_if_exists to uninstall-on-upgrade
468
+ # (#14)
469
+ if not self.ignore_installed:
470
+ req.check_if_exists(self.use_user_site)
471
+
472
+ if req.satisfied_by:
473
+ should_modify = (
474
+ self.upgrade_strategy != "to-satisfy-only"
475
+ or self.force_reinstall
476
+ or self.ignore_installed
477
+ or req.link.scheme == "file"
478
+ )
479
+ if should_modify:
480
+ self._set_req_to_reinstall(req)
481
+ else:
482
+ logger.info(
483
+ "Requirement already satisfied (use --upgrade to upgrade): %s",
484
+ req,
485
+ )
486
+ return dist
487
+
488
+ def _resolve_one(
489
+ self,
490
+ requirement_set: RequirementSet,
491
+ req_to_install: InstallRequirement,
492
+ ) -> list[InstallRequirement]:
493
+ """Prepare a single requirements file.
494
+
495
+ :return: A list of additional InstallRequirements to also install.
496
+ """
497
+ # Tell user what we are doing for this requirement:
498
+ # obtain (editable), skipping, processing (local url), collecting
499
+ # (remote url or package name)
500
+ if req_to_install.constraint or req_to_install.prepared:
501
+ return []
502
+
503
+ req_to_install.prepared = True
504
+
505
+ # Parse and return dependencies
506
+ dist = self._get_dist_for(req_to_install)
507
+ # This will raise UnsupportedPythonVersion if the given Python
508
+ # version isn't compatible with the distribution's Requires-Python.
509
+ _check_dist_requires_python(
510
+ dist,
511
+ version_info=self._py_version_info,
512
+ ignore_requires_python=self.ignore_requires_python,
513
+ )
514
+
515
+ more_reqs: list[InstallRequirement] = []
516
+
517
+ def add_req(subreq: Requirement, extras_requested: Iterable[str]) -> None:
518
+ # This idiosyncratically converts the Requirement to str and let
519
+ # make_install_req then parse it again into Requirement. But this is
520
+ # the legacy resolver so I'm just not going to bother refactoring.
521
+ sub_install_req = self._make_install_req(str(subreq), req_to_install)
522
+ parent_req_name = req_to_install.name
523
+ to_scan_again, add_to_parent = self._add_requirement_to_set(
524
+ requirement_set,
525
+ sub_install_req,
526
+ parent_req_name=parent_req_name,
527
+ extras_requested=extras_requested,
528
+ )
529
+ if parent_req_name and add_to_parent:
530
+ self._discovered_dependencies[parent_req_name].append(add_to_parent)
531
+ more_reqs.extend(to_scan_again)
532
+
533
+ with indent_log():
534
+ # We add req_to_install before its dependencies, so that we
535
+ # can refer to it when adding dependencies.
536
+ assert req_to_install.name is not None
537
+ if not requirement_set.has_requirement(req_to_install.name):
538
+ # 'unnamed' requirements will get added here
539
+ # 'unnamed' requirements can only come from being directly
540
+ # provided by the user.
541
+ assert req_to_install.user_supplied
542
+ self._add_requirement_to_set(
543
+ requirement_set, req_to_install, parent_req_name=None
544
+ )
545
+
546
+ if not self.ignore_dependencies:
547
+ if req_to_install.extras:
548
+ logger.debug(
549
+ "Installing extra requirements: %r",
550
+ ",".join(req_to_install.extras),
551
+ )
552
+ missing_requested = sorted(
553
+ set(req_to_install.extras) - set(dist.iter_provided_extras())
554
+ )
555
+ for missing in missing_requested:
556
+ logger.warning(
557
+ "%s %s does not provide the extra '%s'",
558
+ dist.raw_name,
559
+ dist.version,
560
+ missing,
561
+ )
562
+
563
+ available_requested = sorted(
564
+ set(dist.iter_provided_extras()) & set(req_to_install.extras)
565
+ )
566
+ for subreq in dist.iter_dependencies(available_requested):
567
+ add_req(subreq, extras_requested=available_requested)
568
+
569
+ return more_reqs
570
+
571
+ def get_installation_order(
572
+ self, req_set: RequirementSet
573
+ ) -> list[InstallRequirement]:
574
+ """Create the installation order.
575
+
576
+ The installation order is topological - requirements are installed
577
+ before the requiring thing. We break cycles at an arbitrary point,
578
+ and make no other guarantees.
579
+ """
580
+ # The current implementation, which we may change at any point
581
+ # installs the user specified things in the order given, except when
582
+ # dependencies must come earlier to achieve topological order.
583
+ order = []
584
+ ordered_reqs: set[InstallRequirement] = set()
585
+
586
+ def schedule(req: InstallRequirement) -> None:
587
+ if req.satisfied_by or req in ordered_reqs:
588
+ return
589
+ if req.constraint:
590
+ return
591
+ ordered_reqs.add(req)
592
+ for dep in self._discovered_dependencies[req.name]:
593
+ schedule(dep)
594
+ order.append(req)
595
+
596
+ for install_req in req_set.requirements.values():
597
+ schedule(install_req)
598
+ return order