From 7654e964ef10b3a48d4d7d9452b8492ab29ae218 Mon Sep 17 00:00:00 2001 From: Tim Hatch Date: Wed, 1 Jun 2016 21:22:44 -0700 Subject: Prevent runaway escapes in php string. Fixes #1184 --- pygments/lexers/php.py | 2 +- tests/test_php.py | 36 ++++++++++++++++++++++++++++++++++++ 2 files changed, 37 insertions(+), 1 deletion(-) create mode 100644 tests/test_php.py diff --git a/pygments/lexers/php.py b/pygments/lexers/php.py index 2421738f..1931325a 100644 --- a/pygments/lexers/php.py +++ b/pygments/lexers/php.py @@ -224,7 +224,7 @@ class PhpLexer(RegexLexer): String.Interpol)), (r'(\$\{)(\S+)(\})', bygroups(String.Interpol, Name.Variable, String.Interpol)), - (r'[${\\]+', String.Double) + (r'[${\\]', String.Double) ], } diff --git a/tests/test_php.py b/tests/test_php.py new file mode 100644 index 00000000..050ca70d --- /dev/null +++ b/tests/test_php.py @@ -0,0 +1,36 @@ +# -*- coding: utf-8 -*- +""" + PHP Tests + ~~~~~~~~~ + + :copyright: Copyright 2006-2015 by the Pygments team, see AUTHORS. + :license: BSD, see LICENSE for details. +""" + +import unittest + +from pygments.lexers import PhpLexer +from pygments.token import Token + + +class PhpTest(unittest.TestCase): + def setUp(self): + self.lexer = PhpLexer() + + def testStringEscapingRun(self): + fragment = '\n' + tokens = [ + (Token.Comment.Preproc, ''), + (Token.Other, '\n'), + ] + self.assertEqual(tokens, list(self.lexer.get_tokens(fragment))) -- cgit v1.2.1