mirror of
https://github.com/thunderbrewhq/squall.git
synced 2025-12-12 02:22:30 +00:00
feat(big): add SBigBitLen
This commit is contained in:
parent
5edf49dae7
commit
24c6a5134c
3 changed files with 87 additions and 0 deletions
|
|
@ -7,6 +7,23 @@ void SBigAdd(BigData* a, BigData* b, BigData* c) {
|
||||||
Add(a->Primary(), b->Primary(), c->Primary());
|
Add(a->Primary(), b->Primary(), c->Primary());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void SBigBitLen(BigData* num, uint32_t* len) {
|
||||||
|
auto& buffer = num->Primary();
|
||||||
|
buffer.Trim();
|
||||||
|
|
||||||
|
auto index = buffer.Count() - 1;
|
||||||
|
auto high = buffer[index];
|
||||||
|
|
||||||
|
uint32_t bitIndex;
|
||||||
|
for (bitIndex = 31; bitIndex > 0; bitIndex--) {
|
||||||
|
if (((1 << bitIndex) & high)) {
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
*len = (index * 32) + bitIndex + 1;
|
||||||
|
}
|
||||||
|
|
||||||
int32_t SBigCompare(BigData* a, BigData* b) {
|
int32_t SBigCompare(BigData* a, BigData* b) {
|
||||||
return Compare(a->Primary(), b->Primary());
|
return Compare(a->Primary(), b->Primary());
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -6,6 +6,8 @@
|
||||||
|
|
||||||
void SBigAdd(BigData* a, BigData* b, BigData* c);
|
void SBigAdd(BigData* a, BigData* b, BigData* c);
|
||||||
|
|
||||||
|
void SBigBitLen(BigData* num, uint32_t* len);
|
||||||
|
|
||||||
int32_t SBigCompare(BigData* a, BigData* b);
|
int32_t SBigCompare(BigData* a, BigData* b);
|
||||||
|
|
||||||
void SBigDel(BigData* num);
|
void SBigDel(BigData* num);
|
||||||
|
|
|
||||||
68
test/Big.cpp
68
test/Big.cpp
|
|
@ -459,6 +459,74 @@ TEST_CASE("SBigAdd", "[big]") {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
TEST_CASE("SBigBitLen", "[big]") {
|
||||||
|
SECTION("returns bit length of 1") {
|
||||||
|
BigData* num;
|
||||||
|
SBigNew(&num);
|
||||||
|
SBigFromUnsigned(num, 1);
|
||||||
|
|
||||||
|
uint32_t len;
|
||||||
|
SBigBitLen(num, &len);
|
||||||
|
|
||||||
|
CHECK(len == 1);
|
||||||
|
|
||||||
|
SBigDel(num);
|
||||||
|
}
|
||||||
|
|
||||||
|
SECTION("returns bit length of 5") {
|
||||||
|
BigData* num;
|
||||||
|
SBigNew(&num);
|
||||||
|
SBigFromUnsigned(num, 5);
|
||||||
|
|
||||||
|
uint32_t len;
|
||||||
|
SBigBitLen(num, &len);
|
||||||
|
|
||||||
|
CHECK(len == 3);
|
||||||
|
|
||||||
|
SBigDel(num);
|
||||||
|
}
|
||||||
|
|
||||||
|
SECTION("returns bit length of 0xFFFF") {
|
||||||
|
BigData* num;
|
||||||
|
SBigNew(&num);
|
||||||
|
SBigFromUnsigned(num, 0xFFFF);
|
||||||
|
|
||||||
|
uint32_t len;
|
||||||
|
SBigBitLen(num, &len);
|
||||||
|
|
||||||
|
CHECK(len == 16);
|
||||||
|
|
||||||
|
SBigDel(num);
|
||||||
|
}
|
||||||
|
|
||||||
|
SECTION("returns bit length of 0xFFFFFFFF") {
|
||||||
|
BigData* num;
|
||||||
|
SBigNew(&num);
|
||||||
|
SBigFromUnsigned(num, 0xFFFFFFFF);
|
||||||
|
|
||||||
|
uint32_t len;
|
||||||
|
SBigBitLen(num, &len);
|
||||||
|
|
||||||
|
CHECK(len == 32);
|
||||||
|
|
||||||
|
SBigDel(num);
|
||||||
|
}
|
||||||
|
|
||||||
|
SECTION("returns bit length of 0x22222222AAAAAAAA") {
|
||||||
|
BigData* num;
|
||||||
|
SBigNew(&num);
|
||||||
|
uint64_t num_ = 0x22222222AAAAAAAA;
|
||||||
|
SBigFromBinary(num, reinterpret_cast<uint8_t*>(&num_), sizeof(num_));
|
||||||
|
|
||||||
|
uint32_t len;
|
||||||
|
SBigBitLen(num, &len);
|
||||||
|
|
||||||
|
CHECK(len == 62);
|
||||||
|
|
||||||
|
SBigDel(num);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
TEST_CASE("SBigCompare", "[big]") {
|
TEST_CASE("SBigCompare", "[big]") {
|
||||||
SECTION("compares 10 and 1") {
|
SECTION("compares 10 and 1") {
|
||||||
BigData* a;
|
BigData* a;
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue