Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/mellowcandle/bitwise

Terminal based bit manipulator in ncurses
https://github.com/mellowcandle/bitwise

bitwise bitwise-operation c curses linux terminal-app

Last synced: about 2 months ago
JSON representation

Terminal based bit manipulator in ncurses

Awesome Lists containing this project

README

        

# Bitwise
## Terminal based bitwise calculator in curses
[![Snap Status](https://build.snapcraft.io/badge/mellowcandle/bitwise.svg)](https://build.snapcraft.io/user/mellowcandle/bitwise)
Coverity Scan Build Status

Packaging status

_Bitwise_ is multi base interactive calculator supporting dynamic base conversion and bit manipulation.
It's a handy tool for low level hackers, kernel developers and device drivers developers.

Some of the features include:
* Interactive ncurses interface
* Command line calculator supporting all bitwise operations.
* Individual bit manipulator.
* Bitwise operations such as NOT, OR, AND, XOR, and shifts.

##

![Demo](https://github.com/mellowcandle/bitwise/raw/master/resources/bitwise.gif "Bitwise demo2")

## Usage
_bitwise_ can be used both interactively and in command line mode.

### Command line calculator mode
In command line mode, bitwise will calculate the given expression and will output the result in all bases including binary representation.

_bitwise_ detects the base by the prefix of the input (_0x/0X_ for hexadecimal, leading _0_ for octal, _b_ for binary, and the rest is decimal).

**NEW** Bitwise now support parsing IPv4 addresses, it will also output the possible IPv4 address in both Network and reversed byte order.

### Examples:

#### Simple base conversion

![conversion](https://github.com/mellowcandle/bitwise/raw/master/resources/cmdline.png "Bitwise conversion")

#### C style syntax Calculator

![calculator](https://github.com/mellowcandle/bitwise/raw/master/resources/conversion.png "Bitwise calculator")

### Interactive mode
_bitwise_ starts in interactive mode if no command line parameters are passed or if the _-i | --interactive_ flag is passed.
In this mode, you can input a number and manipulate it and see the other bases change dynamically.
It also allows changing individual bits in the binary.
You can show the help screen by pressing F1 .

#### Navigation in interactive mode
To move around use the arrow keys, or use _vi_ key bindings : h j k l .
Leave the program by pressing q .

##### Binary specific movement
You can toggle a bit using the space key.
You can jump a byte forward using w and backwards one byte using b .

#### Bitwise operation in interactive mode

##### Setting the bit width:

Reducing or extending the bit width interactively is also very easy, just use:
! for 8bit, @ for 16Bit, $ for 32Bit and * for 64Bit.
When changing the bit width, the number is *masked* with the new width, so you might lose precision, use with care.

##### NOT:

Press ~ to perform the NOT operator.

##### Reversing Endianness:

Press r to reverse the endianness.

##### Shifts

Press < and > to perform the left or right shift.

#### expression calculator in interactive mode

You can enter expression calculator mode by typing : (Just like in vim).

To exit the mode, just press ESC .

In this mode, you can type any expression you like to be evaluated.
The result will be printed in the history window and also printed in the binary and various bases on top.

###### operators and functions
* All C operators are supported, additionally, you can use the "$" symbol to refer to the last result.
* Refer to a specific bit by using the function _BIT(x)_.

###### commands
* _h(elp)_ - Show the help screen.
* _c(lear)_ - Clear the history window.
* _w(idth)_ [8 | 16 | 32 | 64] - Set the required width mask
* _o(utput)_ [dec(imal) | hex(adecimal) | oct(al) | bin(ary) | all] - Set the default output for results.
* _q(uit)_ - Exit

## Integration with other software
### Vim
* [vim-bitwise](https://github.com/mellowcandle/vim-bitwise "vim bitwise")

## Installation

### Linux
#### Ubuntu
From 20.04 you can just type
```
sudo apt-get install bitwise
```
For earlier versions:
```
sudo add-apt-repository ppa:ramon-fried/bitwise
sudo apt-get update
sudo apt-get install bitwise
```
#### Snap
If your distribution supports Snap just type:
`
sudo snap install bitwise
`
#### OpenSuse
`
zypper install bitwise
`

#### Arch
You can use the AUR repository: https://aur.archlinux.org/packages/bitwise/

#### Void
_bitwise_ is in the default repository, so just type:
`
sudo xbps-install -S bitwise
`

#### Fedora Linux

bitwise is available in the [official repository](https://src.fedoraproject.org/rpms/bitwise)

```
sudo dnf install bitwise
```

#### Buildroot / Yocto
Bitwise is available both in Buildroot and in Yocto, please refer to the documentation on how to add those to your target image.

### macOS

#### MacPorts
```
sudo port install bitwise
```

#### Homebrew
```
brew install bitwise
```

### Windows
NCurses doesn't support Windows. You can use the Windows Subsystem for Linux as a workaround.

### Nix
```
nix-env -i bitwise
```

### Building from source

#### Prerequisites
* libreadline
* libncurses (with forms)
* libcunit (only needed for testing)

On Ubuntu/Debian system you can just paste:
```
sudo apt-get install build-essential
sudo apt-get install libncurses5-dev
sudo apt-get install libreadline-dev
sudo apt-get install libcunit1-dev
```
On Mac systems:
```
brew install automake
brew install autoconf
brew install readline
export LDFLAGS="-L/usr/local/opt/readline/lib"
export CPPFLAGS="-I/usr/local/opt/readline/include"
```
- Download [the latest release](https://github.com/mellowcandle/bitwise/releases/latest)

```sh
tar xfz RELEASE-FILE.TAR.GZ
cd RELEASE-DIR
./configure
make
sudo make install
```

Running unit tests by typing
``` make check ```

### Contribution
* Install prerequisites
* Fork the repo
* Run ```./bootstrap.sh```
* Follow the building from source section.
* commit and send pull request