TrinityCore
BigNumber.cpp
Go to the documentation of this file.
1/*
2 * This file is part of the TrinityCore Project. See AUTHORS file for Copyright information
3 *
4 * This program is free software; you can redistribute it and/or modify it
5 * under the terms of the GNU General Public License as published by the
6 * Free Software Foundation; either version 2 of the License, or (at your
7 * option) any later version.
8 *
9 * This program is distributed in the hope that it will be useful, but WITHOUT
10 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
11 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
12 * more details.
13 *
14 * You should have received a copy of the GNU General Public License along
15 * with this program. If not, see <http://www.gnu.org/licenses/>.
16 */
17
19#include "Errors.h"
20#include <openssl/bn.h>
21#include <algorithm>
22#include <memory>
23
25 : _bn(BN_new())
26{ }
27
29 : _bn(BN_dup(bn.BN()))
30{ }
31
33{
34 BN_free(_bn);
35}
36
38{
39 SetDword(uint32(abs(val)));
40 if (val < 0)
41 BN_set_negative(_bn, 1);
42}
43
45{
46 BN_set_word(_bn, val);
47}
48
50{
51 BN_set_word(_bn, (uint32)(val >> 32));
52 BN_lshift(_bn, _bn, 32);
53 BN_add_word(_bn, (uint32)(val & 0xFFFFFFFF));
54}
55
56void BigNumber::SetBinary(uint8 const* bytes, int32 len, bool littleEndian)
57{
58 if (littleEndian)
59 BN_lebin2bn(bytes, len, _bn);
60 else
61 BN_bin2bn(bytes, len, _bn);
62}
63
64bool BigNumber::SetHexStr(char const* str)
65{
66 int n = BN_hex2bn(&_bn, str);
67 return (n > 0);
68}
69
71{
72 BN_rand(_bn, numbits, 0, 1);
73}
74
76{
77 if (this == &bn)
78 return *this;
79
80 BN_copy(_bn, bn._bn);
81 return *this;
82}
83
85{
86 BN_add(_bn, _bn, bn._bn);
87 return *this;
88}
89
91{
92 BN_sub(_bn, _bn, bn._bn);
93 return *this;
94}
95
97{
98 BN_CTX *bnctx;
99
100 bnctx = BN_CTX_new();
101 BN_mul(_bn, _bn, bn._bn, bnctx);
102 BN_CTX_free(bnctx);
103
104 return *this;
105}
106
108{
109 BN_CTX *bnctx;
110
111 bnctx = BN_CTX_new();
112 BN_div(_bn, nullptr, _bn, bn._bn, bnctx);
113 BN_CTX_free(bnctx);
114
115 return *this;
116}
117
119{
120 BN_CTX *bnctx;
121
122 bnctx = BN_CTX_new();
123 BN_nnmod(_bn, _bn, bn._bn, bnctx);
124 BN_CTX_free(bnctx);
125
126 return *this;
127}
128
130{
131 BN_lshift(_bn, _bn, n);
132 return *this;
133}
134
136{
137 return BN_cmp(_bn, bn._bn);
138}
139
141{
142 BigNumber ret;
143 BN_CTX *bnctx;
144
145 bnctx = BN_CTX_new();
146 BN_exp(ret._bn, _bn, bn._bn, bnctx);
147 BN_CTX_free(bnctx);
148
149 return ret;
150}
151
152BigNumber BigNumber::ModExp(BigNumber const& bn1, BigNumber const& bn2) const
153{
154 BigNumber ret;
155 BN_CTX *bnctx;
156
157 bnctx = BN_CTX_new();
158 BN_mod_exp(ret._bn, _bn, bn1._bn, bn2._bn, bnctx);
159 BN_CTX_free(bnctx);
160
161 return ret;
162}
163
165{
166 return BN_num_bytes(_bn);
167}
168
170{
171 return BN_num_bits(_bn);
172}
173
175{
176 return (uint32)BN_get_word(_bn);
177}
178
180{
181 return BN_is_zero(_bn);
182}
183
185{
186 return BN_is_negative(_bn);
187}
188
189void BigNumber::GetBytes(uint8* buf, size_t bufsize, bool littleEndian) const
190{
191 int res = littleEndian ? BN_bn2lebinpad(_bn, buf, bufsize) : BN_bn2binpad(_bn, buf, bufsize);
192 ASSERT(res > 0, "Buffer of size %zu is too small to hold bignum with %d bytes.\n", bufsize, BN_num_bytes(_bn));
193}
194
195std::vector<uint8> BigNumber::ToByteVector(int32 minSize, bool littleEndian) const
196{
197 std::size_t length = std::max(GetNumBytes(), minSize);
198 std::vector<uint8> v;
199 v.resize(length);
200 GetBytes(v.data(), length, littleEndian);
201 return v;
202}
203
204std::string BigNumber::AsHexStr() const
205{
206 char* ch = BN_bn2hex(_bn);
207 std::string ret = ch;
208 OPENSSL_free(ch);
209 return ret;
210}
211
212std::string BigNumber::AsDecStr() const
213{
214 char* ch = BN_bn2dec(_bn);
215 std::string ret = ch;
216 OPENSSL_free(ch);
217 return ret;
218}
uint8_t uint8
Definition: Define.h:144
int32_t int32
Definition: Define.h:138
uint64_t uint64
Definition: Define.h:141
uint32_t uint32
Definition: Define.h:142
#define ASSERT
Definition: Errors.h:68
BigNumber & operator<<=(int n)
Definition: BigNumber.cpp:129
BigNumber Exp(BigNumber const &) const
Definition: BigNumber.cpp:140
BigNumber ModExp(BigNumber const &bn1, BigNumber const &bn2) const
Definition: BigNumber.cpp:152
std::string AsDecStr() const
Definition: BigNumber.cpp:212
std::vector< uint8 > ToByteVector(int32 minSize=0, bool littleEndian=true) const
Definition: BigNumber.cpp:195
uint32 AsDword() const
Definition: BigNumber.cpp:174
BigNumber & operator/=(BigNumber const &bn)
Definition: BigNumber.cpp:107
void SetRand(int32 numbits)
Definition: BigNumber.cpp:70
void SetDword(int32)
Definition: BigNumber.cpp:37
void SetBinary(uint8 const *bytes, int32 len, bool littleEndian=true)
Definition: BigNumber.cpp:56
std::string AsHexStr() const
Definition: BigNumber.cpp:204
bool IsNegative() const
Definition: BigNumber.cpp:184
int32 GetNumBits() const
Definition: BigNumber.cpp:169
int32 CompareTo(BigNumber const &bn) const
Definition: BigNumber.cpp:135
BigNumber & operator*=(BigNumber const &bn)
Definition: BigNumber.cpp:96
struct bignum_st * _bn
Definition: BigNumber.h:139
BigNumber & operator%=(BigNumber const &bn)
Definition: BigNumber.cpp:118
int32 GetNumBytes() const
Definition: BigNumber.cpp:164
BigNumber & operator-=(BigNumber const &bn)
Definition: BigNumber.cpp:90
void GetBytes(uint8 *buf, size_t bufsize, bool littleEndian=true) const
Definition: BigNumber.cpp:189
BigNumber & operator+=(BigNumber const &bn)
Definition: BigNumber.cpp:84
bool IsZero() const
Definition: BigNumber.cpp:179
void SetQword(uint64)
Definition: BigNumber.cpp:49
BigNumber & operator=(BigNumber const &bn)
Definition: BigNumber.cpp:75
bool SetHexStr(char const *str)
Definition: BigNumber.cpp:64