2023-08-23 12:45:53 +00:00
|
|
|
/**
|
|
|
|
* @file Bitset.h
|
|
|
|
* @author apio (cloudapio.eu)
|
|
|
|
* @brief A wrapper class to modify/inspect specific bits of an integer type.
|
|
|
|
*
|
|
|
|
* @copyright Copyright (c) 2023, the Luna authors.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
2023-08-23 08:51:02 +00:00
|
|
|
#pragma once
|
|
|
|
#include <luna/Check.h>
|
|
|
|
|
2023-08-23 12:45:53 +00:00
|
|
|
/**
|
|
|
|
* @brief A wrapper class to modify/inspect specific bits of an integer type, to avoid manual error-prone bit shifting.
|
|
|
|
*
|
|
|
|
* @tparam T The integer type to use.
|
|
|
|
*/
|
2023-08-23 08:51:02 +00:00
|
|
|
template <typename T> class Bitset
|
|
|
|
{
|
|
|
|
public:
|
2023-08-23 12:45:53 +00:00
|
|
|
/**
|
|
|
|
* @brief Construct a new empty Bitset object.
|
|
|
|
*/
|
|
|
|
Bitset() : m_value(0)
|
2023-08-23 08:51:02 +00:00
|
|
|
{
|
|
|
|
}
|
|
|
|
|
2023-08-23 12:45:53 +00:00
|
|
|
/**
|
|
|
|
* @brief Construct a new Bitset object with a value.
|
|
|
|
*
|
|
|
|
* @param value The value to use.
|
|
|
|
*/
|
2023-08-23 08:51:02 +00:00
|
|
|
Bitset(T value) : m_value(value)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
2023-08-23 12:45:53 +00:00
|
|
|
/**
|
|
|
|
* @brief Construct a copy of another Bitset object.
|
|
|
|
*
|
|
|
|
* @param other The original object.
|
|
|
|
*/
|
2023-08-23 08:51:02 +00:00
|
|
|
Bitset(const Bitset<T>& other) : m_value(other.m_value)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
2023-08-23 12:45:53 +00:00
|
|
|
/**
|
|
|
|
* @brief Update the internal value of this bitset.
|
|
|
|
*
|
|
|
|
* @param value The new value.
|
|
|
|
* @return Bitset<T>& A reference to this itset.
|
|
|
|
*/
|
2023-08-23 08:51:02 +00:00
|
|
|
Bitset<T>& operator=(T value)
|
|
|
|
{
|
|
|
|
m_value = value;
|
|
|
|
return *this;
|
|
|
|
}
|
|
|
|
|
2023-08-23 12:45:53 +00:00
|
|
|
/**
|
|
|
|
* @brief Set this bitset to the same value as another bitset.
|
|
|
|
*
|
|
|
|
* @param other The pther bitset.
|
|
|
|
* @return Bitset<T>& A reference to this bitset.
|
|
|
|
*/
|
2023-08-23 08:51:02 +00:00
|
|
|
Bitset<T>& operator=(const Bitset<T>& other)
|
|
|
|
{
|
|
|
|
if (&other == this) return *this;
|
|
|
|
m_value = other.m_value;
|
|
|
|
return *this;
|
|
|
|
}
|
|
|
|
|
2023-08-23 12:45:53 +00:00
|
|
|
/**
|
|
|
|
* @brief Return the value contained in this bitset.
|
|
|
|
*
|
|
|
|
* @return T The contained value.
|
|
|
|
*/
|
2023-08-23 08:51:02 +00:00
|
|
|
T value() const
|
|
|
|
{
|
|
|
|
return m_value;
|
|
|
|
}
|
|
|
|
|
2023-08-23 12:45:53 +00:00
|
|
|
/**
|
|
|
|
* @brief Modify one of the individual bits in this bitset.
|
|
|
|
*
|
|
|
|
* @param index The index of the bit (this will set/unset 1 << index). It must be less than the bit width of the
|
|
|
|
* underlying type.
|
|
|
|
* @param b The value to set the bit to.
|
|
|
|
*/
|
2023-08-23 08:51:02 +00:00
|
|
|
void set(int index, bool b)
|
|
|
|
{
|
|
|
|
check((usize)index < (sizeof(T) * 8));
|
|
|
|
if (b) m_value |= (((T)1) << index);
|
|
|
|
else
|
|
|
|
m_value &= ~(((T)1) << index);
|
|
|
|
}
|
|
|
|
|
2023-08-23 12:45:53 +00:00
|
|
|
/**
|
|
|
|
* @brief Get the value of one of the individual bits in this bitset.
|
|
|
|
*
|
|
|
|
* @param index The index of the bit (this will read 1 << index). It must be less than the bit width of the
|
|
|
|
* underlying type.
|
|
|
|
* @return bool The value of the requested bit.
|
|
|
|
*/
|
2023-08-23 08:51:02 +00:00
|
|
|
bool get(int index)
|
|
|
|
{
|
|
|
|
check((usize)index < (sizeof(T) * 8));
|
|
|
|
return m_value & (((T)1) << index);
|
|
|
|
}
|
|
|
|
|
2023-08-23 12:45:53 +00:00
|
|
|
/**
|
|
|
|
* @brief Clear all the bits in this bitset.
|
|
|
|
*/
|
2023-08-23 08:51:02 +00:00
|
|
|
void clear()
|
|
|
|
{
|
|
|
|
m_value = 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
private:
|
|
|
|
T m_value;
|
|
|
|
};
|