Cython 3.2.0__cp39-abi3-win32.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 (333) hide show
  1. Cython/Build/BuildExecutable.py +169 -0
  2. Cython/Build/Cache.py +199 -0
  3. Cython/Build/Cythonize.py +350 -0
  4. Cython/Build/Dependencies.py +1314 -0
  5. Cython/Build/Distutils.py +1 -0
  6. Cython/Build/Inline.py +463 -0
  7. Cython/Build/IpythonMagic.py +560 -0
  8. Cython/Build/SharedModule.py +94 -0
  9. Cython/Build/Tests/TestCyCache.py +194 -0
  10. Cython/Build/Tests/TestCythonizeArgsParser.py +481 -0
  11. Cython/Build/Tests/TestDependencies.py +133 -0
  12. Cython/Build/Tests/TestInline.py +177 -0
  13. Cython/Build/Tests/TestIpythonMagic.py +287 -0
  14. Cython/Build/Tests/TestRecythonize.py +212 -0
  15. Cython/Build/Tests/TestStripLiterals.py +155 -0
  16. Cython/Build/Tests/__init__.py +1 -0
  17. Cython/Build/__init__.py +11 -0
  18. Cython/CodeWriter.py +815 -0
  19. Cython/Compiler/AnalysedTreeTransforms.py +97 -0
  20. Cython/Compiler/Annotate.py +328 -0
  21. Cython/Compiler/AutoDocTransforms.py +320 -0
  22. Cython/Compiler/Buffer.py +680 -0
  23. Cython/Compiler/Builtin.py +984 -0
  24. Cython/Compiler/CmdLine.py +263 -0
  25. Cython/Compiler/Code.pxd +149 -0
  26. Cython/Compiler/Code.py +3746 -0
  27. Cython/Compiler/Code.pyd +0 -0
  28. Cython/Compiler/CodeGeneration.py +33 -0
  29. Cython/Compiler/CythonScope.py +191 -0
  30. Cython/Compiler/Dataclass.py +864 -0
  31. Cython/Compiler/DebugFlags.py +24 -0
  32. Cython/Compiler/Errors.py +297 -0
  33. Cython/Compiler/ExprNodes.py +15562 -0
  34. Cython/Compiler/FlowControl.pxd +97 -0
  35. Cython/Compiler/FlowControl.py +1451 -0
  36. Cython/Compiler/FlowControl.pyd +0 -0
  37. Cython/Compiler/FusedNode.py +971 -0
  38. Cython/Compiler/FusedNode.pyd +0 -0
  39. Cython/Compiler/Future.py +16 -0
  40. Cython/Compiler/Interpreter.py +57 -0
  41. Cython/Compiler/Lexicon.py +421 -0
  42. Cython/Compiler/LineTable.py +114 -0
  43. Cython/Compiler/LineTable.pyd +0 -0
  44. Cython/Compiler/Main.py +857 -0
  45. Cython/Compiler/MatchCaseNodes.py +259 -0
  46. Cython/Compiler/MemoryView.py +905 -0
  47. Cython/Compiler/ModuleNode.py +4235 -0
  48. Cython/Compiler/Naming.py +363 -0
  49. Cython/Compiler/Nodes.py +10831 -0
  50. Cython/Compiler/Optimize.py +5288 -0
  51. Cython/Compiler/Options.py +843 -0
  52. Cython/Compiler/ParseTreeTransforms.pxd +78 -0
  53. Cython/Compiler/ParseTreeTransforms.py +4638 -0
  54. Cython/Compiler/Parsing.pxd +9 -0
  55. Cython/Compiler/Parsing.py +4775 -0
  56. Cython/Compiler/Parsing.pyd +0 -0
  57. Cython/Compiler/Pipeline.py +439 -0
  58. Cython/Compiler/PyrexTypes.py +5870 -0
  59. Cython/Compiler/Pythran.py +232 -0
  60. Cython/Compiler/Scanning.pxd +48 -0
  61. Cython/Compiler/Scanning.py +701 -0
  62. Cython/Compiler/Scanning.pyd +0 -0
  63. Cython/Compiler/StringEncoding.py +298 -0
  64. Cython/Compiler/Symtab.py +3073 -0
  65. Cython/Compiler/Tests/TestBuffer.py +105 -0
  66. Cython/Compiler/Tests/TestBuiltin.py +72 -0
  67. Cython/Compiler/Tests/TestCmdLine.py +586 -0
  68. Cython/Compiler/Tests/TestCode.py +144 -0
  69. Cython/Compiler/Tests/TestFlowControl.py +65 -0
  70. Cython/Compiler/Tests/TestGrammar.py +202 -0
  71. Cython/Compiler/Tests/TestMemView.py +71 -0
  72. Cython/Compiler/Tests/TestParseTreeTransforms.py +285 -0
  73. Cython/Compiler/Tests/TestScanning.py +134 -0
  74. Cython/Compiler/Tests/TestSignatureMatching.py +73 -0
  75. Cython/Compiler/Tests/TestStringEncoding.py +21 -0
  76. Cython/Compiler/Tests/TestTreeFragment.py +63 -0
  77. Cython/Compiler/Tests/TestTreePath.py +103 -0
  78. Cython/Compiler/Tests/TestTypes.py +75 -0
  79. Cython/Compiler/Tests/TestUtilityLoad.py +112 -0
  80. Cython/Compiler/Tests/TestVisitor.py +61 -0
  81. Cython/Compiler/Tests/Utils.py +36 -0
  82. Cython/Compiler/Tests/__init__.py +1 -0
  83. Cython/Compiler/TreeFragment.py +278 -0
  84. Cython/Compiler/TreePath.py +303 -0
  85. Cython/Compiler/TypeInference.py +591 -0
  86. Cython/Compiler/TypeSlots.py +1174 -0
  87. Cython/Compiler/UFuncs.py +311 -0
  88. Cython/Compiler/UtilNodes.py +389 -0
  89. Cython/Compiler/UtilityCode.py +344 -0
  90. Cython/Compiler/Version.py +8 -0
  91. Cython/Compiler/Visitor.pxd +53 -0
  92. Cython/Compiler/Visitor.py +861 -0
  93. Cython/Compiler/Visitor.pyd +0 -0
  94. Cython/Compiler/__init__.py +1 -0
  95. Cython/Coverage.py +448 -0
  96. Cython/Debugger/Cygdb.py +177 -0
  97. Cython/Debugger/DebugWriter.py +82 -0
  98. Cython/Debugger/Tests/TestLibCython.py +275 -0
  99. Cython/Debugger/Tests/__init__.py +1 -0
  100. Cython/Debugger/Tests/cfuncs.c +8 -0
  101. Cython/Debugger/Tests/codefile +49 -0
  102. Cython/Debugger/Tests/test_libcython_in_gdb.py +578 -0
  103. Cython/Debugger/Tests/test_libpython_in_gdb.py +90 -0
  104. Cython/Debugger/__init__.py +1 -0
  105. Cython/Debugger/libcython.py +1548 -0
  106. Cython/Debugger/libpython.py +2821 -0
  107. Cython/Debugging.py +20 -0
  108. Cython/Distutils/__init__.py +2 -0
  109. Cython/Distutils/build_ext.py +139 -0
  110. Cython/Distutils/extension.py +96 -0
  111. Cython/Distutils/old_build_ext.py +351 -0
  112. Cython/Includes/cpython/__init__.pxd +173 -0
  113. Cython/Includes/cpython/array.pxd +178 -0
  114. Cython/Includes/cpython/bool.pxd +37 -0
  115. Cython/Includes/cpython/buffer.pxd +112 -0
  116. Cython/Includes/cpython/bytearray.pxd +33 -0
  117. Cython/Includes/cpython/bytes.pxd +200 -0
  118. Cython/Includes/cpython/cellobject.pxd +35 -0
  119. Cython/Includes/cpython/ceval.pxd +8 -0
  120. Cython/Includes/cpython/codecs.pxd +121 -0
  121. Cython/Includes/cpython/complex.pxd +60 -0
  122. Cython/Includes/cpython/contextvars.pxd +145 -0
  123. Cython/Includes/cpython/conversion.pxd +36 -0
  124. Cython/Includes/cpython/datetime.pxd +395 -0
  125. Cython/Includes/cpython/descr.pxd +26 -0
  126. Cython/Includes/cpython/dict.pxd +187 -0
  127. Cython/Includes/cpython/exc.pxd +263 -0
  128. Cython/Includes/cpython/fileobject.pxd +57 -0
  129. Cython/Includes/cpython/float.pxd +47 -0
  130. Cython/Includes/cpython/function.pxd +65 -0
  131. Cython/Includes/cpython/genobject.pxd +25 -0
  132. Cython/Includes/cpython/getargs.pxd +12 -0
  133. Cython/Includes/cpython/instance.pxd +25 -0
  134. Cython/Includes/cpython/iterator.pxd +36 -0
  135. Cython/Includes/cpython/iterobject.pxd +24 -0
  136. Cython/Includes/cpython/list.pxd +92 -0
  137. Cython/Includes/cpython/long.pxd +149 -0
  138. Cython/Includes/cpython/longintrepr.pxd +14 -0
  139. Cython/Includes/cpython/mapping.pxd +63 -0
  140. Cython/Includes/cpython/marshal.pxd +66 -0
  141. Cython/Includes/cpython/mem.pxd +120 -0
  142. Cython/Includes/cpython/memoryview.pxd +50 -0
  143. Cython/Includes/cpython/method.pxd +49 -0
  144. Cython/Includes/cpython/module.pxd +208 -0
  145. Cython/Includes/cpython/number.pxd +258 -0
  146. Cython/Includes/cpython/object.pxd +433 -0
  147. Cython/Includes/cpython/pycapsule.pxd +143 -0
  148. Cython/Includes/cpython/pylifecycle.pxd +68 -0
  149. Cython/Includes/cpython/pyport.pxd +8 -0
  150. Cython/Includes/cpython/pystate.pxd +95 -0
  151. Cython/Includes/cpython/pythread.pxd +53 -0
  152. Cython/Includes/cpython/ref.pxd +141 -0
  153. Cython/Includes/cpython/sequence.pxd +134 -0
  154. Cython/Includes/cpython/set.pxd +119 -0
  155. Cython/Includes/cpython/slice.pxd +70 -0
  156. Cython/Includes/cpython/time.pxd +129 -0
  157. Cython/Includes/cpython/tuple.pxd +72 -0
  158. Cython/Includes/cpython/type.pxd +53 -0
  159. Cython/Includes/cpython/unicode.pxd +639 -0
  160. Cython/Includes/cpython/version.pxd +32 -0
  161. Cython/Includes/cpython/weakref.pxd +78 -0
  162. Cython/Includes/libc/__init__.pxd +1 -0
  163. Cython/Includes/libc/complex.pxd +35 -0
  164. Cython/Includes/libc/errno.pxd +127 -0
  165. Cython/Includes/libc/float.pxd +43 -0
  166. Cython/Includes/libc/limits.pxd +28 -0
  167. Cython/Includes/libc/locale.pxd +46 -0
  168. Cython/Includes/libc/math.pxd +209 -0
  169. Cython/Includes/libc/setjmp.pxd +10 -0
  170. Cython/Includes/libc/signal.pxd +64 -0
  171. Cython/Includes/libc/stddef.pxd +9 -0
  172. Cython/Includes/libc/stdint.pxd +105 -0
  173. Cython/Includes/libc/stdio.pxd +80 -0
  174. Cython/Includes/libc/stdlib.pxd +72 -0
  175. Cython/Includes/libc/string.pxd +50 -0
  176. Cython/Includes/libc/threads.pxd +234 -0
  177. Cython/Includes/libc/time.pxd +52 -0
  178. Cython/Includes/libcpp/__init__.pxd +4 -0
  179. Cython/Includes/libcpp/algorithm.pxd +320 -0
  180. Cython/Includes/libcpp/any.pxd +16 -0
  181. Cython/Includes/libcpp/atomic.pxd +59 -0
  182. Cython/Includes/libcpp/barrier.pxd +22 -0
  183. Cython/Includes/libcpp/bit.pxd +29 -0
  184. Cython/Includes/libcpp/cast.pxd +12 -0
  185. Cython/Includes/libcpp/cmath.pxd +518 -0
  186. Cython/Includes/libcpp/complex.pxd +106 -0
  187. Cython/Includes/libcpp/condition_variable.pxd +322 -0
  188. Cython/Includes/libcpp/deque.pxd +165 -0
  189. Cython/Includes/libcpp/exception.pxd +86 -0
  190. Cython/Includes/libcpp/execution.pxd +15 -0
  191. Cython/Includes/libcpp/forward_list.pxd +63 -0
  192. Cython/Includes/libcpp/functional.pxd +26 -0
  193. Cython/Includes/libcpp/future.pxd +103 -0
  194. Cython/Includes/libcpp/iterator.pxd +34 -0
  195. Cython/Includes/libcpp/latch.pxd +17 -0
  196. Cython/Includes/libcpp/limits.pxd +61 -0
  197. Cython/Includes/libcpp/list.pxd +117 -0
  198. Cython/Includes/libcpp/map.pxd +252 -0
  199. Cython/Includes/libcpp/memory.pxd +115 -0
  200. Cython/Includes/libcpp/mutex.pxd +387 -0
  201. Cython/Includes/libcpp/numbers.pxd +15 -0
  202. Cython/Includes/libcpp/numeric.pxd +131 -0
  203. Cython/Includes/libcpp/optional.pxd +34 -0
  204. Cython/Includes/libcpp/pair.pxd +1 -0
  205. Cython/Includes/libcpp/queue.pxd +25 -0
  206. Cython/Includes/libcpp/random.pxd +166 -0
  207. Cython/Includes/libcpp/semaphore.pxd +43 -0
  208. Cython/Includes/libcpp/set.pxd +228 -0
  209. Cython/Includes/libcpp/shared_mutex.pxd +96 -0
  210. Cython/Includes/libcpp/span.pxd +87 -0
  211. Cython/Includes/libcpp/stack.pxd +11 -0
  212. Cython/Includes/libcpp/stop_token.pxd +117 -0
  213. Cython/Includes/libcpp/string.pxd +355 -0
  214. Cython/Includes/libcpp/string_view.pxd +183 -0
  215. Cython/Includes/libcpp/typeindex.pxd +15 -0
  216. Cython/Includes/libcpp/typeinfo.pxd +10 -0
  217. Cython/Includes/libcpp/unordered_map.pxd +193 -0
  218. Cython/Includes/libcpp/unordered_set.pxd +152 -0
  219. Cython/Includes/libcpp/utility.pxd +30 -0
  220. Cython/Includes/libcpp/vector.pxd +186 -0
  221. Cython/Includes/numpy/math.pxd +150 -0
  222. Cython/Includes/openmp.pxd +50 -0
  223. Cython/Includes/posix/__init__.pxd +1 -0
  224. Cython/Includes/posix/dlfcn.pxd +14 -0
  225. Cython/Includes/posix/fcntl.pxd +86 -0
  226. Cython/Includes/posix/ioctl.pxd +4 -0
  227. Cython/Includes/posix/mman.pxd +101 -0
  228. Cython/Includes/posix/resource.pxd +57 -0
  229. Cython/Includes/posix/select.pxd +21 -0
  230. Cython/Includes/posix/signal.pxd +73 -0
  231. Cython/Includes/posix/stat.pxd +98 -0
  232. Cython/Includes/posix/stdio.pxd +37 -0
  233. Cython/Includes/posix/stdlib.pxd +29 -0
  234. Cython/Includes/posix/strings.pxd +9 -0
  235. Cython/Includes/posix/time.pxd +71 -0
  236. Cython/Includes/posix/types.pxd +30 -0
  237. Cython/Includes/posix/uio.pxd +26 -0
  238. Cython/Includes/posix/unistd.pxd +271 -0
  239. Cython/Includes/posix/wait.pxd +38 -0
  240. Cython/Plex/Actions.pxd +24 -0
  241. Cython/Plex/Actions.py +119 -0
  242. Cython/Plex/Actions.pyd +0 -0
  243. Cython/Plex/DFA.pxd +14 -0
  244. Cython/Plex/DFA.py +164 -0
  245. Cython/Plex/DFA.pyd +0 -0
  246. Cython/Plex/Errors.py +48 -0
  247. Cython/Plex/Lexicons.py +178 -0
  248. Cython/Plex/Machines.pxd +36 -0
  249. Cython/Plex/Machines.py +238 -0
  250. Cython/Plex/Machines.pyd +0 -0
  251. Cython/Plex/Regexps.py +535 -0
  252. Cython/Plex/Scanners.pxd +45 -0
  253. Cython/Plex/Scanners.py +328 -0
  254. Cython/Plex/Scanners.pyd +0 -0
  255. Cython/Plex/Transitions.pxd +14 -0
  256. Cython/Plex/Transitions.py +239 -0
  257. Cython/Plex/Transitions.pyd +0 -0
  258. Cython/Plex/__init__.py +34 -0
  259. Cython/Runtime/__init__.py +1 -0
  260. Cython/Runtime/refnanny.pyd +0 -0
  261. Cython/Runtime/refnanny.pyx +237 -0
  262. Cython/Shadow.py +690 -0
  263. Cython/Shadow.pyi +521 -0
  264. Cython/StringIOTree.py +170 -0
  265. Cython/StringIOTree.pyd +0 -0
  266. Cython/Tempita/__init__.py +4 -0
  267. Cython/Tempita/_looper.py +154 -0
  268. Cython/Tempita/_tempita.py +1091 -0
  269. Cython/Tempita/_tempita.pyd +0 -0
  270. Cython/TestUtils.py +422 -0
  271. Cython/Tests/TestCodeWriter.py +128 -0
  272. Cython/Tests/TestCythonUtils.py +202 -0
  273. Cython/Tests/TestJediTyper.py +223 -0
  274. Cython/Tests/TestShadow.py +114 -0
  275. Cython/Tests/TestStringIOTree.py +67 -0
  276. Cython/Tests/TestTestUtils.py +90 -0
  277. Cython/Tests/__init__.py +1 -0
  278. Cython/Tests/xmlrunner.py +390 -0
  279. Cython/Utility/AsyncGen.c +1031 -0
  280. Cython/Utility/Buffer.c +865 -0
  281. Cython/Utility/BufferFormatFromTypeInfo.pxd +2 -0
  282. Cython/Utility/Builtins.c +810 -0
  283. Cython/Utility/CConvert.pyx +134 -0
  284. Cython/Utility/CMath.c +104 -0
  285. Cython/Utility/CommonStructures.c +226 -0
  286. Cython/Utility/Complex.c +378 -0
  287. Cython/Utility/Coroutine.c +2300 -0
  288. Cython/Utility/CpdefEnums.pyx +103 -0
  289. Cython/Utility/CppConvert.pyx +282 -0
  290. Cython/Utility/CppSupport.cpp +151 -0
  291. Cython/Utility/CythonFunction.c +1832 -0
  292. Cython/Utility/Dataclasses.c +101 -0
  293. Cython/Utility/Embed.c +121 -0
  294. Cython/Utility/Exceptions.c +1016 -0
  295. Cython/Utility/ExtensionTypes.c +996 -0
  296. Cython/Utility/FunctionArguments.c +1043 -0
  297. Cython/Utility/FusedFunction.pyx +44 -0
  298. Cython/Utility/ImportExport.c +907 -0
  299. Cython/Utility/MemoryView.pxd +188 -0
  300. Cython/Utility/MemoryView.pyx +1482 -0
  301. Cython/Utility/MemoryView_C.c +927 -0
  302. Cython/Utility/ModuleSetupCode.c +3203 -0
  303. Cython/Utility/NumpyImportArray.c +46 -0
  304. Cython/Utility/ObjectHandling.c +3273 -0
  305. Cython/Utility/Optimize.c +1603 -0
  306. Cython/Utility/Overflow.c +384 -0
  307. Cython/Utility/Printing.c +86 -0
  308. Cython/Utility/Profile.c +732 -0
  309. Cython/Utility/StringTools.c +1379 -0
  310. Cython/Utility/Synchronization.c +399 -0
  311. Cython/Utility/TString.c +356 -0
  312. Cython/Utility/TestCyUtilityLoader.pyx +8 -0
  313. Cython/Utility/TestCythonScope.pyx +75 -0
  314. Cython/Utility/TestUtilityLoader.c +12 -0
  315. Cython/Utility/TypeConversion.c +1385 -0
  316. Cython/Utility/UFuncs.pyx +50 -0
  317. Cython/Utility/UFuncs_C.c +89 -0
  318. Cython/Utility/__init__.py +28 -0
  319. Cython/Utility/arrayarray.h +167 -0
  320. Cython/Utils.py +687 -0
  321. Cython/Utils.pyd +0 -0
  322. Cython/__init__.py +10 -0
  323. Cython/__init__.pyi +7 -0
  324. Cython/py.typed +0 -0
  325. cython-3.2.0.dist-info/METADATA +85 -0
  326. cython-3.2.0.dist-info/RECORD +333 -0
  327. cython-3.2.0.dist-info/WHEEL +5 -0
  328. cython-3.2.0.dist-info/entry_points.txt +4 -0
  329. cython-3.2.0.dist-info/top_level.txt +3 -0
  330. cython.py +29 -0
  331. pyximport/__init__.py +4 -0
  332. pyximport/pyxbuild.py +160 -0
  333. pyximport/pyximport.py +482 -0
