Index: sdk/lib/core/int.dart |
diff --git a/sdk/lib/core/int.dart b/sdk/lib/core/int.dart |
index 96a6d40e6dc5654b8e2e3d5d130d52dfbf25365b..1651f226bde847e8cfa8836f2f46dfd92ca734f5 100644 |
--- a/sdk/lib/core/int.dart |
+++ b/sdk/lib/core/int.dart |
@@ -99,6 +99,56 @@ abstract class int extends num { |
bool get isOdd; |
/** |
+ * Returns the minimum number of bits required to store this integer. |
+ * |
+ * The number of bits excludes the sign bit, which gives the natural length |
+ * for non-negative (unsigned) values. Negative values are complemented to |
+ * return the bit position of the first bit that differs from the sign bit. |
+ * |
+ * To find the the number of bits needed to store the value as a signed value, |
+ * add one, i.e. use `x.bitLength + 1`. |
+ * |
+ * x.bitLength == (-x-1).bitLength |
+ * |
+ * 3.bitLength == 2; // 00000011 |
+ * 2.bitLength == 2; // 00000010 |
+ * 1.bitLength == 1; // 00000001 |
+ * 0.bitLength == 0; // 00000000 |
+ * (-1).bitLength == 0; // 11111111 |
+ * (-2).bitLength == 1; // 11111110 |
+ * (-3).bitLength == 2; // 11111101 |
+ * (-4).bitLength == 2; // 11111100 |
+ */ |
+ int get bitLength; |
+ |
+ /** |
+ * Returns the least significant [width] bits of this integer as a |
+ * non-negative number (i.e. unsigned representation). The returned value has |
+ * zeros in all bit positions higher than [width]. |
+ * |
+ * (-1).toUnsigned(5) == 32 // 11111111 -> 00011111 |
+ * |
+ * This operation can be used to simulate arithmetic from low level languages. |
+ * For example, to increment an 8 bit quantity: |
+ * |
+ * q = (q + 1).toUnsigned(8); |
+ */ |
+ int toUnsigned(int width); |
+ |
+ /** |
+ * Returns the least significant [width] bits of this integer, extending the |
+ * highest retained bit to the sign. This is the same as truncating the value |
+ * to fit in [width] bits using an signed 2-s complement representation. The |
+ * returned value has the same bit value in all positions higher than [width]. |
+ * |
+ * V--sign bit-V |
+ * 16.toSigned(5) == -16 // 00010000 -> 11110000 |
+ * 239.toSigned(5) == 15 // 11101111 -> 00001111 |
+ * ^ ^ |
Lasse Reichstein Nielsen
2013/09/06 12:40:11
If I'm correct then
x == x.toSigned(x.bitLength
sra1
2013/09/06 22:11:57
I added this relation to the documentation.
|
+ */ |
+ int toSigned(int width); |
+ |
+ /** |
* Return the negative value of this integer. |
* |
* The result of negating an integer always has the opposite sign, except |