1
0
mirror of https://github.com/doitsujin/dxvk.git synced 2025-01-20 17:52:11 +01:00
dxvk/src/util/util_flags.h
Mahdi Tayarani ae881981f9 Fix raw() accessor on the Flags class
The current implementation has a bug where it casts the underlying
int type to a uint32_t. The is incorrect for enums like DxvkShaderFlag
which are based on uint64_t.
2021-08-24 22:23:20 +02:00

110 lines
2.0 KiB
C++

#pragma once
#include <type_traits>
#include "util_bit.h"
namespace dxvk {
template<typename T>
class Flags {
public:
using IntType = std::underlying_type_t<T>;
Flags() { }
Flags(IntType t)
: m_bits(t) { }
template<typename... Tx>
Flags(T f, Tx... fx) {
this->set(f, fx...);
}
template<typename... Tx>
void set(Tx... fx) {
m_bits |= bits(fx...);
}
void set(Flags flags) {
m_bits |= flags.m_bits;
}
template<typename... Tx>
void clr(Tx... fx) {
m_bits &= ~bits(fx...);
}
void clr(Flags flags) {
m_bits &= ~flags.m_bits;
}
template<typename... Tx>
bool any(Tx... fx) const {
return (m_bits & bits(fx...)) != 0;
}
template<typename... Tx>
bool all(Tx... fx) const {
const IntType mask = bits(fx...);
return (m_bits & mask) == mask;
}
bool test(T f) const {
return this->any(f);
}
bool isClear() const {
return m_bits == 0;
}
void clrAll() {
m_bits = 0;
}
IntType raw() const {
return m_bits;
}
Flags operator & (const Flags& other) const {
return Flags(m_bits & other.m_bits);
}
Flags operator | (const Flags& other) const {
return Flags(m_bits | other.m_bits);
}
Flags operator ^ (const Flags& other) const {
return Flags(m_bits ^ other.m_bits);
}
bool operator == (const Flags& other) const {
return m_bits == other.m_bits;
}
bool operator != (const Flags& other) const {
return m_bits != other.m_bits;
}
private:
IntType m_bits = 0;
static IntType bit(T f) {
return IntType(1) << static_cast<IntType>(f);
}
template<typename... Tx>
static IntType bits(T f, Tx... fx) {
return bit(f) | bits(fx...);
}
static IntType bits() {
return 0;
}
};
}