# Mpint # Copyright 2018 Status Research & Development GmbH # Licensed under either of # # * Apache License, version 2.0, ([LICENSE-APACHE](LICENSE-APACHE) or http://www.apache.org/licenses/LICENSE-2.0) # * MIT license ([LICENSE-MIT](LICENSE-MIT) or http://opensource.org/licenses/MIT) # # at your option. This file may not be copied, modified, or distributed except according to those terms. import ./uint_type, macros macro optim(x: typed): untyped = let size = getSize(x) if size > 64: result = quote do: array[`size` div 64, uint64] elif size == 64: result = quote do: uint64 elif size == 32: result = quote do: uint32 elif size == 16: result = quote do: uint16 elif size == 8: result = quote do: uint8 else: error "Unreachable path reached" # The following iterators allow efficient iteration on multiprecision integers internal representation. # Note: in case the size in one, hopefully the compiler optimizes it. # using a template is not more efficient due to having to allocate the injection variable. # This can be rewritten using macros though # # template asWordsRawZip*(x, y: MpUintImpl, xw, yw: untyped, body: untyped): untyped = # when optim(x) is array: # let # x_ptr = cast[ptr optim(x)](x.unsafeaddr) # y_ptr = cast[ptr optim(y)](y.unsafeaddr) # for i in 0..