From ff37ccc570cd40dd2d4a0332b64a16171f51b1c2 Mon Sep 17 00:00:00 2001 From: Ted Kremenek Date: Thu, 1 Nov 2007 22:23:34 +0000 Subject: Removed ReadVal from SerializeTrait, and also removed it from Deserializer. There were issues with Visual C++ barfing when instantiating SerializeTrait when "T" was an abstract class AND SerializeTrait::ReadVal was *never* called: template struct SerializeTrait { static inline T ReadVal(Deserializer& D) { T::ReadVal(D); } }; Visual C++ would complain about "T" being an abstract class, even though ReadVal was never instantiated (although one of the other member functions were). Removing this from the trait is not a big deal. It was used hardly ever, and users who want "read-by-value" deserialization can simply call the appropriate methods directly instead of relying on trait-based-dispatch. The trait dispatch for serialization/deserialization is simply sugar in many cases (like this one). git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@43624 91177308-0d34-0410-b5e6-96231b3b80d8 --- lib/Bitcode/Reader/Deserialize.cpp | 4 +--- 1 file changed, 1 insertion(+), 3 deletions(-) (limited to 'lib/Bitcode/Reader/Deserialize.cpp') diff --git a/lib/Bitcode/Reader/Deserialize.cpp b/lib/Bitcode/Reader/Deserialize.cpp index e5a4d18aa2..0482b1f7e9 100644 --- a/lib/Bitcode/Reader/Deserialize.cpp +++ b/lib/Bitcode/Reader/Deserialize.cpp @@ -166,9 +166,7 @@ void Deserializer::BPEntry::SetPtr(BPNode*& FreeList, void* P) { #define INT_READ(TYPE)\ void SerializeTrait::Read(Deserializer& D, TYPE& X) {\ - X = (TYPE) D.ReadInt(); }\ -TYPE SerializeTrait::ReadVal(Deserializer& D) {\ - return (TYPE) D.ReadInt(); } + X = (TYPE) D.ReadInt(); } INT_READ(bool) INT_READ(unsigned char) -- cgit v1.2.3-18-g5258