feat(big): add SBigBitLen

This commit is contained in:
fallenoak 2023-02-01 22:54:33 -06:00
parent 5edf49dae7
commit 24c6a5134c
No known key found for this signature in database
GPG key ID: 7628F8E61AEA070D
3 changed files with 87 additions and 0 deletions

View file

@ -7,6 +7,23 @@ void SBigAdd(BigData* a, BigData* b, BigData* c) {
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) {
return Compare(a->Primary(), b->Primary());
}

View file

@ -6,6 +6,8 @@
void SBigAdd(BigData* a, BigData* b, BigData* c);
void SBigBitLen(BigData* num, uint32_t* len);
int32_t SBigCompare(BigData* a, BigData* b);
void SBigDel(BigData* num);