MC: Make setVariableValue check the redefinition condition a bit more strongly.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@103110 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
Daniel Dunbar 2010-05-05 19:00:56 +00:00
parent 3d720fbc6a
commit 8d627d3153
2 changed files with 9 additions and 4 deletions

View File

@ -131,10 +131,7 @@ namespace llvm {
return Value;
}
void setVariableValue(const MCExpr *Value) {
assert(Value && "Invalid variable value!");
this->Value = Value;
}
void setVariableValue(const MCExpr *Value);
/// @}

View File

@ -8,6 +8,7 @@
//===----------------------------------------------------------------------===//
#include "llvm/MC/MCSymbol.h"
#include "llvm/MC/MCExpr.h"
#include "llvm/Support/Debug.h"
#include "llvm/Support/raw_ostream.h"
using namespace llvm;
@ -38,6 +39,13 @@ static bool NameNeedsQuoting(StringRef Str) {
return false;
}
void MCSymbol::setVariableValue(const MCExpr *Value) {
assert(Value && "Invalid variable value!");
assert((isUndefined() || (isAbsolute() && isa<MCConstantExpr>(Value))) &&
"Invalid redefinition!");
this->Value = Value;
}
void MCSymbol::print(raw_ostream &OS) const {
// The name for this MCSymbol is required to be a valid target name. However,
// some targets support quoting names with funny characters. If the name