diff options
author | Chandler Carruth <chandlerc@gmail.com> | 2014-03-04 09:00:15 +0000 |
---|---|---|
committer | Chandler Carruth <chandlerc@gmail.com> | 2014-03-04 09:00:15 +0000 |
commit | 4ffd9d250cba883e0f85b1cbd759fcbb8a7a7de5 (patch) | |
tree | 336999ab79a07af46ee27abcfff728a1e4224978 /llvm/lib/IR/Use.cpp | |
parent | a7c602ac2993be60bac08d99f8374c286f02e010 (diff) | |
download | bcm5719-llvm-4ffd9d250cba883e0f85b1cbd759fcbb8a7a7de5.tar.gz bcm5719-llvm-4ffd9d250cba883e0f85b1cbd759fcbb8a7a7de5.zip |
[cleanup] Use early exit and simpler temporary variables to clarify the
swap implementation.
llvm-svn: 202802
Diffstat (limited to 'llvm/lib/IR/Use.cpp')
-rw-r--r-- | llvm/lib/IR/Use.cpp | 37 |
1 files changed, 18 insertions, 19 deletions
diff --git a/llvm/lib/IR/Use.cpp b/llvm/lib/IR/Use.cpp index b6720e56764..5f01e238e04 100644 --- a/llvm/lib/IR/Use.cpp +++ b/llvm/lib/IR/Use.cpp @@ -14,27 +14,26 @@ namespace llvm { void Use::swap(Use &RHS) { - Value *V1(Val); - Value *V2(RHS.Val); - if (V1 != V2) { - if (V1) { - removeFromList(); - } + if (Val == RHS.Val) + return; - if (V2) { - RHS.removeFromList(); - Val = V2; - V2->addUse(*this); - } else { - Val = 0; - } + if (Val) + removeFromList(); - if (V1) { - RHS.Val = V1; - V1->addUse(RHS); - } else { - RHS.Val = 0; - } + Value *OldVal = Val; + if (RHS.Val) { + RHS.removeFromList(); + Val = RHS.Val; + Val->addUse(*this); + } else { + Val = 0; + } + + if (OldVal) { + RHS.Val = OldVal; + RHS.Val->addUse(RHS); + } else { + RHS.Val = 0; } } |