about summary refs log tree commit diff stats
diff options
context:
space:
mode:
authorAjax <commial@gmail.com>2018-02-15 13:22:45 +0100
committerAjax <commial@gmail.com>2018-02-15 14:17:38 +0100
commite28713fa12f50eaaec8753c60fa573ff427f0d1f (patch)
tree8aa2502aeb41a2638fd2a5f7753e66b7b154eaef
parent9dd075f09e4f31ec7fe12e50709d9e58c65ed5f4 (diff)
downloadmiasm-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.py12
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)