summaryrefslogtreecommitdiff
path: root/git/config.py
diff options
context:
space:
mode:
Diffstat (limited to 'git/config.py')
-rw-r--r--git/config.py30
1 files changed, 27 insertions, 3 deletions
diff --git a/git/config.py b/git/config.py
index c71bb8ca..620f7b10 100644
--- a/git/config.py
+++ b/git/config.py
@@ -245,8 +245,28 @@ class GitConfigParser(cp.RawConfigParser, object):
if pos != -1 and optval[pos-1].isspace():
optval = optval[:pos]
optval = optval.strip()
- if optval == '""':
- optval = ''
+
+ # Remove paired unescaped-quotes
+ unquoted_optval = ''
+ escaped = False
+ in_quote = False
+ for c in optval:
+ if not escaped and c == '"':
+ in_quote = not in_quote
+ else:
+ escaped = (c == '\\') and not escaped
+ unquoted_optval += c
+
+ if in_quote:
+ if not e:
+ e = cp.ParsingError(fpname)
+ e.append(lineno, repr(line))
+
+ optval = unquoted_optval
+
+ optval = optval.replace('\\\\', '\\') # Unescape backslashes
+ optval = optval.replace(r'\"', '"') # Unescape quotes
+
optname = self.optionxform(optname.rstrip())
cursect[optname] = optval
else:
@@ -303,7 +323,11 @@ class GitConfigParser(cp.RawConfigParser, object):
fp.write("[%s]\n" % name)
for (key, value) in section_dict.items():
if key != "__name__":
- fp.write("\t%s = %s\n" % (key, str(value).replace('\n', '\n\t')))
+ value = str(value)
+ value = value.replace('\\', '\\\\') # Escape backslashes
+ value = value.replace('"', r'\"') # Escape quotes
+ value = value.replace('\n', '\n\t')
+ fp.write("\t%s = %s\n" % (key, value))
# END if key is not __name__
# END section writing