mirror of
https://github.com/nspcc-dev/neo-go.git
synced 2025-01-11 01:20:37 +00:00
keys: use (*Int).FillBytes where appropriate
Allows to avoid some allocations. Refs. #1319.
This commit is contained in:
parent
76eca07961
commit
f4ba21a41a
1 changed files with 3 additions and 5 deletions
|
@ -155,10 +155,9 @@ func (p *PrivateKey) SignHashable(net uint32, hh hash.Hashable) []byte {
|
||||||
func getSignatureSlice(curve elliptic.Curve, r, s *big.Int) []byte {
|
func getSignatureSlice(curve elliptic.Curve, r, s *big.Int) []byte {
|
||||||
params := curve.Params()
|
params := curve.Params()
|
||||||
curveOrderByteSize := params.P.BitLen() / 8
|
curveOrderByteSize := params.P.BitLen() / 8
|
||||||
rBytes, sBytes := r.Bytes(), s.Bytes()
|
|
||||||
signature := make([]byte, curveOrderByteSize*2)
|
signature := make([]byte, curveOrderByteSize*2)
|
||||||
copy(signature[curveOrderByteSize-len(rBytes):], rBytes)
|
_ = r.FillBytes(signature[:curveOrderByteSize])
|
||||||
copy(signature[curveOrderByteSize*2-len(sBytes):], sBytes)
|
_ = s.FillBytes(signature[curveOrderByteSize:])
|
||||||
|
|
||||||
return signature
|
return signature
|
||||||
}
|
}
|
||||||
|
@ -170,9 +169,8 @@ func (p *PrivateKey) String() string {
|
||||||
|
|
||||||
// Bytes returns the underlying bytes of the PrivateKey.
|
// Bytes returns the underlying bytes of the PrivateKey.
|
||||||
func (p *PrivateKey) Bytes() []byte {
|
func (p *PrivateKey) Bytes() []byte {
|
||||||
bytes := p.D.Bytes()
|
|
||||||
result := make([]byte, 32)
|
result := make([]byte, 32)
|
||||||
copy(result[32-len(bytes):], bytes)
|
_ = p.D.FillBytes(result)
|
||||||
|
|
||||||
return result
|
return result
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue