llvmlite 0.43.0rc1__cp310-cp310-win_amd64.whl → 0.44.0__cp310-cp310-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 llvmlite might be problematic. Click here for more details.

Files changed (47) hide show
  1. llvmlite/__init__.py +10 -3
  2. llvmlite/_version.py +2 -2
  3. llvmlite/binding/__init__.py +19 -18
  4. llvmlite/binding/analysis.py +69 -69
  5. llvmlite/binding/common.py +34 -34
  6. llvmlite/binding/context.py +39 -29
  7. llvmlite/binding/dylib.py +45 -45
  8. llvmlite/binding/executionengine.py +330 -330
  9. llvmlite/binding/ffi.py +395 -390
  10. llvmlite/binding/initfini.py +73 -73
  11. llvmlite/binding/linker.py +20 -20
  12. llvmlite/binding/llvmlite.dll +0 -0
  13. llvmlite/binding/module.py +349 -349
  14. llvmlite/binding/newpassmanagers.py +357 -0
  15. llvmlite/binding/object_file.py +82 -82
  16. llvmlite/binding/options.py +17 -17
  17. llvmlite/binding/orcjit.py +342 -342
  18. llvmlite/binding/passmanagers.py +946 -939
  19. llvmlite/binding/targets.py +520 -450
  20. llvmlite/binding/transforms.py +151 -151
  21. llvmlite/binding/typeref.py +285 -198
  22. llvmlite/binding/value.py +632 -618
  23. llvmlite/ir/__init__.py +11 -11
  24. llvmlite/ir/_utils.py +80 -80
  25. llvmlite/ir/builder.py +1120 -1119
  26. llvmlite/ir/context.py +20 -20
  27. llvmlite/ir/instructions.py +920 -893
  28. llvmlite/ir/module.py +246 -246
  29. llvmlite/ir/transforms.py +64 -64
  30. llvmlite/ir/types.py +734 -614
  31. llvmlite/ir/values.py +1217 -1217
  32. llvmlite/tests/__init__.py +57 -57
  33. llvmlite/tests/__main__.py +3 -3
  34. llvmlite/tests/customize.py +407 -407
  35. llvmlite/tests/refprune_proto.py +329 -329
  36. llvmlite/tests/test_binding.py +3208 -2585
  37. llvmlite/tests/test_ir.py +2994 -2729
  38. llvmlite/tests/test_refprune.py +730 -557
  39. llvmlite/tests/test_valuerepr.py +60 -60
  40. llvmlite/utils.py +29 -29
  41. {llvmlite-0.43.0rc1.dist-info → llvmlite-0.44.0.dist-info}/LICENSE +24 -24
  42. {llvmlite-0.43.0rc1.dist-info → llvmlite-0.44.0.dist-info}/LICENSE.thirdparty +225 -225
  43. {llvmlite-0.43.0rc1.dist-info → llvmlite-0.44.0.dist-info}/METADATA +7 -6
  44. llvmlite-0.44.0.dist-info/RECORD +46 -0
  45. {llvmlite-0.43.0rc1.dist-info → llvmlite-0.44.0.dist-info}/WHEEL +1 -1
  46. llvmlite-0.43.0rc1.dist-info/RECORD +0 -45
  47. {llvmlite-0.43.0rc1.dist-info → llvmlite-0.44.0.dist-info}/top_level.txt +0 -0