@@ -0,0 +1,701 @@
1
+ # cython: infer_types=True
2
+ #
3
+ # Cython Scanner
4
+ #
5
+
6
+
7
+ import cython
8
+ cython.declare(make_lexicon=object, lexicon=object,
9
+ print_function=object, error=object, warning=object,
10
+ os=object, platform=object)
11
+
12
+ import os
13
+ import platform
14
+ from unicodedata import normalize
15
+ from contextlib import contextmanager
16
+
17
+ from .. import Utils
18
+ from ..Plex.Scanners import Scanner
19
+ from ..Plex.Errors import UnrecognizedInput
20
+ from .Errors import error, warning, hold_errors, release_errors, CompileError
21
+ from .Lexicon import any_string_prefix, ft_string_prefixes, make_lexicon, IDENT
22
+ from .Future import print_function
23
+
24
+ debug_scanner = 0
25
+ trace_scanner = 0
26
+ scanner_debug_flags = 0
27
+ scanner_dump_file = None
28
+
29
+ lexicon = None
30
+
31
+
32
+ def get_lexicon():
33
+ global lexicon
34
+ if not lexicon:
35
+ lexicon = make_lexicon()
36
+ return lexicon
37
+
38
+
39
+ #------------------------------------------------------------------
40
+
41
+ py_reserved_words = [
42
+ "global", "nonlocal", "def", "class", "print", "del", "pass", "break",
43
+ "continue", "return", "raise", "import", "exec", "try",
44
+ "except", "finally", "while", "if", "elif", "else", "for",
45
+ "in", "assert", "and", "or", "not", "is", "lambda",
46
+ "from", "yield", "with",
47
+ ]
48
+
49
+ pyx_reserved_words = py_reserved_words + [
50
+ "include", "ctypedef", "cdef", "cpdef",
51
+ "cimport", "DEF", "IF", "ELIF", "ELSE"
52
+ ]
53
+
54
+
55
+ #------------------------------------------------------------------
56
+
57
+ class CompileTimeScope:
58
+
59
+ def __init__(self, outer=None):
60
+ self.entries = {}
61
+ self.outer = outer
62
+
63
+ def declare(self, name, value):
64
+ self.entries[name] = value
65
+
66
+ def update(self, other):
67
+ self.entries.update(other)
68
+
69
+ def lookup_here(self, name):
70
+ return self.entries[name]
71
+
72
+ def __contains__(self, name):
73
+ return name in self.entries
74
+
75
+ def lookup(self, name):
76
+ try:
77
+ return self.lookup_here(name)
78
+ except KeyError:
79
+ outer = self.outer
80
+ if outer:
81
+ return outer.lookup(name)
82
+ else:
83
+ raise
84
+
85
+
86
+ def initial_compile_time_env():
87
+ benv = CompileTimeScope()
88
+ names = ('UNAME_SYSNAME', 'UNAME_NODENAME', 'UNAME_RELEASE', 'UNAME_VERSION', 'UNAME_MACHINE')
89
+ for name, value in zip(names, platform.uname()):
90
+ benv.declare(name, value)
91
+ import builtins
92
+
93
+ names = (
94
+ 'False', 'True',
95
+ 'abs', 'all', 'any', 'ascii', 'bin', 'bool', 'bytearray', 'bytes',
96
+ 'chr', 'complex', 'dict', 'divmod', 'enumerate', 'filter',
97
+ 'float', 'format', 'frozenset', 'hash', 'hex', 'int', 'len',
98
+ 'list', 'map', 'max', 'min', 'next', 'oct', 'ord', 'pow', 'range',
99
+ 'repr', 'reversed', 'round', 'set', 'slice', 'sorted', 'str',
100
+ 'sum', 'tuple', 'zip',
101
+ ### defined below in a platform independent way
102
+ # 'long', 'unicode', 'reduce', 'xrange'
103
+ )
104
+
105
+ for name in names:
106
+ benv.declare(name, getattr(builtins, name))
107
+
108
+ # legacy Py2 names
109
+ from functools import reduce
110
+ benv.declare('reduce', reduce)
111
+ benv.declare('unicode', str)
112
+ benv.declare('long', int)
113
+ benv.declare('xrange', range)
114
+
115
+ denv = CompileTimeScope(benv)
116
+ return denv
117
+
118
+
119
+ #------------------------------------------------------------------
120
+
121
+ class SourceDescriptor:
122
+ """
123
+ A SourceDescriptor should be considered immutable.
124
+ """
125
+ filename = None
126
+ in_utility_code = False
127
+
128
+ _file_type = 'pyx'
129
+
130
+ _escaped_description = None
131
+ _cmp_name = ''
132
+ def __str__(self):
133
+ assert False # To catch all places where a descriptor is used directly as a filename
134
+
135
+ def set_file_type_from_name(self, filename):
136
+ name, ext = os.path.splitext(filename)
137
+ self._file_type = ext in ('.pyx', '.pxd', '.py') and ext[1:] or 'pyx'
138
+
139
+ def is_cython_file(self):
140
+ return self._file_type in ('pyx', 'pxd')
141
+
142
+ def is_python_file(self):
143
+ return self._file_type == 'py'
144
+
145
+ def get_escaped_description(self):
146
+ if self._escaped_description is None:
147
+ # Use forward slashes on Windows since these paths
148
+ # will be used in the #line directives in the C/C++ files.
149
+ self._escaped_description = self.get_description().replace('\\', '/')
150
+ return self._escaped_description
151
+
152
+ def __gt__(self, other):
153
+ # this is only used to provide some sort of order
154
+ try:
155
+ return self._cmp_name > other._cmp_name
156
+ except AttributeError:
157
+ return False
158
+
159
+ def __lt__(self, other):
160
+ # this is only used to provide some sort of order
161
+ try:
162
+ return self._cmp_name < other._cmp_name
163
+ except AttributeError:
164
+ return False
165
+
166
+ def __le__(self, other):
167
+ # this is only used to provide some sort of order
168
+ try:
169
+ return self._cmp_name <= other._cmp_name
170
+ except AttributeError:
171
+ return False
172
+
173
+ def __copy__(self):
174
+ return self # immutable, no need to copy
175
+
176
+ def __deepcopy__(self, memo):
177
+ return self # immutable, no need to copy
178
+
179
+
180
+ class FileSourceDescriptor(SourceDescriptor):
181
+ """
182
+ Represents a code source. A code source is a more generic abstraction
183
+ for a "filename" (as sometimes the code doesn't come from a file).
184
+ Instances of code sources are passed to Scanner.__init__ as the
185
+ optional name argument and will be passed back when asking for
186
+ the position()-tuple.
187
+ """
188
+ def __init__(self, filename, path_description=None):
189
+ filename = Utils.decode_filename(filename)
190
+ self.filename = filename
191
+ self.path_description = path_description or filename
192
+ try:
193
+ self._short_path_description = os.path.relpath(self.path_description)
194
+ except ValueError:
195
+ # path not under current directory => use complete file path
196
+ self._short_path_description = self.path_description
197
+ # Prefer relative paths to current directory (which is most likely the project root) over absolute paths.
198
+ workdir = os.path.abspath('.') + os.sep
199
+ self.file_path = filename[len(workdir):] if filename.startswith(workdir) else filename
200
+ self.set_file_type_from_name(filename)
201
+ self._cmp_name = filename
202
+ self._lines = {}
203
+
204
+ def get_lines(self, encoding=None, error_handling=None):
205
+ # we cache the lines only the second time this is called, in
206
+ # order to save memory when they are only used once
207
+ key = (encoding, error_handling)
208
+ lines = self._lines.get(key)
209
+ if lines is not None:
210
+ return lines
211
+
212
+ with self.get_file_object(encoding=encoding, error_handling=error_handling) as f:
213
+ lines = [line.rstrip() for line in f.readlines()]
214
+
215
+ # Do not cache the first access, but add the key to remember that we already read it once.
216
+ self._lines[key] = lines if key in self._lines else None
217
+ return lines
218
+
219
+ def get_file_object(self, encoding=None, error_handling=None):
220
+ return Utils.open_source_file(self.filename, encoding, error_handling)
221
+
222
+ def get_description(self):
223
+ return self._short_path_description
224
+
225
+ def get_error_description(self):
226
+ path = self.filename
227
+ cwd = Utils.decode_filename(os.getcwd() + os.path.sep)
228
+ if path.startswith(cwd):
229
+ return path[len(cwd):]
230
+ return path
231
+
232
+ def get_filenametable_entry(self):
233
+ return self.file_path
234
+
235
+ def __eq__(self, other):
236
+ return isinstance(other, FileSourceDescriptor) and self.filename == other.filename
237
+
238
+ def __hash__(self):
239
+ return hash(self.filename)
240
+
241
+ def __repr__(self):
242
+ return "<FileSourceDescriptor:%s>" % self.filename
243
+
244
+
245
+ class StringSourceDescriptor(SourceDescriptor):
246
+ """
247
+ Instances of this class can be used instead of a filenames if the
248
+ code originates from a string object.
249
+ """
250
+ def __init__(self, name, code):
251
+ self.name = name
252
+ #self.set_file_type_from_name(name)
253
+ self.codelines = [line.rstrip() for line in code.splitlines()]
254
+ self._cmp_name = name
255
+
256
+ def get_lines(self, encoding=None, error_handling=None):
257
+ if not encoding:
258
+ return self.codelines
259
+ else:
260
+ return [line.encode(encoding, error_handling).decode(encoding)
261
+ for line in self.codelines]
262
+
263
+ def get_description(self):
264
+ return self.name
265
+
266
+ get_error_description = get_description
267
+
268
+ def get_filenametable_entry(self):
269
+ return "<stringsource>"
270
+
271
+ def __hash__(self):
272
+ return id(self)
273
+ # Do not hash on the name, an identical string source should be the
274
+ # same object (name is often defaulted in other places)
275
+ # return hash(self.name)
276
+
277
+ def __eq__(self, other):
278
+ return isinstance(other, StringSourceDescriptor) and self.name == other.name
279
+
280
+ def __repr__(self):
281
+ return "<StringSourceDescriptor:%s>" % self.name
282
+
283
+
284
+ #------------------------------------------------------------------
285
+
286
+ class PyrexScanner(Scanner):
287
+ # context Context Compilation context
288
+ # included_files [string] Files included with 'include' statement
289
+ # compile_time_env dict Environment for conditional compilation
290
+ # compile_time_eval boolean In a true conditional compilation context
291
+ # compile_time_expr boolean In a compile-time expression context
292
+ # put_back_on_failure list or None If set, this records states so the tentatively_scan
293
+ # contextmanager can restore it
294
+
295
+ def __init__(self, file, filename, parent_scanner=None,
296
+ scope=None, context=None, source_encoding=None, parse_comments=True, initial_pos=None):
297
+ Scanner.__init__(self, get_lexicon(), file, filename, initial_pos)
298
+
299
+ if filename.is_python_file():
300
+ self.in_python_file = True
301
+ keywords = py_reserved_words
302
+ else:
303
+ self.in_python_file = False
304
+ keywords = pyx_reserved_words
305
+ self.keywords = {keyword: keyword for keyword in keywords}
306
+
307
+ self.async_enabled = 0
308
+
309
+ if parent_scanner:
310
+ self.context = parent_scanner.context
311
+ self.included_files = parent_scanner.included_files
312
+ self.compile_time_env = parent_scanner.compile_time_env
313
+ self.compile_time_eval = parent_scanner.compile_time_eval
314
+ self.compile_time_expr = parent_scanner.compile_time_expr
315
+
316
+ if parent_scanner.async_enabled:
317
+ self.enter_async()
318
+ else:
319
+ self.context = context
320
+ self.included_files = scope.included_files
321
+ self.compile_time_env = initial_compile_time_env()
322
+ self.compile_time_eval = 1
323
+ self.compile_time_expr = 0
324
+ if getattr(context.options, 'compile_time_env', None):
325
+ self.compile_time_env.update(context.options.compile_time_env)
326
+ self.parse_comments = parse_comments
327
+ self.source_encoding = source_encoding
328
+ self.trace = trace_scanner
329
+ self.indentation_stack = [0]
330
+ self.indentation_char = '\0'
331
+ self.bracket_nesting_level = 0
332
+ # fstrings/tstrings
333
+ self.ft_string_state_stack = []
334
+ self.in_ft_string_expr_prescan = 0
335
+
336
+ self.put_back_on_failure = None
337
+
338
+ self.begin('INDENT')
339
+ self.sy = ''
340
+ self.next()
341
+
342
+ def normalize_ident(self, text):
343
+ if not text.isascii():
344
+ text = normalize('NFKC', text)
345
+ self.produce(IDENT, text)
346
+
347
+ def commentline(self, text):
348
+ if self.parse_comments:
349
+ self.produce('commentline', text)
350
+
351
+ def strip_underscores(self, text, symbol):
352
+ self.produce(symbol, text.replace('_', ''))
353
+
354
+ def current_level(self):
355
+ return self.indentation_stack[-1]
356
+
357
+ def open_bracket_action(self, text):
358
+ self.bracket_nesting_level += 1
359
+ return text
360
+
361
+ def close_bracket_action(self, text):
362
+ self.bracket_nesting_level -= 1
363
+ return text
364
+
365
+ def open_brace_action(self, text):
366
+ return self.open_bracket_action(text)
367
+
368
+ def close_brace_action(self, text):
369
+ assert text == '}'
370
+ if (self.ft_string_state_stack and
371
+ self.ft_string_state_stack[-1].bracket_nesting_level() == self.bracket_nesting_level):
372
+ if not self.ft_string_state_stack[-1].in_format_specifier():
373
+ self.in_ft_string_expr_prescan -= 1
374
+ if self.in_ft_string_expr_prescan == 0:
375
+ self.produce("END_FT_STRING_EXPR")
376
+ self.begin(self.ft_string_state_stack[-1].scanner_state)
377
+ self.ft_string_state_stack[-1].pop_bracket_state()
378
+ self.bracket_nesting_level -= 1
379
+ return text
380
+
381
+ def colon_action(self, text):
382
+ if (self.ft_string_state_stack and
383
+ self.ft_string_state_stack[-1].bracket_nesting_level() == self.bracket_nesting_level):
384
+ self.in_ft_string_expr_prescan -= 1
385
+ if self.in_ft_string_expr_prescan == 0:
386
+ self.produce("END_FT_STRING_EXPR")
387
+ self.begin(self.ft_string_state_stack[-1].scanner_state)
388
+ self.ft_string_state_stack[-1].set_in_format_specifier()
389
+ return text
390
+
391
+ def newline_action(self, text):
392
+ if self.bracket_nesting_level == 0:
393
+ self.begin('INDENT')
394
+ self.produce('NEWLINE', '')
395
+
396
+ string_states = {
397
+ "'": 'SQ_STRING',
398
+ '"': 'DQ_STRING',
399
+ "'''": 'TSQ_STRING',
400
+ '"""': 'TDQ_STRING'
401
+ }
402
+
403
+ def begin_string_action(self, text: str):
404
+ while text and text[0] in any_string_prefix:
405
+ text = text[1:]
406
+ self.begin(self.string_states[text])
407
+ self.produce('BEGIN_STRING')
408
+
409
+ def end_string_action(self, text):
410
+ self.begin('FT_STRING_EXPR_PRESCAN' if self.in_ft_string_expr_prescan else '')
411
+ self.produce('END_STRING')
412
+
413
+ def begin_ft_string_action(self, text):
414
+ is_raw = 'r' in text or 'R' in text
415
+ while text and (text[0] in any_string_prefix or text[0] in ft_string_prefixes):
416
+ text = text[1:]
417
+ ft_string_state = f'{self.string_states[text]}_FT{"R" if is_raw else ""}'
418
+ self.ft_string_state_stack.append(
419
+ FTStringState(ft_string_state)
420
+ )
421
+ self.begin(ft_string_state)
422
+ self.produce('BEGIN_FT_STRING')
423
+
424
+ def end_ft_string_action(self, text):
425
+ self.ft_string_state_stack.pop()
426
+ self.begin('FT_STRING_EXPR_PRESCAN' if self.in_ft_string_expr_prescan else '')
427
+ self.produce('END_FT_STRING')
428
+
429
+ def _handle_open_single_ft_string_brace(self, started_ft_string_expr):
430
+ self.bracket_nesting_level += 1
431
+ if not started_ft_string_expr:
432
+ self.ft_string_state_stack[-1].push_bracket_state(self.bracket_nesting_level)
433
+ self.begin('FT_STRING_EXPR_PRESCAN')
434
+ self.in_ft_string_expr_prescan += 1
435
+ self.produce('{')
436
+
437
+ def open_ft_string_brace_action(self, text):
438
+ len_text = len(text)
439
+ started_ft_string_expr = False
440
+ if self.ft_string_state_stack[-1].in_format_specifier():
441
+ self._handle_open_single_ft_string_brace(started_ft_string_expr)
442
+ len_text -= 1
443
+ started_ft_string_expr = True
444
+ assert not self.ft_string_state_stack[-1].in_format_specifier()
445
+
446
+ double_braces = len_text // 2
447
+ for _ in range(double_braces):
448
+ self.produce('CHARS', '{')
449
+ len_text -= (double_braces*2)
450
+
451
+ if len_text:
452
+ assert len_text == 1
453
+ self._handle_open_single_ft_string_brace(started_ft_string_expr)
454
+
455
+ def _handle_close_single_ft_string_brace(self):
456
+ ft_string_bracket_level = self.ft_string_state_stack[-1].bracket_nesting_level()
457
+ if ft_string_bracket_level is None or self.bracket_nesting_level < ft_string_bracket_level:
458
+ # To help try to parse a little further, don't reduce the bracket
459
+ # nesting level more.
460
+ self.error(
461
+ # Unfortunately the scanner doesn't know which
462
+ "f-string or t-string: single '}' is not allowed",
463
+ pos=self.get_current_scan_pos(),
464
+ fatal=False)
465
+ self.produce('}', '}')
466
+ else:
467
+ self.produce(self.close_brace_action('}'), '}')
468
+
469
+ def close_ft_string_brace_action(self, text):
470
+ len_text = len(text)
471
+ while len_text and self.ft_string_state_stack[-1].in_format_specifier():
472
+ self._handle_close_single_ft_string_brace()
473
+ len_text -= 1
474
+
475
+ double_braces = len_text // 2
476
+ for _ in range(double_braces):
477
+ self.produce('CHARS', '}')
478
+ len_text -= double_braces*2
479
+
480
+ if len_text:
481
+ self._handle_close_single_ft_string_brace()
482
+
483
+ def unclosed_string_action(self, text):
484
+ self.end_string_action(text)
485
+ self.error_at_scanpos("Unclosed string literal")
486
+
487
+ def indentation_action(self, text: str):
488
+ self.begin('')
489
+ # Indentation within brackets should be ignored.
490
+ #if self.bracket_nesting_level > 0:
491
+ # return
492
+ # Check that tabs and spaces are being used consistently.
493
+ if text:
494
+ c = text[0]
495
+ #print "Scanner.indentation_action: indent with", repr(c) ###
496
+ if self.indentation_char == '\0':
497
+ self.indentation_char = c
498
+ #print "Scanner.indentation_action: setting indent_char to", repr(c)
499
+ else:
500
+ if self.indentation_char != c:
501
+ self.error_at_scanpos("Mixed use of tabs and spaces")
502
+ if text.replace(c, "") != "":
503
+ self.error_at_scanpos("Mixed use of tabs and spaces")
504
+ # Figure out how many indents/dedents to do
505
+ current_level: cython.Py_ssize_t = self.current_level()
506
+ new_level: cython.Py_ssize_t = len(text)
507
+ #print "Changing indent level from", current_level, "to", new_level ###
508
+ if new_level == current_level:
509
+ return
510
+ elif new_level > current_level:
511
+ #print "...pushing level", new_level ###
512
+ self.indentation_stack.append(new_level)
513
+ self.produce('INDENT', '')
514
+ else:
515
+ while new_level < self.current_level():
516
+ #print "...popping level", self.indentation_stack[-1] ###
517
+ self.indentation_stack.pop()
518
+ self.produce('DEDENT', '')
519
+ #print "...current level now", self.current_level() ###
520
+ if new_level != self.current_level():
521
+ self.error_at_scanpos("Inconsistent indentation")
522
+
523
+ def eof_action(self, text):
524
+ while len(self.indentation_stack) > 1:
525
+ self.produce('DEDENT', '')
526
+ self.indentation_stack.pop()
527
+ self.produce('EOF', '')
528
+
529
+ def next(self):
530
+ try:
531
+ sy, systring = self.read()
532
+ except UnrecognizedInput:
533
+ self.error_at_scanpos("Unrecognized character")
534
+ return # just a marker, error() always raises
535
+ if sy == IDENT:
536
+ if systring in self.keywords:
537
+ if systring == 'print' and print_function in self.context.future_directives:
538
+ self.keywords.pop('print', None)
539
+ elif systring == 'exec' and self.context.language_level >= 3:
540
+ self.keywords.pop('exec', None)
541
+ else:
542
+ sy = self.keywords[systring] # intern
543
+ systring = self.context.intern_ustring(systring)
544
+ if self.put_back_on_failure is not None:
545
+ self.put_back_on_failure.append((sy, systring, self.position()))
546
+ self.sy = sy
547
+ self.systring = systring
548
+ if False: # debug_scanner:
549
+ _, line, col = self.position()
550
+ if not self.systring or self.sy == self.systring:
551
+ t = self.sy
552
+ else:
553
+ t = "%s %s" % (self.sy, self.systring)
554
+ print("--- %3d %2d %s" % (line, col, t))
555
+
556
+ def peek(self):
557
+ saved = self.sy, self.systring
558
+ saved_pos = self.position()
559
+ self.next()
560
+ next = self.sy, self.systring
561
+ self.unread(self.sy, self.systring, self.position())
562
+ self.sy, self.systring = saved
563
+ self.last_token_position_tuple = saved_pos
564
+ return next
565
+
566
+ def put_back(self, sy, systring, pos):
567
+ self.unread(self.sy, self.systring, self.last_token_position_tuple)
568
+ self.sy = sy
569
+ self.systring = systring
570
+ self.last_token_position_tuple = pos
571
+
572
+
573
+ def error(self, message, pos=None, fatal=True):
574
+ if pos is None:
575
+ pos = self.position()
576
+ if self.sy == 'INDENT':
577
+ error(pos, "Possible inconsistent indentation")
578
+ err = error(pos, message)
579
+ if fatal: raise err
580
+
581
+ def error_at_scanpos(self, message):
582
+ # Like error(fatal=True), but gets the current scanning position rather than
583
+ # the position of the last token read.
584
+ pos = self.get_current_scan_pos()
585
+ self.error(message, pos, True)
586
+
587
+ def expect(self, what, message=None):
588
+ if self.sy == what:
589
+ self.next()
590
+ else:
591
+ self.expected(what, message)
592
+
593
+ def expect_keyword(self, what, message=None):
594
+ if self.sy == IDENT and self.systring == what:
595
+ self.next()
596
+ else:
597
+ self.expected(what, message)
598
+
599
+ def expected(self, what, message=None):
600
+ if message:
601
+ self.error(message)
602
+ else:
603
+ if self.sy == IDENT:
604
+ found = self.systring
605
+ else:
606
+ found = self.sy
607
+ self.error("Expected '%s', found '%s'" % (what, found))
608
+
609
+ def expect_indent(self):
610
+ self.expect('INDENT', "Expected an increase in indentation level")
611
+
612
+ def expect_dedent(self):
613
+ self.expect('DEDENT', "Expected a decrease in indentation level")
614
+
615
+ def expect_newline(self, message="Expected a newline", ignore_semicolon: cython.bint = False):
616
+ # Expect either a newline or end of file
617
+ useless_trailing_semicolon = None
618
+ if ignore_semicolon and self.sy == ';':
619
+ useless_trailing_semicolon = self.position()
620
+ self.next()
621
+ if self.sy != 'EOF':
622
+ self.expect('NEWLINE', message)
623
+ if useless_trailing_semicolon is not None:
624
+ warning(useless_trailing_semicolon, "useless trailing semicolon")
625
+
626
+ def enter_async(self):
627
+ self.async_enabled += 1
628
+ if self.async_enabled == 1:
629
+ self.keywords['async'] = 'async'
630
+ self.keywords['await'] = 'await'
631
+
632
+ def exit_async(self):
633
+ assert self.async_enabled > 0
634
+ self.async_enabled -= 1
635
+ if not self.async_enabled:
636
+ del self.keywords['await']
637
+ del self.keywords['async']
638
+ if self.sy in ('async', 'await'):
639
+ self.sy, self.systring = IDENT, self.context.intern_ustring(self.sy)
640
+
641
+ @contextmanager
642
+ def tentatively_scan(scanner: PyrexScanner):
643
+ errors = hold_errors()
644
+ try:
645
+ put_back_on_failure = scanner.put_back_on_failure
646
+ scanner.put_back_on_failure = []
647
+ initial_state = (scanner.sy, scanner.systring, scanner.position())
648
+ try:
649
+ yield errors
650
+ except CompileError as e:
651
+ pass
652
+ finally:
653
+ if errors:
654
+ if scanner.put_back_on_failure:
655
+ for put_back in reversed(scanner.put_back_on_failure[:-1]):
656
+ scanner.put_back(*put_back)
657
+ # we need to restore the initial state too
658
+ scanner.put_back(*initial_state)
659
+ elif put_back_on_failure is not None:
660
+ # the outer "tentatively_scan" block that we're in might still
661
+ # want to undo this block
662
+ put_back_on_failure.extend(scanner.put_back_on_failure)
663
+ scanner.put_back_on_failure = put_back_on_failure
664
+ finally:
665
+ release_errors(ignore=True)
666
+
667
+
668
+ class FTStringState:
669
+ def __init__(self, scanner_state):
670
+ self.scanner_state = scanner_state
671
+ self.bracket_states = []
672
+
673
+ def bracket_nesting_level(self):
674
+ if not self.bracket_states:
675
+ return None
676
+ return self.bracket_states[-1].bracket_nesting_level
677
+
678
+ def in_format_specifier(self):
679
+ if not self.bracket_states:
680
+ return False
681
+ return self.bracket_states[-1].in_format_specifier
682
+
683
+ def set_in_format_specifier(self):
684
+ self.bracket_states[-1].in_format_specifier = True
685
+
686
+ def push_bracket_state(self, bracket_nesting_level: int):
687
+ self.bracket_states.append(FTStringBracketState(bracket_nesting_level))
688
+
689
+ def pop_bracket_state(self):
690
+ self.bracket_states.pop()
691
+
692
+
693
+ class FTStringBracketState:
694
+ # Because of the way this is accessed, it probably doesn't make sense as a cdef class
695
+ # so just use __slots__ to keep it compact.
696
+ __slots__ = ('bracket_nesting_level', 'in_format_specifier')
697
+ bracket_nesting_level: int
698
+ in_format_specifier: bool
699
+ def __init__(self, bracket_nesting_level: int):
700
+ self.bracket_nesting_level = bracket_nesting_level
701
+ self.in_format_specifier = False
Binary file