Nuitka-winsvc 2.3.9__cp311-cp311-win_amd64.whl → 2.4.1__cp311-cp311-win_amd64.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.

Potentially problematic release.


This version of Nuitka-winsvc might be problematic. Click here for more details.

Files changed (213) hide show
  1. Nuitka_winsvc-2.3.9.data/scripts/nuitka-run.bat → Nuitka_winsvc-2.4.1.data/scripts/nuitka-run.cmd +1 -1
  2. {Nuitka_winsvc-2.3.9.dist-info → Nuitka_winsvc-2.4.1.dist-info}/METADATA +1 -1
  3. {Nuitka_winsvc-2.3.9.dist-info → Nuitka_winsvc-2.4.1.dist-info}/RECORD +213 -210
  4. {Nuitka_winsvc-2.3.9.dist-info → Nuitka_winsvc-2.4.1.dist-info}/WHEEL +1 -1
  5. nuitka/CacheCleanup.py +6 -1
  6. nuitka/HardImportRegistry.py +29 -2
  7. nuitka/MainControl.py +62 -35
  8. nuitka/ModuleRegistry.py +11 -3
  9. nuitka/OptionParsing.py +78 -39
  10. nuitka/Options.py +142 -35
  11. nuitka/OutputDirectories.py +5 -0
  12. nuitka/PostProcessing.py +23 -14
  13. nuitka/PythonFlavors.py +22 -4
  14. nuitka/PythonVersions.py +18 -0
  15. nuitka/Tracing.py +26 -23
  16. nuitka/TreeXML.py +6 -3
  17. nuitka/Version.py +1 -1
  18. nuitka/__main__.py +55 -10
  19. nuitka/build/Backend.scons +6 -1
  20. nuitka/build/CCompilerVersion.scons +1 -0
  21. nuitka/build/Onefile.scons +4 -0
  22. nuitka/build/SconsCaching.py +1 -0
  23. nuitka/build/SconsCompilerSettings.py +1 -0
  24. nuitka/build/SconsHacks.py +5 -1
  25. nuitka/build/SconsInterface.py +2 -0
  26. nuitka/build/SconsUtils.py +5 -2
  27. nuitka/build/include/nuitka/allocator.h +27 -5
  28. nuitka/build/include/nuitka/calling.h +1 -1
  29. nuitka/build/include/nuitka/compiled_frame.h +23 -23
  30. nuitka/build/include/nuitka/compiled_method.h +1 -1
  31. nuitka/build/include/nuitka/exception_groups.h +0 -2
  32. nuitka/build/include/nuitka/helper/attributes.h +7 -1
  33. nuitka/build/include/nuitka/helper/subscripts.h +1 -1
  34. nuitka/build/include/nuitka/helpers.h +7 -4
  35. nuitka/build/include/nuitka/prelude.h +6 -10
  36. nuitka/build/include/nuitka/printing.h +2 -0
  37. nuitka/build/include/nuitka/unfreezing.h +5 -5
  38. nuitka/build/inline_copy/tqdm/tqdm/_monitor.py +4 -1
  39. nuitka/build/static_src/CompiledAsyncgenType.c +2 -4
  40. nuitka/build/static_src/CompiledCellType.c +7 -7
  41. nuitka/build/static_src/CompiledCodeHelpers.c +51 -36
  42. nuitka/build/static_src/CompiledCoroutineType.c +2 -4
  43. nuitka/build/static_src/CompiledFrameType.c +109 -82
  44. nuitka/build/static_src/CompiledFunctionType.c +36 -9
  45. nuitka/build/static_src/CompiledGeneratorType.c +12 -10
  46. nuitka/build/static_src/CompiledGeneratorTypeUncompiledIntegration.c +2 -2
  47. nuitka/build/static_src/CompiledMethodType.c +14 -13
  48. nuitka/build/static_src/HelpersAttributes.c +13 -15
  49. nuitka/build/static_src/HelpersBuiltin.c +18 -9
  50. nuitka/build/static_src/HelpersCalling.c +13 -13
  51. nuitka/build/static_src/HelpersCallingGenerated.c +22 -22
  52. nuitka/build/static_src/HelpersComparisonEq.c +110 -110
  53. nuitka/build/static_src/HelpersComparisonEqUtils.c +1 -1
  54. nuitka/build/static_src/HelpersComparisonGe.c +110 -110
  55. nuitka/build/static_src/HelpersComparisonGt.c +110 -110
  56. nuitka/build/static_src/HelpersComparisonLe.c +110 -110
  57. nuitka/build/static_src/HelpersComparisonLt.c +110 -110
  58. nuitka/build/static_src/HelpersComparisonNe.c +110 -110
  59. nuitka/build/static_src/HelpersConstantsBlob.c +480 -481
  60. nuitka/build/static_src/HelpersDictionaries.c +9 -0
  61. nuitka/build/static_src/HelpersFiles.c +2 -2
  62. nuitka/build/static_src/HelpersFilesystemPaths.c +28 -13
  63. nuitka/build/static_src/HelpersHeapStorage.c +4 -0
  64. nuitka/build/static_src/HelpersImport.c +1 -1
  65. nuitka/build/static_src/HelpersLists.c +5 -1
  66. nuitka/build/static_src/HelpersMatching.c +95 -35
  67. nuitka/build/static_src/HelpersOperationInplaceAdd.c +23 -23
  68. nuitka/build/static_src/HelpersOperationInplaceAddUtils.c +1 -0
  69. nuitka/build/static_src/HelpersOperationInplaceBitand.c +11 -11
  70. nuitka/build/static_src/HelpersOperationInplaceBitor.c +11 -11
  71. nuitka/build/static_src/HelpersOperationInplaceBitxor.c +11 -11
  72. nuitka/build/static_src/HelpersOperationInplaceFloordiv.c +17 -17
  73. nuitka/build/static_src/HelpersOperationInplaceLshift.c +9 -9
  74. nuitka/build/static_src/HelpersOperationInplaceMatmult.c +10 -10
  75. nuitka/build/static_src/HelpersOperationInplaceMod.c +47 -47
  76. nuitka/build/static_src/HelpersOperationInplaceMult.c +28 -28
  77. nuitka/build/static_src/HelpersOperationInplaceOlddiv.c +17 -17
  78. nuitka/build/static_src/HelpersOperationInplacePow.c +17 -17
  79. nuitka/build/static_src/HelpersOperationInplaceRshift.c +9 -9
  80. nuitka/build/static_src/HelpersOperationInplaceSub.c +17 -17
  81. nuitka/build/static_src/HelpersOperationInplaceTruediv.c +17 -17
  82. nuitka/build/static_src/HelpersSequences.c +1 -1
  83. nuitka/build/static_src/HelpersTypes.c +8 -4
  84. nuitka/build/static_src/MainProgram.c +28 -9
  85. nuitka/build/static_src/MetaPathBasedLoader.c +126 -110
  86. nuitka/build/static_src/MetaPathBasedLoaderImportlibMetadataDistribution.c +13 -4
  87. nuitka/build/static_src/MetaPathBasedLoaderResourceReaderFiles.c +30 -1
  88. nuitka/build/static_src/OnefileBootstrap.c +34 -6
  89. nuitka/code_generation/AttributeCodes.py +12 -10
  90. nuitka/code_generation/CodeGeneration.py +6 -7
  91. nuitka/code_generation/ConstantCodes.py +53 -10
  92. nuitka/code_generation/GlobalConstants.py +6 -6
  93. nuitka/code_generation/Indentation.py +3 -4
  94. nuitka/code_generation/LoaderCodes.py +3 -0
  95. nuitka/code_generation/LocalsDictCodes.py +36 -14
  96. nuitka/code_generation/MatchCodes.py +23 -4
  97. nuitka/code_generation/ModuleCodes.py +0 -7
  98. nuitka/code_generation/Namify.py +2 -0
  99. nuitka/code_generation/PackageResourceCodes.py +5 -1
  100. nuitka/code_generation/templates/CodeTemplatesConstants.py +6 -4
  101. nuitka/code_generation/templates/CodeTemplatesLoader.py +1 -1
  102. nuitka/code_generation/templates/CodeTemplatesModules.py +3 -3
  103. nuitka/code_generation/templates/CodeTemplatesVariables.py +16 -2
  104. nuitka/code_generation/templates_c/CodeTemplateCallsMethodPositional.c.j2 +2 -2
  105. nuitka/code_generation/templates_c/HelperOperationBinary.c.j2 +1 -1
  106. nuitka/code_generation/templates_c/HelperOperationInplace.c.j2 +1 -1
  107. nuitka/code_generation/templates_c/HelperSlotsBinary.c.j2 +7 -7
  108. nuitka/freezer/DependsExe.py +3 -1
  109. nuitka/freezer/DllDependenciesMacOS.py +28 -14
  110. nuitka/freezer/IncludedDataFiles.py +12 -3
  111. nuitka/freezer/IncludedEntryPoints.py +8 -2
  112. nuitka/freezer/Onefile.py +6 -1
  113. nuitka/freezer/Standalone.py +9 -2
  114. nuitka/importing/Importing.py +14 -5
  115. nuitka/importing/Recursion.py +3 -0
  116. nuitka/nodes/AttributeNodesGenerated.py +21 -12
  117. nuitka/nodes/BuiltinOpenNodes.py +5 -0
  118. nuitka/nodes/BuiltinOperationNodeBasesGenerated.py +11 -11
  119. nuitka/nodes/BuiltinRefNodes.py +41 -1
  120. nuitka/nodes/ChildrenHavingMixins.py +143 -355
  121. nuitka/nodes/ClassNodes.py +30 -12
  122. nuitka/nodes/CodeObjectSpecs.py +9 -0
  123. nuitka/nodes/ExpressionBasesGenerated.py +11 -11
  124. nuitka/nodes/FunctionNodes.py +11 -12
  125. nuitka/nodes/FutureSpecs.py +16 -3
  126. nuitka/nodes/GeneratorNodes.py +2 -2
  127. nuitka/nodes/HardImportNodesGenerated.py +11 -134
  128. nuitka/nodes/LocalsScopes.py +19 -23
  129. nuitka/nodes/MatchNodes.py +18 -7
  130. nuitka/nodes/ModuleAttributeNodes.py +1 -20
  131. nuitka/nodes/ModuleNodes.py +23 -6
  132. nuitka/nodes/NodeBases.py +13 -11
  133. nuitka/nodes/NodeMetaClasses.py +26 -10
  134. nuitka/nodes/ReturnNodes.py +1 -1
  135. nuitka/nodes/StatementBasesGenerated.py +11 -11
  136. nuitka/nodes/SubscriptNodes.py +4 -4
  137. nuitka/nodes/VariableAssignNodes.py +1 -1
  138. nuitka/nodes/VariableRefNodes.py +28 -2
  139. nuitka/nodes/shapes/BuiltinTypeShapes.py +21 -1
  140. nuitka/optimizations/FunctionInlining.py +3 -6
  141. nuitka/optimizations/Optimization.py +13 -12
  142. nuitka/optimizations/TraceCollections.py +19 -4
  143. nuitka/plugins/PluginBase.py +121 -133
  144. nuitka/plugins/Plugins.py +91 -3
  145. nuitka/plugins/YamlPluginBase.py +121 -0
  146. nuitka/plugins/standard/AntiBloatPlugin.py +87 -28
  147. nuitka/plugins/standard/DataFilesPlugin.py +15 -6
  148. nuitka/plugins/standard/DelvewheelPlugin.py +7 -3
  149. nuitka/plugins/standard/DllFilesPlugin.py +5 -3
  150. nuitka/plugins/standard/ImplicitImports.py +34 -20
  151. nuitka/plugins/standard/MatplotlibPlugin.py +3 -1
  152. nuitka/plugins/standard/MultiprocessingPlugin.py +2 -2
  153. nuitka/plugins/standard/OptionsNannyPlugin.py +1 -1
  154. nuitka/plugins/standard/PySidePyQtPlugin.py +11 -12
  155. nuitka/plugins/standard/SpacyPlugin.py +136 -0
  156. nuitka/plugins/standard/standard.nuitka-package.config.yml +491 -186
  157. nuitka/plugins/standard/stdlib3.nuitka-package.config.yml +17 -0
  158. nuitka/reports/Reports.py +53 -5
  159. nuitka/specs/BuiltinParameterSpecs.py +1 -1
  160. nuitka/specs/HardImportSpecs.py +0 -6
  161. nuitka/tools/data_composer/DataComposer.py +29 -27
  162. nuitka/tools/environments/CreateEnvironment.py +1 -0
  163. nuitka/tools/environments/Virtualenv.py +25 -11
  164. nuitka/tools/general/find_module/FindModuleCode.py +13 -3
  165. nuitka/tools/onefile_compressor/OnefileCompressor.py +21 -4
  166. nuitka/tools/scanning/DisplayPackageDLLs.py +17 -3
  167. nuitka/tools/specialize/CTypeDescriptions.py +13 -7
  168. nuitka/tools/specialize/SpecializePython.py +18 -1
  169. nuitka/tools/testing/Common.py +19 -6
  170. nuitka/tools/testing/check_reference_counts/__main__.py +1 -1
  171. nuitka/tools/testing/run_nuitka_tests/__main__.py +0 -20
  172. nuitka/tools/watch/AutoStage.py +144 -0
  173. nuitka/tools/watch/__main__.py +79 -32
  174. nuitka/tree/Building.py +105 -104
  175. nuitka/tree/ComplexCallHelperFunctions.py +16 -26
  176. nuitka/tree/InternalModule.py +9 -1
  177. nuitka/tree/ReformulationAssignmentStatements.py +29 -59
  178. nuitka/tree/ReformulationClasses.py +10 -17
  179. nuitka/tree/ReformulationClasses3.py +69 -43
  180. nuitka/tree/ReformulationComparisonExpressions.py +6 -16
  181. nuitka/tree/ReformulationContractionExpressions.py +14 -23
  182. nuitka/tree/ReformulationDictionaryCreation.py +6 -10
  183. nuitka/tree/ReformulationExecStatements.py +10 -10
  184. nuitka/tree/ReformulationForLoopStatements.py +6 -12
  185. nuitka/tree/ReformulationFunctionStatements.py +22 -28
  186. nuitka/tree/ReformulationImportStatements.py +8 -10
  187. nuitka/tree/ReformulationLambdaExpressions.py +3 -6
  188. nuitka/tree/ReformulationMatchStatements.py +166 -60
  189. nuitka/tree/ReformulationMultidist.py +3 -1
  190. nuitka/tree/ReformulationNamespacePackages.py +1 -1
  191. nuitka/tree/ReformulationPrintStatements.py +3 -6
  192. nuitka/tree/ReformulationSequenceCreation.py +13 -26
  193. nuitka/tree/ReformulationTryFinallyStatements.py +15 -0
  194. nuitka/tree/ReformulationWithStatements.py +12 -16
  195. nuitka/tree/SourceHandling.py +13 -8
  196. nuitka/tree/VariableClosure.py +5 -21
  197. nuitka/utils/Distributions.py +80 -11
  198. nuitka/utils/Download.py +38 -31
  199. nuitka/utils/Execution.py +21 -9
  200. nuitka/utils/FileOperations.py +55 -28
  201. nuitka/utils/Images.py +6 -1
  202. nuitka/utils/Importing.py +1 -1
  203. nuitka/utils/ModuleNames.py +11 -5
  204. nuitka/utils/ReExecute.py +17 -13
  205. nuitka/utils/SharedLibraries.py +69 -41
  206. nuitka/utils/Signing.py +3 -1
  207. nuitka/utils/StaticLibraries.py +51 -41
  208. nuitka/utils/Timing.py +1 -1
  209. nuitka/utils/Utils.py +29 -7
  210. /Nuitka_winsvc-2.3.9.data/scripts/nuitka.bat → /Nuitka_winsvc-2.4.1.data/scripts/nuitka.cmd +0 -0
  211. {Nuitka_winsvc-2.3.9.dist-info → Nuitka_winsvc-2.4.1.dist-info}/LICENSE.txt +0 -0
  212. {Nuitka_winsvc-2.3.9.dist-info → Nuitka_winsvc-2.4.1.dist-info}/entry_points.txt +0 -0
  213. {Nuitka_winsvc-2.3.9.dist-info → Nuitka_winsvc-2.4.1.dist-info}/top_level.txt +0 -0