llvmlite/ir/__init__.py CHANGED
@@ -1,11 +1,11 @@
1
- """
2
- This subpackage implements the LLVM IR classes in pure python
3
- """
4
-
5
- from .types import *
6
- from .values import *
7
- from .module import *
8
- from .builder import *
9
- from .instructions import *
10
- from .transforms import *
11
- from .context import Context, global_context
1
+ """
2
+ This subpackage implements the LLVM IR classes in pure python
3
+ """
4
+
5
+ from .types import *
6
+ from .values import *
7
+ from .module import *
8
+ from .builder import *
9
+ from .instructions import *
10
+ from .transforms import *
11
+ from .context import Context, global_context
llvmlite/ir/_utils.py CHANGED
@@ -1,80 +1,80 @@
1
- from collections import defaultdict
2
-
3
-
4
- class DuplicatedNameError(NameError):
5
- pass
6
-
7
-
8
- class NameScope(object):
9
- def __init__(self):
10
- self._useset = set([''])
11
- self._basenamemap = defaultdict(int)
12
-
13
- def is_used(self, name):
14
- return name in self._useset
15
-
16
- def register(self, name, deduplicate=False):
17
- if deduplicate:
18
- name = self.deduplicate(name)
19
- elif self.is_used(name):
20
- raise DuplicatedNameError(name)
21
- self._useset.add(name)
22
- return name
23
-
24
- def deduplicate(self, name):
25
- basename = name
26
- while self.is_used(name):
27
- ident = self._basenamemap[basename] + 1
28
- self._basenamemap[basename] = ident
29
- name = "{0}.{1}".format(basename, ident)
30
- return name
31
-
32
- def get_child(self):
33
- return type(self)(parent=self)
34
-
35
-
36
- class _StrCaching(object):
37
-
38
- def _clear_string_cache(self):
39
- try:
40
- del self.__cached_str
41
- except AttributeError:
42
- pass
43
-
44
- def __str__(self):
45
- try:
46
- return self.__cached_str
47
- except AttributeError:
48
- s = self.__cached_str = self._to_string()
49
- return s
50
-
51
-
52
- class _StringReferenceCaching(object):
53
-
54
- def get_reference(self):
55
- try:
56
- return self.__cached_refstr
57
- except AttributeError:
58
- s = self.__cached_refstr = self._get_reference()
59
- return s
60
-
61
-
62
- class _HasMetadata(object):
63
-
64
- def set_metadata(self, name, node):
65
- """
66
- Attach unnamed metadata *node* to the metadata slot *name* of this
67
- value.
68
- """
69
- self.metadata[name] = node
70
-
71
- def _stringify_metadata(self, leading_comma=False):
72
- if self.metadata:
73
- buf = []
74
- if leading_comma:
75
- buf.append("")
76
- buf += ["!{0} {1}".format(k, v.get_reference())
77
- for k, v in self.metadata.items()]
78
- return ', '.join(buf)
79
- else:
80
- return ''
1
+ from collections import defaultdict
2
+
3
+
4
+ class DuplicatedNameError(NameError):
5
+ pass
6
+
7
+
8
+ class NameScope(object):
9
+ def __init__(self):
10
+ self._useset = set([''])
11
+ self._basenamemap = defaultdict(int)
12
+
13
+ def is_used(self, name):
14
+ return name in self._useset
15
+
16
+ def register(self, name, deduplicate=False):
17
+ if deduplicate:
18
+ name = self.deduplicate(name)
19
+ elif self.is_used(name):
20
+ raise DuplicatedNameError(name)
21
+ self._useset.add(name)
22
+ return name
23
+
24
+ def deduplicate(self, name):
25
+ basename = name
26
+ while self.is_used(name):
27
+ ident = self._basenamemap[basename] + 1
28
+ self._basenamemap[basename] = ident
29
+ name = "{0}.{1}".format(basename, ident)
30
+ return name
31
+
32
+ def get_child(self):
33
+ return type(self)(parent=self)
34
+
35
+
36
+ class _StrCaching(object):
37
+
38
+ def _clear_string_cache(self):
39
+ try:
40
+ del self.__cached_str
41
+ except AttributeError:
42
+ pass
43
+
44
+ def __str__(self):
45
+ try:
46
+ return self.__cached_str
47
+ except AttributeError:
48
+ s = self.__cached_str = self._to_string()
49
+ return s
50
+
51
+
52
+ class _StringReferenceCaching(object):
53
+
54
+ def get_reference(self):
55
+ try:
56
+ return self.__cached_refstr
57
+ except AttributeError:
58
+ s = self.__cached_refstr = self._get_reference()
59
+ return s
60
+
61
+
62
+ class _HasMetadata(object):
63
+
64
+ def set_metadata(self, name, node):
65
+ """
66
+ Attach unnamed metadata *node* to the metadata slot *name* of this
67
+ value.
68
+ """
69
+ self.metadata[name] = node
70
+
71
+ def _stringify_metadata(self, leading_comma=False):
72
+ if self.metadata:
73
+ buf = []
74
+ if leading_comma:
75
+ buf.append("")
76
+ buf += ["!{0} {1}".format(k, v.get_reference())
77
+ for k, v in self.metadata.items()]
78
+ return ', '.join(buf)
79
+ else:
80
+ return ''