diff options
Diffstat (limited to 'git/config.py')
-rw-r--r-- | git/config.py | 30 |
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 |