@@ -10,18 +10,18 @@
10
10
 
11
11
  WARNING, this code is GENERATED. Modify the template ChildrenHavingMixin.py.j2 instead!
12
12
 
13
- spell-checker: ignore __prepare__ append args autograph buffering capitalize casefold
14
- spell-checker: ignore center chars clear closefd copy count decode default delete dist
15
- spell-checker: ignore distribution_name encode encoding end endswith errors exit_code
16
- spell-checker: ignore expandtabs experimental_attributes experimental_autograph_options
13
+ spell-checker: ignore __prepare__ append args autograph capitalize casefold center chars
14
+ spell-checker: ignore clear copy count decode default delete dist distribution_name encode
15
+ spell-checker: ignore encoding end endswith errors exit_code expandtabs
16
+ spell-checker: ignore experimental_attributes experimental_autograph_options
17
17
  spell-checker: ignore experimental_compile experimental_follow_type_hints
18
- spell-checker: ignore experimental_implements experimental_relax_shapes extend file
19
- spell-checker: ignore fillchar find format format_map formatmap fromkeys func get group
20
- spell-checker: ignore handle has_key haskey index input_signature insert isalnum isalpha
21
- spell-checker: ignore isascii isdecimal isdigit isidentifier islower isnumeric isprintable
22
- spell-checker: ignore isspace istitle isupper item items iterable iteritems iterkeys
23
- spell-checker: ignore itervalues jit_compile join keepends key keys kwargs ljust lower
24
- spell-checker: ignore lstrip maketrans maxsplit mode name new newline old opener p package
18
+ spell-checker: ignore experimental_implements experimental_relax_shapes extend fillchar
19
+ spell-checker: ignore find format format_map formatmap fromkeys func get group handle
20
+ spell-checker: ignore has_key haskey index input_signature insert isalnum isalpha isascii
21
+ spell-checker: ignore isdecimal isdigit isidentifier islower isnumeric isprintable isspace
22
+ spell-checker: ignore istitle isupper item items iterable iteritems iterkeys itervalues
23
+ spell-checker: ignore jit_compile join keepends key keys kwargs ljust lower lstrip
24
+ spell-checker: ignore maketrans maxsplit mode name new old p package
25
25
  spell-checker: ignore package_or_requirement pairs partition path pop popitem prefix
