<div dir="ltr"><div class="gmail_extra"><div class="gmail_quote">On Sat, Jan 25, 2014 at 12:04 PM, Saleem Abdulrasool <span dir="ltr"><<a href="mailto:compnerd@compnerd.org" target="_blank">compnerd@compnerd.org</a>></span> wrote:<br>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">Author: compnerd<br>
Date: Sat Jan 25 14:04:44 2014<br>
New Revision: 200096<br>
<br>
URL: <a href="http://llvm.org/viewvc/llvm-project?rev=200096&view=rev" target="_blank">http://llvm.org/viewvc/llvm-project?rev=200096&view=rev</a><br>
Log:<br>
unittests: explicit stringify StringRefs for conversion<br>
<br>
When clang is built outside of the LLVM tree (against a corresponding version),<br>
there is no definition providing for operator<<(std::ostream &, StringRef) which<br>
is required for the assertion routines in google-test tests.</blockquote><div><br></div><div>Hmm, why is this different for an in-tree vs an out-of-tree build?</div><div> </div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
Avoid the<br>
compilation failure by explicitly stringifying the StringRef prior to use.<br>
<br>
Modified:<br>
cfe/trunk/unittests/AST/DeclPrinterTest.cpp<br>
cfe/trunk/unittests/AST/StmtPrinterTest.cpp<br>
cfe/trunk/unittests/Tooling/CompilationDatabaseTest.cpp<br>
<br>
Modified: cfe/trunk/unittests/AST/DeclPrinterTest.cpp<br>
URL: <a href="http://llvm.org/viewvc/llvm-project/cfe/trunk/unittests/AST/DeclPrinterTest.cpp?rev=200096&r1=200095&r2=200096&view=diff" target="_blank">http://llvm.org/viewvc/llvm-project/cfe/trunk/unittests/AST/DeclPrinterTest.cpp?rev=200096&r1=200095&r2=200096&view=diff</a><br>
==============================================================================<br>
--- cfe/trunk/unittests/AST/DeclPrinterTest.cpp (original)<br>
+++ cfe/trunk/unittests/AST/DeclPrinterTest.cpp Sat Jan 25 14:04:44 2014<br>
@@ -77,7 +77,8 @@ public:<br>
OwningPtr<FrontendActionFactory> Factory(newFrontendActionFactory(&Finder));<br>
<br>
if (!runToolOnCodeWithArgs(Factory->create(), Code, Args, FileName))<br>
- return testing::AssertionFailure() << "Parsing error in \"" << Code << "\"";<br>
+ return testing::AssertionFailure()<br>
+ << "Parsing error in \"" << Code.str() << "\"";<br>
<br>
if (Printer.getNumFoundDecls() == 0)<br>
return testing::AssertionFailure()<br>
@@ -90,8 +91,8 @@ public:<br>
<br>
if (Printer.getPrinted() != ExpectedPrinted)<br>
return ::testing::AssertionFailure()<br>
- << "Expected \"" << ExpectedPrinted << "\", "<br>
- "got \"" << Printer.getPrinted() << "\"";<br>
+ << "Expected \"" << ExpectedPrinted.str() << "\", "<br>
+ "got \"" << Printer.getPrinted().str() << "\"";<br>
<br>
return ::testing::AssertionSuccess();<br>
}<br>
<br>
Modified: cfe/trunk/unittests/AST/StmtPrinterTest.cpp<br>
URL: <a href="http://llvm.org/viewvc/llvm-project/cfe/trunk/unittests/AST/StmtPrinterTest.cpp?rev=200096&r1=200095&r2=200096&view=diff" target="_blank">http://llvm.org/viewvc/llvm-project/cfe/trunk/unittests/AST/StmtPrinterTest.cpp?rev=200096&r1=200095&r2=200096&view=diff</a><br>
==============================================================================<br>
--- cfe/trunk/unittests/AST/StmtPrinterTest.cpp (original)<br>
+++ cfe/trunk/unittests/AST/StmtPrinterTest.cpp Sat Jan 25 14:04:44 2014<br>
@@ -76,7 +76,8 @@ public:<br>
OwningPtr<FrontendActionFactory> Factory(newFrontendActionFactory(&Finder));<br>
<br>
if (!runToolOnCodeWithArgs(Factory->create(), Code, Args))<br>
- return testing::AssertionFailure() << "Parsing error in \"" << Code << "\"";<br>
+ return testing::AssertionFailure()<br>
+ << "Parsing error in \"" << Code.str() << "\"";<br>
<br>
if (Printer.getNumFoundStmts() == 0)<br>
return testing::AssertionFailure()<br>
@@ -89,8 +90,8 @@ public:<br>
<br>
if (Printer.getPrinted() != ExpectedPrinted)<br>
return ::testing::AssertionFailure()<br>
- << "Expected \"" << ExpectedPrinted << "\", "<br>
- "got \"" << Printer.getPrinted() << "\"";<br>
+ << "Expected \"" << ExpectedPrinted.str() << "\", "<br>
+ "got \"" << Printer.getPrinted().str() << "\"";<br>
<br>
return ::testing::AssertionSuccess();<br>
}<br>
<br>
Modified: cfe/trunk/unittests/Tooling/CompilationDatabaseTest.cpp<br>
URL: <a href="http://llvm.org/viewvc/llvm-project/cfe/trunk/unittests/Tooling/CompilationDatabaseTest.cpp?rev=200096&r1=200095&r2=200096&view=diff" target="_blank">http://llvm.org/viewvc/llvm-project/cfe/trunk/unittests/Tooling/CompilationDatabaseTest.cpp?rev=200096&r1=200095&r2=200096&view=diff</a><br>
==============================================================================<br>
--- cfe/trunk/unittests/Tooling/CompilationDatabaseTest.cpp (original)<br>
+++ cfe/trunk/unittests/Tooling/CompilationDatabaseTest.cpp Sat Jan 25 14:04:44 2014<br>
@@ -24,7 +24,7 @@ static void expectFailure(StringRef JSON<br>
std::string ErrorMessage;<br>
EXPECT_EQ(NULL, JSONCompilationDatabase::loadFromBuffer(JSONDatabase,<br>
ErrorMessage))<br>
- << "Expected an error because of: " << Explanation;<br>
+ << "Expected an error because of: " << Explanation.str();<br>
}<br>
<br>
TEST(JSONCompilationDatabase, ErrsOnInvalidFormat) {<br>
<br>
<br>
_______________________________________________<br>
cfe-commits mailing list<br>
<a href="mailto:cfe-commits@cs.uiuc.edu">cfe-commits@cs.uiuc.edu</a><br>
<a href="http://lists.cs.uiuc.edu/mailman/listinfo/cfe-commits" target="_blank">http://lists.cs.uiuc.edu/mailman/listinfo/cfe-commits</a><br>
</blockquote></div><br></div></div>