cli-ih 0.6.3.1__py3-none-any.whl → 0.7.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 (427) hide show
  1. cli_ih/__init__.py +1 -0
  2. cli_ih/asyncClient.py +109 -10
  3. cli_ih/client.py +110 -18
  4. cli_ih/utils.py +51 -0
  5. cli_ih-0.7.1.dist-info/METADATA +100 -0
  6. cli_ih-0.7.1.dist-info/RECORD +9 -0
  7. {cli_ih-0.6.3.1.dist-info → cli_ih-0.7.1.dist-info}/top_level.txt +0 -1
  8. cli_ih-0.6.3.1.dist-info/METADATA +0 -86
  9. cli_ih-0.6.3.1.dist-info/RECORD +0 -425
  10. venv/Lib/site-packages/__editable___cli_ih_0_6_3_1_finder.py +0 -85
  11. venv/Lib/site-packages/pip/__init__.py +0 -13
  12. venv/Lib/site-packages/pip/__main__.py +0 -24
  13. venv/Lib/site-packages/pip/__pip-runner__.py +0 -50
  14. venv/Lib/site-packages/pip/_internal/__init__.py +0 -18
  15. venv/Lib/site-packages/pip/_internal/build_env.py +0 -349
  16. venv/Lib/site-packages/pip/_internal/cache.py +0 -291
  17. venv/Lib/site-packages/pip/_internal/cli/__init__.py +0 -3
  18. venv/Lib/site-packages/pip/_internal/cli/autocompletion.py +0 -184
  19. venv/Lib/site-packages/pip/_internal/cli/base_command.py +0 -244
  20. venv/Lib/site-packages/pip/_internal/cli/cmdoptions.py +0 -1138
  21. venv/Lib/site-packages/pip/_internal/cli/command_context.py +0 -28
  22. venv/Lib/site-packages/pip/_internal/cli/index_command.py +0 -175
  23. venv/Lib/site-packages/pip/_internal/cli/main.py +0 -80
  24. venv/Lib/site-packages/pip/_internal/cli/main_parser.py +0 -134
  25. venv/Lib/site-packages/pip/_internal/cli/parser.py +0 -298
  26. venv/Lib/site-packages/pip/_internal/cli/progress_bars.py +0 -151
  27. venv/Lib/site-packages/pip/_internal/cli/req_command.py +0 -351
  28. venv/Lib/site-packages/pip/_internal/cli/spinners.py +0 -235
  29. venv/Lib/site-packages/pip/_internal/cli/status_codes.py +0 -6
  30. venv/Lib/site-packages/pip/_internal/commands/__init__.py +0 -139
  31. venv/Lib/site-packages/pip/_internal/commands/cache.py +0 -231
  32. venv/Lib/site-packages/pip/_internal/commands/check.py +0 -66
  33. venv/Lib/site-packages/pip/_internal/commands/completion.py +0 -135
  34. venv/Lib/site-packages/pip/_internal/commands/configuration.py +0 -288
  35. venv/Lib/site-packages/pip/_internal/commands/debug.py +0 -203
  36. venv/Lib/site-packages/pip/_internal/commands/download.py +0 -145
  37. venv/Lib/site-packages/pip/_internal/commands/freeze.py +0 -107
  38. venv/Lib/site-packages/pip/_internal/commands/hash.py +0 -58
  39. venv/Lib/site-packages/pip/_internal/commands/help.py +0 -40
  40. venv/Lib/site-packages/pip/_internal/commands/index.py +0 -159
  41. venv/Lib/site-packages/pip/_internal/commands/inspect.py +0 -92
  42. venv/Lib/site-packages/pip/_internal/commands/install.py +0 -798
  43. venv/Lib/site-packages/pip/_internal/commands/list.py +0 -400
  44. venv/Lib/site-packages/pip/_internal/commands/lock.py +0 -170
  45. venv/Lib/site-packages/pip/_internal/commands/search.py +0 -178
  46. venv/Lib/site-packages/pip/_internal/commands/show.py +0 -231
  47. venv/Lib/site-packages/pip/_internal/commands/uninstall.py +0 -113
  48. venv/Lib/site-packages/pip/_internal/commands/wheel.py +0 -181
  49. venv/Lib/site-packages/pip/_internal/configuration.py +0 -397
  50. venv/Lib/site-packages/pip/_internal/distributions/__init__.py +0 -21
  51. venv/Lib/site-packages/pip/_internal/distributions/base.py +0 -55
  52. venv/Lib/site-packages/pip/_internal/distributions/installed.py +0 -33
  53. venv/Lib/site-packages/pip/_internal/distributions/sdist.py +0 -165
  54. venv/Lib/site-packages/pip/_internal/distributions/wheel.py +0 -44
  55. venv/Lib/site-packages/pip/_internal/exceptions.py +0 -881
  56. venv/Lib/site-packages/pip/_internal/index/__init__.py +0 -1
  57. venv/Lib/site-packages/pip/_internal/index/collector.py +0 -489
  58. venv/Lib/site-packages/pip/_internal/index/package_finder.py +0 -1059
  59. venv/Lib/site-packages/pip/_internal/index/sources.py +0 -287
  60. venv/Lib/site-packages/pip/_internal/locations/__init__.py +0 -441
  61. venv/Lib/site-packages/pip/_internal/locations/_distutils.py +0 -173
  62. venv/Lib/site-packages/pip/_internal/locations/_sysconfig.py +0 -215
  63. venv/Lib/site-packages/pip/_internal/locations/base.py +0 -82
  64. venv/Lib/site-packages/pip/_internal/main.py +0 -12
  65. venv/Lib/site-packages/pip/_internal/metadata/__init__.py +0 -164
  66. venv/Lib/site-packages/pip/_internal/metadata/_json.py +0 -87
  67. venv/Lib/site-packages/pip/_internal/metadata/base.py +0 -685
  68. venv/Lib/site-packages/pip/_internal/metadata/importlib/__init__.py +0 -6
  69. venv/Lib/site-packages/pip/_internal/metadata/importlib/_compat.py +0 -87
  70. venv/Lib/site-packages/pip/_internal/metadata/importlib/_dists.py +0 -223
  71. venv/Lib/site-packages/pip/_internal/metadata/importlib/_envs.py +0 -143
  72. venv/Lib/site-packages/pip/_internal/metadata/pkg_resources.py +0 -298
  73. venv/Lib/site-packages/pip/_internal/models/__init__.py +0 -1
  74. venv/Lib/site-packages/pip/_internal/models/candidate.py +0 -25
  75. venv/Lib/site-packages/pip/_internal/models/direct_url.py +0 -227
  76. venv/Lib/site-packages/pip/_internal/models/format_control.py +0 -78
  77. venv/Lib/site-packages/pip/_internal/models/index.py +0 -28
  78. venv/Lib/site-packages/pip/_internal/models/installation_report.py +0 -57
  79. venv/Lib/site-packages/pip/_internal/models/link.py +0 -613
  80. venv/Lib/site-packages/pip/_internal/models/pylock.py +0 -188
  81. venv/Lib/site-packages/pip/_internal/models/scheme.py +0 -25
  82. venv/Lib/site-packages/pip/_internal/models/search_scope.py +0 -126
  83. venv/Lib/site-packages/pip/_internal/models/selection_prefs.py +0 -53
  84. venv/Lib/site-packages/pip/_internal/models/target_python.py +0 -122
  85. venv/Lib/site-packages/pip/_internal/models/wheel.py +0 -141
  86. venv/Lib/site-packages/pip/_internal/network/__init__.py +0 -1
  87. venv/Lib/site-packages/pip/_internal/network/auth.py +0 -564
  88. venv/Lib/site-packages/pip/_internal/network/cache.py +0 -133
  89. venv/Lib/site-packages/pip/_internal/network/download.py +0 -342
  90. venv/Lib/site-packages/pip/_internal/network/lazy_wheel.py +0 -213
  91. venv/Lib/site-packages/pip/_internal/network/session.py +0 -528
  92. venv/Lib/site-packages/pip/_internal/network/utils.py +0 -98
  93. venv/Lib/site-packages/pip/_internal/network/xmlrpc.py +0 -61
  94. venv/Lib/site-packages/pip/_internal/operations/__init__.py +0 -0
  95. venv/Lib/site-packages/pip/_internal/operations/build/__init__.py +0 -0
  96. venv/Lib/site-packages/pip/_internal/operations/build/build_tracker.py +0 -140
  97. venv/Lib/site-packages/pip/_internal/operations/build/metadata.py +0 -38
  98. venv/Lib/site-packages/pip/_internal/operations/build/metadata_editable.py +0 -41
  99. venv/Lib/site-packages/pip/_internal/operations/build/metadata_legacy.py +0 -73
  100. venv/Lib/site-packages/pip/_internal/operations/build/wheel.py +0 -38
  101. venv/Lib/site-packages/pip/_internal/operations/build/wheel_editable.py +0 -47
  102. venv/Lib/site-packages/pip/_internal/operations/build/wheel_legacy.py +0 -119
  103. venv/Lib/site-packages/pip/_internal/operations/check.py +0 -175
  104. venv/Lib/site-packages/pip/_internal/operations/freeze.py +0 -259
  105. venv/Lib/site-packages/pip/_internal/operations/install/__init__.py +0 -1
  106. venv/Lib/site-packages/pip/_internal/operations/install/editable_legacy.py +0 -48
  107. venv/Lib/site-packages/pip/_internal/operations/install/wheel.py +0 -746
  108. venv/Lib/site-packages/pip/_internal/operations/prepare.py +0 -742
  109. venv/Lib/site-packages/pip/_internal/pyproject.py +0 -182
  110. venv/Lib/site-packages/pip/_internal/req/__init__.py +0 -105
  111. venv/Lib/site-packages/pip/_internal/req/constructors.py +0 -562
  112. venv/Lib/site-packages/pip/_internal/req/req_dependency_group.py +0 -75
  113. venv/Lib/site-packages/pip/_internal/req/req_file.py +0 -620
  114. venv/Lib/site-packages/pip/_internal/req/req_install.py +0 -937
  115. venv/Lib/site-packages/pip/_internal/req/req_set.py +0 -81
  116. venv/Lib/site-packages/pip/_internal/req/req_uninstall.py +0 -639
  117. venv/Lib/site-packages/pip/_internal/resolution/__init__.py +0 -0
  118. venv/Lib/site-packages/pip/_internal/resolution/base.py +0 -20
  119. venv/Lib/site-packages/pip/_internal/resolution/legacy/__init__.py +0 -0
  120. venv/Lib/site-packages/pip/_internal/resolution/legacy/resolver.py +0 -598
  121. venv/Lib/site-packages/pip/_internal/resolution/resolvelib/__init__.py +0 -0
  122. venv/Lib/site-packages/pip/_internal/resolution/resolvelib/base.py +0 -142
  123. venv/Lib/site-packages/pip/_internal/resolution/resolvelib/candidates.py +0 -582
  124. venv/Lib/site-packages/pip/_internal/resolution/resolvelib/factory.py +0 -814
  125. venv/Lib/site-packages/pip/_internal/resolution/resolvelib/found_candidates.py +0 -166
  126. venv/Lib/site-packages/pip/_internal/resolution/resolvelib/provider.py +0 -276
  127. venv/Lib/site-packages/pip/_internal/resolution/resolvelib/reporter.py +0 -85
  128. venv/Lib/site-packages/pip/_internal/resolution/resolvelib/requirements.py +0 -247
  129. venv/Lib/site-packages/pip/_internal/resolution/resolvelib/resolver.py +0 -336
  130. venv/Lib/site-packages/pip/_internal/self_outdated_check.py +0 -254
  131. venv/Lib/site-packages/pip/_internal/utils/__init__.py +0 -0
  132. venv/Lib/site-packages/pip/_internal/utils/_jaraco_text.py +0 -109
  133. venv/Lib/site-packages/pip/_internal/utils/_log.py +0 -38
  134. venv/Lib/site-packages/pip/_internal/utils/appdirs.py +0 -52
  135. venv/Lib/site-packages/pip/_internal/utils/compat.py +0 -85
  136. venv/Lib/site-packages/pip/_internal/utils/compatibility_tags.py +0 -201
  137. venv/Lib/site-packages/pip/_internal/utils/datetime.py +0 -10
  138. venv/Lib/site-packages/pip/_internal/utils/deprecation.py +0 -126
  139. venv/Lib/site-packages/pip/_internal/utils/direct_url_helpers.py +0 -87
  140. venv/Lib/site-packages/pip/_internal/utils/egg_link.py +0 -81
  141. venv/Lib/site-packages/pip/_internal/utils/entrypoints.py +0 -88
  142. venv/Lib/site-packages/pip/_internal/utils/filesystem.py +0 -152
  143. venv/Lib/site-packages/pip/_internal/utils/filetypes.py +0 -24
  144. venv/Lib/site-packages/pip/_internal/utils/glibc.py +0 -102
  145. venv/Lib/site-packages/pip/_internal/utils/hashes.py +0 -150
  146. venv/Lib/site-packages/pip/_internal/utils/logging.py +0 -364
  147. venv/Lib/site-packages/pip/_internal/utils/misc.py +0 -765
  148. venv/Lib/site-packages/pip/_internal/utils/packaging.py +0 -44
  149. venv/Lib/site-packages/pip/_internal/utils/retry.py +0 -45
  150. venv/Lib/site-packages/pip/_internal/utils/setuptools_build.py +0 -149
  151. venv/Lib/site-packages/pip/_internal/utils/subprocess.py +0 -248
  152. venv/Lib/site-packages/pip/_internal/utils/temp_dir.py +0 -294
  153. venv/Lib/site-packages/pip/_internal/utils/unpacking.py +0 -337
  154. venv/Lib/site-packages/pip/_internal/utils/urls.py +0 -55
  155. venv/Lib/site-packages/pip/_internal/utils/virtualenv.py +0 -105
  156. venv/Lib/site-packages/pip/_internal/utils/wheel.py +0 -132
  157. venv/Lib/site-packages/pip/_internal/vcs/__init__.py +0 -15
  158. venv/Lib/site-packages/pip/_internal/vcs/bazaar.py +0 -130
  159. venv/Lib/site-packages/pip/_internal/vcs/git.py +0 -571
  160. venv/Lib/site-packages/pip/_internal/vcs/mercurial.py +0 -186
  161. venv/Lib/site-packages/pip/_internal/vcs/subversion.py +0 -335
  162. venv/Lib/site-packages/pip/_internal/vcs/versioncontrol.py +0 -693
  163. venv/Lib/site-packages/pip/_internal/wheel_builder.py +0 -334
  164. venv/Lib/site-packages/pip/_vendor/__init__.py +0 -117
  165. venv/Lib/site-packages/pip/_vendor/cachecontrol/__init__.py +0 -29
  166. venv/Lib/site-packages/pip/_vendor/cachecontrol/_cmd.py +0 -70
  167. venv/Lib/site-packages/pip/_vendor/cachecontrol/adapter.py +0 -168
  168. venv/Lib/site-packages/pip/_vendor/cachecontrol/cache.py +0 -75
  169. venv/Lib/site-packages/pip/_vendor/cachecontrol/caches/__init__.py +0 -8
  170. venv/Lib/site-packages/pip/_vendor/cachecontrol/caches/file_cache.py +0 -145
  171. venv/Lib/site-packages/pip/_vendor/cachecontrol/caches/redis_cache.py +0 -48
  172. venv/Lib/site-packages/pip/_vendor/cachecontrol/controller.py +0 -511
  173. venv/Lib/site-packages/pip/_vendor/cachecontrol/filewrapper.py +0 -119
  174. venv/Lib/site-packages/pip/_vendor/cachecontrol/heuristics.py +0 -157
  175. venv/Lib/site-packages/pip/_vendor/cachecontrol/py.typed +0 -0
  176. venv/Lib/site-packages/pip/_vendor/cachecontrol/serialize.py +0 -146
  177. venv/Lib/site-packages/pip/_vendor/cachecontrol/wrapper.py +0 -43
  178. venv/Lib/site-packages/pip/_vendor/certifi/__init__.py +0 -4
  179. venv/Lib/site-packages/pip/_vendor/certifi/__main__.py +0 -12
  180. venv/Lib/site-packages/pip/_vendor/certifi/core.py +0 -83
  181. venv/Lib/site-packages/pip/_vendor/certifi/py.typed +0 -0
  182. venv/Lib/site-packages/pip/_vendor/dependency_groups/__init__.py +0 -13
  183. venv/Lib/site-packages/pip/_vendor/dependency_groups/__main__.py +0 -65
  184. venv/Lib/site-packages/pip/_vendor/dependency_groups/_implementation.py +0 -209
  185. venv/Lib/site-packages/pip/_vendor/dependency_groups/_lint_dependency_groups.py +0 -59
  186. venv/Lib/site-packages/pip/_vendor/dependency_groups/_pip_wrapper.py +0 -62
  187. venv/Lib/site-packages/pip/_vendor/dependency_groups/_toml_compat.py +0 -9
  188. venv/Lib/site-packages/pip/_vendor/dependency_groups/py.typed +0 -0
  189. venv/Lib/site-packages/pip/_vendor/distlib/__init__.py +0 -33
  190. venv/Lib/site-packages/pip/_vendor/distlib/compat.py +0 -1137
  191. venv/Lib/site-packages/pip/_vendor/distlib/resources.py +0 -358
  192. venv/Lib/site-packages/pip/_vendor/distlib/scripts.py +0 -447
  193. venv/Lib/site-packages/pip/_vendor/distlib/util.py +0 -1984
  194. venv/Lib/site-packages/pip/_vendor/distro/__init__.py +0 -54
  195. venv/Lib/site-packages/pip/_vendor/distro/__main__.py +0 -4
  196. venv/Lib/site-packages/pip/_vendor/distro/distro.py +0 -1403
  197. venv/Lib/site-packages/pip/_vendor/distro/py.typed +0 -0
  198. venv/Lib/site-packages/pip/_vendor/idna/__init__.py +0 -45
  199. venv/Lib/site-packages/pip/_vendor/idna/codec.py +0 -122
  200. venv/Lib/site-packages/pip/_vendor/idna/compat.py +0 -15
  201. venv/Lib/site-packages/pip/_vendor/idna/core.py +0 -437
  202. venv/Lib/site-packages/pip/_vendor/idna/idnadata.py +0 -4243
  203. venv/Lib/site-packages/pip/_vendor/idna/intranges.py +0 -57
  204. venv/Lib/site-packages/pip/_vendor/idna/package_data.py +0 -1
  205. venv/Lib/site-packages/pip/_vendor/idna/py.typed +0 -0
  206. venv/Lib/site-packages/pip/_vendor/idna/uts46data.py +0 -8681
  207. venv/Lib/site-packages/pip/_vendor/msgpack/__init__.py +0 -55
  208. venv/Lib/site-packages/pip/_vendor/msgpack/exceptions.py +0 -48
  209. venv/Lib/site-packages/pip/_vendor/msgpack/ext.py +0 -170
  210. venv/Lib/site-packages/pip/_vendor/msgpack/fallback.py +0 -929
  211. venv/Lib/site-packages/pip/_vendor/packaging/__init__.py +0 -15
  212. venv/Lib/site-packages/pip/_vendor/packaging/_elffile.py +0 -109
  213. venv/Lib/site-packages/pip/_vendor/packaging/_manylinux.py +0 -262
  214. venv/Lib/site-packages/pip/_vendor/packaging/_musllinux.py +0 -85
  215. venv/Lib/site-packages/pip/_vendor/packaging/_parser.py +0 -353
  216. venv/Lib/site-packages/pip/_vendor/packaging/_structures.py +0 -61
  217. venv/Lib/site-packages/pip/_vendor/packaging/_tokenizer.py +0 -195
  218. venv/Lib/site-packages/pip/_vendor/packaging/licenses/__init__.py +0 -145
  219. venv/Lib/site-packages/pip/_vendor/packaging/licenses/_spdx.py +0 -759
  220. venv/Lib/site-packages/pip/_vendor/packaging/markers.py +0 -362
  221. venv/Lib/site-packages/pip/_vendor/packaging/metadata.py +0 -862
  222. venv/Lib/site-packages/pip/_vendor/packaging/py.typed +0 -0
  223. venv/Lib/site-packages/pip/_vendor/packaging/requirements.py +0 -91
  224. venv/Lib/site-packages/pip/_vendor/packaging/specifiers.py +0 -1019
  225. venv/Lib/site-packages/pip/_vendor/packaging/tags.py +0 -656
  226. venv/Lib/site-packages/pip/_vendor/packaging/utils.py +0 -163
  227. venv/Lib/site-packages/pip/_vendor/packaging/version.py +0 -582
  228. venv/Lib/site-packages/pip/_vendor/pkg_resources/__init__.py +0 -3676
  229. venv/Lib/site-packages/pip/_vendor/platformdirs/__init__.py +0 -631
  230. venv/Lib/site-packages/pip/_vendor/platformdirs/__main__.py +0 -55
  231. venv/Lib/site-packages/pip/_vendor/platformdirs/android.py +0 -249
  232. venv/Lib/site-packages/pip/_vendor/platformdirs/api.py +0 -299
  233. venv/Lib/site-packages/pip/_vendor/platformdirs/macos.py +0 -144
  234. venv/Lib/site-packages/pip/_vendor/platformdirs/py.typed +0 -0
  235. venv/Lib/site-packages/pip/_vendor/platformdirs/unix.py +0 -272
  236. venv/Lib/site-packages/pip/_vendor/platformdirs/version.py +0 -21
  237. venv/Lib/site-packages/pip/_vendor/platformdirs/windows.py +0 -272
  238. venv/Lib/site-packages/pip/_vendor/pygments/__init__.py +0 -82
  239. venv/Lib/site-packages/pip/_vendor/pygments/__main__.py +0 -17
  240. venv/Lib/site-packages/pip/_vendor/pygments/console.py +0 -70
  241. venv/Lib/site-packages/pip/_vendor/pygments/filter.py +0 -70
  242. venv/Lib/site-packages/pip/_vendor/pygments/filters/__init__.py +0 -940
  243. venv/Lib/site-packages/pip/_vendor/pygments/formatter.py +0 -129
  244. venv/Lib/site-packages/pip/_vendor/pygments/formatters/__init__.py +0 -157
  245. venv/Lib/site-packages/pip/_vendor/pygments/formatters/_mapping.py +0 -23
  246. venv/Lib/site-packages/pip/_vendor/pygments/lexer.py +0 -963
  247. venv/Lib/site-packages/pip/_vendor/pygments/lexers/__init__.py +0 -362
  248. venv/Lib/site-packages/pip/_vendor/pygments/lexers/_mapping.py +0 -602
  249. venv/Lib/site-packages/pip/_vendor/pygments/lexers/python.py +0 -1201
  250. venv/Lib/site-packages/pip/_vendor/pygments/modeline.py +0 -43
  251. venv/Lib/site-packages/pip/_vendor/pygments/plugin.py +0 -72
  252. venv/Lib/site-packages/pip/_vendor/pygments/regexopt.py +0 -91
  253. venv/Lib/site-packages/pip/_vendor/pygments/scanner.py +0 -104
  254. venv/Lib/site-packages/pip/_vendor/pygments/sphinxext.py +0 -247
  255. venv/Lib/site-packages/pip/_vendor/pygments/style.py +0 -203
  256. venv/Lib/site-packages/pip/_vendor/pygments/styles/__init__.py +0 -61
  257. venv/Lib/site-packages/pip/_vendor/pygments/styles/_mapping.py +0 -54
  258. venv/Lib/site-packages/pip/_vendor/pygments/token.py +0 -214
  259. venv/Lib/site-packages/pip/_vendor/pygments/unistring.py +0 -153
  260. venv/Lib/site-packages/pip/_vendor/pygments/util.py +0 -324
  261. venv/Lib/site-packages/pip/_vendor/pyproject_hooks/__init__.py +0 -31
  262. venv/Lib/site-packages/pip/_vendor/pyproject_hooks/_impl.py +0 -410
  263. venv/Lib/site-packages/pip/_vendor/pyproject_hooks/_in_process/__init__.py +0 -21
  264. venv/Lib/site-packages/pip/_vendor/pyproject_hooks/_in_process/_in_process.py +0 -389
  265. venv/Lib/site-packages/pip/_vendor/pyproject_hooks/py.typed +0 -0
  266. venv/Lib/site-packages/pip/_vendor/requests/__init__.py +0 -179
  267. venv/Lib/site-packages/pip/_vendor/requests/__version__.py +0 -14
  268. venv/Lib/site-packages/pip/_vendor/requests/_internal_utils.py +0 -50
  269. venv/Lib/site-packages/pip/_vendor/requests/adapters.py +0 -719
  270. venv/Lib/site-packages/pip/_vendor/requests/api.py +0 -157
  271. venv/Lib/site-packages/pip/_vendor/requests/auth.py +0 -314
  272. venv/Lib/site-packages/pip/_vendor/requests/certs.py +0 -17
  273. venv/Lib/site-packages/pip/_vendor/requests/compat.py +0 -90
  274. venv/Lib/site-packages/pip/_vendor/requests/cookies.py +0 -561
  275. venv/Lib/site-packages/pip/_vendor/requests/exceptions.py +0 -151
  276. venv/Lib/site-packages/pip/_vendor/requests/help.py +0 -127
  277. venv/Lib/site-packages/pip/_vendor/requests/hooks.py +0 -33
  278. venv/Lib/site-packages/pip/_vendor/requests/models.py +0 -1039
  279. venv/Lib/site-packages/pip/_vendor/requests/packages.py +0 -25
  280. venv/Lib/site-packages/pip/_vendor/requests/sessions.py +0 -831
  281. venv/Lib/site-packages/pip/_vendor/requests/status_codes.py +0 -128
  282. venv/Lib/site-packages/pip/_vendor/requests/structures.py +0 -99
  283. venv/Lib/site-packages/pip/_vendor/requests/utils.py +0 -1086
  284. venv/Lib/site-packages/pip/_vendor/resolvelib/__init__.py +0 -27
  285. venv/Lib/site-packages/pip/_vendor/resolvelib/providers.py +0 -196
  286. venv/Lib/site-packages/pip/_vendor/resolvelib/py.typed +0 -0
  287. venv/Lib/site-packages/pip/_vendor/resolvelib/reporters.py +0 -55
  288. venv/Lib/site-packages/pip/_vendor/resolvelib/resolvers/__init__.py +0 -27
  289. venv/Lib/site-packages/pip/_vendor/resolvelib/resolvers/abstract.py +0 -47
  290. venv/Lib/site-packages/pip/_vendor/resolvelib/resolvers/criterion.py +0 -48
  291. venv/Lib/site-packages/pip/_vendor/resolvelib/resolvers/exceptions.py +0 -57
  292. venv/Lib/site-packages/pip/_vendor/resolvelib/resolvers/resolution.py +0 -622
  293. venv/Lib/site-packages/pip/_vendor/resolvelib/structs.py +0 -209
  294. venv/Lib/site-packages/pip/_vendor/rich/__init__.py +0 -177
  295. venv/Lib/site-packages/pip/_vendor/rich/__main__.py +0 -245
  296. venv/Lib/site-packages/pip/_vendor/rich/_cell_widths.py +0 -454
  297. venv/Lib/site-packages/pip/_vendor/rich/_emoji_codes.py +0 -3610
  298. venv/Lib/site-packages/pip/_vendor/rich/_emoji_replace.py +0 -32
  299. venv/Lib/site-packages/pip/_vendor/rich/_export_format.py +0 -76
  300. venv/Lib/site-packages/pip/_vendor/rich/_extension.py +0 -10
  301. venv/Lib/site-packages/pip/_vendor/rich/_fileno.py +0 -24
  302. venv/Lib/site-packages/pip/_vendor/rich/_inspect.py +0 -268
  303. venv/Lib/site-packages/pip/_vendor/rich/_log_render.py +0 -94
  304. venv/Lib/site-packages/pip/_vendor/rich/_loop.py +0 -43
  305. venv/Lib/site-packages/pip/_vendor/rich/_null_file.py +0 -69
  306. venv/Lib/site-packages/pip/_vendor/rich/_palettes.py +0 -309
  307. venv/Lib/site-packages/pip/_vendor/rich/_pick.py +0 -17
  308. venv/Lib/site-packages/pip/_vendor/rich/_ratio.py +0 -153
  309. venv/Lib/site-packages/pip/_vendor/rich/_spinners.py +0 -482
  310. venv/Lib/site-packages/pip/_vendor/rich/_stack.py +0 -16
  311. venv/Lib/site-packages/pip/_vendor/rich/_timer.py +0 -19
  312. venv/Lib/site-packages/pip/_vendor/rich/_win32_console.py +0 -661
  313. venv/Lib/site-packages/pip/_vendor/rich/_windows.py +0 -71
  314. venv/Lib/site-packages/pip/_vendor/rich/_windows_renderer.py +0 -56
  315. venv/Lib/site-packages/pip/_vendor/rich/_wrap.py +0 -93
  316. venv/Lib/site-packages/pip/_vendor/rich/abc.py +0 -33
  317. venv/Lib/site-packages/pip/_vendor/rich/align.py +0 -306
  318. venv/Lib/site-packages/pip/_vendor/rich/ansi.py +0 -241
  319. venv/Lib/site-packages/pip/_vendor/rich/bar.py +0 -93
  320. venv/Lib/site-packages/pip/_vendor/rich/box.py +0 -474
  321. venv/Lib/site-packages/pip/_vendor/rich/cells.py +0 -174
  322. venv/Lib/site-packages/pip/_vendor/rich/color.py +0 -621
  323. venv/Lib/site-packages/pip/_vendor/rich/color_triplet.py +0 -38
  324. venv/Lib/site-packages/pip/_vendor/rich/columns.py +0 -187
  325. venv/Lib/site-packages/pip/_vendor/rich/console.py +0 -2680
  326. venv/Lib/site-packages/pip/_vendor/rich/constrain.py +0 -37
  327. venv/Lib/site-packages/pip/_vendor/rich/containers.py +0 -167
  328. venv/Lib/site-packages/pip/_vendor/rich/control.py +0 -219
  329. venv/Lib/site-packages/pip/_vendor/rich/default_styles.py +0 -193
  330. venv/Lib/site-packages/pip/_vendor/rich/diagnose.py +0 -39
  331. venv/Lib/site-packages/pip/_vendor/rich/emoji.py +0 -91
  332. venv/Lib/site-packages/pip/_vendor/rich/errors.py +0 -34
  333. venv/Lib/site-packages/pip/_vendor/rich/file_proxy.py +0 -57
  334. venv/Lib/site-packages/pip/_vendor/rich/filesize.py +0 -88
  335. venv/Lib/site-packages/pip/_vendor/rich/highlighter.py +0 -232
  336. venv/Lib/site-packages/pip/_vendor/rich/json.py +0 -139
  337. venv/Lib/site-packages/pip/_vendor/rich/jupyter.py +0 -101
  338. venv/Lib/site-packages/pip/_vendor/rich/layout.py +0 -442
  339. venv/Lib/site-packages/pip/_vendor/rich/live.py +0 -400
  340. venv/Lib/site-packages/pip/_vendor/rich/live_render.py +0 -106
  341. venv/Lib/site-packages/pip/_vendor/rich/logging.py +0 -297
  342. venv/Lib/site-packages/pip/_vendor/rich/markup.py +0 -251
  343. venv/Lib/site-packages/pip/_vendor/rich/measure.py +0 -151
  344. venv/Lib/site-packages/pip/_vendor/rich/padding.py +0 -141
  345. venv/Lib/site-packages/pip/_vendor/rich/pager.py +0 -34
  346. venv/Lib/site-packages/pip/_vendor/rich/palette.py +0 -100
  347. venv/Lib/site-packages/pip/_vendor/rich/panel.py +0 -317
  348. venv/Lib/site-packages/pip/_vendor/rich/pretty.py +0 -1016
  349. venv/Lib/site-packages/pip/_vendor/rich/progress.py +0 -1715
  350. venv/Lib/site-packages/pip/_vendor/rich/progress_bar.py +0 -223
  351. venv/Lib/site-packages/pip/_vendor/rich/prompt.py +0 -400
  352. venv/Lib/site-packages/pip/_vendor/rich/protocol.py +0 -42
  353. venv/Lib/site-packages/pip/_vendor/rich/py.typed +0 -0
  354. venv/Lib/site-packages/pip/_vendor/rich/region.py +0 -10
  355. venv/Lib/site-packages/pip/_vendor/rich/repr.py +0 -149
  356. venv/Lib/site-packages/pip/_vendor/rich/rule.py +0 -130
  357. venv/Lib/site-packages/pip/_vendor/rich/scope.py +0 -86
  358. venv/Lib/site-packages/pip/_vendor/rich/screen.py +0 -54
  359. venv/Lib/site-packages/pip/_vendor/rich/segment.py +0 -752
  360. venv/Lib/site-packages/pip/_vendor/rich/spinner.py +0 -132
  361. venv/Lib/site-packages/pip/_vendor/rich/status.py +0 -131
  362. venv/Lib/site-packages/pip/_vendor/rich/style.py +0 -796
  363. venv/Lib/site-packages/pip/_vendor/rich/styled.py +0 -42
  364. venv/Lib/site-packages/pip/_vendor/rich/syntax.py +0 -985
  365. venv/Lib/site-packages/pip/_vendor/rich/table.py +0 -1006
  366. venv/Lib/site-packages/pip/_vendor/rich/terminal_theme.py +0 -153
  367. venv/Lib/site-packages/pip/_vendor/rich/text.py +0 -1361
  368. venv/Lib/site-packages/pip/_vendor/rich/theme.py +0 -115
  369. venv/Lib/site-packages/pip/_vendor/rich/themes.py +0 -5
  370. venv/Lib/site-packages/pip/_vendor/rich/traceback.py +0 -899
  371. venv/Lib/site-packages/pip/_vendor/rich/tree.py +0 -257
  372. venv/Lib/site-packages/pip/_vendor/tomli/__init__.py +0 -8
  373. venv/Lib/site-packages/pip/_vendor/tomli/_parser.py +0 -770
  374. venv/Lib/site-packages/pip/_vendor/tomli/_re.py +0 -112
  375. venv/Lib/site-packages/pip/_vendor/tomli/_types.py +0 -10
  376. venv/Lib/site-packages/pip/_vendor/tomli/py.typed +0 -1
  377. venv/Lib/site-packages/pip/_vendor/tomli_w/__init__.py +0 -4
  378. venv/Lib/site-packages/pip/_vendor/tomli_w/_writer.py +0 -229
  379. venv/Lib/site-packages/pip/_vendor/tomli_w/py.typed +0 -1
  380. venv/Lib/site-packages/pip/_vendor/truststore/__init__.py +0 -36
  381. venv/Lib/site-packages/pip/_vendor/truststore/_api.py +0 -333
  382. venv/Lib/site-packages/pip/_vendor/truststore/_macos.py +0 -571
  383. venv/Lib/site-packages/pip/_vendor/truststore/_openssl.py +0 -66
  384. venv/Lib/site-packages/pip/_vendor/truststore/_ssl_constants.py +0 -31
  385. venv/Lib/site-packages/pip/_vendor/truststore/_windows.py +0 -567
  386. venv/Lib/site-packages/pip/_vendor/truststore/py.typed +0 -0
  387. venv/Lib/site-packages/pip/_vendor/urllib3/__init__.py +0 -102
  388. venv/Lib/site-packages/pip/_vendor/urllib3/_collections.py +0 -355
  389. venv/Lib/site-packages/pip/_vendor/urllib3/_version.py +0 -2
  390. venv/Lib/site-packages/pip/_vendor/urllib3/connection.py +0 -572
  391. venv/Lib/site-packages/pip/_vendor/urllib3/connectionpool.py +0 -1140
  392. venv/Lib/site-packages/pip/_vendor/urllib3/contrib/__init__.py +0 -0
  393. venv/Lib/site-packages/pip/_vendor/urllib3/contrib/_appengine_environ.py +0 -36
  394. venv/Lib/site-packages/pip/_vendor/urllib3/contrib/_securetransport/__init__.py +0 -0
  395. venv/Lib/site-packages/pip/_vendor/urllib3/contrib/_securetransport/bindings.py +0 -519
  396. venv/Lib/site-packages/pip/_vendor/urllib3/contrib/_securetransport/low_level.py +0 -397
  397. venv/Lib/site-packages/pip/_vendor/urllib3/contrib/appengine.py +0 -314
  398. venv/Lib/site-packages/pip/_vendor/urllib3/contrib/ntlmpool.py +0 -130
  399. venv/Lib/site-packages/pip/_vendor/urllib3/contrib/pyopenssl.py +0 -518
  400. venv/Lib/site-packages/pip/_vendor/urllib3/contrib/securetransport.py +0 -920
  401. venv/Lib/site-packages/pip/_vendor/urllib3/contrib/socks.py +0 -216
  402. venv/Lib/site-packages/pip/_vendor/urllib3/exceptions.py +0 -323
  403. venv/Lib/site-packages/pip/_vendor/urllib3/fields.py +0 -274
  404. venv/Lib/site-packages/pip/_vendor/urllib3/filepost.py +0 -98
  405. venv/Lib/site-packages/pip/_vendor/urllib3/packages/__init__.py +0 -0
  406. venv/Lib/site-packages/pip/_vendor/urllib3/packages/backports/__init__.py +0 -0
  407. venv/Lib/site-packages/pip/_vendor/urllib3/packages/backports/makefile.py +0 -51
  408. venv/Lib/site-packages/pip/_vendor/urllib3/packages/backports/weakref_finalize.py +0 -155
  409. venv/Lib/site-packages/pip/_vendor/urllib3/packages/six.py +0 -1076
  410. venv/Lib/site-packages/pip/_vendor/urllib3/poolmanager.py +0 -540
  411. venv/Lib/site-packages/pip/_vendor/urllib3/request.py +0 -191
  412. venv/Lib/site-packages/pip/_vendor/urllib3/response.py +0 -879
  413. venv/Lib/site-packages/pip/_vendor/urllib3/util/__init__.py +0 -49
  414. venv/Lib/site-packages/pip/_vendor/urllib3/util/connection.py +0 -149
  415. venv/Lib/site-packages/pip/_vendor/urllib3/util/proxy.py +0 -57
  416. venv/Lib/site-packages/pip/_vendor/urllib3/util/queue.py +0 -22
  417. venv/Lib/site-packages/pip/_vendor/urllib3/util/request.py +0 -137
  418. venv/Lib/site-packages/pip/_vendor/urllib3/util/response.py +0 -107
  419. venv/Lib/site-packages/pip/_vendor/urllib3/util/retry.py +0 -622
  420. venv/Lib/site-packages/pip/_vendor/urllib3/util/ssl_.py +0 -504
  421. venv/Lib/site-packages/pip/_vendor/urllib3/util/ssl_match_hostname.py +0 -159
  422. venv/Lib/site-packages/pip/_vendor/urllib3/util/ssltransport.py +0 -221
  423. venv/Lib/site-packages/pip/_vendor/urllib3/util/timeout.py +0 -271
  424. venv/Lib/site-packages/pip/_vendor/urllib3/util/url.py +0 -435
  425. venv/Lib/site-packages/pip/_vendor/urllib3/util/wait.py +0 -152
  426. venv/Lib/site-packages/pip/py.typed +0 -4
  427. {cli_ih-0.6.3.1.dist-info → cli_ih-0.7.1.dist-info}/WHEEL +0 -0
