1 Star 0 Fork 0

wwwanghhhlll/pbc

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
克隆/下载
gmp_big.go 2.42 KB
一键复制 编辑 原始数据 按行查看 历史
Nik 提交于 2018-12-04 23:18 . Bump copyright date to 2018
// Copyright © 2018 Nik Unger
//
// This file is part of The PBC Go Wrapper.
//
// The PBC Go Wrapper is free software: you can redistribute it and/or modify
// it under the terms of the GNU Lesser General Public License as published by
// the Free Software Foundation, either version 3 of the License, or (at your
// option) any later version.
//
// The PBC Go Wrapper is distributed in the hope that it will be useful, but
// WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
// or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public
// License for more details.
//
// You should have received a copy of the GNU Lesser General Public License
// along with The PBC Go Wrapper. If not, see <http://www.gnu.org/licenses/>.
//
// The PBC Go Wrapper makes use of The PBC library. The PBC Library and its use
// are covered under the terms of the GNU Lesser General Public License
// version 3, or (at your option) any later version.
package pbc
/*
#include <gmp.h>
#include <stdlib.h>
mpz_t* newMpzT() {
mpz_t* x = malloc(sizeof(mpz_t));
mpz_init(*x);
return x;
}
void freeMpzT(mpz_t* x) {
mpz_clear(*x);
free(x);
}
*/
import "C"
import (
"math/big"
"runtime"
"unsafe"
)
type mpz struct {
i *C.mpz_t
}
var wordSize C.size_t
var bitsPerWord C.size_t
func clearMpz(x *mpz) {
C.freeMpzT(x.i)
}
func newMpz() *mpz {
out := &mpz{}
out.i = C.newMpzT()
runtime.SetFinalizer(out, clearMpz)
return out
}
// big2thisMpz imports the value of num into out
func big2thisMpz(num *big.Int, out *mpz) {
words := num.Bits()
if len(words) > 0 {
C.mpz_import(&out.i[0], C.size_t(len(words)), -1, wordSize, 0, 0, unsafe.Pointer(&words[0]))
}
}
// big2mpz allocates a new mpz_t and imports a big.Int value
func big2mpz(num *big.Int) *mpz {
out := newMpz()
big2thisMpz(num, out)
return out
}
// mpz2thisBig imports the value of num into out
func mpz2thisBig(num *mpz, out *big.Int) {
wordsNeeded := (C.mpz_sizeinbase(&num.i[0], 2) + (bitsPerWord - 1)) / bitsPerWord
words := make([]big.Word, wordsNeeded)
var wordsWritten C.size_t
C.mpz_export(unsafe.Pointer(&words[0]), &wordsWritten, -1, wordSize, 0, 0, &num.i[0])
out.SetBits(words)
}
// mpz2big allocates a new big.Int and imports an mpz_t value
func mpz2big(num *mpz) (out *big.Int) {
out = &big.Int{}
mpz2thisBig(num, out)
return
}
func init() {
var oneWord big.Word
size := unsafe.Sizeof(oneWord)
wordSize = C.size_t(size)
bitsPerWord = C.size_t(8 * size)
}
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
1
https://gitee.com/wwwanghhhlll/pbc.git
[email protected]:wwwanghhhlll/pbc.git
wwwanghhhlll
pbc
pbc
master

搜索帮助