aboutsummaryrefslogtreecommitdiffstats
path: root/include/bls.hpp
diff options
context:
space:
mode:
authorMITSUNARI Shigeo <herumi@nifty.com>2017-01-20 16:43:04 +0800
committerMITSUNARI Shigeo <herumi@nifty.com>2017-01-20 16:43:04 +0800
commitb680d8e089cd81f95c458f2c24f003cc36783c5a (patch)
tree0bb5fde1b19840e47b9c532aad67c4fe4a55ba70 /include/bls.hpp
parentca93275c32037b83577f7e52bc63714006228d21 (diff)
downloaddexon-bls-b680d8e089cd81f95c458f2c24f003cc36783c5a.tar.gz
dexon-bls-b680d8e089cd81f95c458f2c24f003cc36783c5a.tar.zst
dexon-bls-b680d8e089cd81f95c458f2c24f003cc36783c5a.zip
cgo accesses to T[] of Go
Diffstat (limited to 'include/bls.hpp')
-rw-r--r--include/bls.hpp14
1 files changed, 9 insertions, 5 deletions
diff --git a/include/bls.hpp b/include/bls.hpp
index cf2580b..d9ad086 100644
--- a/include/bls.hpp
+++ b/include/bls.hpp
@@ -62,6 +62,7 @@ class Id {
friend class SecretKey;
template<class T, class G> friend struct Wrap;
template<class T, class G> friend struct WrapPointer;
+ template<class T, class G> friend struct WrapArray;
impl::Id& getInner() { return *reinterpret_cast<impl::Id*>(self_); }
const impl::Id& getInner() const { return *reinterpret_cast<const impl::Id*>(self_); }
public:
@@ -86,6 +87,7 @@ class SecretKey {
uint64_t self_[4]; // 256-bit
template<class T, class G> friend struct Wrap;
template<class T, class G> friend struct WrapPointer;
+ template<class T, class G> friend struct WrapArray;
impl::SecretKey& getInner() { return *reinterpret_cast<impl::SecretKey*>(self_); }
const impl::SecretKey& getInner() const { return *reinterpret_cast<const impl::SecretKey*>(self_); }
public:
@@ -131,8 +133,8 @@ public:
/*
the size of msk must be k
*/
- void set(const SecretKey *const *msk, size_t k, const Id& id);
- void recover(const SecretKey *const *secVec, const Id *const *idVec, size_t n);
+ void set(const SecretKey *msk, size_t k, const Id& id);
+ void recover(const SecretKey *secVec, const Id *idVec, size_t n);
};
/*
@@ -144,6 +146,7 @@ class PublicKey {
friend class Sign;
template<class T, class G> friend struct Wrap;
template<class T, class G> friend struct WrapPointer;
+ template<class T, class G> friend struct WrapArray;
impl::PublicKey& getInner() { return *reinterpret_cast<impl::PublicKey*>(self_); }
const impl::PublicKey& getInner() const { return *reinterpret_cast<const impl::PublicKey*>(self_); }
public:
@@ -166,8 +169,8 @@ public:
void add(const PublicKey& rhs);
// the following methods are for C api
- void set(const PublicKey *const *mpk, size_t k, const Id& id);
- void recover(const PublicKey *const *pubVec, const Id *const *idVec, size_t n);
+ void set(const PublicKey *mpk, size_t k, const Id& id);
+ void recover(const PublicKey *pubVec, const Id *idVec, size_t n);
};
/*
@@ -178,6 +181,7 @@ class Sign {
friend class SecretKey;
template<class T, class G> friend struct Wrap;
template<class T, class G> friend struct WrapPointer;
+ template<class T, class G> friend struct WrapArray;
impl::Sign& getInner() { return *reinterpret_cast<impl::Sign*>(self_); }
const impl::Sign& getInner() const { return *reinterpret_cast<const impl::Sign*>(self_); }
public:
@@ -201,7 +205,7 @@ public:
void add(const Sign& rhs);
// the following methods are for C api
- void recover(const Sign* const *signVec, const Id *const *idVec, size_t n);
+ void recover(const Sign* signVec, const Id *idVec, size_t n);
};
/*