summaryrefslogtreecommitdiff
path: root/python/skytools/scripting.py
diff options
context:
space:
mode:
authorMarko Kreen2012-10-16 11:04:45 +0000
committerMarko Kreen2012-10-16 11:04:45 +0000
commit5077ff9551ad578228027f47d613d79692bfdfc2 (patch)
tree14d595f76bf55d163b12142e4f3c62c8307eaecd /python/skytools/scripting.py
parent01a731c376fe0b2594c66ca94dab3d13a9602fb7 (diff)
Allow overrided options with --set to show up in --ini output
Diffstat (limited to 'python/skytools/scripting.py')
-rw-r--r--python/skytools/scripting.py30
1 files changed, 26 insertions, 4 deletions
diff --git a/python/skytools/scripting.py b/python/skytools/scripting.py
index 12a72da9..049da251 100644
--- a/python/skytools/scripting.py
+++ b/python/skytools/scripting.py
@@ -273,9 +273,6 @@ class BaseScript(object):
self.log_level = skytools.skylog.TRACE
elif self.options.verbose:
self.log_level = logging.DEBUG
- if self.options.ini:
- self.print_ini()
- sys.exit(0)
self.cf_override = {}
if self.options.set:
@@ -283,6 +280,10 @@ class BaseScript(object):
k, v = a.split('=', 1)
self.cf_override[k.strip()] = v.strip()
+ if self.options.ini:
+ self.print_ini()
+ sys.exit(0)
+
# read config file
self.reload()
@@ -331,8 +332,29 @@ class BaseScript(object):
if pos < 0:
return
doc = doc[pos+2 : ].rstrip()
+ doc = skytools.dedent(doc)
+
+ # merge overrided options into output
+ for ln in doc.splitlines():
+ vals = ln.split('=', 1)
+ if len(vals) != 2:
+ print(ln)
+ continue
+
+ k = vals[0].strip()
+ v = vals[1].strip()
+ if k and k[0] == '#':
+ print(ln)
+ k = k[1:]
+ if k in self.cf_override:
+ print('%s = %s' % (k, self.cf_override[k]))
+ elif k in self.cf_override:
+ if v:
+ print('#' + ln)
+ print('%s = %s' % (k, self.cf_override[k]))
+ else:
+ print(ln)
- print(skytools.dedent(doc))
print('')
def load_config(self):