diff options
author | Lang Hames <lhames@gmail.com> | 2012-05-27 21:39:49 +0000 |
---|---|---|
committer | Lang Hames <lhames@gmail.com> | 2012-05-27 21:39:49 +0000 |
commit | 6ccb51130e8a2155f9fcaeac38c40f5bfdbc210a (patch) | |
tree | 2e30c859c5469f6baf4a48b4426954bb2879016d /clang/lib/AST/MicrosoftMangle.cpp | |
parent | 78eb6e91bd0767ed1eb016c46767823d58295e77 (diff) | |
download | bcm5719-llvm-6ccb51130e8a2155f9fcaeac38c40f5bfdbc210a.tar.gz bcm5719-llvm-6ccb51130e8a2155f9fcaeac38c40f5bfdbc210a.zip |
Fix call to APSInt constructor - it doesn't take an initial value, just a
bitwidth and signedness. Also rename the variable to reflect its purpose.
No test case - discovered during random code exploration.
llvm-svn: 157547
Diffstat (limited to 'clang/lib/AST/MicrosoftMangle.cpp')
-rw-r--r-- | clang/lib/AST/MicrosoftMangle.cpp | 7 |
1 files changed, 4 insertions, 3 deletions
diff --git a/clang/lib/AST/MicrosoftMangle.cpp b/clang/lib/AST/MicrosoftMangle.cpp index 6918ce48264..c2811fb8ab5 100644 --- a/clang/lib/AST/MicrosoftMangle.cpp +++ b/clang/lib/AST/MicrosoftMangle.cpp @@ -317,10 +317,11 @@ void MicrosoftCXXNameMangler::mangleNumber(const llvm::APSInt &Value) { char Encoding[64]; char *EndPtr = Encoding+sizeof(Encoding); char *CurPtr = EndPtr; - llvm::APSInt Fifteen(Value.getBitWidth(), 15); + llvm::APSInt NibbleMask(Value.getBitWidth()); + NibbleMask = 0xf; for (int i = 0, e = Value.getActiveBits() / 4; i != e; ++i) { - *--CurPtr = 'A' + Value.And(Fifteen).lshr(i*4).getLimitedValue(15); - Fifteen = Fifteen.shl(4); + *--CurPtr = 'A' + Value.And(NibbleMask).lshr(i*4).getLimitedValue(0xf); + NibbleMask = NibbleMask.shl(4); }; Out.write(CurPtr, EndPtr-CurPtr); Out << '@'; |