summaryrefslogtreecommitdiffstats
path: root/llvm/lib/IR/Metadata.cpp
diff options
context:
space:
mode:
authorAlexey Samsonov <samsonov@google.com>2013-11-18 09:31:53 +0000
committerAlexey Samsonov <samsonov@google.com>2013-11-18 09:31:53 +0000
commit49109a279c6b7b3622fa0227f6c77a96d075f718 (patch)
treed3ee87a1f6131cd29380a4ce6dd84aa232b2fa4c /llvm/lib/IR/Metadata.cpp
parent6588c1a638032c8146be7f5d62a125f5d89dea76 (diff)
downloadbcm5719-llvm-49109a279c6b7b3622fa0227f6c77a96d075f718.tar.gz
bcm5719-llvm-49109a279c6b7b3622fa0227f6c77a96d075f718.zip
Revert r194865 and r194874.
This change is incorrect. If you delete virtual destructor of both a base class and a subclass, then the following code: Base *foo = new Child(); delete foo; will not cause the destructor for members of Child class. As a result, I observe plently of memory leaks. Notable examples I investigated are: ObjectBuffer and ObjectBufferStream, AttributeImpl and StringSAttributeImpl. llvm-svn: 194997
Diffstat (limited to 'llvm/lib/IR/Metadata.cpp')
-rw-r--r--llvm/lib/IR/Metadata.cpp4
1 files changed, 1 insertions, 3 deletions
diff --git a/llvm/lib/IR/Metadata.cpp b/llvm/lib/IR/Metadata.cpp
index ef0660da864..bd4d9c0a077 100644
--- a/llvm/lib/IR/Metadata.cpp
+++ b/llvm/lib/IR/Metadata.cpp
@@ -65,7 +65,7 @@ class MDNodeOperand : public CallbackVH {
public:
MDNodeOperand(Value *V) : CallbackVH(V) {}
- virtual ~MDNodeOperand();
+ ~MDNodeOperand() {}
void set(Value *V) {
unsigned IsFirst = this->getValPtrInt();
@@ -82,8 +82,6 @@ public:
};
} // end namespace llvm.
-MDNodeOperand::~MDNodeOperand() {}
-
void MDNodeOperand::deleted() {
getParent()->replaceOperand(this, 0);
OpenPOWER on IntegriCloud