From: Jeffrey Yasskin Date: Mon, 18 Jul 2011 16:43:53 +0000 (+0000) Subject: Define DiagnosticBuilder<"; + break; + } +} + +const DiagnosticBuilder &clang::operator<<(const DiagnosticBuilder &DB, + const APValue &V) { + llvm::SmallString<64> Buffer; + llvm::raw_svector_ostream Out(Buffer); + WriteShortAPValueToStream(Out, V); + return DB << Out.str(); +} + const Expr* APValue::getLValueBase() const { assert(isLValue() && "Invalid accessor"); return ((const LV*)(const void*)Data)->Base; diff --git a/unittests/AST/APValueTest.cpp b/unittests/AST/APValueTest.cpp new file mode 100644 index 0000000000..ae054b363b --- /dev/null +++ b/unittests/AST/APValueTest.cpp @@ -0,0 +1,79 @@ +//===- unittests/AST/APValueTest.cpp - APValue tests ---===// +// +// The LLVM Compiler Infrastructure +// +// This file is distributed under the University of Illinois Open Source +// License. See LICENSE.TXT for details. +// +//===----------------------------------------------------------------------===// + +#include "clang/AST/APValue.h" + +#include "clang/Basic/Diagnostic.h" +#include "llvm/ADT/STLExtras.h" +#include "llvm/ADT/SmallString.h" + +#include "gtest/gtest.h" + +using namespace llvm; +using namespace clang; + +namespace { + +class DiagnosticOutputGetter { + class LastDiagnosticString : public DiagnosticClient { + SmallString<64> LastDiagnostic; + public: + virtual void HandleDiagnostic(Diagnostic::Level DiagLevel, + const DiagnosticInfo &Info) { + LastDiagnostic.clear(); + Info.FormatDiagnostic(LastDiagnostic); + } + + StringRef get() const { return LastDiagnostic; } + }; + + const IntrusiveRefCntPtr DiagIDs; + const unsigned diag_just_format; + LastDiagnosticString LastDiagnostic; + Diagnostic Diag; + +public: + DiagnosticOutputGetter() + : DiagIDs(new DiagnosticIDs), + diag_just_format(DiagIDs->getCustomDiagID(DiagnosticIDs::Error, "%0")), + Diag(DiagIDs, &LastDiagnostic, false) { + } + + template + std::string operator()(const T& value) { + Diag.Report(diag_just_format) << value; + return LastDiagnostic.get().str(); + } +}; + +TEST(APValue, Diagnostics) { + DiagnosticOutputGetter GetDiagnosticOutput; + + EXPECT_EQ("Uninitialized", GetDiagnosticOutput(APValue())); + EXPECT_EQ("5", GetDiagnosticOutput(APValue(APSInt(APInt(16, 5))))); + EXPECT_EQ("3.141590e+00", + GetDiagnosticOutput(APValue(APFloat(APFloat::IEEEdouble, + "3.14159")))); + EXPECT_EQ("3+4i", + GetDiagnosticOutput(APValue(APSInt(APInt(16, 3)), + APSInt(APInt(16, 4))))); + EXPECT_EQ("3.200000e+00+5.700000e+00i", + GetDiagnosticOutput(APValue( + APFloat(APFloat::IEEEdouble, "3.2"), + APFloat(APFloat::IEEEdouble, "5.7")))); + APValue V[] = { + APValue(APSInt(APInt(16, 3))), + APValue(APSInt(APInt(16, 4))), + APValue(APSInt(APInt(16, 5))) + }; + EXPECT_EQ("[3, 4, 5]", + GetDiagnosticOutput(APValue(V, array_lengthof(V)))); +} + +} // anonymous namespace diff --git a/unittests/AST/Makefile b/unittests/AST/Makefile new file mode 100644 index 0000000000..74191d037f --- /dev/null +++ b/unittests/AST/Makefile @@ -0,0 +1,15 @@ +##===- unittests/Frontend/Makefile -------------------------*- Makefile -*-===## +# +# The LLVM Compiler Infrastructure +# +# This file is distributed under the University of Illinois Open Source +# License. See LICENSE.TXT for details. +# +##===----------------------------------------------------------------------===## + +CLANG_LEVEL = ../.. +TESTNAME = AST +LINK_COMPONENTS := support mc +USEDLIBS = clangAST.a clangBasic.a + +include $(CLANG_LEVEL)/unittests/Makefile diff --git a/unittests/CMakeLists.txt b/unittests/CMakeLists.txt index cb44dc59dc..901f167f35 100644 --- a/unittests/CMakeLists.txt +++ b/unittests/CMakeLists.txt @@ -50,6 +50,11 @@ if(SUPPORTS_NO_VARIADIC_MACROS_FLAG) add_definitions("-Wno-variadic-macros") endif() +add_clang_unittest(AST + AST/APValueTest.cpp + USED_LIBS gtest gtest_main clangAST + ) + add_clang_unittest(Basic Basic/FileManagerTest.cpp USED_LIBS gtest gtest_main clangBasic diff --git a/unittests/Makefile b/unittests/Makefile index 951e17e217..f4ce6adaa7 100644 --- a/unittests/Makefile +++ b/unittests/Makefile @@ -14,7 +14,7 @@ ifndef CLANG_LEVEL IS_UNITTEST_LEVEL := 1 CLANG_LEVEL := .. -PARALLEL_DIRS = Basic Frontend +PARALLEL_DIRS = AST Basic Frontend endif # CLANG_LEVEL