diff options
| author | Ajax <commial@gmail.com> | 2018-02-15 13:22:45 +0100 |
|---|---|---|
| committer | Ajax <commial@gmail.com> | 2018-02-15 14:17:38 +0100 |
| commit | e28713fa12f50eaaec8753c60fa573ff427f0d1f (patch) | |
| tree | 8aa2502aeb41a2638fd2a5f7753e66b7b154eaef | |
| parent | 9dd075f09e4f31ec7fe12e50709d9e58c65ed5f4 (diff) | |
| download | miasm-e28713fa12f50eaaec8753c60fa573ff427f0d1f.tar.gz miasm-e28713fa12f50eaaec8753c60fa573ff427f0d1f.zip | |
Translator: import 'z3' only when it is really needed
Avoid importing a pretty big module, and the side effects of z3, such as declaring the stack as unlimited
| -rw-r--r-- | miasm2/ir/translators/z3_ir.py | 12 |
1 files changed, 11 insertions, 1 deletions
diff --git a/miasm2/ir/translators/z3_ir.py b/miasm2/ir/translators/z3_ir.py index d33764fb..74bdd79c 100644 --- a/miasm2/ir/translators/z3_ir.py +++ b/miasm2/ir/translators/z3_ir.py @@ -1,7 +1,9 @@ +import imp import logging import operator -import z3 +# Raise an ImportError if z3 is not available WITHOUT actually importing it +imp.find_module("z3") from miasm2.core.asmblock import AsmLabel from miasm2.ir.translators.translator import Translator @@ -31,6 +33,10 @@ class Z3Mem(object): @name: name of memory Arrays generated. They will be named name+str(address size) (for example mem32, mem16...). """ + # Import z3 only on demand + global z3 + import z3 + if endianness not in ['<', '>']: raise ValueError("Endianness should be '>' (big) or '<' (little)") self.endianness = endianness @@ -114,6 +120,10 @@ class TranslatorZ3(Translator): """Instance a Z3 translator @endianness: (optional) memory endianness """ + # Import z3 only on demand + global z3 + import z3 + super(TranslatorZ3, self).__init__(**kwargs) self._mem = Z3Mem(endianness) |