Skip to content

Commit

Permalink
Editorial: Express some Number methods more explicitly
Browse files Browse the repository at this point in the history
Specifically, write
- Number::bitwiseNOT
- Number::leftShift
- Number::signedRightShift
- Number::unsignedRightShift

in terms of NumberToInt32Bits/Int32BitsToNumber
or the analogous NumberToUint32Bits/Uint32BitsToNumber.
  • Loading branch information
jmdyck committed Aug 10, 2024
1 parent 57a798c commit 7fe57e8
Showing 1 changed file with 40 additions and 8 deletions.
48 changes: 40 additions & 8 deletions spec.html
Original file line number Diff line number Diff line change
Expand Up @@ -1903,8 +1903,9 @@ <h1>
<dl class="header">
</dl>
<emu-alg>
1. Let _oldValue_ be ! ToInt32(_x_).
1. Return the bitwise complement of _oldValue_. The mathematical value of the result is exactly representable as a 32-bit two's complement bit string.
1. Let _xBits_ be NumberToInt32Bits(_x_).
1. Let _cBits_ be the bitwise complement of _xBits_.
1. Return Int32BitsToNumber(_cBits_).
</emu-alg>
</emu-clause>

Expand Down Expand Up @@ -2107,10 +2108,11 @@ <h1>
<dl class="header">
</dl>
<emu-alg>
1. Let _lNum_ be ! ToInt32(_x_).
1. Let _lBits_ be NumberToInt32Bits(_x_).
1. Let _rNum_ be ! ToUint32(_y_).
1. Let _shiftCount_ be ℝ(_rNum_) modulo 32.
1. Return the result of left shifting _lNum_ by _shiftCount_ bits. The mathematical value of the result is exactly representable as a 32-bit two's complement bit string.
1. Let _shifted_ be the result of left shifting _lBits_ by _shiftCount_ bits.
1. Return Int32BitsToNumber(_shifted_).
</emu-alg>
</emu-clause>

Expand All @@ -2124,10 +2126,11 @@ <h1>
<dl class="header">
</dl>
<emu-alg>
1. Let _lNum_ be ! ToInt32(_x_).
1. Let _lBits_ be NumberToInt32Bits(_x_).
1. Let _rNum_ be ! ToUint32(_y_).
1. Let _shiftCount_ be ℝ(_rNum_) modulo 32.
1. Return the result of performing a sign-extending right shift of _lNum_ by _shiftCount_ bits. The most significant bit is propagated. The mathematical value of the result is exactly representable as a 32-bit two's complement bit string.
1. Let _shifted_ be the result of performing a sign-extending right shift of _lBits_ by _shiftCount_ bits. The most significant bit is propagated.
1. Return Int32BitsToNumber(_shifted_).
</emu-alg>
</emu-clause>

Expand All @@ -2141,10 +2144,11 @@ <h1>
<dl class="header">
</dl>
<emu-alg>
1. Let _lNum_ be ! ToUint32(_x_).
1. Let _lBits_ be NumberToUint32Bits(_x_).
1. Let _rNum_ be ! ToUint32(_y_).
1. Let _shiftCount_ be ℝ(_rNum_) modulo 32.
1. Return the result of performing a zero-filling right shift of _lNum_ by _shiftCount_ bits. Vacated bits are filled with zero. The mathematical value of the result is exactly representable as a 32-bit unsigned bit string.
1. Let _shifted_ be the result of performing a zero-filling right shift of _lBits_ by _shiftCount_ bits. Vacated bits are filled with zero.
1. Return Uint32BitsToNumber(_shifted_).
</emu-alg>
</emu-clause>

Expand Down Expand Up @@ -2279,6 +2283,34 @@ <h1>
</emu-alg>
</emu-clause>

<emu-clause id="sec-numbertouint32bits" type="abstract operation">
<h1>
NumberToUint32Bits (
_number_: a Number,
): a 32-bit bit string
</h1>
<dl class="header">
</dl>
<emu-alg>
1. Let _n_ be ! ToUint32(_number_).
1. Return the 32-bit unsigned bit string representing ℝ(_n_).
</emu-alg>
</emu-clause>

<emu-clause id="sec-uint32bitstonumber" type="abstract operation">
<h1>
Uint32BitsToNumber (
_bits_: a 32-bit bit string,
): an integral Number
</h1>
<dl class="header">
</dl>
<emu-alg>
1. Let _i_ be the result of interpreting _bits_ as a 32-bit unsigned integer.
1. Return 𝔽(_i_).
</emu-alg>
</emu-clause>

<emu-clause id="sec-numeric-types-number-bitwiseAND" type="numeric method">
<h1>
Number::bitwiseAND (
Expand Down

0 comments on commit 7fe57e8

Please sign in to comment.