Down-integrate from internal branch
This commit is contained in:
parent
de3494fe5c
commit
7f372559cc
4 changed files with 29 additions and 4 deletions
|
@ -429,6 +429,26 @@ class TextFormatTest(unittest.TestCase):
|
|||
('1:17 : Couldn\'t parse integer: bork'),
|
||||
text_format.Merge, text, message)
|
||||
|
||||
def testMergeStringFieldUnescape(self):
|
||||
message = unittest_pb2.TestAllTypes()
|
||||
text = r'''repeated_string: "\xf\x62"
|
||||
repeated_string: "\\xf\\x62"
|
||||
repeated_string: "\\\xf\\\x62"
|
||||
repeated_string: "\\\\xf\\\\x62"
|
||||
repeated_string: "\\\\\xf\\\\\x62"
|
||||
repeated_string: "\x5cx20"'''
|
||||
text_format.Merge(text, message)
|
||||
|
||||
SLASH = '\\'
|
||||
self.assertEqual('\x0fb', message.repeated_string[0])
|
||||
self.assertEqual(SLASH + 'xf' + SLASH + 'x62', message.repeated_string[1])
|
||||
self.assertEqual(SLASH + '\x0f' + SLASH + 'b', message.repeated_string[2])
|
||||
self.assertEqual(SLASH + SLASH + 'xf' + SLASH + SLASH + 'x62',
|
||||
message.repeated_string[3])
|
||||
self.assertEqual(SLASH + SLASH + '\x0f' + SLASH + SLASH + 'b',
|
||||
message.repeated_string[4])
|
||||
self.assertEqual(SLASH + 'x20', message.repeated_string[5])
|
||||
|
||||
def assertRaisesWithMessage(self, e_class, e, func, *args, **kwargs):
|
||||
"""Same as assertRaises, but also compares the exception message."""
|
||||
if hasattr(e_class, '__name__'):
|
||||
|
|
|
@ -608,12 +608,17 @@ def _CEscape(text, as_utf8):
|
|||
return "".join([escape(c) for c in text])
|
||||
|
||||
|
||||
_CUNESCAPE_HEX = re.compile('\\\\x([0-9a-fA-F]{2}|[0-9a-fA-F])')
|
||||
_CUNESCAPE_HEX = re.compile(r'(\\+)x([0-9a-fA-F])(?![0-9a-fA-F])')
|
||||
|
||||
|
||||
def _CUnescape(text):
|
||||
def ReplaceHex(m):
|
||||
return chr(int(m.group(0)[2:], 16))
|
||||
# Only replace the match if the number of leading back slashes is odd. i.e.
|
||||
# the slash itself is not escaped.
|
||||
if len(m.group(1)) & 1:
|
||||
return m.group(1) + 'x0' + m.group(2)
|
||||
return m.group(0)
|
||||
|
||||
# This is required because the 'string_escape' encoding doesn't
|
||||
# allow single-digit hex escapes (like '\xf').
|
||||
result = _CUNESCAPE_HEX.sub(ReplaceHex, text)
|
||||
|
|
|
@ -59,7 +59,7 @@ void WriteMethodDocComment(io::Printer* printer,
|
|||
const MethodDescriptor* method);
|
||||
|
||||
// Exposed for testing only.
|
||||
string EscapeJavadoc(const string& input);
|
||||
LIBPROTOC_EXPORT string EscapeJavadoc(const string& input);
|
||||
|
||||
} // namespace java
|
||||
} // namespace compiler
|
||||
|
|
|
@ -53,7 +53,7 @@ class Message;
|
|||
namespace compiler {
|
||||
|
||||
// Utility class for launching sub-processes.
|
||||
class Subprocess {
|
||||
class LIBPROTOC_EXPORT Subprocess {
|
||||
public:
|
||||
Subprocess();
|
||||
~Subprocess();
|
||||
|
|
Loading…
Add table
Reference in a new issue