[C++11] Use std::tie to simplify compare operators.

No functionality change.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@202751 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
Benjamin Kramer 2014-03-03 19:58:30 +00:00
parent c3835ccef9
commit 9efaf2f2da
8 changed files with 22 additions and 54 deletions

View File

@ -173,7 +173,7 @@ namespace llvm {
} }
bool operator<(const Segment &Other) const { bool operator<(const Segment &Other) const {
return start < Other.start || (start == Other.start && end < Other.end); return std::tie(start, end) < std::tie(Other.start, Other.end);
} }
bool operator==(const Segment &Other) const { bool operator==(const Segment &Other) const {
return start == Other.start && end == Other.end; return start == Other.start && end == Other.end;
@ -552,8 +552,7 @@ namespace llvm {
bool operator<(const LiveInterval& other) const { bool operator<(const LiveInterval& other) const {
const SlotIndex &thisIndex = beginIndex(); const SlotIndex &thisIndex = beginIndex();
const SlotIndex &otherIndex = other.beginIndex(); const SlotIndex &otherIndex = other.beginIndex();
return thisIndex < otherIndex || return std::tie(thisIndex, reg) < std::tie(otherIndex, other.reg);
(thisIndex == otherIndex && reg < other.reg);
} }
void print(raw_ostream &OS) const; void print(raw_ostream &OS) const;

View File

@ -120,7 +120,7 @@ public:
return !operator==(O); return !operator==(O);
} }
bool operator<(const SDValue &O) const { bool operator<(const SDValue &O) const {
return Node < O.Node || (Node == O.Node && ResNo < O.ResNo); return std::tie(Node, ResNo) < std::tie(O.Node, O.ResNo);
} }
SDValue getValue(unsigned R) const { SDValue getValue(unsigned R) const {

View File

@ -135,8 +135,7 @@ public:
} }
bool operator!=(const UniqueID &Other) const { return !(*this == Other); } bool operator!=(const UniqueID &Other) const { return !(*this == Other); }
bool operator<(const UniqueID &Other) const { bool operator<(const UniqueID &Other) const {
return Device < Other.Device || return std::tie(Device, File) < std::tie(Other.Device, Other.File);
(Device == Other.Device && File < Other.File);
} }
uint64_t getDevice() const { return Device; } uint64_t getDevice() const { return Device; }
uint64_t getFile() const { return File; } uint64_t getFile() const { return File; }

View File

@ -190,9 +190,8 @@ class RAGreedy : public MachineFunctionPass,
void setBrokenHints(unsigned NHints) { BrokenHints = NHints; } void setBrokenHints(unsigned NHints) { BrokenHints = NHints; }
bool operator<(const EvictionCost &O) const { bool operator<(const EvictionCost &O) const {
if (BrokenHints != O.BrokenHints) return std::tie(BrokenHints, MaxWeight) <
return BrokenHints < O.BrokenHints; std::tie(O.BrokenHints, O.MaxWeight);
return MaxWeight < O.MaxWeight;
} }
}; };

View File

