[llvm] r219586 - APSInt: Simplify code to reduce the number of copies. No functionality change.

David Blaikie dblaikie at gmail.com
Tue Oct 14 10:28:48 PDT 2014


On Sun, Oct 12, 2014 at 8:36 AM, Benjamin Kramer <benny.kra at googlemail.com>
wrote:

> Author: d0k
> Date: Sun Oct 12 10:36:31 2014
> New Revision: 219586
>
> URL: http://llvm.org/viewvc/llvm-project?rev=219586&view=rev
> Log:
> APSInt: Simplify code to reduce the number of copies. No functionality
> change.
>
> Modified:
>     llvm/trunk/include/llvm/ADT/APSInt.h
>
> Modified: llvm/trunk/include/llvm/ADT/APSInt.h
> URL:
> http://llvm.org/viewvc/llvm-project/llvm/trunk/include/llvm/ADT/APSInt.h?rev=219586&r1=219585&r2=219586&view=diff
>
> ==============================================================================
> --- llvm/trunk/include/llvm/ADT/APSInt.h (original)
> +++ llvm/trunk/include/llvm/ADT/APSInt.h Sun Oct 12 10:36:31 2014
> @@ -269,19 +269,15 @@ public:
>      else if (I2.getBitWidth() > I1.getBitWidth())
>        return isSameValue(I1.extend(I2.getBitWidth()), I2);
>
> -    // We have a signedness mismatch. Turn the signed value into an
> unsigned
> -    // value.
> -    if (I1.isSigned()) {
> -      if (I1.isNegative())
> -        return false;
> +    assert(I1.isSigned() != I2.isSigned());
>
> -      return APSInt(I1, true) == I2;
> -    }
> -
> -    if (I2.isNegative())
> +    // We have a signedness mismatch. Check for negative values and do an
> +    // unsigned compare if signs match.
> +    if ((I1.isSigned() && I1.isNegative()) ||
> +        (!I1.isSigned() && I2.isNegative()))
>        return false;
>
> -    return I1 == APSInt(I2, true);
> +    return I1.eq(I2);
>

Hmm, is this different from l1 == l2? (that seems like a dangerously subtle
API if that's the case)


>    }
>
>    /// Profile - Used to insert APSInt objects, or objects that contain
> APSInt
>
>
> _______________________________________________
> llvm-commits mailing list
> llvm-commits at cs.uiuc.edu
> http://lists.cs.uiuc.edu/mailman/listinfo/llvm-commits
>
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20141014/70b5f725/attachment.html>


More information about the llvm-commits mailing list