README.md

# BitFlagger

[![Hex version](https://img.shields.io/hexpm/v/bit_flagger.svg 'Hex version')](https://hex.pm/packages/bit_flagger)
[![API docs](https://img.shields.io/hexpm/v/bit_flagger.svg?label=docs 'API docs')](https://hexdocs.pm/bit_flagger)
[![CI](https://github.com/mnishiguchi/bit_flagger/actions/workflows/ci.yml/badge.svg)](https://github.com/mnishiguchi/bit_flagger/actions/workflows/ci.yml)

Manipulate bit flags in Elixir.

## Usage

```elixir
# Let's say we want to remember certain days of week as a single integer
iex> days_of_week = [:sunday, :monday, :tuesday, :wednesday, :thursday, :friday, :saturday]

# The number of bit flags
iex> size = 7

# All the days of the week are 127, no day of the week is the value 0
iex> state = 0b0000000
0

iex> BitFlagger.parse(state, size)
[false, false, false, false, false, false, false]

# Turn on the flags at index 1 (Monday) and 3 (Wednesday)
iex> state = state |> BitFlagger.on(1) |> BitFlagger.on(3)
10

iex> BitFlagger.parse(state, size)
[false, true, false, true, false, false, false]

# Turn off the flag at index 1 (Monday)
iex> state = BitFlagger.off(state, 1)
8

iex> BitFlagger.parse(state, size)
[false, false, false, true, false, false, false]

# We can easily make it human readable
iex> Enum.zip(days_of_week, BitFlagger.parse(state, size))
[
  sunday: false,
  monday: false,
  tuesday: false,
  wednesday: true,
  thursday: false,
  friday: false,
  saturday: false
]
```

## Installation

Add `bit_flagger` to your list of dependencies in `mix.exs`:

```elixir
def deps do
  [
    {:bit_flagger, "~> 0.1.0"}
  ]
end
```

Documentation can be found at [https://hexdocs.pm/bit_flagger](https://hexdocs.pm/bit_flagger).