@ -334,14 +334,10 @@ struct ExprMapKeyType {
this->indices == that.indices; this->indices == that.indices;
} }
bool operator<(const ExprMapKeyType & that) const { bool operator<(const ExprMapKeyType & that) const {
if (this->opcode != that.opcode) return this->opcode < that.opcode; return std::tie(opcode, operands, subclassdata, subclassoptionaldata,
if (this->operands != that.operands) return this->operands < that.operands; indices) <
if (this->subclassdata != that.subclassdata) std::tie(that.opcode, that.operands, that.subclassdata,
return this->subclassdata < that.subclassdata; that.subclassoptionaldata, that.indices);
if (this->subclassoptionaldata != that.subclassoptionaldata)
return this->subclassoptionaldata < that.subclassoptionaldata;
if (this->indices != that.indices) return this->indices < that.indices;
return false;
} }
bool operator!=(const ExprMapKeyType& that) const { bool operator!=(const ExprMapKeyType& that) const {
@ -369,17 +365,10 @@ struct InlineAsmKeyType {
this->asm_dialect == that.asm_dialect; this->asm_dialect == that.asm_dialect;
} }
bool operator<(const InlineAsmKeyType& that) const { bool operator<(const InlineAsmKeyType& that) const {
if (this->asm_string != that.asm_string) return std::tie(asm_string, constraints, has_side_effects, is_align_stack,
return this->asm_string < that.asm_string; asm_dialect) <
if (this->constraints != that.constraints) std::tie(that.asm_string, that.constraints, that.has_side_effects,
return this->constraints < that.constraints; that.is_align_stack, that.asm_dialect);
if (this->has_side_effects != that.has_side_effects)
return this->has_side_effects < that.has_side_effects;
if (this->is_align_stack != that.is_align_stack)
return this->is_align_stack < that.is_align_stack;
if (this->asm_dialect != that.asm_dialect)
return this->asm_dialect < that.asm_dialect;
return false;
} }
bool operator!=(const InlineAsmKeyType& that) const { bool operator!=(const InlineAsmKeyType& that) const {

View File

@ -62,12 +62,7 @@ namespace {
/// Make RetOrArg comparable, so we can put it into a map. /// Make RetOrArg comparable, so we can put it into a map.
bool operator<(const RetOrArg &O) const { bool operator<(const RetOrArg &O) const {
if (F != O.F) return std::tie(F, Idx, IsArg) < std::tie(O.F, O.Idx, O.IsArg);
return F < O.F;
else if (Idx != O.Idx)
return Idx < O.Idx;
else
return IsArg < O.IsArg;
} }
/// Make RetOrArg comparable, so we can easily iterate the multimap. /// Make RetOrArg comparable, so we can easily iterate the multimap.

View File

@ -979,21 +979,11 @@ void Cost::Lose() {
/// operator< - Choose the lower cost. /// operator< - Choose the lower cost.
bool Cost::operator<(const Cost &Other) const { bool Cost::operator<(const Cost &Other) const {
if (NumRegs != Other.NumRegs) return std::tie(NumRegs, AddRecCost, NumIVMuls, NumBaseAdds, ScaleCost,
return NumRegs < Other.NumRegs; ImmCost, SetupCost) <
if (AddRecCost != Other.AddRecCost) std::tie(Other.NumRegs, Other.AddRecCost, Other.NumIVMuls,
return AddRecCost < Other.AddRecCost; Other.NumBaseAdds, Other.ScaleCost, Other.ImmCost,
if (NumIVMuls != Other.NumIVMuls) Other.SetupCost);
return NumIVMuls < Other.NumIVMuls;
if (NumBaseAdds != Other.NumBaseAdds)
return NumBaseAdds < Other.NumBaseAdds;
if (ScaleCost != Other.ScaleCost)
return ScaleCost < Other.ScaleCost;
if (ImmCost != Other.ImmCost)
return ImmCost < Other.ImmCost;
if (SetupCost != Other.SetupCost)
return SetupCost < Other.SetupCost;
return false;
} }
void Cost::print(raw_ostream &OS) const { void Cost::print(raw_ostream &OS) const {

View File

@ -782,11 +782,8 @@ namespace llvm {
bool CodeGenRegisterClass::Key:: bool CodeGenRegisterClass::Key::
operator<(const CodeGenRegisterClass::Key &B) const { operator<(const CodeGenRegisterClass::Key &B) const {
assert(Members && B.Members); assert(Members && B.Members);
if (*Members != *B.Members) return std::tie(*Members, SpillSize, SpillAlignment) <
return *Members < *B.Members; std::tie(*B.Members, B.SpillSize, B.SpillAlignment);
if (SpillSize != B.SpillSize)
return SpillSize < B.SpillSize;
return SpillAlignment < B.SpillAlignment;
} }
// Returns true if RC is a strict subclass. // Returns true if RC is a strict subclass.