iota.lib.cpp
IOTA C++ Library
big_int.hpp
1 //
2 // MIT License
3 //
4 // Copyright (c) 2017-2018 Thibault Martinez and Simon Ninon
5 //
6 // Permission is hereby granted, free of charge, to any person obtaining a copy
7 // of this software and associated documentation files (the "Software"), to deal
8 // in the Software without restriction, including without limitation the rights
9 // to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
10 // copies of the Software, and to permit persons to whom the Software is
11 // furnished to do so, subject to the following conditions:
12 //
13 // The above copyright notice and this permission notice shall be included in all
14 // copies or substantial portions of the Software.
15 //
16 // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
17 // IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
18 // FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
19 // AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
20 // LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
21 // OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
22 // SOFTWARE.
23 //
24 //
25 
26 #pragma once
27 
28 #include <iota/constants.hpp>
29 #include <iota/types/trinary.hpp>
30 
31 namespace IOTA {
32 
33 namespace Types {
34 
35 class Bigint {
36 public:
40  Bigint();
44  virtual ~Bigint();
45 
46 public:
52  void fromTrits(const Trits &trits, std::size_t offset = 0);
58  void fromBytes(const std::vector<uint8_t> &bytes, std::size_t offset = 0);
59 
60 public:
66  Trits toTrits();
72  void toBytes(std::vector<uint8_t> &bytes, std::size_t offset = 0) const;
73 
74 public:
75  bool setLastTritZero();
76  unsigned int addU32(uint32_t summand);
77 
78 private:
79  inline bool isNegative() const;
80  inline uint32_t mul(uint8_t factor, unsigned int ms_index);
81  inline uint32_t div(uint8_t divisor);
82  inline bool add(const uint32_t *a, const uint32_t *b);
83  inline bool sub(const uint32_t *a, const uint32_t *b);
84  inline bool addcarryU32(uint32_t *r, uint32_t a, uint32_t b, bool c_in);
85  inline int cmp(const uint32_t *b) const;
86 
87 private:
88  uint32_t data[WordHashLength];
89 };
90 
91 } // namespace Types
92 
93 } // namespace IOTA
Definition: big_int.hpp:35
void fromBytes(const std::vector< uint8_t > &bytes, std::size_t offset=0)
void toBytes(std::vector< uint8_t > &bytes, std::size_t offset=0) const
void fromTrits(const Trits &trits, std::size_t offset=0)
Definition: core.hpp:33