GitXplorerGitXplorer
d

bitwise-rotation

public
11 stars
1 forks
14 issues

Commits

List of commits on branch master.
Unverified
ebd96ac986243cc58d3c37c06a7da368cc858057

Update README.md

ddfrankland committed 8 years ago
Unverified
100ec4306215d110d619e806ac3416db1ccf53b2

1.0.1

ddfrankland committed 8 years ago
Unverified
e128a464a194303698f02c932fd83947f5952fa4

Update documentation with convenience methods and rename byte to value

ddfrankland committed 8 years ago
Unverified
94e3c3855bc742692e372a876add2f963714af9f

Rename byte to value

ddfrankland committed 8 years ago
Unverified
ae835430410f36abf49a1d638bd9da0ba2c62ebd

Add convenience methods for 8, 16, and 32-bit values

ddfrankland committed 8 years ago
Unverified
1f80e8ddb788836ab64889373164b1984a7a70c7

1.0.0

ddfrankland committed 8 years ago

README

The README file for this repository.

bitwise-rotation

Rotate values with a bitwise rotation.

In computer programming, a circular shift (or bitwise rotation) is a shift operator that shifts all bits of its operand. Unlike an arithmetic shift, a circular shift does not preserve a number's sign bit or distinguish a number's exponent from its significand (sometimes referred to as the mantissa). ā€” Wikipedia

How to Use

import bitwiseRotation from 'bitwise-rotation';

// Set the bit-width/length; max of `32`, min of `0`.
const rotationObject = bitwiseRotation(8);

// Returns an object with rotate right (`ror`) and rotate left (`rol`) methods.
const { ror, rol } = rotationObject;

// Rotate a value by an amount.
rol(101, 2); // 149
ror(101, 2); // 89

Visual Example

import { rolInt8, rorInt8 } from 'bitwise-rotation';

const value = 1;
value.toString(2);             // 00000001
rolInt8(value, 1).toString(2); // 00000010
rolInt8(value, 2).toString(2); // 00000100
rolInt8(value, 3).toString(2); // 00001000
rolInt8(value, 4).toString(2); // 00010000
rorInt8(value, 4).toString(2); // 00010000
rorInt8(value, 3).toString(2); // 00100000
rorInt8(value, 2).toString(2); // 01000000
rorInt8(value, 1).toString(2); // 10000000

API

bitwiseRotation(bitWidth) (default)

A function to specify a custom bitWidth that returns a rotationObject.

  • bitWidth: An integer between [0, 32] that specifies the limit for rotating values.

bitWidth cannot be larger than 32 because operands of all bitwise operators are converted to signed 32-bit integers in two's complement format. ā€” MDN

rotationObject

An object with the following 2 methods for rotating bytes:

  • ror(value, rotation): Rotate a byte to the right by the specified amount of rotation.

    • value: Decimal representation of a value to be rotated.

    • rotation: The amount to rotate the value by.

  • rol(value, rotation): Rotate a byte to the left by the specified amount of rotation.

    • value: Decimal representation of a byte to be rotated.

    • rotation: The amount to rotate the value by.

Both methods return a decimal representation of a value rotated.

rorInt8(value, rotation)

Convenience method for rotating an 8-bit value right.

rolInt8(value, rotation)

Convenience method for rotating an 8-bit value left.

rorInt16(value, rotation)

Convenience method for rotating a 16-bit value right.

rolInt16(value, rotation)

Convenience method for rotating a 16-bit value left.

rorInt32(value, rotation)

Convenience method for rotating a 32-bit value right.

rolInt32(value, rotation)

Convenience method for rotating a 32-bit value left.