From 0e46ca6aa6400a7eda1980b1ff1a1b90ed2a2ca0 Mon Sep 17 00:00:00 2001 From: Yang Zhang Date: Sat, 1 Nov 2008 17:38:01 -0400 Subject: [PATCH] fixed string literal parsing; broder will test svn path=/trunk/packages/invirt-dns/; revision=1511 --- invirt-dns | 51 ++++++++++++++++----------------------------------- 1 file changed, 16 insertions(+), 35 deletions(-) diff --git a/invirt-dns b/invirt-dns index 4193be1..b2a9ac6 100755 --- a/invirt-dns +++ b/invirt-dns @@ -121,9 +121,18 @@ class QuotingBindAuthority(authority.BindAuthority): This will catch double quotes as marking the start or end of a quoted phrase, unless the double quote is escaped by a backslash """ - # Grab everything up to the first whitespace character or - # quotation mark not proceeded by a backslash - whitespace_re = re.compile(r'(.*?)([\t\n\x0b\x0c\r ]+|(? 0: - match = self.whitespace_re.match(line) - if match is None: - # If there's no match, that means that there's no - # whitespace in the rest of the line, so it should - # be treated as a single entity, quoted or not - # - # This also means that a closing quote isn't - # strictly necessary if the line ends the quote - substr = line - end = '' - else: - substr, end = match.groups() - - if in_quote: - # If we're in the middle of the quote, the string - # we just grabbed belongs at the end of the - # previous string - # - # Including the whitespace! Unless it's not - # whitespace and is actually a closequote instead - split_line[-1] += substr + (end if end != '"' else '') - else: - # If we're not in the middle of a quote, than this - # is the next new string - split_line.append(substr) - - if end == '"': - in_quote = not in_quote - - # Then strip off what we just processed - line = line[len(substr + end):] + for m in string_pat.finditer(line): + [x] = [x for x in m.groups() if x is not None] + split_line.append(escape_pat.sub(r'\1', x)) L.append(split_line) return filter(None, L) -- 1.7.9.5