PR45267: Don't reject pure-specifiers with escaped newlines in their '0' token.
diff --git a/clang/lib/Parse/ParseDeclCXX.cpp b/clang/lib/Parse/ParseDeclCXX.cpp
index 85dc4e3..86a9a82 100644
--- a/clang/lib/Parse/ParseDeclCXX.cpp
+++ b/clang/lib/Parse/ParseDeclCXX.cpp
@@ -2670,7 +2670,7 @@
 
     auto &Zero = NextToken();
     SmallString<8> Buffer;
-    if (Zero.isNot(tok::numeric_constant) || Zero.getLength() != 1 ||
+    if (Zero.isNot(tok::numeric_constant) ||
         PP.getSpelling(Zero, Buffer) != "0")
       return false;
 
diff --git a/clang/test/Parser/cxx-class.cpp b/clang/test/Parser/cxx-class.cpp
index e672c45..e73c874 100644
--- a/clang/test/Parser/cxx-class.cpp
+++ b/clang/test/Parser/cxx-class.cpp
@@ -37,7 +37,9 @@
   virtual int vf5a(){0;}; // function definition, expected-warning {{unused}}
   virtual int vf6()(0); // expected-error +{{}} expected-note +{{}}
   virtual int vf7() = { 0 }; // expected-error {{does not look like a pure-specifier}}
-  
+  virtual int PR45267() = \
+                        0; // ok, despite escaped newline
+
 private:
   int x,f(),y,g();
   inline int h();