aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorTed Kremenek <kremenek@apple.com>2007-10-31 18:23:21 +0000
committerTed Kremenek <kremenek@apple.com>2007-10-31 18:23:21 +0000
commit90f6724f404919a83aa99055666634b523621b63 (patch)
treee81d956e0980dddd32fe5015c836fc2e3d6dfc8f
parent16db217bd7bc9913fee0a50a43deab8b90ed5987 (diff)
downloadexternal_llvm-90f6724f404919a83aa99055666634b523621b63.zip
external_llvm-90f6724f404919a83aa99055666634b523621b63.tar.gz
external_llvm-90f6724f404919a83aa99055666634b523621b63.tar.bz2
Added Serializer::EmitRef to deal with emitting arbitrary references.
Modified Serializer::EmitPtr to handle const pointers. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@43565 91177308-0d34-0410-b5e6-96231b3b80d8
-rw-r--r--include/llvm/Bitcode/Serialize.h9
-rw-r--r--lib/Bitcode/Writer/Serialize.cpp2
2 files changed, 7 insertions, 4 deletions
diff --git a/include/llvm/Bitcode/Serialize.h b/include/llvm/Bitcode/Serialize.h
index 72aac9d..be5adb8 100644
--- a/include/llvm/Bitcode/Serialize.h
+++ b/include/llvm/Bitcode/Serialize.h
@@ -27,7 +27,7 @@ class Serializer {
SmallVector<uint64_t,10> Record;
bool inBlock;
- typedef DenseMap<void*,unsigned> MapTy;
+ typedef DenseMap<const void*,unsigned> MapTy;
MapTy PtrMap;
public:
@@ -42,7 +42,10 @@ public:
void EmitCStr(const char* beg, const char* end);
void EmitCStr(const char* cstr);
- void EmitPtr(void* ptr) { EmitInt(getPtrId(ptr)); }
+ void EmitPtr(const void* ptr) { EmitInt(getPtrId(ptr)); }
+
+ template <typename T>
+ void EmitRef(const T& ref) { EmitPtr(&ref); }
template <typename T>
void EmitOwnedPtr(T* ptr) {
@@ -55,7 +58,7 @@ public:
private:
void EmitRecord();
inline bool inRecord() { return Record.size() > 0; }
- unsigned getPtrId(void* ptr);
+ unsigned getPtrId(const void* ptr);
};
} // end namespace llvm
diff --git a/lib/Bitcode/Writer/Serialize.cpp b/lib/Bitcode/Writer/Serialize.cpp
index a1d7320..58baf10 100644
--- a/lib/Bitcode/Writer/Serialize.cpp
+++ b/lib/Bitcode/Writer/Serialize.cpp
@@ -57,7 +57,7 @@ void Serializer::EmitCStr(const char* s) {
EmitCStr(s,s+strlen(s));
}
-unsigned Serializer::getPtrId(void* ptr) {
+unsigned Serializer::getPtrId(const void* ptr) {
if (!ptr)
return 0;