| Index: third_party/google-endpoints/libfuturize/fixes/fix_unicode_keep_u.py
|
| diff --git a/third_party/google-endpoints/libfuturize/fixes/fix_unicode_keep_u.py b/third_party/google-endpoints/libfuturize/fixes/fix_unicode_keep_u.py
|
| new file mode 100644
|
| index 0000000000000000000000000000000000000000..a6f70f092abf4a641a4b3e0717dd5e731c71e296
|
| --- /dev/null
|
| +++ b/third_party/google-endpoints/libfuturize/fixes/fix_unicode_keep_u.py
|
| @@ -0,0 +1,25 @@
|
| +"""Fixer that changes unicode to str and unichr to chr, but -- unlike the
|
| +lib2to3 fix_unicode.py fixer, does not change u"..." into "...".
|
| +
|
| +The reason is that Py3.3+ supports the u"..." string prefix, and, if
|
| +present, the prefix may provide useful information for disambiguating
|
| +between byte strings and unicode strings, which is often the hardest part
|
| +of the porting task.
|
| +
|
| +"""
|
| +
|
| +from lib2to3.pgen2 import token
|
| +from lib2to3 import fixer_base
|
| +
|
| +_mapping = {u"unichr" : u"chr", u"unicode" : u"str"}
|
| +
|
| +class FixUnicodeKeepU(fixer_base.BaseFix):
|
| + BM_compatible = True
|
| + PATTERN = "'unicode' | 'unichr'"
|
| +
|
| + def transform(self, node, results):
|
| + if node.type == token.NAME:
|
| + new = node.clone()
|
| + new.value = _mapping[node.value]
|
| + return new
|
| +
|
|
|