From: Zac Medico Date: Fri, 29 Jan 2010 18:48:21 +0000 (-0000) Subject: Fix unicode quote handling to work with python3. (trunk r15195) X-Git-Tag: v2.1.7.17~23 X-Git-Url: http://git.tremily.us/?a=commitdiff_plain;h=eb245d02d14b851f38d700f63665f4e0024737c0;p=portage.git Fix unicode quote handling to work with python3. (trunk r15195) svn path=/main/branches/2.1.7/; revision=15249 --- diff --git a/bin/check-implicit-pointer-usage.py b/bin/check-implicit-pointer-usage.py index 179e73d23..ebd4c3629 100755 --- a/bin/check-implicit-pointer-usage.py +++ b/bin/check-implicit-pointer-usage.py @@ -21,7 +21,7 @@ import sys implicit_pattern = re.compile("([^:]*):(\d+): warning: implicit declaration " + "of function [`']([^']*)'") -pointer_pattern = re.compile( +pointer_pattern = ( "([^:]*):(\d+): warning: " + "(" + "(assignment" @@ -32,6 +32,16 @@ pointer_pattern = re.compile( + ") makes pointer from integer without a cast" + "|" + "cast to pointer from integer of different size)") + +if sys.hexversion < 0x3000000: + pointer_pattern = unicode(pointer_pattern, encoding='utf_8') + unicode_quote_open = unicode('\xE2\x80\x98', encoding='utf_8') + unicode_quote_close = unicode('\xE2\x80\x99', encoding='utf_8') +else: + unicode_quote_open = '\u2018' + unicode_quote_close = '\u2019' +pointer_pattern = re.compile(pointer_pattern) + last_implicit_filename = "" last_implicit_linenum = -1 last_implicit_func = "" @@ -40,11 +50,13 @@ while True: if sys.hexversion >= 0x3000000: line = sys.stdin.buffer.readline().decode('utf_8', 'replace') else: - line = sys.stdin.readline() - if line == '': + line = unicode(sys.stdin.readline(), + encoding='utf_8', errors='replace') + if not line: break # translate unicode open/close quotes to ascii ones - line = line.replace("\xE2\x80\x98", "`").replace("\xE2\x80\x99", "'") + line = line.replace(unicode_quote_open, "`") + line = line.replace(unicode_quote_close, "'") m = implicit_pattern.match(line) if m: last_implicit_filename = m.group(1)