refactor how we deal with TTLs
[zonemaker.git] / zone-maker
index 57f8afe3470c4bdf169d18168d295bf6d4c41b78..4a02e17d85ead5a6bd0c7328d5c3b33b124db570 100755 (executable)
@@ -1,21 +1,26 @@
 #!/usr/bin/python3
 import sys, os
 from zonemaker.zone import Zone
 #!/usr/bin/python3
 import sys, os
 from zonemaker.zone import Zone
-from typing import Sequence
+#import typing
 
 def load_module(name, path, write_bytecode = False):
 
 def load_module(name, path, write_bytecode = False):
-    import importlib.machinery
     old_val = sys.dont_write_bytecode
     sys.dont_write_bytecode = not write_bytecode
     old_val = sys.dont_write_bytecode
     sys.dont_write_bytecode = not write_bytecode
-    module = importlib.machinery.SourceFileLoader(name, path).load_module()
-    sys.dont_write_bytecode = old_val
+    module = None
+    try:
+        from importlib.machinery import SourceFileLoader
+        module = SourceFileLoader(name, path).load_module()
+    except ImportError:
+        import imp
+        module = imp.load_source(name, path)
+    finally:
+        sys.dont_write_bytecode = old_val
     return module
 
 def make_zone(filename: str) -> None:
     zonefile = load_module(os.path.basename(filename), filename)
     return module
 
 def make_zone(filename: str) -> None:
     zonefile = load_module(os.path.basename(filename), filename)
-    zones = zonefile.__zones__ # type: Sequence[Zone]
-    for zone in zones:
-        zone.write()
+    zone = zonefile.__zone__ # type: Zone
+    zone.write()
 
 if __name__ == "__main__":
     for name in sys.argv[1:]:
 
 if __name__ == "__main__":
     for name in sys.argv[1:]: