]> git.phdru.name Git - m_librarian.git/blobdiff - m_librarian/config.py
Update code for compatibility with Python 3
[m_librarian.git] / m_librarian / config.py
index 3609d34666b3d99c3a9f18a332fbe4590737498a..2540ac463097408de93019713243c4e56d6c78c0 100755 (executable)
@@ -1,9 +1,10 @@
 #! /usr/bin/env python
 
-__all__ = ['get_config']
-
+from __future__ import print_function
 import os
-from ConfigParser import SafeConfigParser
+from ConfigParser import RawConfigParser
+
+__all__ = ['get_config']
 
 
 def _find_config_dirs_posix():
@@ -35,18 +36,23 @@ def find_config_file(config_dirs=None):
         raise IOError("Cannot find m_librarian.conf in %s" % config_dirs)
 
 
-def get_config(config_filename=None):
-    if config_filename is None:
-        config_filename = find_config_file()
-    ml_conf = SafeConfigParser()
-    ml_conf.read(config_filename)
-    return ml_conf
+_ml_config = None
+
+
+def get_config(config_path=None):
+    global _ml_config
+    if _ml_config is None:
+        if config_path is None:
+            config_path = find_config_file()
+        _ml_config = RawConfigParser()
+        _ml_config.read(config_path)
+    return _ml_config
 
 
 def test():
     config_dirs = find_config_dirs()
-    print "Config dirs:", config_dirs
-    print "Config file:", find_config_file(config_dirs)
+    print("Config dirs:", config_dirs)
+    print("Config file:", find_config_file(config_dirs))
 
 if __name__ == '__main__':
     test()