26
26
  spell-checker: ignore prepare reduce_retracing remove replace resource resource_name
27
27
  spell-checker: ignore reverse rfind rindex rjust rpartition rsplit rstrip s sep setdefault
@@ -161,13 +161,13 @@ class ExpressionMatchSubscriptCheck(
161
161
 
162
162
  return result, tags, change_desc
163
163
 
164
- trace_collection.onExceptionRaiseExit(BaseException)
164
+ if subscript.mayRaiseException(BaseException):
165
+ trace_collection.onExceptionRaiseExit(BaseException)
165
166
 
166
167
  return self, None, None
167
168
 
168
- @staticmethod
169
- def mayRaiseException(exception_type):
170
- return False
169
+ def mayRaiseException(self, exception_type):
170
+ return self.subnode_subscript.mayRaiseException(exception_type)
171
171
 
172
172
 
173
173
  class ExpressionSubscriptLookupForUnpack(ExpressionSubscriptLookup):
@@ -798,7 +798,7 @@ class StatementAssignmentVariableConstantMutableTrusted(
798
798
 
799
799
  @staticmethod
800
800
  def hasVeryTrustedValue():
801
- return True
801
+ return False
802
802
 
803
803
 
804
804
  class StatementAssignmentVariableConstantImmutableTrusted(
@@ -318,6 +318,23 @@ Subscript del to dictionary lowered to dictionary del."""
318
318
  Subscript look-up to dictionary lowered to dictionary look-up.""",
319
319
  )
320
320
 
321
+ if subscript.isCompileTimeConstant():
322
+ attribute_node = self.variable_trace.getAttributeNode()
323
+
324
+ if attribute_node is not None:
325
+ # TODO: That could probably be one single question.
326
+ if (
327
+ attribute_node.isCompileTimeConstant()
328
+ and not attribute_node.isMutable()
329
+ ):
330
+ return trace_collection.getCompileTimeComputationResult(
331
+ node=lookup_node,
332
+ computation=lambda: attribute_node.getCompileTimeConstant()[
333
+ subscript.getCompileTimeConstant()
334
+ ],
335
+ description="Subscript of variable immutable value.",
336
+ )
337
+
321
338
  # Any code could be run, note that.
322
339
  trace_collection.onControlFlowEscape(self)
323
340
 
@@ -420,6 +437,15 @@ class ExpressionVariableRef(ExpressionVariableRefBase):
420
437
  # could be decided from context.
421
438
  trace_collection.onExceptionRaiseExit(BaseException)
422
439
 
440
+ very_trusted_node = self.variable_trace.getAttributeNodeVeryTrusted()
441
+ if very_trusted_node is not None:
442
+ return (
443
+ very_trusted_node.makeClone(),
444
+ "new_expression",
445
+ lambda: "Forward propagating value of %s from very trusted %s value."
446
+ % (self.getVariableName(), very_trusted_node.kind),
447
+ )
448
+
423
449
  if variable.isModuleVariable() and (
424
450
  variable.hasDefiniteWrites() is False or variable.getName() == "super"
425
451
  ):
@@ -494,7 +520,7 @@ Replaced read-only module attribute '__package__' with module attribute referenc
494
520
  change_tags = "new_expression"
495
521
  change_desc = """\
496
522
  Replaced read-only module attribute '__loader__' with module attribute reference."""
497
- elif variable_name == "__spec__" and python_version >= 0x340:
523
+ elif variable_name == "__spec__" and python_version >= 0x300:
498
524
  new_node = ExpressionModuleAttributeSpecRef(
499
525
  variable=variable, source_ref=self.source_ref
500
526
  )
@@ -586,7 +612,7 @@ Replaced read-only module attribute '__spec__' with module attribute reference."
586
612
  return (
587
613
  bool(attribute_node.getCompileTimeConstant()),
588
614
  attribute_node.makeClone(),
589
- "Using very trusted constant truth value.",
615
+ "Using trusted constant's truth value.",
590
616
  )
591
617
 
592
618
  # TODO: This is probably only default stuff here, that could be compressed.
@@ -26,6 +26,7 @@ from .ControlFlowDescriptions import (
26
26
  ControlFlowDescriptionElementBasedEscape,
27
27
  ControlFlowDescriptionFloorDivUnsupported,
28
28
  ControlFlowDescriptionFormatError,
29
+ ControlFlowDescriptionFullEscape,
29
30
  ControlFlowDescriptionLshiftUnsupported,
30
31
  ControlFlowDescriptionMatmultUnsupported,
31
32
  ControlFlowDescriptionModUnsupported,
@@ -1729,7 +1730,9 @@ class ShapeTypeXrangeIterator(ShapeIteratorMixin, ShapeNotNumberMixin, ShapeBase
1729
1730
  tshape_xrange_iterator = ShapeTypeXrangeIterator()
1730
1731
 
1731
1732
 
1732
- class ShapeTypeType(ShapeNotContainerMixin, ShapeNotNumberMixin, ShapeBase):
1733
+ class ShapeTypeTypeBase(ShapeNotNumberMixin, ShapeBase):
1734
+ # Base classes can be abstract, pylint: disable=abstract-method
1735
+
1733
1736
  __slots__ = ()
1734
1737
 
1735
1738
  typical_value = int
@@ -1756,6 +1759,23 @@ class ShapeTypeType(ShapeNotContainerMixin, ShapeNotNumberMixin, ShapeBase):
1756
1759
  return hasattr(int, attribute_name)
1757
1760
 
1758
1761
 
1762
+ if python_version < 0x390:
1763
+
1764
+ class ShapeTypeType(ShapeNotContainerMixin, ShapeTypeTypeBase):
1765
+ __slots__ = ()
1766
+
1767
+ else:
1768
+
1769
+ class ShapeTypeType(ShapeTypeTypeBase):
1770
+ __slots__ = ()
1771
+
1772
+ @staticmethod
1773
+ def getOperationUnaryReprEscape():
1774
+ # We can't really say it's element based, since it may not be iterable
1775
+ # still.
1776
+ return ControlFlowDescriptionFullEscape
1777
+
1778
+
1759
1779
  tshape_type = ShapeTypeType()
1760
1780
 
1761
1781
 
@@ -9,10 +9,9 @@ from the in-lined function.
9
9
 
10
10
  from nuitka.nodes.OutlineNodes import ExpressionOutlineBody
11
11
  from nuitka.nodes.VariableAssignNodes import makeStatementAssignmentVariable
12
- from nuitka.nodes.VariableReleaseNodes import makeStatementsReleaseVariables
13
12
  from nuitka.tree.Operations import VisitorNoopMixin, visitTree
14
13
  from nuitka.tree.ReformulationTryFinallyStatements import (
15
- makeTryFinallyStatement,
14
+ makeTryFinallyReleaseStatement,
16
15
  )
17
16
  from nuitka.tree.TreeHelpers import makeStatementsSequence
18
17
 
@@ -83,12 +82,10 @@ def convertFunctionCallToOutline(provider, function_body, values, call_source_re
83
82
 
84
83
  # TODO: Not possible to auto release with outline bodies too?
85
84
  if auto_releases:
86
- body = makeTryFinallyStatement(
85
+ body = makeTryFinallyReleaseStatement(
87
86
  provider=outline_body,
88
87
  tried=body,
89
- final=makeStatementsReleaseVariables(
90
- variables=auto_releases, source_ref=function_source_ref
91
- ),
88
+ variables=auto_releases,
92
89
  source_ref=function_source_ref,
93
90
  )
94
91
 
@@ -26,7 +26,7 @@ from nuitka.utils.Timing import TimerReport
26
26
  from . import Graphs
27
27
  from .BytecodeDemotion import demoteCompiledModuleToBytecode
28
28
  from .Tags import TagSet
29
- from .TraceCollections import withChangeIndicationsTo
29
+ from .TraceCollections import fetchMergeCounts, withChangeIndicationsTo
30
30
 
31
31
  tag_set = None
32
32
 
@@ -68,7 +68,12 @@ def optimizeCompiledPythonModule(module):
68
68
  # allow to continue the loop even without changes one more time.
69
69
  unchanged_count = 0
70
70
 
71
+ # Count the micro passes, so we can see how often we looped
72
+ micro_pass = 0
73
+
71
74
  while True:
75
+ micro_pass += 1
76
+
72
77
  tag_set.clear()
73
78
 
74
79
  try:
@@ -120,7 +125,7 @@ def optimizeCompiledPythonModule(module):
120
125
 
121
126
  considerUsedModules(module=module, pass_count=pass_count)
122
127
 
123
- return touched
128
+ return touched, micro_pass
124
129
 
125
130
 
126
131
  def optimizeUncompiledPythonModule(module):
@@ -156,14 +161,12 @@ def optimizeModule(module):
156
161
 
157
162
  if module.isPythonExtensionModule():
158
163
  optimizeExtensionModule(module)
159
- changed = False
164
+ return False, 0
160
165
  elif module.isCompiledPythonModule():
161
- changed = optimizeCompiledPythonModule(module)
166
+ return optimizeCompiledPythonModule(module)
162
167
  else:
163
168
  optimizeUncompiledPythonModule(module)
164
- changed = False
165
-
166
- return changed
169
+ return False, 0
167
170
 
168
171
 
169
172
  pass_count = 0
@@ -250,8 +253,6 @@ def restoreFromXML(text):
250
253
  def makeOptimizationPass():
251
254
  """Make a single pass for optimization, indication potential completion."""
252
255
 
253
- # Controls complex optimization
254
-
255
256
  finished = True
256
257
 
257
258
  ModuleRegistry.startTraversal()
@@ -284,14 +285,14 @@ def makeOptimizationPass():
284
285
  with TimerReport(
285
286
  message="Optimizing %s" % module_name, decider=False
286
287
  ) as module_timer:
287
- changed = optimizeModule(current_module)
288
-
289
- # module_timer=module_time_report.getTimer()
288
+ changed, micro_passes = optimizeModule(current_module)
290
289
 
291
290
  ModuleRegistry.addModuleOptimizationTimeInformation(
292
291
  module_name=module_name,
293
292
  pass_number=pass_count,
294
293
  time_used=module_timer.getDelta(),
294
+ micro_passes=micro_passes,
295
+ merge_counts=fetchMergeCounts(),
295
296
  )
296
297
 
297
298
  _traceProgressModuleEnd(current_module)
@@ -51,6 +51,16 @@ from .ValueTraces import (
51
51
  ValueTraceUnknown,
52
52
  )
53
53
 
54
+ # Keeping trace of how often branches are merged between calls
55
+ _merge_counts = defaultdict(int)
56
+
57
+
58
+ def fetchMergeCounts():
59
+ result = dict(_merge_counts)
60
+ _merge_counts.clear()
61
+ return result
62
+
63
+
54
64
  signalChange = None
55
65
 
56
66
 
@@ -189,10 +199,10 @@ class CollectionStartPointMixin(CollectionUpdateMixin):
189
199
 
190
200
  # TODO: We might want to track per exception, pylint: disable=unused-argument
191
201
 
192
- if collection is None:
193
- collection = self
194
-
195
202
  if self.exception_collections is not None:
203
+ if collection is None:
204
+ collection = self
205
+
196
206
  self.exception_collections.append(
197
207
  TraceCollectionBranch(parent=collection, name="exception")
198
208
  )
@@ -754,6 +764,8 @@ class TraceCollectionBase(object):
754
764
  collection1 = collection_yes
755
765
  collection2 = collection_no
756
766
 
767
+ _merge_counts[2] += 1
768
+
757
769
  variable_versions = {}
758
770
 
759
771
  for variable, version in iterItems(collection1.variable_actives):
@@ -816,7 +828,8 @@ class TraceCollectionBase(object):
816
828
  elif merge_size == 2:
817
829
  return self.mergeBranches(*collections)
818
830
 
819
- # print("Enter mergeMultipleBranches", len(collections))
831
+ _merge_counts[len(collections)] += 1
832
+
820
833
  with TimerReport(
821
834
  message="Running merge for %s took %%.2f seconds" % collections,
822
835
  decider=False,
@@ -874,6 +887,8 @@ class TraceCollectionBase(object):
874
887
  self.variable_actives.update(collection_replace.variable_actives)
875
888
  collection_replace.variable_actives = None
876
889
 
890
+ _merge_counts[1] += 1
891
+
877
892
  def onLoopBreak(self, collection=None):
878
893
  if collection is None:
879
894
  collection = self