@@ -1,963 +0,0 @@
1
- """
2
- pygments.lexer
3
- ~~~~~~~~~~~~~~
4
-
5
- Base lexer classes.
6
-
7
- :copyright: Copyright 2006-2025 by the Pygments team, see AUTHORS.
8
- :license: BSD, see LICENSE for details.
9
- """
10
-
11
- import re
12
- import sys
13
- import time
14
-
15
- from pip._vendor.pygments.filter import apply_filters, Filter
16
- from pip._vendor.pygments.filters import get_filter_by_name
17
- from pip._vendor.pygments.token import Error, Text, Other, Whitespace, _TokenType
18
- from pip._vendor.pygments.util import get_bool_opt, get_int_opt, get_list_opt, \
19
- make_analysator, Future, guess_decode
20
- from pip._vendor.pygments.regexopt import regex_opt
21
-
22
- __all__ = ['Lexer', 'RegexLexer', 'ExtendedRegexLexer', 'DelegatingLexer',
23
- 'LexerContext', 'include', 'inherit', 'bygroups', 'using', 'this',
24
- 'default', 'words', 'line_re']
25
-
26
- line_re = re.compile('.*?\n')
27
-
28
- _encoding_map = [(b'\xef\xbb\xbf', 'utf-8'),
29
- (b'\xff\xfe\0\0', 'utf-32'),
30
- (b'\0\0\xfe\xff', 'utf-32be'),
31
- (b'\xff\xfe', 'utf-16'),
32
- (b'\xfe\xff', 'utf-16be')]
33
-
34
- _default_analyse = staticmethod(lambda x: 0.0)
35
-
36
-
37
- class LexerMeta(type):
38
- """
39
- This metaclass automagically converts ``analyse_text`` methods into
40
- static methods which always return float values.
41
- """
42
-
43
- def __new__(mcs, name, bases, d):
44
- if 'analyse_text' in d:
45
- d['analyse_text'] = make_analysator(d['analyse_text'])
46
- return type.__new__(mcs, name, bases, d)
47
-
48
-
49
- class Lexer(metaclass=LexerMeta):
50
- """
51
- Lexer for a specific language.
52
-
53
- See also :doc:`lexerdevelopment`, a high-level guide to writing
54
- lexers.
55
-
56
- Lexer classes have attributes used for choosing the most appropriate
57
- lexer based on various criteria.
58
-
59
- .. autoattribute:: name
60
- :no-value:
61
- .. autoattribute:: aliases
62
- :no-value:
63
- .. autoattribute:: filenames
64
- :no-value:
65
- .. autoattribute:: alias_filenames
66
- .. autoattribute:: mimetypes
67
- :no-value:
68
- .. autoattribute:: priority
69
-
70
- Lexers included in Pygments should have two additional attributes:
71
-
72
- .. autoattribute:: url
73
- :no-value:
74
- .. autoattribute:: version_added
75
- :no-value:
76
-
77
- Lexers included in Pygments may have additional attributes:
78
-
79
- .. autoattribute:: _example
80
- :no-value:
81
-
82
- You can pass options to the constructor. The basic options recognized
83
- by all lexers and processed by the base `Lexer` class are:
84
-
85
- ``stripnl``
86
- Strip leading and trailing newlines from the input (default: True).
87
- ``stripall``
88
- Strip all leading and trailing whitespace from the input
89
- (default: False).
90
- ``ensurenl``
91
- Make sure that the input ends with a newline (default: True). This
92
- is required for some lexers that consume input linewise.
93
-
94
- .. versionadded:: 1.3
95
-
96
- ``tabsize``
97
- If given and greater than 0, expand tabs in the input (default: 0).
98
- ``encoding``
99
- If given, must be an encoding name. This encoding will be used to
100
- convert the input string to Unicode, if it is not already a Unicode
101
- string (default: ``'guess'``, which uses a simple UTF-8 / Locale /
102
- Latin1 detection. Can also be ``'chardet'`` to use the chardet
103
- library, if it is installed.
104
- ``inencoding``
105
- Overrides the ``encoding`` if given.
106
- """
107
-
108
- #: Full name of the lexer, in human-readable form
109
- name = None
110
-
111
- #: A list of short, unique identifiers that can be used to look
112
- #: up the lexer from a list, e.g., using `get_lexer_by_name()`.
113
- aliases = []
114
-
115
- #: A list of `fnmatch` patterns that match filenames which contain
116
- #: content for this lexer. The patterns in this list should be unique among
117
- #: all lexers.
118
- filenames = []
119
-
120
- #: A list of `fnmatch` patterns that match filenames which may or may not
121
- #: contain content for this lexer. This list is used by the
122
- #: :func:`.guess_lexer_for_filename()` function, to determine which lexers
123
- #: are then included in guessing the correct one. That means that
124
- #: e.g. every lexer for HTML and a template language should include
125
- #: ``\*.html`` in this list.
126
- alias_filenames = []
127
-
128
- #: A list of MIME types for content that can be lexed with this lexer.
129
- mimetypes = []
130
-
131
- #: Priority, should multiple lexers match and no content is provided
132
- priority = 0
133
-
134
- #: URL of the language specification/definition. Used in the Pygments
135
- #: documentation. Set to an empty string to disable.
136
- url = None
137
-
138
- #: Version of Pygments in which the lexer was added.
139
- version_added = None
140
-
141
- #: Example file name. Relative to the ``tests/examplefiles`` directory.
142
- #: This is used by the documentation generator to show an example.
143
- _example = None
144
-
145
- def __init__(self, **options):
146
- """
147
- This constructor takes arbitrary options as keyword arguments.
148
- Every subclass must first process its own options and then call
149
- the `Lexer` constructor, since it processes the basic
150
- options like `stripnl`.
151
-
152
- An example looks like this:
153
-
154
- .. sourcecode:: python
155
-
156
- def __init__(self, **options):
157
- self.compress = options.get('compress', '')
158
- Lexer.__init__(self, **options)
159
-
160
- As these options must all be specifiable as strings (due to the
161
- command line usage), there are various utility functions
162
- available to help with that, see `Utilities`_.
163
- """
164
- self.options = options
165
- self.stripnl = get_bool_opt(options, 'stripnl', True)
166
- self.stripall = get_bool_opt(options, 'stripall', False)
167
- self.ensurenl = get_bool_opt(options, 'ensurenl', True)
168
- self.tabsize = get_int_opt(options, 'tabsize', 0)
169
- self.encoding = options.get('encoding', 'guess')
170
- self.encoding = options.get('inencoding') or self.encoding
171
- self.filters = []
172
- for filter_ in get_list_opt(options, 'filters', ()):
173
- self.add_filter(filter_)
174
-
175
- def __repr__(self):
176
- if self.options:
177
- return f'<pygments.lexers.{self.__class__.__name__} with {self.options!r}>'
178
- else:
179
- return f'<pygments.lexers.{self.__class__.__name__}>'
180
-
181
- def add_filter(self, filter_, **options):
182
- """
183
- Add a new stream filter to this lexer.
184
- """
185
- if not isinstance(filter_, Filter):
186
- filter_ = get_filter_by_name(filter_, **options)
187
- self.filters.append(filter_)
188
-
189
- def analyse_text(text):
190
- """
191
- A static method which is called for lexer guessing.
192
-
193
- It should analyse the text and return a float in the range
194
- from ``0.0`` to ``1.0``. If it returns ``0.0``, the lexer
195
- will not be selected as the most probable one, if it returns
196
- ``1.0``, it will be selected immediately. This is used by
197
- `guess_lexer`.
198
-
199
- The `LexerMeta` metaclass automatically wraps this function so
200
- that it works like a static method (no ``self`` or ``cls``
201
- parameter) and the return value is automatically converted to
202
- `float`. If the return value is an object that is boolean `False`
203
- it's the same as if the return values was ``0.0``.
204
- """
205
-
206
- def _preprocess_lexer_input(self, text):
207
- """Apply preprocessing such as decoding the input, removing BOM and normalizing newlines."""
208
-
209
- if not isinstance(text, str):
210
- if self.encoding == 'guess':
211
- text, _ = guess_decode(text)
212
- elif self.encoding == 'chardet':
213
- try:
214
- # pip vendoring note: this code is not reachable by pip,
215
- # removed import of chardet to make it clear.
216
- raise ImportError('chardet is not vendored by pip')
217
- except ImportError as e:
218
- raise ImportError('To enable chardet encoding guessing, '
219
- 'please install the chardet library '
220
- 'from http://chardet.feedparser.org/') from e
221
- # check for BOM first
222
- decoded = None
223
- for bom, encoding in _encoding_map:
224
- if text.startswith(bom):
225
- decoded = text[len(bom):].decode(encoding, 'replace')
226
- break
227
- # no BOM found, so use chardet
228
- if decoded is None:
229
- enc = chardet.detect(text[:1024]) # Guess using first 1KB
230
- decoded = text.decode(enc.get('encoding') or 'utf-8',
231
- 'replace')
232
- text = decoded
233
- else:
234
- text = text.decode(self.encoding)
235
- if text.startswith('\ufeff'):
236
- text = text[len('\ufeff'):]
237
- else:
238
- if text.startswith('\ufeff'):
239
- text = text[len('\ufeff'):]
240
-
241
- # text now *is* a unicode string
242
- text = text.replace('\r\n', '\n')
243
- text = text.replace('\r', '\n')
244
- if self.stripall:
245
- text = text.strip()
246
- elif self.stripnl:
247
- text = text.strip('\n')
248
- if self.tabsize > 0:
249
- text = text.expandtabs(self.tabsize)
250
- if self.ensurenl and not text.endswith('\n'):
251
- text += '\n'
252
-
253
- return text
254
-
255
- def get_tokens(self, text, unfiltered=False):
256
- """
257
- This method is the basic interface of a lexer. It is called by
258
- the `highlight()` function. It must process the text and return an
259
- iterable of ``(tokentype, value)`` pairs from `text`.
260
-
261
- Normally, you don't need to override this method. The default
262
- implementation processes the options recognized by all lexers
263
- (`stripnl`, `stripall` and so on), and then yields all tokens
264
- from `get_tokens_unprocessed()`, with the ``index`` dropped.
265
-
266
- If `unfiltered` is set to `True`, the filtering mechanism is
267
- bypassed even if filters are defined.
268
- """
269
- text = self._preprocess_lexer_input(text)
270
-
271
- def streamer():
272
- for _, t, v in self.get_tokens_unprocessed(text):
273
- yield t, v
274
- stream = streamer()
275
- if not unfiltered:
276
- stream = apply_filters(stream, self.filters, self)
277
- return stream
278
-
279
- def get_tokens_unprocessed(self, text):
280
- """
281
- This method should process the text and return an iterable of
282
- ``(index, tokentype, value)`` tuples where ``index`` is the starting
283
- position of the token within the input text.
284
-
285
- It must be overridden by subclasses. It is recommended to
286
- implement it as a generator to maximize effectiveness.
287
- """
288
- raise NotImplementedError
289
-
290
-
291
- class DelegatingLexer(Lexer):
292
- """
293
- This lexer takes two lexer as arguments. A root lexer and
294
- a language lexer. First everything is scanned using the language
295
- lexer, afterwards all ``Other`` tokens are lexed using the root
296
- lexer.
297
-
298
- The lexers from the ``template`` lexer package use this base lexer.
299
- """
300
-
301
- def __init__(self, _root_lexer, _language_lexer, _needle=Other, **options):
302
- self.root_lexer = _root_lexer(**options)
303
- self.language_lexer = _language_lexer(**options)
304
- self.needle = _needle
305
- Lexer.__init__(self, **options)
306
-
307
- def get_tokens_unprocessed(self, text):
308
- buffered = ''
309
- insertions = []
310
- lng_buffer = []
311
- for i, t, v in self.language_lexer.get_tokens_unprocessed(text):
312
- if t is self.needle:
313
- if lng_buffer:
314
- insertions.append((len(buffered), lng_buffer))
315
- lng_buffer = []
316
- buffered += v
317
- else:
318
- lng_buffer.append((i, t, v))
319
- if lng_buffer:
320
- insertions.append((len(buffered), lng_buffer))
321
- return do_insertions(insertions,
322
- self.root_lexer.get_tokens_unprocessed(buffered))
323
-
324
-
325
- # ------------------------------------------------------------------------------
326
- # RegexLexer and ExtendedRegexLexer
327
- #
328
-
329
-
330
- class include(str): # pylint: disable=invalid-name
331
- """
332
- Indicates that a state should include rules from another state.
333
- """
334
- pass
335
-
336
-
337
- class _inherit:
338
- """
339
- Indicates the a state should inherit from its superclass.
340
- """
341
- def __repr__(self):
342
- return 'inherit'
343
-
344
- inherit = _inherit() # pylint: disable=invalid-name
345
-
346
-
347
- class combined(tuple): # pylint: disable=invalid-name
348
- """
349
- Indicates a state combined from multiple states.
350
- """
351
-
352
- def __new__(cls, *args):
353
- return tuple.__new__(cls, args)
354
-
355
- def __init__(self, *args):
356
- # tuple.__init__ doesn't do anything
357
- pass
358
-
359
-
360
- class _PseudoMatch:
361
- """
362
- A pseudo match object constructed from a string.
363
- """
364
-
365
- def __init__(self, start, text):
366
- self._text = text
367
- self._start = start
368
-
369
- def start(self, arg=None):
370
- return self._start
371
-
372
- def end(self, arg=None):
373
- return self._start + len(self._text)
374
-
375
- def group(self, arg=None):
376
- if arg:
377
- raise IndexError('No such group')
378
- return self._text
379
-
380
- def groups(self):
381
- return (self._text,)
382
-
383
- def groupdict(self):
384
- return {}
385
-
386
-
387
- def bygroups(*args):
388
- """
389
- Callback that yields multiple actions for each group in the match.
390
- """
391
- def callback(lexer, match, ctx=None):
392
- for i, action in enumerate(args):
393
- if action is None:
394
- continue
395
- elif type(action) is _TokenType:
396
- data = match.group(i + 1)
397
- if data:
398
- yield match.start(i + 1), action, data
399
- else:
400
- data = match.group(i + 1)
401
- if data is not None:
402
- if ctx:
403
- ctx.pos = match.start(i + 1)
404
- for item in action(lexer,
405
- _PseudoMatch(match.start(i + 1), data), ctx):
406
- if item:
407
- yield item
408
- if ctx:
409
- ctx.pos = match.end()
410
- return callback
411
-
412
-
413
- class _This:
414
- """
415
- Special singleton used for indicating the caller class.
416
- Used by ``using``.
417
- """
418
-
419
- this = _This()
420
-
421
-
422
- def using(_other, **kwargs):
423
- """
424
- Callback that processes the match with a different lexer.
425
-
426
- The keyword arguments are forwarded to the lexer, except `state` which
427
- is handled separately.
428
-
429
- `state` specifies the state that the new lexer will start in, and can
430
- be an enumerable such as ('root', 'inline', 'string') or a simple
431
- string which is assumed to be on top of the root state.
432
-
433
- Note: For that to work, `_other` must not be an `ExtendedRegexLexer`.
434
- """
435
- gt_kwargs = {}
436
- if 'state' in kwargs:
437
- s = kwargs.pop('state')
438
- if isinstance(s, (list, tuple)):
439
- gt_kwargs['stack'] = s
440
- else:
441
- gt_kwargs['stack'] = ('root', s)
442
-
443
- if _other is this:
444
- def callback(lexer, match, ctx=None):
445
- # if keyword arguments are given the callback
446
- # function has to create a new lexer instance
447
- if kwargs:
448
- # XXX: cache that somehow
449
- kwargs.update(lexer.options)
450
- lx = lexer.__class__(**kwargs)
451
- else:
452
- lx = lexer
453
- s = match.start()
454
- for i, t, v in lx.get_tokens_unprocessed(match.group(), **gt_kwargs):
455
- yield i + s, t, v
456
- if ctx:
457
- ctx.pos = match.end()
458
- else:
459
- def callback(lexer, match, ctx=None):
460
- # XXX: cache that somehow
461
- kwargs.update(lexer.options)
462
- lx = _other(**kwargs)
463
-
464
- s = match.start()
465
- for i, t, v in lx.get_tokens_unprocessed(match.group(), **gt_kwargs):
466
- yield i + s, t, v
467
- if ctx:
468
- ctx.pos = match.end()
469
- return callback
470
-
471
-
472
- class default:
473
- """
474
- Indicates a state or state action (e.g. #pop) to apply.
475
- For example default('#pop') is equivalent to ('', Token, '#pop')
476
- Note that state tuples may be used as well.
477
-
478
- .. versionadded:: 2.0
479
- """
480
- def __init__(self, state):
481
- self.state = state
482
-
483
-
484
- class words(Future):
485
- """
486
- Indicates a list of literal words that is transformed into an optimized
487
- regex that matches any of the words.
488
-
489
- .. versionadded:: 2.0
490
- """
491
- def __init__(self, words, prefix='', suffix=''):
492
- self.words = words
493
- self.prefix = prefix
494
- self.suffix = suffix
495
-
496
- def get(self):
497
- return regex_opt(self.words, prefix=self.prefix, suffix=self.suffix)
498
-
499
-
500
- class RegexLexerMeta(LexerMeta):
501
- """
502
- Metaclass for RegexLexer, creates the self._tokens attribute from
503
- self.tokens on the first instantiation.
504
- """
505
-
506
- def _process_regex(cls, regex, rflags, state):
507
- """Preprocess the regular expression component of a token definition."""
508
- if isinstance(regex, Future):
509
- regex = regex.get()
510
- return re.compile(regex, rflags).match
511
-
512
- def _process_token(cls, token):
513
- """Preprocess the token component of a token definition."""
514
- assert type(token) is _TokenType or callable(token), \
515
- f'token type must be simple type or callable, not {token!r}'
516
- return token
517
-
518
- def _process_new_state(cls, new_state, unprocessed, processed):
519
- """Preprocess the state transition action of a token definition."""
520
- if isinstance(new_state, str):
521
- # an existing state
522
- if new_state == '#pop':
523
- return -1
524
- elif new_state in unprocessed:
525
- return (new_state,)
526
- elif new_state == '#push':
527
- return new_state
528
- elif new_state[:5] == '#pop:':
529
- return -int(new_state[5:])
530
- else:
531
- assert False, f'unknown new state {new_state!r}'
532
- elif isinstance(new_state, combined):
533
- # combine a new state from existing ones
534
- tmp_state = '_tmp_%d' % cls._tmpname
535
- cls._tmpname += 1
536
- itokens = []
537
- for istate in new_state:
538
- assert istate != new_state, f'circular state ref {istate!r}'
539
- itokens.extend(cls._process_state(unprocessed,
540
- processed, istate))
541
- processed[tmp_state] = itokens
542
- return (tmp_state,)
543
- elif isinstance(new_state, tuple):
544
- # push more than one state
545
- for istate in new_state:
546
- assert (istate in unprocessed or
547
- istate in ('#pop', '#push')), \
548
- 'unknown new state ' + istate
549
- return new_state
550
- else:
551
- assert False, f'unknown new state def {new_state!r}'
552
-
553
- def _process_state(cls, unprocessed, processed, state):
554
- """Preprocess a single state definition."""
555
- assert isinstance(state, str), f"wrong state name {state!r}"
556
- assert state[0] != '#', f"invalid state name {state!r}"
557
- if state in processed:
558
- return processed[state]
559
- tokens = processed[state] = []
560
- rflags = cls.flags
561
- for tdef in unprocessed[state]:
562
- if isinstance(tdef, include):
563
- # it's a state reference
564
- assert tdef != state, f"circular state reference {state!r}"
565
- tokens.extend(cls._process_state(unprocessed, processed,
566
- str(tdef)))
567
- continue
568
- if isinstance(tdef, _inherit):
569
- # should be processed already, but may not in the case of:
570
- # 1. the state has no counterpart in any parent
571
- # 2. the state includes more than one 'inherit'
572
- continue
573
- if isinstance(tdef, default):
574
- new_state = cls._process_new_state(tdef.state, unprocessed, processed)
575
- tokens.append((re.compile('').match, None, new_state))
576
- continue
577
-
578
- assert type(tdef) is tuple, f"wrong rule def {tdef!r}"
579
-
580
- try:
581
- rex = cls._process_regex(tdef[0], rflags, state)
582
- except Exception as err:
583
- raise ValueError(f"uncompilable regex {tdef[0]!r} in state {state!r} of {cls!r}: {err}") from err
584
-
585
- token = cls._process_token(tdef[1])
586
-
587
- if len(tdef) == 2:
588
- new_state = None
589
- else:
590
- new_state = cls._process_new_state(tdef[2],
591
- unprocessed, processed)
592
-
593
- tokens.append((rex, token, new_state))
594
- return tokens
595
-
596
- def process_tokendef(cls, name, tokendefs=None):
597
- """Preprocess a dictionary of token definitions."""
598
- processed = cls._all_tokens[name] = {}
599
- tokendefs = tokendefs or cls.tokens[name]
600
- for state in list(tokendefs):
601
- cls._process_state(tokendefs, processed, state)
602
- return processed
603
-
604
- def get_tokendefs(cls):
605
- """
606
- Merge tokens from superclasses in MRO order, returning a single tokendef
607
- dictionary.
608
-
609
- Any state that is not defined by a subclass will be inherited
610
- automatically. States that *are* defined by subclasses will, by
611
- default, override that state in the superclass. If a subclass wishes to
612
- inherit definitions from a superclass, it can use the special value
613
- "inherit", which will cause the superclass' state definition to be
614
- included at that point in the state.
615
- """
616
- tokens = {}
617
- inheritable = {}
618
- for c in cls.__mro__:
619
- toks = c.__dict__.get('tokens', {})
620
-
621
- for state, items in toks.items():
622
- curitems = tokens.get(state)
623
- if curitems is None:
624
- # N.b. because this is assigned by reference, sufficiently
625
- # deep hierarchies are processed incrementally (e.g. for
626
- # A(B), B(C), C(RegexLexer), B will be premodified so X(B)
627
- # will not see any inherits in B).
628
- tokens[state] = items
629
- try:
630
- inherit_ndx = items.index(inherit)
631
- except ValueError:
632
- continue
633
- inheritable[state] = inherit_ndx
634
- continue
635
-
636
- inherit_ndx = inheritable.pop(state, None)
637
- if inherit_ndx is None:
638
- continue
639
-
640
- # Replace the "inherit" value with the items
641
- curitems[inherit_ndx:inherit_ndx+1] = items
642
- try:
643
- # N.b. this is the index in items (that is, the superclass
644
- # copy), so offset required when storing below.
645
- new_inh_ndx = items.index(inherit)
646
- except ValueError:
647
- pass
648
- else:
649
- inheritable[state] = inherit_ndx + new_inh_ndx
650
-
651
- return tokens
652
-
653
- def __call__(cls, *args, **kwds):
654
- """Instantiate cls after preprocessing its token definitions."""
655
- if '_tokens' not in cls.__dict__:
656
- cls._all_tokens = {}
657
- cls._tmpname = 0
658
- if hasattr(cls, 'token_variants') and cls.token_variants:
659
- # don't process yet
660
- pass
661
- else:
662
- cls._tokens = cls.process_tokendef('', cls.get_tokendefs())
663
-
664
- return type.__call__(cls, *args, **kwds)
665
-
666
-
667
- class RegexLexer(Lexer, metaclass=RegexLexerMeta):
668
- """
669
- Base for simple stateful regular expression-based lexers.
670
- Simplifies the lexing process so that you need only
671
- provide a list of states and regular expressions.
672
- """
673
-
674
- #: Flags for compiling the regular expressions.
675
- #: Defaults to MULTILINE.
676
- flags = re.MULTILINE
677
-
678
- #: At all time there is a stack of states. Initially, the stack contains
679
- #: a single state 'root'. The top of the stack is called "the current state".
680
- #:
681
- #: Dict of ``{'state': [(regex, tokentype, new_state), ...], ...}``
682
- #:
683
- #: ``new_state`` can be omitted to signify no state transition.
684
- #: If ``new_state`` is a string, it is pushed on the stack. This ensure
685
- #: the new current state is ``new_state``.
686
- #: If ``new_state`` is a tuple of strings, all of those strings are pushed
687
- #: on the stack and the current state will be the last element of the list.
688
- #: ``new_state`` can also be ``combined('state1', 'state2', ...)``
689
- #: to signify a new, anonymous state combined from the rules of two
690
- #: or more existing ones.
691
- #: Furthermore, it can be '#pop' to signify going back one step in
692
- #: the state stack, or '#push' to push the current state on the stack
693
- #: again. Note that if you push while in a combined state, the combined
694
- #: state itself is pushed, and not only the state in which the rule is
695
- #: defined.
696
- #:
697
- #: The tuple can also be replaced with ``include('state')``, in which
698
- #: case the rules from the state named by the string are included in the
699
- #: current one.
700
- tokens = {}
701
-
702
- def get_tokens_unprocessed(self, text, stack=('root',)):
703
- """
704
- Split ``text`` into (tokentype, text) pairs.
705
-
706
- ``stack`` is the initial stack (default: ``['root']``)
707
- """
708
- pos = 0
709
- tokendefs = self._tokens
710
- statestack = list(stack)
711
- statetokens = tokendefs[statestack[-1]]
712
- while 1:
713
- for rexmatch, action, new_state in statetokens:
714
- m = rexmatch(text, pos)
715
- if m:
716
- if action is not None:
717
- if type(action) is _TokenType:
718
- yield pos, action, m.group()
719
- else:
720
- yield from action(self, m)
721
- pos = m.end()
722
- if new_state is not None:
723
- # state transition
724
- if isinstance(new_state, tuple):
725
- for state in new_state:
726
- if state == '#pop':
727
- if len(statestack) > 1:
728
- statestack.pop()
729
- elif state == '#push':
730
- statestack.append(statestack[-1])
731
- else:
732
- statestack.append(state)
733
- elif isinstance(new_state, int):
734
- # pop, but keep at least one state on the stack
735
- # (random code leading to unexpected pops should
736
- # not allow exceptions)
737
- if abs(new_state) >= len(statestack):
738
- del statestack[1:]
739
- else:
740
- del statestack[new_state:]
741
- elif new_state == '#push':
742
- statestack.append(statestack[-1])
743
- else:
744
- assert False, f"wrong state def: {new_state!r}"
745
- statetokens = tokendefs[statestack[-1]]
746
- break
747
- else:
748
- # We are here only if all state tokens have been considered
749
- # and there was not a match on any of them.
750
- try:
751
- if text[pos] == '\n':
752
- # at EOL, reset state to "root"
753
- statestack = ['root']
754
- statetokens = tokendefs['root']
755
- yield pos, Whitespace, '\n'
756
- pos += 1
757
- continue
758
- yield pos, Error, text[pos]
759
- pos += 1
760
- except IndexError:
761
- break
762
-
763
-
764
- class LexerContext:
765
- """
766
- A helper object that holds lexer position data.
767
- """
768
-
769
- def __init__(self, text, pos, stack=None, end=None):
770
- self.text = text
771
- self.pos = pos
772
- self.end = end or len(text) # end=0 not supported ;-)
773
- self.stack = stack or ['root']
774
-
775
- def __repr__(self):
776
- return f'LexerContext({self.text!r}, {self.pos!r}, {self.stack!r})'
777
-
778
-
779
- class ExtendedRegexLexer(RegexLexer):
780
- """
781
- A RegexLexer that uses a context object to store its state.
782
- """
783
-
784
- def get_tokens_unprocessed(self, text=None, context=None):
785
- """
786
- Split ``text`` into (tokentype, text) pairs.
787
- If ``context`` is given, use this lexer context instead.
788
- """
789
- tokendefs = self._tokens
790
- if not context:
791
- ctx = LexerContext(text, 0)
792
- statetokens = tokendefs['root']
793
- else:
794
- ctx = context
795
- statetokens = tokendefs[ctx.stack[-1]]
796
- text = ctx.text
797
- while 1:
798
- for rexmatch, action, new_state in statetokens:
799
- m = rexmatch(text, ctx.pos, ctx.end)
800
- if m:
801
- if action is not None:
802
- if type(action) is _TokenType:
803
- yield ctx.pos, action, m.group()
804
- ctx.pos = m.end()
805
- else:
806
- yield from action(self, m, ctx)
807
- if not new_state:
808
- # altered the state stack?
809
- statetokens = tokendefs[ctx.stack[-1]]
810
- # CAUTION: callback must set ctx.pos!
811
- if new_state is not None:
812
- # state transition
813
- if isinstance(new_state, tuple):
814
- for state in new_state:
815
- if state == '#pop':
816
- if len(ctx.stack) > 1:
817
- ctx.stack.pop()
818
- elif state == '#push':
819
- ctx.stack.append(ctx.stack[-1])
820
- else:
821
- ctx.stack.append(state)
822
- elif isinstance(new_state, int):
823
- # see RegexLexer for why this check is made
824
- if abs(new_state) >= len(ctx.stack):
825
- del ctx.stack[1:]
826
- else:
827
- del ctx.stack[new_state:]
828
- elif new_state == '#push':
829
- ctx.stack.append(ctx.stack[-1])
830
- else:
831
- assert False, f"wrong state def: {new_state!r}"
832
- statetokens = tokendefs[ctx.stack[-1]]
833
- break
834
- else:
835
- try:
836
- if ctx.pos >= ctx.end:
837
- break
838
- if text[ctx.pos] == '\n':
839
- # at EOL, reset state to "root"
840
- ctx.stack = ['root']
841
- statetokens = tokendefs['root']
842
- yield ctx.pos, Text, '\n'
843
- ctx.pos += 1
844
- continue
845
- yield ctx.pos, Error, text[ctx.pos]
846
- ctx.pos += 1
847
- except IndexError:
848
- break
849
-
850
-
851
- def do_insertions(insertions, tokens):
852
- """
853
- Helper for lexers which must combine the results of several
854
- sublexers.
855
-
856
- ``insertions`` is a list of ``(index, itokens)`` pairs.
857
- Each ``itokens`` iterable should be inserted at position
858
- ``index`` into the token stream given by the ``tokens``
859
- argument.
860
-
861
- The result is a combined token stream.
862
-
863
- TODO: clean up the code here.
864
- """
865
- insertions = iter(insertions)
866
- try:
867
- index, itokens = next(insertions)
868
- except StopIteration:
869
- # no insertions
870
- yield from tokens
871
- return
872
-
873
- realpos = None
874
- insleft = True
875
-
876
- # iterate over the token stream where we want to insert
877
- # the tokens from the insertion list.
878
- for i, t, v in tokens:
879
- # first iteration. store the position of first item
880
- if realpos is None:
881
- realpos = i
882
- oldi = 0
883
- while insleft and i + len(v) >= index:
884
- tmpval = v[oldi:index - i]
885
- if tmpval:
886
- yield realpos, t, tmpval
887
- realpos += len(tmpval)
888
- for it_index, it_token, it_value in itokens:
889
- yield realpos, it_token, it_value
890
- realpos += len(it_value)
891
- oldi = index - i
892
- try:
893
- index, itokens = next(insertions)
894
- except StopIteration:
895
- insleft = False
896
- break # not strictly necessary
897
- if oldi < len(v):
898
- yield realpos, t, v[oldi:]
899
- realpos += len(v) - oldi
900
-
901
- # leftover tokens
902
- while insleft:
903
- # no normal tokens, set realpos to zero
904
- realpos = realpos or 0
905
- for p, t, v in itokens:
906
- yield realpos, t, v
907
- realpos += len(v)
908
- try:
909
- index, itokens = next(insertions)
910
- except StopIteration:
911
- insleft = False
912
- break # not strictly necessary
913
-
914
-
915
- class ProfilingRegexLexerMeta(RegexLexerMeta):
916
- """Metaclass for ProfilingRegexLexer, collects regex timing info."""
917
-
918
- def _process_regex(cls, regex, rflags, state):
919
- if isinstance(regex, words):
920
- rex = regex_opt(regex.words, prefix=regex.prefix,
921
- suffix=regex.suffix)
922
- else:
923
- rex = regex
924
- compiled = re.compile(rex, rflags)
925
-
926
- def match_func(text, pos, endpos=sys.maxsize):
927
- info = cls._prof_data[-1].setdefault((state, rex), [0, 0.0])
928
- t0 = time.time()
929
- res = compiled.match(text, pos, endpos)
930
- t1 = time.time()
931
- info[0] += 1
932
- info[1] += t1 - t0
933
- return res
934
- return match_func
935
-
936
-
937
- class ProfilingRegexLexer(RegexLexer, metaclass=ProfilingRegexLexerMeta):
938
- """Drop-in replacement for RegexLexer that does profiling of its regexes."""
939
-
940
- _prof_data = []
941
- _prof_sort_index = 4 # defaults to time per call
942
-
943
- def get_tokens_unprocessed(self, text, stack=('root',)):
944
- # this needs to be a stack, since using(this) will produce nested calls
945
- self.__class__._prof_data.append({})
946
- yield from RegexLexer.get_tokens_unprocessed(self, text, stack)
947
- rawdata = self.__class__._prof_data.pop()
948
- data = sorted(((s, repr(r).strip('u\'').replace('\\\\', '\\')[:65],
949
- n, 1000 * t, 1000 * t / n)
950
- for ((s, r), (n, t)) in rawdata.items()),
951
- key=lambda x: x[self._prof_sort_index],
952
- reverse=True)
953
- sum_total = sum(x[3] for x in data)
954
-
955
- print()
956
- print('Profiling result for %s lexing %d chars in %.3f ms' %
957
- (self.__class__.__name__, len(text), sum_total))
958
- print('=' * 110)
959
- print('%-20s %-64s ncalls tottime percall' % ('state', 'regex'))
960
- print('-' * 110)
961
- for d in data:
962
- print('%-20s %-65s %5d %8.4f %8.4f' % d)
963
- print('=' * 110)